@import url("https://cdn.jsdelivr.net/npm/yakuhanjp@3.4.1/dist/css/yakuhanjp_s.min.css");
@import url("https://fonts.googleapis.com/css?family=Noto+Sans+JP:400,500&subset=japanese");
@import url("https://fonts.googleapis.com/css2?family=Poppins:wght@200;300;400;500;600&display=swap");
/*
Typography
*/
:root {
  --f-noto: "Noto Sans JP", sans-serif;
  --f-poppins: "Poppins", sans-serif;
  --leading-trim: calc((1em - 1lh) / 2);
  --leading-trim-en: calc((1cap - 1lh) / 2);
  --c-citizen-black: #292C2D;
  --c-gray4: #D4D7DA;
}

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

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    -webkit-animation-delay: 0s !important;
    animation-delay: 0s !important;
    -webkit-animation-duration: 1ms !important;
    animation-duration: 1ms !important;
    -webkit-animation-iteration-count: 1 !important;
    animation-iteration-count: 1 !important;
    background-attachment: scroll !important;
    scroll-behavior: auto !important;
    -webkit-transition-delay: 0s !important;
            transition-delay: 0s !important;
    -webkit-transition-duration: 1ms !important;
            transition-duration: 1ms !important;
  }
}
html {
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

a,
abbr,
acronym,
address,
applet,
article,
aside,
audio,
b,
big,
blockquote,
body,
canvas,
caption,
center,
cite,
code,
dd,
del,
details,
dfn,
dialog,
div,
dl,
dt,
em,
embed,
fieldset,
figcaption,
figure,
font,
footer,
form,
header,
hgroup,
hr,
html,
i,
iframe,
img,
ins,
kbd,
label,
legend,
li,
mark,
menu,
meter,
nav,
object,
ol,
output,
p,
pre,
progress,
q,
rp,
rt,
ruby,
s,
samp,
section,
small,
span,
strike,
strong,
sub,
summary,
sup,
table,
tbody,
td,
tfoot,
th,
thead,
time,
tr,
tt,
u,
ul,
var,
video,
xmp {
  border: 0;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
}

audio,
embed,
img,
object {
  height: auto;
  max-width: 100%;
  vertical-align: middle;
  width: auto;
}

img,
picture {
  display: block;
  max-width: 100%;
}

button {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  background-color: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
  text-transform: none;
}

button,
input,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  font-family: inherit;
  font-size: 100%;
  margin: 0;
}

button,
[type=button],
[type=reset],
[type=submit],
label[for],
select,
summary,
[role=tab],
[role=button] {
  cursor: pointer;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 100%;
  font-weight: normal;
  margin: 0;
  padding: 0;
}

iframe {
  border: 0;
  display: block;
  height: auto;
  max-width: 100%;
}

ol,
ul {
  list-style-type: "";
}

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

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

summary {
  display: block;
}

summary::-webkit-details-marker {
  display: none;
}

svg {
  vertical-align: bottom;
}

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

td,
th {
  padding: 0;
  text-align: left;
}

textarea {
  field-sizing: content;
}

a,
area,
button,
input,
label,
select,
summary,
textarea,
[tabindex] {
  -ms-touch-action: manipulation;
      touch-action: manipulation;
}

a {
  cursor: pointer;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

*:focus:not(:focus-visible),
*::before:focus:not(:focus-visible),
*::after:focus:not(:focus-visible) {
  outline: none;
}

button::-moz-focus-inner {
  border: 0;
}

* {
  -webkit-touch-callout: none;
}

input[type=text],
select,
textarea {
  font-size: 1rem;
}

input[type=text],
input[type=tel],
input[type=email],
textarea {
  -webkit-appearance: none;
  -webkit-tap-highlight-color: rgba(255, 255, 255, 0);
  -moz-appearance: none;
       appearance: none;
}

input[type=submit] {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  border-radius: 0;
}

:where(button, [type=button], [type=reset], [type=submit]) {
  -ms-touch-action: manipulation;
      touch-action: manipulation;
}

.fb_iframe_widget > span {
  vertical-align: baseline !important;
}

#map-canvas img {
  max-width: none;
}

#map-canvas label {
  display: inline;
  width: auto;
}

/*
Basic style
*/
body {
  background-color: black;
  color: black;
  font-family: var(--f-noto);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  min-height: 100dvh;
  overflow-x: clip;
  overscroll-behavior-y: none;
}

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

a:focus-visible {
  text-decoration: none;
}

@media (any-hover: hover) {
  a:hover {
    text-decoration: none;
  }
}
b,
strong,
.-bold {
  font-weight: 500;
}

sup {
  display: inline-block;
  -webkit-transform: scale(0.8) translateX(-0.2em);
  margin-right: -0.2em;
  transform: scale(0.8) translateX(-0.2em);
}

.svg-spacer {
  fill: transparent;
}

@media (min-width: 751px) {
  .-sm {
    display: none !important;
  }
}
@media (max-width: 750px) {
  .-md {
    display: none !important;
  }
}
@media (max-width: 1200px) {
  .-lg {
    display: none !important;
  }
}
@media (max-width: 1280px) {
  .-xl {
    display: none !important;
  }
}
/*
Loader
*/
@media (scripting: none) {
  .loader {
    display: none;
  }
}
.loader {
  background-color: var(--c-citizen-black);
  bottom: 0;
  height: 100vh;
  left: 0;
  opacity: 1;
  overflow: hidden;
  place-content: center;
  position: fixed;
  -webkit-transition: opacity 0.4s cubic-bezier(0.77, 0, 0.175, 1), height 0s 1s;
  transition: opacity 0.4s cubic-bezier(0.77, 0, 0.175, 1), height 0s 1s;
  width: 100vw;
  z-index: calc(infinity);
}
.loader.is-loaded {
  height: 0;
  opacity: 0;
}

/*
Header
*/
.is-fixed {
  position: fixed;
  width: 100%;
}

.header {
  position: sticky;
  display: block;
  width: 100%;
  height: 80px;
  background-color: #fff;
  top: 0;
  -webkit-transition: top 0.4s;
  transition: top 0.4s;
  z-index: 11;
}
@media (max-width: 750px) {
  .header {
    height: 16vw;
  }
}

.header__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: min(100%, 1440px);
  height: 100%;
  padding: 0;
  margin-left: auto;
  margin-right: auto;
}
@media (max-width: 750px) {
  .header__inner {
    padding: 0 5.3333333333vw;
  }
}

.header__nav--sm {
  display: none;
  width: 16vw;
}
@media (max-width: 750px) {
  .header__nav--sm {
    display: block;
  }
}

.header__nav--lg {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 40px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media (max-width: 750px) {
  .header__nav--lg {
    display: none;
  }
}
.header__nav--lg a {
  position: relative;
  color: #000;
  font-family: var(--f-poppins);
  font-size: 16px;
  font-weight: 500;
  text-decoration: none;
  text-transform: uppercase;
  -webkit-transition: opacity 0.4s;
  transition: opacity 0.4s;
}
.header__nav--lg a::after {
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background-color: black;
}
@media (min-width: 751px) {
  .header__nav--lg a:focus-visible, .header__nav--lg a:hover {
    opacity: 0.6;
  }
}

.header__attesa {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: calc(104px + clamp(32px, -26.6956521739px + 7.8260869565vw, 86px));
  height: 100%;
  padding-left: clamp(32px, -26.6956521739px + 7.8260869565vw, 86px);
  -webkit-filter: brightness(0);
          filter: brightness(0);
}
@media (max-width: 750px) {
  .header__attesa {
    width: 18.6666666667vw;
    padding-left: 0;
  }
}

.header__citizen {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: calc(130px + clamp(24px, -15.1304347826px + 5.2173913043vw, 60px));
  height: 100%;
  padding-right: clamp(24px, -15.1304347826px + 5.2173913043vw, 60px);
  padding-left: 26px;
}
@media (max-width: 750px) {
  .header__citizen {
    width: 18.6666666667vw;
    padding-left: 0;
    padding-right: 0;
  }
}

.navTrigger {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 5.8666666667vw;
  height: 4.8vw;
  cursor: pointer;
}
.navTrigger span {
  position: relative;
  display: block;
  width: 100%;
  height: 2px;
  background-color: var(--c-citizen-black);
  -webkit-transition: background-color 0.4s, width 0.4s;
  transition: background-color 0.4s, width 0.4s;
}
.navTrigger span::before, .navTrigger span::after {
  position: absolute;
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background-color: var(--c-citizen-black);
  -webkit-transition: translate 0.4s, rotate 0.4s;
  transition: translate 0.4s, rotate 0.4s;
}
.navTrigger span::before {
  translate: 0 calc((4.8vw - 6px) / -2);
}
.navTrigger span::after {
  translate: 0 calc((4.8vw - 6px) / 2);
}
.navTrigger.is-open span {
  background-color: transparent;
}
.navTrigger.is-open span::before {
  rotate: 30deg;
  -webkit-transition: rotate 0.4s;
  transition: rotate 0.4s;
  translate: 0;
}
.navTrigger.is-open span::after {
  rotate: -30deg;
  -webkit-transition: rotate 0.4s;
  transition: rotate 0.4s;
  translate: 0;
}
@media (min-width: 751px) {
  .navTrigger:hover span {
    width: 2.6666666667vw;
  }
  .navTrigger:hover span::before, .navTrigger:hover span::after {
    translate: 0;
    width: 5.3333333333vw;
  }
}

/*
Nav
*/
.nav {
  position: fixed;
  width: 100%;
  height: 100vh;
  padding-top: 16vw;
  background-color: white;
  opacity: 0;
  top: 0;
  left: -100vw;
  -webkit-transition: opacity 0.4s cubic-bezier(0.19, 1, 0.22, 1), left 1s cubic-bezier(0.77, 0, 0.175, 1);
  transition: opacity 0.4s cubic-bezier(0.19, 1, 0.22, 1), left 1s cubic-bezier(0.77, 0, 0.175, 1);
  z-index: 10;
}
.nav a {
  display: block;
  padding: 0.8em 1em;
  color: black;
  font-family: var(--f-poppins);
  font-size: 5.3333333333vw;
  font-weight: 500;
  line-height: 2;
  text-decoration: none;
  text-transform: uppercase;
}
.nav span {
  position: relative;
  display: inline-block;
  height: 100%;
  font-size: 1em;
}
.nav span::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 0.1em;
  background-color: black;
  left: 0;
  bottom: 0;
}
.nav.is-open {
  left: 0;
  opacity: 1;
}

/*
Footer
*/
.footer {
  position: relative;
  width: 100%;
  padding-top: 6.25vw;
}
@media (max-width: 750px) {
  .footer {
    padding-top: 8vw;
  }
}

.footer__links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 20px;
  width: 100%;
  padding: 20px 0;
}
@media (max-width: 750px) {
  .footer__links {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 3.2vw;
    padding-top: 5.3333333333vw;
    padding-bottom: 5.3333333333vw;
  }
}
.footer__links a {
  color: white;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.6;
}
@media (min-width: 751px) {
  .footer__links a:focus-visible, .footer__links a:hover {
    text-decoration: underline;
  }
}
@media (max-width: 750px) {
  .footer__links a {
    font-size: 3.2vw;
  }
}

.footer__copyright {
  padding-top: 1.4285714286em;
  padding-bottom: 1.4285714286em;
  color: var(--c-gray4);
  font-family: var(--f-poppins);
  font-size: 14px;
  font-weight: 300;
  line-height: 1.6;
  text-align: center;
}
@media (max-width: 750px) {
  .footer__copyright {
    padding-bottom: 3.5em;
    font-size: 3.7333333333vw;
  }
}

/* ------------
 >>> Page Top
------------ */
.pagetop {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  padding-top: 2.2857142857em;
  padding-bottom: 1em;
  border-bottom: 1px solid var(--c-citizen-black);
  color: white;
  font-family: var(--f-poppins);
  font-size: 14px;
  font-weight: 300;
  line-height: 1.6;
  text-align: center;
  text-transform: uppercase;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}
.pagetop svg {
  position: absolute;
  width: 1em;
  top: 1em;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media (min-width: 751px) {
  .pagetop:hover {
    opacity: 0.6;
  }
}
@media (max-width: 750px) {
  .pagetop {
    font-size: 3.7333333333vw;
  }
}

/* ---------
 >>> Kv
--------- */
.kv {
  position: relative;
  width: 100%;
  height: auto;
  aspect-ratio: 2880/1640;
  background-color: black;
}
@media (max-width: 750px) {
  .kv {
    aspect-ratio: 375/636;
  }
}
.kv .kv__img {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}
.kv .kv__contents {
  position: absolute;
  width: 100%;
  padding-top: 2.0833333333vw;
  padding-left: 2.5vw;
  top: 0;
  left: 0;
}
@media (max-width: 750px) {
  .kv .kv__contents {
    padding-top: 5.3333333333vw;
    padding-left: 5.3333333333vw;
  }
}
.kv .kv__catch {
  color: white;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  font-size: 2.2916666667vw;
  letter-spacing: 0.2em;
  line-height: 1.3;
}
@media (max-width: 750px) {
  .kv .kv__catch {
    font-size: 6.4vw;
  }
}
.kv .kv__title {
  padding-top: 2.0833333333vw;
  margin-top: 2.0833333333vw;
}
@media (max-width: 750px) {
  .kv .kv__title {
    padding-top: 3.2vw;
    margin-top: 3.2vw;
  }
}
.kv .kv__title::before {
  position: absolute;
  content: "";
  width: 2.0833333333vw;
  height: 2px;
  background-color: #D9D9D9;
  top: 0;
  left: 0;
  -webkit-transition: width 1.5s cubic-bezier(0.19, 1, 0.22, 1);
  transition: width 1.5s cubic-bezier(0.19, 1, 0.22, 1);
}
@media (max-width: 750px) {
  .kv .kv__title::before {
    width: 4.2666666667vw;
    height: 1px;
  }
}
.kv .kv__title span {
  display: inline-block;
  padding-top: 0.3125em;
  color: white;
  font-family: var(--f-poppins);
  font-size: 1.6666666667vw;
  font-weight: 300;
  line-height: 1.6;
}
@media (max-width: 750px) {
  .kv .kv__title span {
    padding-top: 0.5333333333em;
    font-size: 5vw;
    line-height: 1;
  }
}
.kv .kv__attesa {
  width: 16.1458333333vw;
}
@media (max-width: 750px) {
  .kv .kv__attesa {
    width: 37.8666666667vw;
  }
}
.kv .kv__text {
  padding-top: 1.6666666667em;
  color: white;
  font-size: 1.25vw;
  font-weight: 500;
  line-height: 1.6;
}
@media (max-width: 750px) {
  .kv .kv__text {
    padding-top: 4vw;
    font-size: 4.48vw;
  }
}
.kv .kv__catch {
  opacity: 0;
  -webkit-transition: opacity 2.5s ease;
  transition: opacity 2.5s ease;
}
.kv .kv__title {
  position: relative;
  opacity: 0;
  -webkit-transform: translateX(8px);
          transform: translateX(8px);
  -webkit-transition: all 2.5s ease;
  transition: all 2.5s ease;
  -webkit-transition-delay: 0.8s;
          transition-delay: 0.8s;
}
.kv .kv__text {
  opacity: 0;
  -webkit-transition: opacity 2.5s ease;
  transition: opacity 2.5s ease;
  -webkit-transition-delay: 1.5s;
          transition-delay: 1.5s;
}
.kv.-active .kv__catch {
  opacity: 1;
}
.kv.-active .kv__title {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}
.kv.-active .kv__text {
  opacity: 1;
}

/* -----------
 >>> About
----------- */
.about {
  width: 100%;
  padding-bottom: 6.25vw;
}
@media (max-width: 750px) {
  .about {
    padding-bottom: 13.3333333333vw;
  }
}

.about__inner {
  width: min(100%, 1200px);
  margin: 0 auto;
}
@media (max-width: 750px) {
  .about__inner {
    width: 100%;
  }
}

.about__catch {
  width: 100%;
  padding-bottom: 5em;
  color: white;
  font-size: clamp(18px, 14.1538461538px + 0.5128205128vw, 24px);
  font-weight: 400;
  line-height: 2;
  text-align: center;
}
@media (max-width: 750px) {
  .about__catch {
    padding: 0 1.3333333333em 2.6666666667em;
    margin-top: -4em;
    font-size: 4vw;
    letter-spacing: 0.04em;
  }
}

.about__img {
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
}
.about__img > * {
  display: block;
  width: 100%;
  height: 100%;
}

.section__header {
  position: relative;
  margin-bottom: 80px;
  z-index: 5;
}
@media (max-width: 750px) {
  .section__header {
    margin-bottom: 16vw;
  }
}
.section__header::before {
  position: absolute;
  content: "";
  width: 594px;
  height: auto;
  aspect-ratio: 594/298;
  background: url(../img/heading_bg_obj_leather.webp) no-repeat center/100% auto;
  opacity: 0.7;
  mix-blend-mode: hard-light;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media (max-width: 750px) {
  .section__header::before {
    width: 100%;
  }
}

.section__heading {
  position: relative;
  color: white;
  font-family: var(--f-poppins);
  font-size: 56px;
  font-weight: 400;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}
@media (max-width: 750px) {
  .section__heading {
    font-size: 9.6vw;
  }
}

/* -----------
 >>> Products
----------- */
.products {
  position: relative;
  width: 100%;
  padding-top: 6.25vw;
  padding-bottom: 2.0833333333vw;
}
@media (max-width: 750px) {
  .products {
    padding-top: 13.3333333333vw;
    padding-bottom: 3.7333333333vw;
  }
}

.product {
  width: 100%;
  padding: 6.25vw 20px 4.1666666667vw;
  background-position: top;
  background-repeat: no-repeat;
  background-size: 100% auto;
}
@media (max-width: 750px) {
  .product {
    padding: 6.4vw 0 16vw;
  }
}

.product__column {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 4.1666666667vw;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
  width: min(100%, 1200px);
  margin: 0 auto;
}
@media (max-width: 750px) {
  .product__column {
    gap: 10.6666666667vw 0;
  }
}

.productSlide {
  width: calc(50% - 2.0833333333vw);
}
@media (max-width: 750px) {
  .productSlide {
    width: 100%;
  }
}
.productSlide .slider-set {
  position: relative;
  width: 100%;
}
.productSlide .slider-main {
  width: min(100%, 375px);
  margin-bottom: 3.125vw;
}
@media (max-width: 750px) {
  .productSlide .slider-main {
    width: 66.6666666667vw;
    margin-bottom: 10.6666666667vw;
  }
}
.productSlide .slider-main .swiper-wrapper {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}
.productSlide .slider-main .swiper-slide {
  width: 100%;
}
.productSlide .slider-main .swiper-slide a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: auto;
  height: 100%;
  aspect-ratio: 1;
  margin-left: auto;
  margin-right: auto;
}
.productSlide .slider-main .swiper-slide img {
  height: 100%;
}
.productSlide .swiper-buttons {
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  pointer-events: none;
  z-index: 1;
}
@media (max-width: 750px) {
  .productSlide .swiper-buttons {
    padding-left: 6.4vw;
    padding-right: 6.4vw;
  }
}
.productSlide .swiper-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 24px;
  height: auto;
  aspect-ratio: 1/2;
  background: url(../img/icon_arrow.svg) no-repeat center/100% auto;
  pointer-events: all;
}
@media (max-width: 750px) {
  .productSlide .swiper-button {
    width: 4.8vw;
  }
}
.productSlide .swiper-button::after {
  content: none;
}
.productSlide .swiper-button svg {
  display: none;
}
@media (max-width: 750px) {
  .productSlide .swiper-button.swiper-button-next {
    right: 6.4vw;
  }
}
.productSlide .swiper-button.swiper-button-prev {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}
@media (max-width: 750px) {
  .productSlide .swiper-button.swiper-button-prev {
    left: 6.4vw;
  }
}
.productSlide .slider-thumbnail .swiper-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1%;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.productSlide .slider-thumbnail .swiper-slide {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 17.1428571429% !important;
  height: auto !important;
  margin: 0 !important;
  -webkit-transition: opacity 0.4s;
  transition: opacity 0.4s;
}
.productSlide .slider-thumbnail .swiper-slide.swiper-slide-thumb-active {
  border: 2px solid white;
  opacity: 1;
}
@media (min-width: 751px) {
  .productSlide .slider-thumbnail .swiper-slide {
    cursor: pointer;
  }
  .productSlide .slider-thumbnail .swiper-slide:focus-visible, .productSlide .slider-thumbnail .swiper-slide:hover {
    opacity: 0.6;
  }
}
@media (max-width: 750px) {
  .productSlide .slider-thumbnail .swiper-slide {
    width: 16vw !important;
  }
}

.productSpec {
  width: calc(50% - 2.0833333333vw);
  border: 1px solid;
  background-color: #010A14;
  -o-border-image: linear-gradient(74deg, #222 14.18%, #DBDBDB 34.98%, #5F5F5F 48.05%, #CCCBCB 66.64%, #222 94.28%);
     border-image: linear-gradient(74deg, #222 14.18%, #DBDBDB 34.98%, #5F5F5F 48.05%, #CCCBCB 66.64%, #222 94.28%);
  border-image-slice: 1;
}
@media (max-width: 750px) {
  .productSpec {
    width: calc(100% - 10.6666666667vw);
    margin-left: auto;
    margin-right: auto;
  }
}
.productSpec .accTrigger {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  width: 100%;
  padding: 1.5em 0 1.25em;
  color: white;
  font-size: clamp(18px, 14.1538461538px + 0.5128205128vw, 24px);
  line-height: 1.5;
  text-align: center;
  cursor: default;
}
.productSpec .accTrigger .__copy {
  display: block;
  width: 100%;
  font-size: 1em;
  line-height: 1.25;
}
.productSpec .accTrigger .__subhead {
  display: block;
  width: 100%;
  font-size: 0.75em;
  line-height: 1.25;
}
@media (max-width: 750px) {
  .productSpec .accTrigger {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 1.0666666667vw;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding-top: 1em;
    padding-bottom: 1em;
    font-size: 3.7333333333vw;
  }
  .productSpec .accTrigger .__subhead {
    font-size: 3.2vw;
  }
  .productSpec .accTrigger .__icon {
    position: absolute;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    width: 4.2666666667vw;
    height: auto;
    aspect-ratio: 1;
    border: 1px solid white;
    border-radius: 50%;
    top: 50%;
    right: 1.5em;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .productSpec .accTrigger .__icon svg {
    position: relative;
    display: block;
    width: 2.6666666667vw;
    height: auto;
    aspect-ratio: 1;
  }
}
.productSpec .accContents {
  width: 100%;
}
.productSpec .accContents dl {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 7em clamp(8px, 5.4358974359px + 0.3418803419vw, 12px) 1fr;
  grid-template-columns: 7em 1fr;
  gap: clamp(20px, 7.1794871795px + 1.7094017094vw, 40px) clamp(8px, 5.4358974359px + 0.3418803419vw, 12px);
  padding: 0 clamp(20px, 7.1794871795px + 1.7094017094vw, 40px) clamp(40px, 27.1794871795px + 1.7094017094vw, 60px);
  color: var(--c-gray4);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.6;
}
@media (max-width: 750px) {
  .productSpec .accContents dl {
    gap: 6.4vw 1.0666666667vw;
    padding: 3.2vw 5.3333333333vw 6.4vw;
    font-size: 3.7333333333vw;
  }
}
.productSpec input[type=checkbox] {
  position: absolute;
  width: 1px;
  height: 1px;
  clip-path: polygon(0, 0, 0, 0);
}
@media (max-width: 750px) {
  .productSpec input[type=checkbox] ~ .accTrigger .__icon svg {
    -webkit-transform: rotate(180deg);
            transform: rotate(180deg);
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
  }
  .productSpec input[type=checkbox] ~ .accContents {
    height: 0;
    opacity: 0;
    -webkit-transition: height 0.4s;
    transition: height 0.4s;
  }
  .productSpec input[type=checkbox]:checked ~ .accTrigger .__icon svg {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  .productSpec input[type=checkbox]:checked ~ .accContents {
    height: auto;
    opacity: 1;
  }
}

.product__infos {
  padding-top: 2.0833333333vw;
}
@media (max-width: 750px) {
  .product__infos {
    padding-top: 6.4vw;
  }
}
.product__infos .__name {
  color: white;
  font-family: var(--f-poppins);
  font-size: clamp(24px, 20.1538461538px + 0.5128205128vw, 30px);
  font-weight: 500;
  line-height: 1.8;
  text-align: center;
}
@media (max-width: 750px) {
  .product__infos .__name {
    font-size: 6.4vw;
  }
}
.product__infos .__fullprice {
  color: white;
  font-family: var(--f-poppins);
  font-size: clamp(24px, 20.1538461538px + 0.5128205128vw, 30px);
  font-weight: 500;
  line-height: 1.8;
  text-align: center;
}
@media (max-width: 750px) {
  .product__infos .__fullprice {
    font-size: 6.4vw;
  }
}
.product__infos .__excltaxprice {
  color: white;
  font-family: var(--f-poppins);
  font-size: 18px;
  font-weight: 500;
  line-height: 1.8;
  text-align: center;
}
@media (max-width: 750px) {
  .product__infos .__excltaxprice {
    font-size: 3.2vw;
    line-height: 1.5;
  }
}
.product__infos .__tag {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0.2em 0.7em 0.3em;
  margin: 12px auto 0;
  background-color: var(--c-citizen-black);
  color: var(--c-gray4);
  font-size: 18px;
  font-weight: 400;
  line-height: 1.6;
  text-align: center;
}
@media (max-width: 750px) {
  .product__infos .__tag {
    padding: 0.333333em 1em;
    margin-top: 0.666666em;
    font-size: 3.2vw;
  }
}

.product_links {
  width: 100%;
}

.product_link {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: min(100%, 800px);
  padding: 1.0333333333em 0 0.9em;
  margin: 0 auto;
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  border: 1px solid #888;
  color: white;
  font-family: var(--f-poppins);
  font-size: clamp(24px, 20.1538461538px + 0.5128205128vw, 30px);
  font-weight: 500;
  line-height: 2;
  text-align: center;
  text-wrap: nowrap;
  -webkit-transition: opacity 0.4s;
  transition: opacity 0.4s;
}
.product_link::after {
  position: absolute;
  content: "";
  width: 12px;
  height: auto;
  aspect-ratio: 1/2;
  background: url(../img/icon_arrow.svg) no-repeat center/100% auto;
  top: 50%;
  right: 1em;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.product_link em {
  font-size: 1em;
  font-style: normal;
}
@media (min-width: 751px) {
  .product_link:focus-visible, .product_link:hover {
    opacity: 0.6;
  }
}
@media (max-width: 750px) {
  .product_link {
    display: block;
    width: calc(100% - 10.6666666667vw);
    font-size: 4.8vw;
    line-height: 1.5;
    text-wrap: auto;
  }
  .product_link::after {
    width: 2.6666666667vw;
  }
  .product_link em {
    font-size: 1.3333333333em;
  }
}

.product--CC4076-65A {
  background-image: url(../img/products/attesa_CC4076-65A_bg_pc.webp);
}
@media (max-width: 750px) {
  .product--CC4076-65A {
    background-image: url(../img/products/attesa_CC4076-65A_bg_sp.webp);
  }
}
.product--CC4076-65A .product_link {
  background-image: url(../img/products/attesa_CC4076-65A_link_pc.webp);
}
@media (max-width: 750px) {
  .product--CC4076-65A .product_link {
    background-image: url(../img/products/attesa_CC4076-65A_link_sp.webp);
  }
}

.product--AT8284-61A {
  background-image: url(../img/products/attesa_AT8284-61A_bg_pc.webp);
}
@media (max-width: 750px) {
  .product--AT8284-61A {
    background-image: url(../img/products/attesa_AT8284-61A_bg_sp.webp);
  }
}
.product--AT8284-61A .product_link {
  background-image: url(../img/products/attesa_AT8284-61A_link_pc.webp);
}
@media (max-width: 750px) {
  .product--AT8284-61A .product_link {
    background-image: url(../img/products/attesa_AT8284-61A_link_sp.webp);
  }
}

.product--CB0284-66A {
  background-image: url(../img/products/attesa_CB0284-66A_bg_pc.webp);
}
@media (max-width: 750px) {
  .product--CB0284-66A {
    background-image: url(../img/products/attesa_CB0284-66A_bg_sp.webp);
  }
}
.product--CB0284-66A .product_link {
  background-image: url(../img/products/attesa_CB0284-66A_link_pc.webp);
}
@media (max-width: 750px) {
  .product--CB0284-66A .product_link {
    background-image: url(../img/products/attesa_CB0284-66A_link_sp.webp);
  }
}

/* ------------
 >>> Details
------------ */
.unique {
  width: 100%;
  padding-top: 6.25vw;
  padding-bottom: 6.25vw;
}
@media (max-width: 750px) {
  .unique {
    padding-top: 13.3333333333vw;
    padding-bottom: 13.3333333333vw;
  }
}

.unique__copy {
  padding-top: 1.333333em;
  margin-bottom: 2em;
  color: white;
  font-size: clamp(24px, 20.1538461538px + 0.5128205128vw, 30px);
  font-weight: 400;
  line-height: 2;
  text-align: center;
}
@media (max-width: 750px) {
  .unique__copy {
    padding-top: 0;
    margin-bottom: 1.6666666667em;
    font-size: 6.4vw;
    line-height: 1.5;
  }
}

.unique__colunmns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 60px 0;
  width: min(100%, 1240px);
  padding-left: 20px;
  padding-right: 20px;
  margin: 0 auto;
}
@media (max-width: 750px) {
  .unique__colunmns {
    gap: 10.6666666667vw 0;
    padding-left: 0;
    padding-right: 0;
  }
}

.unique__colunmn {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 clamp(20px, 7.1794871795px + 1.7094017094vw, 40px);
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (min-width: 751px) {
  .unique__colunmn:nth-child(even) {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
  .unique__colunmn:has(.uniqueSlide) {
    padding-bottom: 64px;
  }
}
@media (max-width: 750px) {
  .unique__colunmn {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 5.3333333333vw 0;
  }
  .unique__colunmn:has(.uniqueSlide) .unique__imgWrapper {
    padding-bottom: 12.8vw;
  }
}

.unique__imgWrapper {
  width: 46.6666666667%;
}
@media (max-width: 750px) {
  .unique__imgWrapper {
    width: calc(100% - 10.6666666667vw);
  }
}
@media (min-width: 751px) {
  .unique__imgWrapper a {
    -webkit-transition: opacity 0.4s;
    transition: opacity 0.4s;
  }
  .unique__imgWrapper a:hover {
    opacity: 0.6;
  }
}

.unique__textWrapper {
  width: 50%;
}
@media (max-width: 750px) {
  .unique__textWrapper {
    width: 100%;
    padding-left: 5.3333333333vw;
    padding-right: 5.3333333333vw;
  }
}
.unique__textWrapper .unique__title {
  margin-bottom: 0.6666666667em;
  color: white;
  font-size: clamp(20px, 17.4358974359px + 0.3418803419vw, 24px);
  font-weight: 500;
  line-height: 1.6;
}
@media (max-width: 750px) {
  .unique__textWrapper .unique__title {
    margin-bottom: 0.5em;
    font-size: 4.8vw;
  }
}
.unique__textWrapper .unique__text {
  color: var(--c-gray4);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.6;
}
@media (max-width: 750px) {
  .unique__textWrapper .unique__text {
    font-size: 3.2vw;
    line-height: 1.8;
  }
}

.uniqueSlide .slider-set {
  position: relative;
}
.uniqueSlide .swiper-buttons {
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: min(100%, 360px);
  height: 64px;
  padding-top: 16px;
  bottom: 0;
  left: 50%;
  -webkit-transform: translate(-50%, 100%);
          transform: translate(-50%, 100%);
  pointer-events: none;
}
@media (max-width: 750px) {
  .uniqueSlide .swiper-buttons {
    height: 12.8vw;
    padding-top: 4.2666666667vw;
  }
}
.uniqueSlide .swiper-button {
  position: static;
  display: block;
  width: 48px;
  height: auto;
  aspect-ratio: 1;
  padding: 0;
  margin: 0;
  background: url(../img/icon_unique_slider_arrow.svg) no-repeat center/11px auto;
  pointer-events: all;
}
.uniqueSlide .swiper-button::after {
  content: none !important;
}
.uniqueSlide .swiper-button.swiper-button-next {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}
.uniqueSlide .swiper-button[disabled] {
  opacity: 0.6;
  pointer-events: none;
}
@media (max-width: 750px) {
  .uniqueSlide .swiper-button {
    width: 8.5333333333vw;
  }
}
.uniqueSlide .swiper-pagination {
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: end;
  gap: 0 36px;
  width: min(100%, 360px);
  height: 64px;
  padding-top: 16px;
  padding-bottom: 12px;
  margin: 0;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  pointer-events: none;
}
@media (max-width: 750px) {
  .uniqueSlide .swiper-pagination {
    gap: 0 6.4vw;
    height: 12.8vw;
    padding: 6.4vw 0 2.1333333333vw;
  }
}
.uniqueSlide .swiper-pagination-bullet {
  width: 2px;
  height: 18px;
  margin: 0;
  background-color: var(--c-gray4);
  border-radius: 0;
  opacity: 1;
}
.uniqueSlide .swiper-pagination-bullet.swiper-pagination-bullet-active {
  width: 6px;
  height: 24px;
  background-color: #D9D9D9;
}
@media (max-width: 750px) {
  .uniqueSlide .swiper-pagination-bullet {
    width: 0.2666666667vw;
    height: 3.2vw;
    margin: 0 !important;
  }
  .uniqueSlide .swiper-pagination-bullet.swiper-pagination-bullet-active {
    width: 1.0666666667vw;
    height: 4.2666666667vw;
  }
}

/* ------------
 >>> Features
------------ */
.features {
  width: 100%;
  padding-top: 6.25vw;
  padding-bottom: 6.25vw;
}
@media (max-width: 750px) {
  .features {
    padding-top: 13.3333333333vw;
    padding-bottom: 13.3333333333vw;
  }
}

.features__heading {
  margin-bottom: 2em;
  color: white;
  font-size: clamp(24px, 20.1538461538px + 0.5128205128vw, 30px);
  font-weight: 400;
  line-height: 2;
  text-align: center;
}
@media (max-width: 750px) {
  .features__heading {
    margin-bottom: 1.6666666667em;
    font-size: 6.4vw;
    line-height: 1.5;
  }
}

.features__tile {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 3.125vw;
  width: min(100%, 1240px);
  padding-left: 20px;
  padding-right: 20px;
  margin: 0 auto;
}
@media (max-width: 750px) {
  .features__tile {
    -ms-grid-columns: 1fr;
    grid-template-columns: repeat(1, 1fr);
    gap: 10.6666666667vw 0;
    padding-left: 5.3333333333vw;
    padding-right: 5.3333333333vw;
  }
}

.features__item {
  -webkit-box-flex: 1;
      -ms-flex: 1 0 auto;
          flex: 1 0 auto;
  width: max(33.333% - 3.125vw, 320px);
}
@media (max-width: 750px) {
  .features__item {
    width: 100%;
  }
}

.features__picture {
  width: 100%;
  margin-bottom: 24px;
}
@media (max-width: 750px) {
  .features__picture {
    margin-bottom: 4.2666666667vw;
  }
}

.features__title {
  margin-bottom: 0.666em;
  color: white;
  font-size: clamp(16px, 14.7179487179px + 0.1709401709vw, 18px);
  font-weight: 500;
  line-height: 1.6;
  text-wrap: nowrap;
}
@media (max-width: 750px) {
  .features__title {
    font-size: 4.2666666667vw;
    margin-bottom: 0.25em;
    text-wrap: auto;
  }
}

.features__text {
  color: var(--c-gray4);
  font-size: clamp(12px, 9.4358974359px + 0.3418803419vw, 16px);
  font-weight: 400;
  line-height: 1.8;
}
@media (max-width: 750px) {
  .features__text {
    font-size: 3.2vw;
  }
}

/* ------------
 >>> Special
------------ */
.special {
  width: 100%;
  padding-top: 6.25vw;
  padding-bottom: 6.25vw;
}
@media (max-width: 750px) {
  .special {
    padding-top: 13.3333333333vw;
    padding-bottom: 13.3333333333vw;
  }
}

.special__videoWrapper {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 67.9117147708% 10.1867572156% 1fr;
  grid-template-columns: 67.9117147708% 1fr;
  gap: 0 10.1867572156%;
  width: min(100%, 1218px);
  padding-left: 20px;
  padding-right: 20px;
  padding-top: 2.0833333333vw;
  margin: 0 auto;
}
@media (max-width: 750px) {
  .special__videoWrapper {
    -ms-grid-columns: 1fr;
    grid-template-columns: repeat(1, 1fr);
    gap: 16vw 0;
    place-items: center;
    padding: 0 5.3333333333vw;
  }
}
.special__videoWrapper > * {
  width: 100%;
}
.special__videoWrapper .video__yt {
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
}
.special__videoWrapper .video__yt img {
  width: 100%;
  height: auto;
}
.special__videoWrapper .video__yt[data-modal] {
  cursor: pointer;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}
@media (min-width: 751px) {
  .special__videoWrapper .video__yt[data-modal]:hover {
    opacity: 0.6;
  }
}
.special__videoWrapper .video__shorts {
  width: 100%;
  height: auto;
  aspect-ratio: 9/16;
  margin-left: auto;
  margin-right: auto;
}
.special__videoWrapper .video__shorts img {
  width: 100%;
  height: auto;
}
.special__videoWrapper .video__shorts[data-modal] {
  cursor: pointer;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}
@media (min-width: 751px) {
  .special__videoWrapper .video__shorts[data-modal]:hover {
    opacity: 0.6;
  }
}
@media (max-width: 750px) {
  .special__videoWrapper .video__shorts {
    width: 67.1641791045%;
  }
}
.special__videoWrapper iframe {
  width: 100%;
  height: 100%;
}

/* ------------
 >>> Line Up
------------ */
.lineup {
  width: 100%;
  padding-top: 6.25vw;
  padding-bottom: 6.25vw;
}
@media (max-width: 750px) {
  .lineup {
    padding-top: 13.3333333333vw;
    padding-bottom: 13.3333333333vw;
  }
}

.lineup__productSet {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 clamp(32px, 11.4871794872px + 2.735042735vw, 64px);
  width: min(100%, 840px);
  padding: 2.0833333333vw 20px 0;
  margin: 0 auto;
}
@media (max-width: 750px) {
  .lineup__productSet {
    gap: 0 4vw;
    padding: 0 5.3333333333vw;
  }
}

.lineup__product {
  width: 100%;
}
@media (max-width: 750px) {
  .lineup__product {
    width: calc(33.333333% - 2.6666666667vw);
  }
}
.lineup__product .__image {
  width: min(100%, 220px);
  padding-bottom: 24px;
  margin: 0 auto;
}
@media (max-width: 750px) {
  .lineup__product .__image {
    width: 100%;
    padding-bottom: 4.2666666667vw;
  }
}
.lineup__product .__name {
  width: 100%;
  color: white;
  font-family: var(--f-poppins);
  font-size: 24px;
  font-weight: 400;
  line-height: 1.8;
  text-align: center;
}
@media (max-width: 750px) {
  .lineup__product .__name {
    font-size: 3.2vw;
    line-height: 1.3;
  }
}
.lineup__product .__fullprice {
  width: 100%;
  padding-bottom: 0.333em;
  color: white;
  font-family: var(--f-poppins);
  font-size: 24px;
  font-weight: 400;
  line-height: 1.8;
  text-align: center;
}
@media (max-width: 750px) {
  .lineup__product .__fullprice {
    padding-bottom: 0.5em;
    font-size: 3.2vw;
    line-height: 1.3;
  }
}
.lineup__product .__excltaxprice {
  width: 100%;
  padding-bottom: 1em;
  color: white;
  font-family: var(--f-poppins);
  font-size: 16px;
  font-weight: 500;
  line-height: 1.6;
  text-align: center;
  text-wrap: nowrap;
}
@media (max-width: 750px) {
  .lineup__product .__excltaxprice {
    font-size: 2.6666666667vw;
    font-weight: 400;
  }
}
.lineup__product .__tag {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0.25em 0.7em;
  margin: 0 auto;
  background-color: var(--c-citizen-black);
  color: var(--c-gray4);
  font-size: 18px;
  font-weight: 400;
  line-height: 1.6;
  text-align: center;
}
@media (max-width: 750px) {
  .lineup__product .__tag {
    padding: 0.2em 0.4em;
    font-size: 2.6666666667vw;
  }
}
.lineup__product .__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 0.75em;
  width: 100%;
  padding: 0.8333333333em 0;
  margin-top: 1.3333333333em;
  background-color: transparent;
  border: 2px solid white;
  color: white;
  font-size: 18px;
  font-weight: 500;
  line-height: 1;
}
.lineup__product .__link::after {
  position: relative;
  content: "";
  width: 11px;
  height: auto;
  aspect-ratio: 1/2;
  background: url(../img/icon_unique_slider_arrow.svg) no-repeat center/100% auto;
  top: 1px;
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}
@media (max-width: 750px) {
  .lineup__product .__link {
    gap: 0 0.75em;
    padding: 0.5em 0;
    border-width: 1px;
    font-size: 3.2vw;
  }
  .lineup__product .__link::after {
    width: 2.4vw;
  }
}
@media (min-width: 751px) {
  .lineup__product a {
    -webkit-transition: opacity 0.4s;
    transition: opacity 0.4s;
  }
  .lineup__product a:focus-visible, .lineup__product a:hover {
    opacity: 0.6;
  }
}

/* ------------
 >>> Banner
------------ */
.banner {
  position: relative;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 240px 24px 1fr;
  grid-template-columns: 240px 1fr;
  gap: 24px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: min(100% - 40px, 800px);
  padding: 24px;
  margin: 0 auto;
  border: 1px solid #888;
}
.banner .__name {
  padding-bottom: 0.5em;
  color: white;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.5;
}
.banner .__text {
  color: white;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
}
.banner a {
  position: absolute;
  display: block;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}
@media (min-width: 751px) {
  .banner {
    -webkit-transition: opacity 0.4s;
    transition: opacity 0.4s;
  }
  .banner:hover {
    opacity: 0.6;
  }
}
@media (max-width: 750px) {
  .banner {
    display: block;
    padding: 5.3333333333vw;
    margin-top: 2.6666666667vw;
    margin-bottom: 13.3333333333vw;
  }
  .banner .__name {
    padding-top: 1em;
    font-size: 4.2666666667vw;
  }
  .banner .__text {
    font-size: 3.2vw;
  }
}

/* ------------
 >>> In-View Settings
------------ */
.in-view {
  translate: none;
  rotate: none;
  scale: none;
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translate(0px, 20px);
          transform: translate(0px, 20px);
  -webkit-transition: all 2s ease;
  transition: all 2s ease;
}
.in-view:nth-child(1) {
  -webkit-transition-delay: 0.15s;
          transition-delay: 0.15s;
}
.in-view:nth-child(2) {
  -webkit-transition-delay: 0.3s;
          transition-delay: 0.3s;
}
.in-view:nth-child(3) {
  -webkit-transition-delay: 0.45s;
          transition-delay: 0.45s;
}
.in-view:nth-child(4) {
  -webkit-transition-delay: 0.6s;
          transition-delay: 0.6s;
}
.in-view:nth-child(5) {
  -webkit-transition-delay: 0.75s;
          transition-delay: 0.75s;
}
.in-view:nth-child(6) {
  -webkit-transition-delay: 0.9s;
          transition-delay: 0.9s;
}
.in-view.is-in {
  opacity: 1;
  visibility: inherit;
  -webkit-transform: translate(0px, 0px);
          transform: translate(0px, 0px);
}

.js-stag {
  position: relative;
}

.js-in {
  position: relative;
}

[data-js-slice] {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  overflow: hidden;
}
[data-js-slice] span {
  opacity: 0;
  -webkit-transition: opacity 1.5s cubic-bezier(0.23, 1, 0.32, 1), translate 1.5s cubic-bezier(0.23, 1, 0.32, 1);
  transition: opacity 1.5s cubic-bezier(0.23, 1, 0.32, 1), translate 1.5s cubic-bezier(0.23, 1, 0.32, 1);
  -webkit-transition-delay: calc(var(--index) * 0.02s);
          transition-delay: calc(var(--index) * 0.02s);
  translate: 0 1em;
}
[data-js-slice] span.-space {
  width: 0.25em;
}
[data-js-slice].is-view span {
  opacity: 1;
  translate: 0;
}

.no-scroll {
  overflow: hidden;
  position: fixed;
  width: 100%;
}

.modal__bg,
.modal__inner,
.modalDetail {
  opacity: 1;
  -webkit-transition: opacity 0.6s ease, visibility 0.6s ease;
  transition: opacity 0.6s ease, visibility 0.6s ease;
  visibility: hidden;
}

.modal__bg.is-active,
.modal__inner.is-active,
.modalDetail.is-active {
  opacity: 1;
  visibility: visible;
}

.modal__bg,
.modal__inner {
  height: 100vh;
  left: 0;
  position: fixed;
  top: 0;
  width: 100vw;
  z-index: 12;
}

.modal__bg {
  background-color: rgba(0, 0, 0, 0.9);
}

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

.modal__close {
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 48px;
  height: auto;
  aspect-ratio: 1;
  background-color: var(--c-citizen-black);
  border-radius: 50%;
  right: 0;
  top: -8px;
  -webkit-transform: translateY(-100%);
          transform: translateY(-100%);
  z-index: 13;
  cursor: pointer;
}
.modal__close::before, .modal__close::after {
  position: absolute;
  content: "";
  display: block;
  width: 50%;
  height: 1px;
  background-color: #fff;
}
.modal__close::before {
  rotate: 45deg;
}
.modal__close::after {
  rotate: -45deg;
}

.modalDetail.modalDetail--yt {
  position: absolute;
  width: min(100% - 40px, 1200px);
  height: auto;
  aspect-ratio: 16/9;
  z-index: 12;
}
.modalDetail.modalDetail--shorts {
  position: absolute;
  width: min(100% - 40px, 335px);
  height: auto;
  aspect-ratio: 9/16;
  z-index: 12;
}
.modalDetail iframe {
  position: absolute;
  width: 100% !important;
  height: 100% !important;
  right: 0;
  top: 0;
}

@-webkit-keyframes splide-loading {
  0% {
    -webkit-transform: rotate(0);
    transform: rotate(0);
  }
  to {
    -webkit-transform: rotate(1turn);
    transform: rotate(1turn);
  }
}
@keyframes splide-loading {
  0% {
    -webkit-transform: rotate(0);
    transform: rotate(0);
  }
  to {
    -webkit-transform: rotate(1turn);
    transform: rotate(1turn);
  }
}
.splide__track--draggable {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  -moz-user-select: none;
       user-select: none;
}

.splide__track--fade > .splide__list > .splide__slide {
  margin: 0 !important;
  opacity: 0;
  z-index: 0;
}

.splide__track--fade > .splide__list > .splide__slide.is-active {
  opacity: 1;
  z-index: 1;
}

.splide--rtl {
  direction: rtl;
}

.splide__track--ttb > .splide__list {
  display: block;
}

.splide__container {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: relative;
}

.splide__list {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  margin: 0 !important;
  padding: 0 !important;
}

.splide.is-initialized:not(.is-active) .splide__list {
  display: block;
}

.splide__pagination {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 0;
  pointer-events: none;
}

.splide__pagination li {
  display: inline-block;
  line-height: 1;
  list-style-type: none;
  margin: 0;
  pointer-events: auto;
}

.splide:not(.is-overflow) .splide__pagination {
  display: none;
}

.splide__progress__bar {
  width: 0;
}

.splide {
  position: relative;
  visibility: hidden;
}

.splide.is-initialized,
.splide.is-rendered {
  visibility: visible;
}

.splide__slide {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  list-style-type: none !important;
  margin: 0;
  position: relative;
}

.splide__slide img {
  vertical-align: bottom;
}

.splide__spinner {
  -webkit-animation: splide-loading 1s linear infinite;
  animation: splide-loading 1s linear infinite;
  border: 2px solid #999;
  border-left-color: transparent;
  border-radius: 50%;
  bottom: 0;
  contain: strict;
  display: inline-block;
  height: 20px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 0;
  width: 20px;
}

.splide__sr {
  clip: rect(0 0 0 0);
  border: 0;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.splide__toggle.is-active .splide__toggle__play,
.splide__toggle__pause {
  display: none;
}

.splide__toggle.is-active .splide__toggle__pause {
  display: inline;
}

.splide__track {
  overflow: hidden;
  position: relative;
  z-index: 0;
}

/*
Print
*/
@media print {
  * {
    background: transparent !important;
    border-color: black !important;
    -webkit-box-shadow: none !important;
            box-shadow: none !important;
    color: black !important;
    text-shadow: none !important;
  }
  body {
    width: 210mm;
  }
  header,
  footer {
    display: none !important;
  }
  footer::after {
    content: "";
  }
  .-noprint {
    display: none;
  }
}
@page {
  margin: 0;
  size: A4;
}