@charset "UTF-8";
:root {
  --white: white;
  --black: black;
  --base: #3D3D3D;
}

.svg-symbol {
  display: none;
}

body {
  color: var(--base);
  font-family: "Yu Gothic Pr6N D", sans-serif;
  overflow-x: hidden;
}

/*
A modern CSS reset 2023 / 9 / 18
https://github.com/Andy-set-studio/modern-css-reset
*/
*, *::before, *::after {
  box-sizing: border-box;
}

html {
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
  text-size-adjust: none;
}

body, h1, h2, h3, h4, p, figure, blockquote, dl, dd {
  margin: 0;
}

ul[role=list], ol[role=list] {
  list-style: none;
}

body {
  min-height: 100vh;
  line-height: 1.5;
}

h1, h2, h3, h4, button, input, label {
  line-height: 1.1;
}

h1, h2, h3, h4 {
  text-wrap: balance;
}

a:not([class]) {
  text-decoration-skip-ink: auto;
  color: currentColor;
}

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

input, button, textarea, select {
  font: inherit;
}

textarea:not([rows]) {
  min-height: 10em;
}

:target {
  scroll-margin-block: 5ex;
}

/**  base  **/
p,
ul,
ol,
h1,
h2,
h3,
figure,
dl,
dd,
button,
pre {
  margin: 0;
  padding: 0;
}

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

ul,
ol {
  list-style: none;
}

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

button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  appearance: none;
}

a {
  color: currentColor;
  text-decoration: none;
  transition: all 0.25s ease;
}
@media (hover: hover) {
  a:hover {
    opacity: 0.5;
  }
}

[x-cloak],
[v-cloak] {
  display: none !important;
}

*:focus {
  outline: none;
}

html {
  font-size: 62.5%;
}

body {
  font-size: 1.6rem;
  overflow-wrap: anywhere; /* 収まらない場合に折り返す */
  word-break: normal; /* 単語の分割はデフォルトに依存 */
  line-break: strict; /* 禁則処理を厳格に適用 */
}
body.scroll_rock {
  overflow: hidden;
}

.bg {
  position: fixed;
  z-index: -1;
  inset: 0;
}
.bg img {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

:root {
  --cover-size: 187.1875vh;
}
@media (width > 48rem) {
  :root {
    --cover-size: 248.6725663717vh;
  }
}

.cover {
  position: relative;
  height: 100vh;
  background-image: url("../img/cover.webp");
  background-repeat: repeat no-repeat;
  background-size: var(--cover-size) 100vh;
  background-position: 0% 0%;
  animation: roll 56s linear infinite;
  color: var(--white);
}
.cover [class^=logo-] {
  position: absolute;
  height: auto;
}
.cover .logo-relaxing-blue {
  left: 10.1333333333%;
  top: 8.28125%;
  width: min(29.8666666667vw, 16.8rem);
}
.cover .logo-haramaki {
  right: 5.0666666667%;
  bottom: 3.90625%;
  width: min(32vw, 13.6rem);
}
@media (width > 48rem) {
  .cover {
    background-image: url("../img/cover_lg.webp");
  }
  .cover .logo-relaxing-blue {
    left: 12.1527777778%;
    top: 11.0619469027%;
  }
  .cover .logo-haramaki {
    bottom: unset;
    right: 2.7083333333%;
    top: 3.6504424779%;
  }
}

@keyframes roll {
  from {
    background-position: 0 0;
  }
  to {
    background-position: calc(var(--cover-size) * -2) 0;
  }
}
.yodogawa {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-bottom: 6.4rem;
  background-color: rgba(224, 244, 246, 0.85);
}
.yodogawa .dates {
  width: 100%;
  height: 4.8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #15C2E9;
}
.yodogawa h1 {
  margin-block: 4.8rem 3.2rem;
  text-align: center;
}
.yodogawa .logo-haramaki {
  width: min(53.3333333333vw, 32rem);
  height: auto;
}
.yodogawa .season {
  display: block;
  margin-top: 1.2rem;
  font-family: "Koburina Gothic W6 JIS2004", sans-serif;
  font-size: 1.403rem;
  line-height: 160%;
  letter-spacing: 0.1799714897em;
}
.yodogawa .season .winter {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.2448rem;
  height: 2.2448rem;
  margin-left: 0.42rem;
  letter-spacing: 0;
  border: 1px solid currentColor;
  border-radius: 50%;
}
.yodogawa p {
  width: min(85.3333333333vw, 36.1rem);
  font-size: 1.5rem;
  line-height: 213.333%;
  letter-spacing: 0.04em;
}
.yodogawa p + p {
  margin-top: 2em;
}
@media (width > 48rem) {
  .yodogawa {
    padding-bottom: 15.5rem;
  }
  .yodogawa .dates {
    height: 8rem;
  }
  .yodogawa .dates img {
    height: 2.06rem;
    width: auto;
  }
  .yodogawa h1 {
    margin-block: 8rem 6.4rem;
  }
  .yodogawa .season {
    font-size: 2.2448rem;
    letter-spacing: 0.1800160371em;
  }
  .yodogawa .season .winter {
    width: 3.5917rem;
    height: 3.5917rem;
    margin-left: 0.673rem;
  }
  .yodogawa p {
    white-space: pre-line;
  }
}

.main {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4rem 0;
}
@media (width > 48rem) {
  .main {
    gap: 6.4rem 0;
  }
}

.lookbook {
  background-color: var(--white);
}

.products {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  padding-block: 3.5rem 6.5rem;
  background-color: var(--white);
}
.products h2 {
  width: min(85.3333333333vw, 56rem);
  margin-bottom: 1.3rem;
  text-align: center;
}
.products h2 img {
  width: 100%;
  height: auto;
}
.products h2 .season {
  display: block;
  margin-top: 1.6rem;
  font-family: "Koburina Gothic W6 JIS2004", sans-serif;
  font-size: 1.4626rem;
  line-height: 160%;
  letter-spacing: 0.1800218788em;
}
.products h2 .season .winter {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.3402rem;
  height: 2.3402rem;
  margin-inline: 0.42rem 0.585rem;
  letter-spacing: 0;
  border: 1px solid currentColor;
  border-radius: 50%;
}
@media (width > 48rem) {
  .products {
    padding-block: 5.9rem 4.6rem;
  }
  .products h2 {
    margin-bottom: 1.4rem;
  }
  .products .season {
    font-size: 2rem;
    letter-spacing: 0.18em;
  }
  .products .season .winter {
    width: 3.2rem;
    height: 3.2rem;
    margin-inline: 0.6rem 0.8rem;
  }
}

.lineup {
  width: min(85.3333333333vw, 100rem);
}
.lineup h3 {
  margin-bottom: 2.4rem;
  padding-bottom: 0.8rem;
  font-family: "Koburina Gothic W6 JIS2004", sans-serif;
  font-size: 1.6rem;
  line-height: 200%;
  letter-spacing: 0.18em;
  border-bottom: 1px solid currentColor;
}
.lineup + .lineup {
  margin-top: 4rem;
}
@media (width > 48rem) {
  .lineup h3 {
    margin-bottom: 4rem;
    font-size: 2rem;
    line-height: 160%;
    letter-spacing: 0.18em;
  }
  .lineup + .lineup {
    margin-top: 6.4rem;
  }
}

.section {
  --section-pad: 3.6rem;
  width: 100%;
  padding-block: var(--section-pad);
  font-family: "Yu Gothic Pr6N D", sans-serif;
  font-size: 1.5rem;
  line-height: 213.333%;
  background-color: var(--white);
}
.section-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: min(85.3333333333vw, 100rem);
  margin-inline: auto;
}
.section.info {
  --section-pad: 6.4rem 8.8rem;
}
@media (width > 48rem) {
  .section {
    --section-pad: 5.6rem;
  }
  .section.info {
    --section-pad: 5.6rem 5.6rem;
  }
}

.info h3 {
  font-size: 1.5rem;
  line-height: 213.333%;
}
.info ul + h3 {
  margin-top: 2.2rem;
}
.info-banner {
  width: min(100%, 40rem);
  aspect-ratio: 320/128;
  margin-top: 4.8rem;
  background-color: #D9D9D9;
  border-radius: 2rem;
  overflow: hidden;
}
.info-banner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.info-banner:hover {
  opacity: 1;
  filter: brightness(1.05);
}
@media (width > 48rem) {
  .info-banner {
    margin-top: 4rem;
  }
}

.footer {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 4rem;
  padding-block: 4rem 2.4rem;
  color: #252525;
  font-family: "Shuei MaruGo L", sans-serif;
  background-color: var(--white);
}
.footer-share {
  display: grid;
  grid-template-columns: repeat(3, 4rem);
  gap: 0 3.1rem;
}
.footer-wrapper {
  display: grid;
  gap: 3.7rem 0;
  width: min(90%, 100rem);
  margin-block: 4rem 2.5rem;
}
.footer-hobo {
  display: grid;
  gap: 2rem 0;
}
.footer-hobo li {
  margin-inline: auto;
}
.footer-hobo a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  height: 4rem;
  min-width: 15rem;
  padding-inline: 2.6rem;
  font-size: 1.4rem;
  border: 1px solid currentColor;
  border-radius: 2.4rem;
}
.footer-store {
  justify-self: center;
}
.footer-store a {
  font-size: 1.2rem;
  letter-spacing: 0.05em;
  line-height: 200%;
}
@media (width > 53rem) {
  .footer {
    margin-top: 4.8rem;
    padding-block: 3.5rem;
  }
  .footer-wrapper {
    grid-template-columns: max-content max-content;
    justify-content: space-between;
  }
  .footer-hobo {
    grid-template-columns: auto auto;
    gap: 2rem 3.8rem;
  }
  .footer-hobo li {
    margin-inline: 0;
  }
  .footer-hobo li:first-of-type {
    order: 1;
  }
  .footer-hobo li:nth-of-type(2) {
    order: 3;
  }
  .footer-hobo li:nth-of-type(3) {
    order: 2;
  }
  .footer-hobo li:last-of-type {
    order: 4;
  }
}

.photo {
  position: relative;
  width: 100%;
  height: auto;
}
.photo img {
  width: 100%;
  height: auto;
}
.photo .photo-info {
  position: absolute;
  color: var(--white);
}
.photo-01 .photo-info {
  left: 5.6%;
  bottom: 7.2727272727%;
}
.photo-02 .photo-info {
  left: 7.4666666667%;
  bottom: 7.2727272727%;
}
.photo-03 .photo-info {
  left: 7.2%;
  bottom: 9.0909090909%;
}
.photo-04 .photo-info {
  left: 7.4666666667%;
  bottom: 9.0909090909%;
}
@media (width > 48rem) {
  .photo .photo-info:not(.left-lg) {
    left: unset;
  }
  .photo.photo-01 .photo-info {
    right: 5.5555555556%;
    bottom: 6.1946902655%;
  }
  .photo.photo-02 .photo-info {
    right: 4.1666666667%;
    bottom: 6.1946902655%;
  }
  .photo.photo-03 .photo-info {
    right: 5.5555555556%;
    bottom: 5.3097345133%;
  }
  .photo.photo-04 .photo-info {
    left: 5.5555555556%;
    bottom: 5.3097345133%;
  }
}

.photo-info {
  display: flex;
  flex-direction: column;
  gap: 0.4rem 0.8rem;
}
.photo-info p {
  color: currentColor;
  font-size: 1.3rem;
  line-height: 153.846%;
}
.photo-info a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 11.2rem;
  height: 2.4rem;
  color: currentColor;
  font-size: 1.4rem;
  line-height: 1;
  border: 1px solid currentColor;
  border-radius: 1.2rem;
}
.photo-info a + p {
  margin-top: 1.6rem;
}
@media (width > 48rem) {
  .photo-info.row-lg {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
  }
}

.photo-header h2 {
  margin-bottom: 1.6rem;
  font-family: "Yu Gothic Pr6N B", sans-serif;
  font-size: 1.3rem;
  line-height: 200%;
}
.photo-header h2 b {
  font-size: 1.3846153846em;
}
.photo-header p {
  font-size: 1.4rem;
  line-height: 228.571%;
}
@media (width > 48rem) {
  .photo-header p {
    white-space: pre-line;
  }
}

.book .wrap {
  width: 85.3333333333%;
}
.book-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-block: 3.2rem;
  background-color: var(--white);
}
.book .photo picture,
.book .photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.book-content .photo-info {
  margin-block: 0.8rem 2.4rem;
}
@media (width > 48rem) {
  .book {
    display: grid;
    grid-template-columns: 50% 50%;
  }
  .book-content {
    padding-block: 12.8rem 5.6rem;
  }
  .book-content .photo-info {
    justify-content: end;
    margin-bottom: 5.8rem;
  }
}

.casual {
  position: relative;
  padding-block: 2.4rem 4rem;
  background-color: var(--white);
}
.casual picture {
  width: 85.3333333333vw;
  margin-left: auto;
}
.casual .photo-header {
  width: 85.3333333333vw;
  margin: 4rem auto 0;
}
@media (width > 48rem) {
  .casual {
    padding-block: 11.2rem;
  }
  .casual picture {
    width: 75%;
  }
}
@media (width > 1024px) {
  .casual .photo-header {
    position: absolute;
    left: 5.5555555556%;
    bottom: 13.2rem;
    margin: 0;
  }
}

.float {
  padding-block: 2.4rem 5.6rem;
  background-color: var(--white);
}
.float picture {
  width: 85.3333333333vw;
}
@media (width > 48rem) {
  .float {
    padding-block: 11.2rem 11.2rem;
  }
  .float picture {
    width: 75%;
  }
}

.lineup-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2.4rem 0;
}
@media (width > 375px) {
  .lineup-list {
    grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
  }
}
@media (width > 48rem) {
  .lineup-list {
    gap: 3.2rem 5%;
  }
}

.lineup-item a {
  transition: all 0.25s ease;
}
@media (hover: hover) {
  .lineup-item a:hover {
    opacity: 1;
    color: #15C2E9;
  }
  .lineup-item a:hover img {
    filter: brightness(1.1);
  }
}
.lineup-item img {
  margin-bottom: 0.8rem;
  transition: filter 0.25s ease;
}
.lineup-item h4 {
  font-size: min(3.8666666667vw, 1.5rem);
  line-height: 142.857%;
  white-space: pre-line;
}
.lineup-item small {
  font-size: 1.2rem;
  line-height: 166.6666666667%;
}

[data-watch=block] {
  opacity: 0;
  transition: opacity 1s linear;
}
[data-watch=block].in-view {
  opacity: 1;
}