@charset "UTF-8";
/*
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  **/
@keyframes fadeIn {
  100% {
    opacity: 1;
  }
}
@keyframes fadeOut {
  100% {
    opacity: 0;
  }
}
@keyframes clipPath {
  100% {
    clip-path: inset(0);
  }
}
@keyframes clipPathCircle {
  100% {
    clip-path: circle(100% at 50% 50%);
  }
}
p,
ul,
ol,
h1,
h2,
h3,
figure,
dl,
dd,
button,
pre {
  margin: 0;
  padding: 0;
}

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

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.35s cubic-bezier(0.075, 0.82, 0.165, 1);
}
@media (hover: hover) {
  a:hover {
    opacity: 0.5;
  }
}

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

*:focus {
  outline: none;
}

@media (min-width: 600px) {
  .device-sp {
    display: none;
  }
}

.device-pc {
  display: none;
}
@media (min-width: 600px) {
  .device-pc {
    display: block;
  }
}

br {
  display: none;
}
@media (min-width: 600px) {
  br {
    display: block;
  }
}

html {
  scroll-behavior: smooth;
}

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

:root {
  --white: #ffffff;
  --black: #000000;
  --orange-light: #FBB03B;
  --orange: #ED6C00;
  --stripy: #FFF9B1;
  --blue: #0096dc;
  --blue-light: #81dfff;
  --link: #005AFF;
  --wrap-lg: min(92.3076923077vw, 55rem);
  --wrap-md: min(82.0512820513vw, 43.125rem);
  --gap: 3.125rem;
  --round-10: 0.625rem;
  --border-width: 2px;
}

.sr-only:not(:focus):not(:active) {
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

body {
  overflow-x: hidden;
  color: var(--black);
  font-family: "Aoto Gothic Medium";
  line-height: 173.3333333333%;
}

.hobonichi {
  display: flex;
  justify-content: center;
}
.hobonichi-wrap {
  display: grid;
  align-items: end;
  justify-content: right;
  width: var(--wrap-lg);
  height: 3.25rem;
  padding-block-end: 0.75rem;
}
.hobonichi .logo {
  width: min(20vw, 7.2125rem);
  height: auto;
}
@media (min-width: 48rem) {
  .hobonichi-wrap {
    height: 4.75rem;
    padding: 0 1.25rem 1rem 0;
  }
}

.main {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.section {
  --section-title-c: var(--orange);
  position: relative;
  width: 100%;
  padding: var(--gap) 0;
  background-color: var(--white);
}
.section .wrap {
  width: var(--wrap-md);
  margin-inline: auto;
}
.section .title {
  position: absolute;
  top: -0.8181818182em;
  left: 50%;
  width: fit-content;
  margin-inline: auto;
  padding: 0.3181818182em 0.9090909091em 0.2272727273em;
  color: var(--section-title-c);
  font-family: "Tunnel Tightline AP";
  font-size: 1.375rem;
  line-height: 1;
  background-color: var(--white);
  border: var(--border-width) solid currentColor;
  border-radius: 0.8181818182em;
  transform: translateX(-50%);
}
.section .lead {
  width: min(100%, 25rem);
  margin: 0 auto 1.875rem;
  font-family: "Aoto Gothic Regular";
  font-size: 1rem;
  line-height: 171.875%;
  font-feature-settings: "palt" on;
}
@media (min-width: 48rem) {
  .section .title {
    font-size: 1.625rem;
    padding-inline: 0.9615384615em;
  }
  .section .lead {
    font-size: 0.9375rem;
    line-height: 173.3333333333%;
  }
}

.shop {
  --wrap-md: min(73.8461538462vw, 43.125rem);
}

.snaps {
  --snap-gap: 1rem;
  width: min(92.3076923077vw, 64.5625rem);
  padding: var(--gap) 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(10.75rem, 1fr));
  gap: var(--snap-gap);
}

.snap.span-two {
  grid-column: span 2;
}
.snap img {
  width: 100%;
  height: auto;
  border-radius: var(--round-10);
}

@media (min-width: 48rem) {
  .snaps {
    --gap: 3.75rem;
    --snap-gap: 1.25rem;
  }
}
.blocks {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-auto-rows: minmax(44.1025641026vw, max-content);
  gap: min(4.1025641026vw, 1.25rem);
}
@media (min-width: 48rem) {
  .blocks {
    grid-auto-rows: minmax(10rem, max-content);
  }
}

.block {
  position: relative;
  overflow: hidden;
  border-radius: var(--round-10);
}
.block.fill {
  grid-column: span 2;
}
.block .fill-block {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.block a,
.block button {
  transition: opacity 0.35s ease-out;
}
.block a:active, .block a:focus, .block a:hover,
.block button:active,
.block button:focus,
.block button:hover {
  opacity: 0.65;
}

.yodogawa {
  padding: 1.25rem;
  background-color: var(--white);
  border: var(--border-width) solid #808080;
}
.yodogawa p {
  font-size: 0.9375rem;
  font-feature-settings: "palt" on;
}
@media (min-width: 34rem) {
  .yodogawa {
    padding: 1.75rem 1.391rem 1.75rem 1.75rem;
  }
  .yodogawa p {
    white-space: pre-line;
  }
  .yodogawa br {
    display: none;
  }
}

.products {
  display: grid;
  gap: 1.5rem min(6.4102564103vw, 3.125rem);
}
@media (min-width: 34rem) {
  .products {
    grid-template-columns: repeat(2, 1fr);
  }
}

.product {
  --prod-c: var(--orange);
  --prod-c-light: var(--orange-light);
}
.product a {
  display: block;
}
.product a:active, .product a:hover, .product a:focus {
  opacity: 1;
}
.product a:active figure, .product a:hover figure, .product a:focus figure {
  border-color: var(--prod-c-light);
}
.product a:active figure:before, .product a:hover figure:before, .product a:focus figure:before {
  background-image: linear-gradient(-45deg, var(--prod-c-light) 50%, transparent 50%);
}
.product figure {
  position: relative;
  width: 100%;
  aspect-ratio: 1;
  overflow: hidden;
  border: var(--border-width) solid var(--prod-c);
  border-radius: var(--round-10);
  box-shadow: 0 0 0 var(--border-width) var(--prod-c) inset;
  transition: all 0.35s cubic-bezier(0.075, 0.82, 0.165, 1);
}
.product figure:before, .product figure:after {
  content: "";
  position: absolute;
}
.product figure:before {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  display: block;
  width: min(30vw, 7.3125rem);
  aspect-ratio: 1;
  background-image: linear-gradient(-45deg, var(--prod-c) 50%, transparent 50%);
  transition: all 0.35s cubic-bezier(0.075, 0.82, 0.165, 1);
}
.product figure:after {
  right: min(2.5641025641vw, 0.625rem);
  bottom: min(3.3333333333vw, 0.8125rem);
  display: block;
  width: min(10.5128205128vw, 2.5625rem);
  aspect-ratio: 41/43;
  background-color: var(--white);
  mask-image: url('data:image/svg+xml, %3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 40.87 40.93"%3E%3Cg%3E%3Cpath d="M40.36,7.13c-.43-.5-1.07-.8-1.74-.8H9.24l-1-3.32h0C7.78,1.54,6.52.41,4.95.09L1.36.02C.75-.1.16.27.03.86c-.13.59.26,1.16.86,1.29l3.59.06c.76.16,1.38.71,1.6,1.43l6.56,21.76c-.15.07-.29.14-.43.22-.71.41-1.27.98-1.66,1.64-.36.63-.56,1.35-.57,2.09h0v.11h0c.01.58.14,1.13.36,1.64.36.81.95,1.49,1.69,1.98.74.49,1.65.77,2.61.77h21.11c.62,0,1.13-.49,1.13-1.09s-.5-1.09-1.13-1.09H14.65c-.34,0-.65-.06-.94-.18-.43-.18-.8-.47-1.06-.85-.25-.36-.4-.78-.41-1.24.01-.55.19-1.03.51-1.41.17-.2.37-.37.62-.51.24-.14.53-.25.87-.32l21.22-3.33c1.39-.22,2.49-1.24,2.77-2.57l2.6-12.31h0c.03-.14.04-.29.04-.43,0-.5-.18-.98-.51-1.38h0ZM36.02,20.82c-.09.44-.46.78-.92.86l-20.27,3.18-4.93-16.35h28.72s-2.6,12.31-2.6,12.31Z"/%3E%3Cpath d="M17.41,36.06c-.42-.29-.94-.45-1.49-.45-.36,0-.72.07-1.03.21-.48.2-.88.54-1.17.96s-.45.94-.45,1.49c0,.36.07.72.21,1.04.2.48.54.88.96,1.17.42.29.94.45,1.49.45.36,0,.72-.07,1.04-.21.48-.2.88-.54,1.17-.96s.46-.94.45-1.49c0-.36-.07-.72-.21-1.03-.2-.48-.54-.88-.96-1.17h-.01Z"/%3E%3Cpath d="M33.55,36.06c-.42-.29-.94-.45-1.49-.45-.36,0-.72.07-1.03.21-.48.2-.88.54-1.17.96s-.45.94-.45,1.49c0,.36.07.72.21,1.04.2.48.54.88.96,1.17.42.29.94.45,1.49.45.36,0,.72-.07,1.04-.21.48-.2.88-.54,1.17-.96.29-.42.45-.94.45-1.49,0-.36-.07-.72-.21-1.03-.2-.48-.54-.88-.96-1.17h0Z"/%3E%3C/g%3E%3C/svg%3E');
  mask-repeat: no-repeat;
}
.product figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.product h3 {
  margin-block-start: 1em;
  font-family: "Aoto Gothic DemiBold";
  font-size: 1.125rem;
  line-height: 144.4444444444%;
  font-feature-settings: "halt" on;
}
.product .name {
  display: block;
}
.product .price-unit {
  font-size: 0.875rem;
}
.product .price-inc {
  font-size: 0.75rem;
}
.product .button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 6.25rem;
  height: 1.875rem;
  margin-block-start: 0.4375rem;
  color: var(--prod-c);
  font-family: "Aoto Gothic Medium";
  font-size: 0.875rem;
  border: 1px solid currentColor;
  border-radius: var(--round-10);
  transition: all 0.35s cubic-bezier(0.075, 0.82, 0.165, 1);
}
.product .button:active, .product .button:hover, .product .button:focus {
  opacity: 1;
  color: var(--prod-c-light);
}
@media (min-width: 34rem) {
  .product h3 {
    margin-block-start: 1.1764705882em;
    font-size: 1.0625rem;
  }
}

.articles {
  display: grid;
  gap: 2.5rem 3.125rem;
}
@media (min-width: 48rem) {
  .articles {
    grid-template-columns: repeat(2, 1fr);
  }
}

.article {
  font-feature-settings: "palt" on;
}
.article h3 {
  margin-block-start: 1em;
  font-family: "Aoto Gothic Bold";
  font-size: 1.125rem;
  line-height: 166.6666666667%;
}
.article img {
  width: 100%;
  height: auto;
}
.article p {
  font-family: "Aoto Gothic Regular";
  font-size: 0.9375rem;
  line-height: 200%;
}
@media (min-width: 48rem) {
  .article p {
    font-size: 0.875rem;
    line-height: 171.4285714286%;
  }
}

.dialog:open {
  opacity: 1;
}

.dialog {
  padding: 0;
  background-color: transparent;
  border: none;
  overflow: hidden;
  opacity: 0;
  transition: all 0.35s ease-out allow-discrete;
  transition: all 0.35s ease-out;
}
.dialog[open] {
  opacity: 1;
}
@starting-style {
  .dialog[open] {
    opacity: 0;
  }
}
.dialog::backdrop {
  background-color: rgba(96, 96, 96, 0);
  transition: all 0.35s ease-out allow-discrete;
  transition: all 0.35s ease-out;
}
.dialog[open]::backdrop {
  background-color: rgba(96, 96, 96, 0.9);
}
@starting-style {
  .dialog[open]::backdrop {
    background-color: rgba(96, 96, 96, 0);
  }
}
.dialog-close {
  --start: calc(50% - 0.5px);
  --end: calc(50% + 0.5px);
  display: block;
  width: 1.75rem;
  aspect-ratio: 1;
  margin: 0 0 1.375rem auto;
  background-image: linear-gradient(45deg, transparent, transparent var(--start), var(--white) var(--start), var(--white) var(--end), transparent var(--end)), linear-gradient(-45deg, transparent, transparent var(--start), var(--white) var(--start), var(--white) var(--end), transparent var(--end));
}
.dialog-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3.125rem 0;
  padding: 2rem 1.5rem;
  width: min(90vw, 31.25rem);
  max-height: 80vh;
  overflow: hidden auto;
  border-radius: var(--round-10);
  background-color: var(--white);
}
@media (min-height: 45rem) {
  .dialog-content {
    padding: 4.5rem 1.5rem 5.375rem;
  }
}
.dialog-video-content {
  width: min(90vw, 35rem);
  aspect-ratio: 560/315;
}
.dialog-video-content iframe {
  width: 100%;
  height: 100%;
}
.dialog p {
  white-space: pre-line;
  font-feature-settings: "palt" on;
}

@keyframes fade-in {
  0% {
    visibility: hidden;
    opacity: 0;
  }
  100% {
    visibility: visible;
    opacity: 1;
  }
}
@keyframes fade-up {
  0% {
    visibility: visible;
    opacity: 0;
    transform: translateY(10%);
  }
  80% {
    transform: translateY(-5%);
  }
  100% {
    visibility: visible;
    transform: translateY(0);
    opacity: 1;
  }
}
@keyframes jump-up {
  0% {
    opacity: 0;
    transform: scale(0.5);
  }
  80% {
    transform: scale(1.1);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
[data-watch=splash] .catch,
[data-watch=splash] .catch + img {
  opacity: 0;
}
[data-watch=splash].in-view .catch {
  animation: fade-up 0.25s 0.25s ease-out forwards;
}
[data-watch=splash].in-view .catch + img {
  animation: fade-up 0.25s 0.5s ease-out forwards;
}

[data-watch=blocks] .block {
  opacity: 0;
}
[data-watch=blocks].in-view .block.yodogawa {
  animation: fade-up 0.35s 0s ease-out forwards;
}
[data-watch=blocks].in-view .block.two {
  animation: fade-up 0.35s 0.25s ease-out forwards;
}
[data-watch=blocks].in-view .block.three {
  animation: fade-up 0.35s 0.5s ease-out forwards;
}
[data-watch=blocks].in-view .block.four {
  animation: fade-up 0.35s 0.75s ease-out forwards;
}
[data-watch=blocks].in-view .block.five {
  animation: fade-up 0.35s 1s ease-out forwards;
}

[data-watch=playground] img {
  opacity: 0;
}
[data-watch=playground].in-view img:first-of-type {
  animation: jump-up 0.5s ease-out forwards;
}
[data-watch=playground].in-view img:last-of-type {
  animation: jump-up 0.5s 0.25s ease-out forwards;
}

[data-watch=snaps] .snap {
  visibility: hidden;
  opacity: 0;
}
[data-watch=snaps].in-view .snap:nth-of-type(1) {
  animation: fade-in 0.5s 0s ease-out forwards;
}
[data-watch=snaps].in-view .snap:nth-of-type(2) {
  animation: fade-in 0.5s 0.5s ease-out forwards;
}
[data-watch=snaps].in-view .snap:nth-of-type(3) {
  animation: fade-in 0.5s 1s ease-out forwards;
}
[data-watch=snaps].in-view .snap:nth-of-type(4) {
  animation: fade-in 0.5s 1.5s ease-out forwards;
}

:root {
  --tri-size-w: 34.1998717949vw;
  --tri-size-h: 30.6565128205vw;
}
@media (min-width: 48rem) {
  :root {
    --tri-size-w: 11.15305625rem;
    --tri-size-h: 9.99599375rem;
  }
}

@keyframes barberpole {
  from {
    background-position: 0 0;
  }
  to {
    background-position: calc(var(--tri-size-w) * 2) var(--tri-size-h);
  }
}
.tri {
  background-image: url("../../polo_layer/img/tri.svg");
  background-size: var(--tri-size-w) var(--tri-size-h);
  animation: barberpole 7s linear infinite;
}
@media (min-width: 48rem) {
  .tri {
    background-image: url("../../polo_layer/img/tri_lg.svg");
  }
}

.splash {
  display: grid;
  gap: 1rem 1.25rem;
  width: var(--wrap-lg);
}

.splash-main {
  position: relative;
  display: grid;
  align-items: end;
  width: 100%;
  aspect-ratio: 360/480;
  padding: 1.5625rem;
}
.splash-main .splash-picture img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: right bottom;
  border-radius: var(--round-10);
}
.splash-main h1 {
  position: relative;
  color: var(--white);
}
.splash-main h1 img {
  width: 100%;
  height: auto;
}
.splash-main .catch {
  display: block;
  font-family: "Aoto Gothic Bold";
  font-size: 0.9375rem;
  line-height: 200.6111111111%;
  letter-spacing: 0.05em;
}
.splash-main .logo {
  position: absolute;
  top: -1.9375rem;
  left: 4.8717948718vw;
  width: min(41.7948717949vw, 14.5rem);
  height: auto;
}

@media (min-width: 48rem) {
  .splash {
    grid-template-columns: auto max-content;
  }
  .splash-main {
    aspect-ratio: unset;
    padding: 2.1875rem 2.3125rem;
  }
  .splash-main .catch {
    margin-block-end: 1em;
    font-size: 1.301875rem;
  }
  .splash-main .logo {
    top: -3.65625rem;
    left: 1.5625rem;
  }
}
.playground {
  position: relative;
  width: 100%;
  aspect-ratio: 390/342;
}
.playground .white,
.playground .black {
  position: absolute;
  height: auto;
}
.playground .white {
  left: 5.3846153846%;
  top: -6.432748538%;
  width: 41.5384615385%;
}
.playground .black {
  right: 14.358974359%;
  top: -13.4502923977%;
  width: 19.7435897436%;
}
@media (min-width: 48rem) {
  .playground {
    width: var(--wrap-md);
    aspect-ratio: 690/146;
  }
  .playground .white {
    left: unset;
    right: 15.5072463768%;
    top: -320.5479452055%;
    width: 30.7246376812%;
  }
  .playground .black {
    right: -2.7536231884%;
    top: -219.8630136986%;
    width: 14.4927536232%;
  }
}

.section {
  --section-title-c: var(--blue);
}

.product {
  --prod-c: var(--blue);
  --prod-c-light: var(--blue-light);
}

.first-snaps {
  --gap: 2.125rem;
}
.first-snaps .snap {
  display: none;
}
@media (min-width: 48rem) {
  .first-snaps {
    --gap: 6.125rem;
  }
  .first-snaps .snap {
    display: block;
  }
}