﻿/* パンくず 追加スタイル PC */
@media only screen and (min-width: 768px){
  .breadcrumb__list{
    padding-bottom: 1.6rem;
  }
}

/* LPコンテンツ */
.main-area {
  --color-text-primary: #000;
  --color-text-secondary: #FFF;
  --color-lead-bg: #4B4A38;
  --color-logo-bg: #DDD9CC;
  --color-logo-border: #000;
  --color-section-body-bg: #EFEDE5;

  --font-hiragino: "hiragino-kaku-gothic-pron", sans-serif;
  --font-inter: "Inter", sans-serif;

  font-family: var(--font-hiragino);
  color: var(--color-text-primary);
  font-weight: 300;
}
.main-area :where(img, svg) {
  width: 100%;
  height: auto;
}
.contents-header {
  
}
.contents-header__keyvisual {

}
.contents-header__lead-wrap {
  background-color: var(--color-lead-bg);
}
.contents-header__lead {
  color: var(--color-text-secondary);
  text-align: center;
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0.05em;
}
.contents-body {
  counter-reset: coordinationCounter;
}
.common-section {
  --bg-grid-border-width: 1px;
  --color-grid-border: rgba(88 77 53 / 5%);
  --color-grid-bg: var(--color-section-body-bg);
  --section-body-bg-grid:
    linear-gradient(
      0deg,
      transparent calc(100% - var(--bg-grid-border-width)),
      var(--color-grid-border) calc(100% - var(--bg-grid-border-width))
    ),
    linear-gradient(
      90deg,
      transparent calc(100% - var(--bg-grid-border-width)),
      var(--color-grid-border) calc(100% - var(--bg-grid-border-width))
    ),
    var(--color-grid-bg);
}
.common-section__brand-header {
  display: grid;
  place-content: center;
  border: 2px var(--color-logo-border);
  border-top-style: solid;
  border-bottom-style: solid;
  background-color: var(--color-logo-bg);
}
.common-section__brand-header-logo {
  width: var(--section-header-logo-width, auto);
}
.common-section__body {
  background: var(--section-body-bg-grid);
  background-size: var(--bg-grid-size) var(--bg-grid-size);
  background-repeat: repeat;
  background-position: top left var(--bg-grid-border-width);
}
.common-section__body-inner {
  padding-left: var(--section-body-inline-padding, 0px);
  padding-right: var(--section-body-inline-padding, 0px);
  margin: 0 auto;
}
.common-section__item {
  counter-increment: coordinationCounter;
}
.common-section__heading {
  display: flex;
  align-items: center;
  border: 1px var(--color-text-primary);
  border-top-style: solid;
  border-bottom-style: solid;
}
.common-section__heading::before {
  content: "";
  align-self: stretch;
  width: 1px;
  background-color: var(--color-text-primary);
}
.common-section__heading::after {
  content: "COORDINATION " counter(coordinationCounter, decimal-leading-zero);
  order: 1;
  font-family: var(--font-inter);
  font-optical-sizing: auto;
  font-weight: 500;
  text-align: center;
  line-height: 1.6;
  letter-spacing: 0.05em;
}
.common-section__heading-logo {
  order: -1;
  flex-grow: 1;
}
.common-section__heading-logo-inner {
  width: var(--section-coordination-logo-width);
}
.common-section__item-body {
  display: flex;
  align-items: flex-start;
}
.common-section__instant-photo {
  background-color: #FFF;
}
.common-section__item-body .common-section__instant-photo {
  transform: rotate(-2deg);
}
.common-section__item-body--reverse .common-section__instant-photo {
  transform: rotate(2deg);
}
.common-section__instant-photo figcaption {
}
.common-section__item-name {
  font-family: var(--font-inter);
  font-optical-sizing: auto;
  text-align: center;
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 0.05em;
}
.common-section__detail {
  display: grid;
  grid-template-columns: 100%;
}
.common-section__detail-section {

}
.common-section__detail-heading {
  font-family: var(--font-inter);
  font-optical-sizing: auto;
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: 0.05em;
  border-bottom: 1px solid var(--color-text-primary);
}
.common-section__detail-text {
  line-height: 1.6;
  letter-spacing: 0.05em;
}
.common-section__item-list {
  display: grid;
  grid-template-columns: 100%;
}
.common-section__item-list li {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.common-section__item-list li .item-name {
  line-height: 1.7;
  letter-spacing: 0.05em;
}
.common-section__item-list li .item-price {
  line-height: 1.7;
  letter-spacing: 0.05em;
}
.common-section__item-list li .buy-button {
  display: inline-grid;
  place-content: center;
  flex-shrink: 0;
  font-family: var(--font-inter);
  font-optical-sizing: auto;
  font-weight: 500;
  letter-spacing: 0.05em;
  color: var(--color-text-secondary);
  background-color: var(--color-text-primary);
}

.common-section__button-area {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin: 0 auto;
}
.common-section__button-press {
  position: relative;
  display: block;
  width: var(--button-width);
  height: var(--button-height);
  border: 1px var(--color-text-primary);
  border-right-style: solid;
  border-bottom-style: solid;
}
.common-section__button-press:hover {
  opacity: 1;
}
.common-section__button-press span {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  width: var(--button-width);
  height: var(--button-height);
  font-family: var(--font-inter);
  font-optical-sizing: auto;
  text-align: center;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.05em;
  background-color: var(--color-section-body-bg);
  border: 1px solid var(--color-text-primary);
  backface-visibility: hidden;
  transition: transform 0.3s ease;
}
.common-section__button-press:hover span {
  transform: translate(0, 0);
}
.common-section__button-press span::after {
  content: "";
  display: inline-block;
  width: var(--icon-width);
  height: var(--icon-height);
  background-color: var(--color-text-primary);
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
}
.contents-footer__button-area {
  display: grid;
  grid-template-columns: 100%;
  margin: 0 auto;
}
.contents-footer__button {
  display: grid;
  place-content: center;
  text-align: center;
  font-weight: 600;
  line-height: 1.6;
  letter-spacing: 0.05em;
  border: 1px solid;
}
.contents-footer__button--fill {
  color: var(--color-text-secondary);
  background-color: var(--color-text-primary);
  border-color: var(--color-text-primary);
}
.contents-footer__button--outline {
  color: var(--color-text-primary);
  background-color: var(--color-text-secondary);
  border-color: currentColor;
}
:where(.main-area) .js-scrollIn {
  transform: translateY(30px);
  opacity: 0;
  transition: 1s ease;
  transition-property: transform, opacity;
}
:where(.main-area) .js-scrollIn.active {
  transform: translateY(0);
  opacity: 1;
}
/* --- for small viewport --- */
@media screen and (max-width: 767px) {
  .main-area {

  }
  .contents-header {
    
  }
  .contents-header__keyvisual {

  }
  .contents-header__lead-wrap {
    padding: calc(40 *(100vw / 375)) 0;
  }
  .contents-header__lead {
    font-size: calc(13 *(100vw / 375));
  }
  .common-section {
    --section-body-inline-padding: calc(15 *(100vw / 375));
    --bg-grid-size: calc(17 *(100vw / 375));
  }
  .common-section:where([id="norc"]) {
    --section-header-logo-width: calc(100 *(100vw / 375));
    --section-coordination-logo-width: calc(75.24 *(100vw / 375));
  }
  .common-section:where([id="lesoukholiday"]) {
    --section-header-logo-width: calc(98.87 *(100vw / 375));
    --section-coordination-logo-width: calc(80.94 *(100vw / 375));
  }
  .common-section:where([id="crossfunction"]) {
    --section-header-logo-width: calc(54.5 *(100vw / 375));
    --section-coordination-logo-width: calc(41.82 *(100vw / 375));
  }
  .common-section:where([id="alphacubic"]) {
    --section-header-logo-width: calc(118.8 *(100vw / 375));
    --section-coordination-logo-width: calc(91.77 *(100vw / 375));
  }
  .common-section:where([id="49av_junkoshimada"]) {
    --section-header-logo-width: calc(164.7 *(100vw / 375));
    --section-coordination-logo-width: calc(121.33 *(100vw / 375));
  }
  .common-section__brand-header {
    height: calc(60 *(100vw / 375));
  }
  .common-section__brand-header-logo {

  }
  .common-section__body {
    padding-top: calc(20 *(100vw / 375));
    padding-bottom: calc(60 *(100vw / 375));
  }
  .common-section__body-inner {

  }
  .common-section__item {
    padding: calc(20 *(100vw / 375)) 0;
  }
  .common-section__heading {
    height: calc(45 *(100vw / 375));
  }
  .common-section__heading::after {
    width: calc(150 *(100vw / 375));
    font-size: calc(12 *(100vw / 375));
  }
  .common-section__heading-logo {
    padding: 0 calc(20 *(100vw / 375));
  }
  .common-section__item-body {
    gap: calc(34 *(100vw / 375));
    flex-direction: column;
    margin-top: calc(30 *(100vw / 375));
  }
  .common-section__instant-photo {
    width: calc(340 *(100vw / 375));
    margin: 0 auto;
    padding: calc(14 *(100vw / 375)) calc(10 *(100vw / 375)) 0;
    box-shadow: 0 calc(10 *(100vw / 375)) calc(10 *(100vw / 375)) rgb(0 0 0 / 5%);
  }
  .common-section__instant-photo figcaption {
    padding: calc(11 *(100vw / 375)) 0;
  }
  .common-section__item-name {
    font-size: calc(10 *(100vw / 375));
  }
  .common-section__detail {
    gap: calc(20 *(100vw / 375));
  }
  .common-section__detail-section {

  }
  .common-section__detail-heading {
    margin-bottom: calc(15 *(100vw / 375));
    padding-bottom: calc(6.5 *(100vw / 375));
    font-size: calc(17 *(100vw / 375));
  }
  .common-section__detail-text {
    font-size: calc(13 *(100vw / 375));
  }
  .common-section__item-list {
    gap: calc(15 *(100vw / 375));
  }
  .common-section__item-list li {
    gap: calc(10 *(100vw / 375));
  }
  .common-section__item-list li .item-name {
    font-size: calc(12 *(100vw / 375));
  }
  .common-section__item-list li .item-price {
    font-size: calc(11 *(100vw / 375));
  }
  .common-section__item-list li .buy-button {
    width: calc(55 *(100vw / 375));
    height: calc(22 *(100vw / 375));
    font-size: calc(12 *(100vw / 375));
  }

  .common-section__button-area {
    gap: calc(11.5 *(100vw / 375));
    margin-top: calc(10 *(100vw / 375));
  }
  .common-section__button-press {
    --button-width: calc(165 *(100vw / 375));
    --button-height: calc(45 *(100vw / 375));
  }
  .common-section__button-press span {
    transform: translate(calc(-2.5 *(100vw / 375)), calc(-2.5 *(100vw / 375)));
    gap: calc(9 *(100vw / 375));
    font-size: calc(15 *(100vw / 375));
  }
  .common-section__button-press span::after {
    --icon-width: calc(8 *(100vw / 375));
    --icon-height: calc(15 *(100vw / 375));
  }
  .contents-footer__button-area {
    gap: calc(7 *(100vw / 375));
    width: calc(280 *(100vw / 375));
    padding: calc(40 *(100vw / 375)) 0;
  }
  .contents-footer__button {
    height: calc(50 *(100vw / 375));
    font-size: calc(14 *(100vw / 375));
  }
  .contents-footer__button--fill {

  }
  .contents-footer__button--outline {

  }
}
/* --- for large viewport --- */
@media screen and (min-width: 768px) {
  .main-area {
    
  }
  .contents-header {
    
  }
  .contents-header__keyvisual {

  }
  .contents-header__lead-wrap {
    padding: 6.6rem 0;
  }
  .contents-header__lead {
    font-size: 1.4rem;
  }
  .common-section {
    --section-body-inline-padding: 2rem;
    --bg-grid-size: 1.7rem;
  }
  .common-section:where([id="norc"]) {
    --section-header-logo-width: 14.015rem;
    --section-coordination-logo-width: 10.351rem;
  }
  .common-section:where([id="lesoukholiday"]) {
    --section-header-logo-width: 13.498rem;
    --section-coordination-logo-width: 9.717rem;
  }
  .common-section:where([id="crossfunction"]) {
    --section-header-logo-width: 7.453rem;
    --section-coordination-logo-width: 4.549rem;
  }
  .common-section:where([id="alphacubic"]) {
    --section-header-logo-width: 17.344rem;
    --section-coordination-logo-width: 10.576rem;
  }
  .common-section:where([id="49av_junkoshimada"]) {
    --section-header-logo-width: 22.925rem;
    --section-coordination-logo-width: 13.289rem;
  }
  .common-section__brand-header {
    height: 9rem;
  }
  .common-section__brand-header-logo {

  }
  .common-section__body {
    padding-top: 3rem;
    padding-bottom: 12rem;
  }
  .common-section__body-inner {
    width: calc(98rem + (var(--section-body-inline-padding, 0px) * 2));
  }
  .common-section__item {
    padding: 3rem 0;
  }
  .common-section__heading {
    height: 5.45rem;
  }
  .common-section__heading::after {
    width: 18.8rem;
    font-size: 1.5rem;
  }
  .common-section__heading-logo {
    padding: 0 2rem;
  }
  .common-section__item-body {
    gap: 3.9rem;
    margin-top: 3rem;
    padding: 0 1rem;
  }
  .common-section__item-body--reverse {
    flex-direction: row-reverse;
  }
  .common-section__instant-photo {
    flex-shrink: 0;
    width: 47rem;
    padding: 2rem 1.5rem 0;
    box-shadow: 0 1rem 1rem rgb(0 0 0 / 5%);
  }
  .common-section__instant-photo figcaption {
    padding: 1.5rem 0;
  }
  .common-section__item-name {
    font-size: 1.4rem;
  }
  .common-section__detail {
    gap: 4rem;
  }
  .common-section__detail-section {

  }
  .common-section__detail-heading {
    margin-bottom: 2rem;
    padding-bottom: 0.75rem;
    font-size: 1.8rem;
  }
  .common-section__detail-text {
    font-size: 1.4rem;
  }
  .common-section__item-list {
    gap: 1.5rem;
  }
  .common-section__item-list li {
    gap: 1rem;
  }
  .common-section__item-list li .item-name {
    font-size: 1.2rem;
  }
  .common-section__item-list li .item-price {
    font-size: 1.1rem;
  }
  .common-section__item-list li .buy-button {
    width: 5.5rem;
    height: 2.2rem;
    font-size: 1.2rem;
  }

  .common-section__button-area {
    gap: 2.45rem;
    width: 58.8rem;
    margin-top: 1rem;
  }
  .common-section__button-press {
    --button-width: 28rem;
    --button-height: 5rem;
    font-size: 1.6rem;
  }
  .common-section__button-press span {
    gap: 1rem;
    transform: translate(-0.4rem, -0.45rem);
  }
  .common-section__button-press span::after {
    --icon-width: 0.8rem;
    --icon-height: 1.5rem;
  }
  .contents-footer__button-area {
    gap: 0.7rem;
    width: 28rem;
    padding: 5rem 0;
  }
  .contents-footer__button {
    height: 5rem;
    font-size: 1.4rem;
  }
  .contents-footer__button--fill {

  }
  .contents-footer__button--outline {

  }
}
