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

body { line-height: 1; }

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; }

nav ul { list-style: none; }

blockquote, q { quotes: none; }

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

a { margin: 0; padding: 0; font-size: 100%; vertical-align: baseline; background: transparent; color: inherit; text-decoration: none; }

/* change colours to suit your needs */
ins { background-color: #ff9; color: #000; text-decoration: none; }

/* change colours to suit your needs */
mark { background-color: #ff9; color: #000; font-style: italic; font-weight: bold; }

del { text-decoration: line-through; }

abbr[title], dfn[title] { border-bottom: 1px dotted; cursor: help; }

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

/* change border colour to suit your needs */
hr { display: block; height: 1px; border: 0; border-top: 1px solid #cccccc; margin: 1em 0; padding: 0; }

input, button, textarea, select { margin: 0; padding: 0; background: none; border: none; border-radius: 0; outline: none; -webkit-appearance: none; -moz-appearance: none; appearance: none; }

textarea { resize: none; }

html, body { -webkit-text-size-adjust: none; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-rendering: optimizeLegibility; }

img, video { vertical-align: bottom; max-width: 100%; height: auto; }

img[src$=".svg"] { width: 100%; }

li { list-style: none; }

main { display: block; }

h1, h2, h3, h4, h5 { font-weight: inherit; }

img { width: 100%; }

*:focus { outline: none; }

/* --------------------------------------------------
Common
-------------------------------------------------- */
@media screen and (max-width: 767px) { .pc { display: none !important; } }
@media screen and (min-width: 768px) { .sp { display: none !important; } }
#pagetop { overflow: clip; }

#content { padding: 0; }

/* --------------------------------------------------
Contents
-------------------------------------------------- */
@keyframes hoverLine { 0% { transform: translate(0, 0); opacity: 1; }
  40% { transform: translate(101%, 0); opacity: 1; }
  41% { transform: translate(101%, 0); opacity: 0; }
  42% { transform: translate(-101%, 0); opacity: 0; }
  50% { transform: translate(-101%, 0); opacity: 1; }
  100% { transform: translate(0, 0); } }
body #lp-contents-wrapper { font-family: "neue-haas-grotesk-text", sans-serif; color: #000000; padding: 52px 0 0; }
body #lp-contents-wrapper .top { position: relative; }
body #lp-contents-wrapper .top .imagearea img { aspect-ratio: 750 / 1160; }
body #lp-contents-wrapper .top .titlearea { position: absolute; left: 0; right: 0; top: 50%; opacity: 0; transform: translate(0, 20px) translate(0, -50%); }
body #lp-contents-wrapper .top .titlearea .title { padding: 0 9.6%; color: #ED220C; }
body #lp-contents-wrapper .top .titlearea .title span { display: block; }
body #lp-contents-wrapper .top .titlearea .title span.text-1 { font-size: 3.07vw; margin: 0 0 8.25%; }
body #lp-contents-wrapper .top .titlearea .title span.text-2 { text-align: right; font-size: 3.73vw; }
body #lp-contents-wrapper .sticky-container .sticky-elm { display: flex; justify-content: center; align-items: center; text-align: center; aspect-ratio: 750 / 260; position: sticky; left: 0; top: 52px; }
body #lp-contents-wrapper .sticky-container .sticky-elm .logo { width: 26.13%; }
body #lp-contents-wrapper .sticky-container .sticky-contents { position: relative; z-index: 2; transform: translate3d(0, 0, 1px); }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper { background: #FFFFFF; }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents { position: sticky; left: 0; top: 52px; }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look { overflow: hidden; position: relative; }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .flex-container { display: flex; will-change: transform; }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .flex-container .image-container { width: 100%; flex: none; position: relative; }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .flex-container .image-container .image-wrapper .imagearea img { aspect-ratio: 2 / 3; }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .flex-container .image-container .image-wrapper a { pointer-events: none; }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .flex-container .image-container .image-wrapper .toggle-icon { display: none; }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look.look02 .flex-container .image-container:nth-child(2) { width: 225%; }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look.look02 .flex-container .image-container:nth-child(2) .image-wrapper .imagearea img { aspect-ratio: 3 / 2; }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .toggle-icon { width: calc(var(--vw) * (0.07 * 100)); aspect-ratio: 1; position: absolute; right: calc(var(--vw) * (0.05 * 100)); bottom: calc(var(--vw) * (0.05 * 100)); }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .toggle-icon::before, body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .toggle-icon::after { display: block; content: ""; background: #FFFFFF; position: absolute; }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .toggle-icon::before { width: 1px; left: calc((100% - 1px) / 2); top: 0; bottom: 0; transition: transform .4s ease 0s, opacity .4s ease 0s; }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .toggle-icon::after { height: 1px; left: 0; right: 0; top: calc((100% - 1px) / 2); }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .textarea { position: absolute; left: 6.67%; bottom: calc(var(--vw) * (0.05 * 100)); display: none; }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .textarea .credit ul li { color: #FFFFFF; font-size: 14px; line-height: 1.61; }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look.credit-open .toggle-icon::before { transform: rotate(90deg); opacity: 0; }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container.sticky01 { height: calc(1475vw + 790px); }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container.sticky02 { height: calc(1225vw + 790px); }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container.sticky03 { height: calc(850vw + 790px); }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container.sticky04 { height: calc(600vw + 790px); }
body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container.sticky05 { height: calc(250vw + 790px); }
body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents { height: 790px; box-sizing: border-box; padding: 235px 0 75px; background: #FFFFFF; text-align: center; }
body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents > * { opacity: 0; transform: translate(0, 20px); }
body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents > *.is-show { opacity: 1; transform: none; transition: opacity 1.6s ease 0s, transform 1.6s ease 0s; }
body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents .concept { margin: 0 0 95px; }
body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents .concept .title { color: #ED220C; font-size: 12.5px; margin: 0 0 20px; }
body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents .concept p { font-family: hiragino-kaku-gothic-pron, sans-serif; font-size: 10.5px; line-height: 1.9; }
body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents .concept p .row { display: block; opacity: 0; transform: translate(0, 20px); }
body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents .concept p .row.is-show { opacity: 1; transform: none; transition: opacity 1.6s ease 0s, transform 1.6s ease 0s; }
body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents .staff-credit { margin: 0 0 95px; }
body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents .staff-credit p { font-size: 10.5px; line-height: 1.57; }
body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents .view-all { font-weight: 500; font-size: 9.5px; }
body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents .view-all a { position: relative; display: inline-block; overflow: hidden; padding: 0 0 3px; }
body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents .view-all a::after { display: block; content: ""; position: absolute; left: 0; top: 0; right: 0; bottom: 0; border-bottom: solid 1px; }
body #lp-contents-wrapper.is-loaded { opacity: 1 !important; transition: opacity 1s ease 0s; }
body #lp-contents-wrapper.is-loaded .top .titlearea { opacity: 1; transform: translate(0, -50%); transition: opacity 1.6s ease .8s, transform 1.6s ease .8s; }

@media screen and (orientation: landscape) { body #lp-contents-wrapper .top .imagearea img { aspect-ratio: 1440 / 957; }
  body #lp-contents-wrapper .top .titlearea .title { padding: 0 17.75%; display: flex; justify-content: space-between; align-items: center; }
  body #lp-contents-wrapper .top .titlearea .title span.text-1 { font-size: 1.5vw; margin: 0; }
  body #lp-contents-wrapper .top .titlearea .title span.text-2 { font-size: 2.6vw; } }
@media screen and (min-width: 768px) { body #lp-contents-wrapper { padding: 60px 0 0; }
  body #lp-contents-wrapper .sticky-container .sticky-elm { aspect-ratio: 2000 / 550; top: 60px; }
  body #lp-contents-wrapper .sticky-container .sticky-elm .logo { width: 21%; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents { position: static; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .flex-container { transform: none !important; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .flex-container .image-container { width: 50%; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .flex-container .image-container .image-wrapper a { pointer-events: auto; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .flex-container .image-container .image-wrapper .toggle-icon { display: block; width: calc(var(--vw) * (0.02 * 100)); right: calc(var(--vw) * (0.03 * 100)); bottom: calc(var(--vw) * (0.03 * 100)); }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .flex-container .image-container .image-wrapper .toggle-icon::before { width: 2px; left: calc((100% - 2px) / 2); }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .flex-container .image-container .image-wrapper .toggle-icon::after { height: 2px; top: calc((100% - 2px) / 2); }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .flex-container .image-container .textarea { left: calc(var(--vw) * (0.03 * 100)); bottom: calc(var(--vw) * (0.03 * 100)); }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .flex-container .image-container .textarea .credit ul li { font-size: 17px; line-height: 1.7; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .flex-container .image-container .textarea .credit ul li a { transition: color .4s ease 0s; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .flex-container .image-container .textarea .credit ul li a:hover { color: #ED220C; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look .flex-container .image-container.credit-open .toggle-icon::before { transform: rotate(90deg); opacity: 0; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look > .toggle-icon { display: none; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look.look02 .flex-container .image-container:nth-child(2) { width: 50%; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look.look02 .flex-container .image-container:nth-child(2) .image-wrapper .imagearea img { aspect-ratio: 2 / 3; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look.look04 .flex-container { flex-direction: row-reverse; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container .look-sticky-contents .look.look04 .flex-container .image-container:nth-child(3) { display: none; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container.sticky01 { height: auto; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container.sticky02 { height: auto; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container.sticky03 { height: auto; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container.sticky04 { height: auto; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .look-wrapper .look-sticky-container.sticky05 { height: auto; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents { height: auto; padding: 350px 0 100px; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents .concept { margin: 0 0 178px; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents .concept .title { font-size: 19px; margin: 0 0 25px; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents .concept p { font-size: 16px; line-height: 1.91; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents .staff-credit { margin: 0 0 178px; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents .staff-credit p { font-size: 16px; line-height: 1.56; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents .view-all { font-size: 11px; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents .view-all a { transition: color .4s ease 0s; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents .view-all a:hover { color: #ED220C; }
  body #lp-contents-wrapper .sticky-container .sticky-contents .lp-foot-contents .view-all a:hover::after { animation: hoverLine .6s linear 0s forwards; } }
