/* =========================================================
   Top Wine Intro
   key: top-wine-intro
   name: ワイン紹介
   group: partial
   type: layout
   layer: top
========================================================= */

.p-top-wine-intro {
  position: relative;
  padding: 82px 0;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(28, 63, 148, .035), rgba(176, 42, 42, .035)),
    var(--ciel-paper);
  color: var(--ciel-ink);
}

.p-top-wine-intro__inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
  gap: clamp(40px, 6vw, 84px);
  align-items: center;
  width: min(var(--ciel-container), calc(100% - 48px));
  margin-inline: auto;
}

.p-top-wine-intro__content {
  min-width: 0;
}

.p-top-wine-intro__eyebrow {
  margin: 0 0 10px;
  color: var(--ciel-blue-deep);
  font-size: .72rem;
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.p-top-wine-intro__title {
  margin: 0;
  color: var(--ciel-ink);
  font-size: clamp(1.65rem, 2.6vw, 2.6rem);
  font-weight: 600;
  line-height: 1.45;
  letter-spacing: .08em;
}

.p-top-wine-intro__title::after {
  content: "";
  display: block;
  width: 54px;
  height: 2px;
  margin-top: 18px;
  background: var(--ciel-blue);
}

.p-top-wine-intro__lead {
  max-width: 650px;
  margin: 26px 0 0;
  color: var(--ciel-muted);
  font-size: .95rem;
  line-height: 2;
}

.p-top-wine-intro__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 28px 0 0;
  padding: 0;
  list-style: none;
}

.p-top-wine-intro__tags li {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 6px 12px;
  border: 1px solid var(--ciel-line);
  background: rgba(255,255,255,.58);
  color: var(--ciel-muted);
  font-size: .72rem;
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.p-top-wine-intro__action {
  margin-top: 34px;
}

.p-top-wine-intro__visual {
  position: relative;
  min-height: 320px;
}

.p-top-wine-intro__glass {
  position: absolute;
  right: 18%;
  top: 50%;
  width: 128px;
  height: 210px;
  transform: translateY(-50%);
  border: 2px solid rgba(11, 95, 130, .24);
  border-top-width: 1px;
  border-radius: 44% 44% 48% 48% / 18% 18% 58% 58%;
}

.p-top-wine-intro__glass::before {
  content: "";
  position: absolute;
  left: 18%;
  right: 18%;
  bottom: 52px;
  height: 54px;
  background: rgba(176, 42, 42, .16);
  border-radius: 0 0 48% 48%;
}

.p-top-wine-intro__glass::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -82px;
  width: 2px;
  height: 82px;
  transform: translateX(-50%);
  background: rgba(11, 95, 130, .22);
  box-shadow: 0 82px 0 34px rgba(11, 95, 130, .10);
}

.p-top-wine-intro__line {
  position: absolute;
  height: 1px;
  pointer-events: none;
}

.p-top-wine-intro__line--blue {
  right: 0;
  top: 34%;
  width: 86%;
  background: rgba(28, 63, 148, .28);
}

.p-top-wine-intro__line--red {
  right: 12%;
  bottom: 30%;
  width: 64%;
  background: rgba(176, 42, 42, .22);
}

/* =========================================================
   Responsive
========================================================= */

@media screen and (max-width: 960px) {
  .p-top-wine-intro {
    padding: 68px 0;
  }

  .p-top-wine-intro__inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .p-top-wine-intro__visual {
    min-height: 210px;
  }

  .p-top-wine-intro__glass {
    right: 50%;
    width: 104px;
    height: 168px;
    transform: translate(50%, -50%);
  }
}

@media screen and (max-width: 768px) {
  .p-top-wine-intro {
    padding: 56px 0;
  }

  .p-top-wine-intro__inner {
    width: min(100% - 28px, var(--ciel-container));
  }

  .p-top-wine-intro__lead {
    margin-top: 22px;
    line-height: 1.9;
  }

  .p-top-wine-intro__tags {
    margin-top: 24px;
  }

  .p-top-wine-intro__action {
    margin-top: 28px;
  }
}

@media screen and (max-width: 560px) {
  .p-top-wine-intro__title {
    font-size: clamp(1.45rem, 7vw, 2rem);
  }

  .p-top-wine-intro__lead {
    font-size: .9rem;
  }

  .p-top-wine-intro__visual {
    min-height: 170px;
  }

  .p-top-wine-intro__glass {
    width: 86px;
    height: 140px;
  }
}
