/* ===============================
   3. Page - Top
================================*/

/* HERO */
.p-top-hero {
  position: relative;
  width: 100%;
  min-height: 700px;
  overflow: hidden;
}

.p-top-hero__media {
  position: absolute;
  inset: 0;
  z-index: -11;
}

.p-top-hero__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.p-top-hero__inner {
  position: relative;
  z-index: 1;
  margin: 0 auto;
  padding: 6rem 1rem 3rem;
  min-height: 700px;
  display: flex;
  align-items: flex-end;
}

@media (max-width: 768px) {
  .p-top-hero {
    min-height: 500px;
  }

  .p-top-hero__inner {
    min-height: 500px;
  }
}

.p-top-hero__status-wrap {
  margin: 0 0 80px 100px;
}

@media (max-width: 768px) {
  .p-top-hero__status-wrap {
    margin: 0 auto 80px auto;
  }
}

.p-top-hero__status {
  color: #fff;
  text-align: left;
}

@media (max-width: 768px) {
  .p-top-hero__status {
    text-align: center;
  }
}

.p-top-hero__status-icon {
  display: inline-block;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  position: relative;
  margin-bottom: 16px;
}

.p-top-hero__status.is-closed .p-top-hero__status-icon {
  border: 6px solid #e53935;
}

.p-top-hero__status.is-closed .p-top-hero__status-icon::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 6px;
  height: 45px;
  background: #e53935;
  transform: translate(-50%, -50%) rotate(45deg);
  border-radius: 999px;
}

.p-top-hero__status.is-open .p-top-hero__status-icon {
  border: 6px solid #2fbf54;
}

.p-top-hero__status-label {
  font-size: 40px;
  font-weight: 700;
  line-height: 1.1;
  margin: 0 0 8px;
}

.p-top-hero__status-sub {
  display: block;
  font-size: 18px;
  font-weight: 400;
  margin-top: 6px;
}

.p-top-hero__status-text {
  font-size: 18px;
  margin: 0;
}

.p-top-hero__action {
  margin-top: 24px;
  text-align: left;
}

@media (max-width: 768px) {
  .p-top-hero__action {
    text-align: center;
  }
  .p-top-hero__sub-action {
    text-align: center;
  }
}

.p-top-hero__btn {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 10px 20px;
  border-radius: 999px;
  background: rgba(0, 106, 169, 0.6);
  backdrop-filter: blur(6px);
  color: #fff;
  text-decoration: none;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.25);
  transition: opacity 0.25s ease, transform 0.25s ease;
}

.p-top-hero__btn:hover {
  opacity: 0.9;
  transform: translateY(-1px);
}

.p-top-hero__btn-text {
  font-size: 16px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.02em;
}

.p-top-hero__btn-icon {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.9);
  position: relative;
  flex: 0 0 auto;
}

.p-top-hero__btn-icon::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 10px;
  height: 10px;
  border-top: 2px solid rgba(255, 255, 255, 0.95);
  border-right: 2px solid rgba(255, 255, 255, 0.95);
  transform: translate(-60%, -50%) rotate(45deg);
}

.p-top-hero__action {
  margin-top: 20px;
}

.p-top-hero__sub-action {
  margin-top: 12px;
}

.p-top-hero__btn--sub {
  /* 必要なら見た目を少し変える */
}

.p-top-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.25),
    rgba(0,0,0,0.45)
  );
  pointer-events: none;
}

.p-top-hero__wave {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 130px;
  z-index: 3;
  pointer-events: none;
}

@media (max-width: 768px) {
  .p-top-hero__wave {
    bottom: 0px;
    height: 70px;
  }
}

.p-top-hero__wave svg {
  width: 100%;
  height: 100%;
  display: block;
}

.p-top-hero__wave path {
  fill: #fff!important;
}

/* ABOUT */
.p-top-about {
  width: 100%;
  padding: 1.5rem 0 2rem;
}

.p-top-about__inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 1rem;
}

.p-top-about__copy {
  text-align: center;
  margin: 100px auto 50px;
}

.p-top-about__copy img {
  margin-left: 30px;
}

.p-top-about__copy p {
  font-size: 24px;
  font-weight: bold;
  color: #006aa9;
}
@media (max-width: 768px) {
  .p-top-about__copy p {
  font-size: 20px;
  }
}

/* To all climbers */
.p-top-tac {
  width: 100%;
  padding: 1.5rem 0 2rem;
}

.p-top-tac__inner-1100 {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 1rem;
}

@media (max-width: 768px) {
  .p-top-tac__inner-1100 {
    width: 100%;
  }
}

.p-top-tac__inner-full {
  width: 100%;
  margin: 0 auto;
}

/* p-top-tac__btn */
.p-top-tac__btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 32px;
  flex-wrap: nowrap;
  width: 100%;
  padding: 40px 48px 36px;
  background-color: #006aa9;
  color: #fff;
  text-decoration: none;
  border: 2px solid #006aa9;
  transition: background-color 0.4s ease, color 0.4s ease;
}

.p-top-tac__btn:hover {
  background-color: #fff;
  color: #006aa9;
  filter: none;
}

.p-top-tac__btn:hover .p-top-tac__btn-arrow {
  border-color: #006aa9;
}

.p-top-tac__btn:hover .p-top-tac__btn-arrow::before {
  background-color: #006aa9;
}

.p-top-tac__btn:hover .p-top-tac__btn-arrow::after {
  border-top-color: #006aa9;
  border-right-color: #006aa9;
}

.p-top-tac__btn:hover .p-top-tac__btn-label {
  color: #006aa9;
  opacity: 1;
}

.p-top-tac__btn-badge {
  position: absolute;
  top: -22px;
  left: 50%;
  transform: translateX(-50%);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: #ffd400;
  border: 4px solid #000;
  color: #000;
  display: grid;
  place-items: center;
  font-size: 28px;
  font-weight: 900;
  line-height: 1;
}

.p-top-tac__btn-body {
  justify-self: center;
  font-size: 20px;
  line-height: 1.6;
  flex: 0 1 auto;
  min-width: 0;
}

.p-top-tac__btn-action {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto;
}

.p-top-tac__btn-arrow {
  position: relative;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.9);
}

.p-top-tac__btn-arrow::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 18px;
  right: 18px;
  height: 2px;
  background-color: #fff;
  transform: translateY(-50%);
}

.p-top-tac__btn-arrow::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 18px;
  width: 12px;
  height: 12px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: translateY(-50%) rotate(45deg);
}

.p-top-tac__btn-label {
  font-size: 14px;
  opacity: .9;
}

@media (max-width: 768px) {
  .p-top-tac__btn {
    gap: 16px;
    padding: 28px 16px 24px;
  }

  .p-top-tac__btn-body {
    font-size: 16px;
    line-height: 1.6;
  }

  .p-top-tac__btn-action {
    grid-auto-flow: row;
    justify-items: center;
    gap: 10px;
  }

  .p-top-tac__btn-arrow {
    width: 56px;
    height: 56px;
  }

  .p-top-tac__btn-label {
    font-size: 12px;
  }
}

/* tac steps */
.p-top-tac__steps {
  margin-top: 4rem;
}

@media (max-width: 768px) {
  .p-top-tac__steps {
    max-width: 340px;
    margin-inline: auto;
  }
}

.p-top-tac__steps-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 56px;
}

.p-top-tac__steps-link {
  display: grid;
  justify-items: center;
  gap: 18px;
  text-decoration: none;
  color: inherit;
}

.p-top-tac__steps-media {
  width: 240px;
  max-width: 100%;
}

.p-top-tac__steps-media img {
  width: 200px;
  height: auto;
  display: block;
}

.p-top-tac__steps-body {
  text-align: left;
}

.p-top-tac__steps-title-num {
  font-size: 48px;
  font-weight: 700;
  color: #006aa9;
}

.p-top-tac__steps-title {
  margin: 0 0 14px;
  font-size: 20px;
  font-weight: 700;
  color: #006aa9;
  line-height: 1.5;
}

.p-top-tac__steps-more {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  color: #006aa9;
}

.p-top-tac__steps-more-icon {
  width: 20px;
  height: 20px;
  border: 1px solid #006aa9;
  border-radius: 50%;
  position: relative;
}

.p-top-tac__steps-more-icon::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 6px;
  width: 8px;
  height: 2px;
  background: #006aa9;
  transform: translateY(-50%);
}

.p-top-tac__steps-more-icon::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 6px;
  width: 6px;
  height: 6px;
  border-top: 2px solid #006aa9;
  border-right: 2px solid #006aa9;
  transform: translateY(-50%) rotate(45deg);
}

@media (max-width: 768px) {
  .p-top-tac__steps {
    margin-top: 2.5rem;
  }

  .p-top-tac__steps-list {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .p-top-tac__steps-link {
    grid-template-columns: 170px 1fr;
    justify-items: start;
    align-items: center;
    gap: 16px;
  }

  .p-top-tac__steps-media {
    width: 160px;
  }

  .p-top-tac__steps-body {
    text-align: left;
  }

  .p-top-tac__steps-title {
    font-size: 16px;
    margin-bottom: 8px;
  }
}

/* reserve btn */
.p-top-reserve-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 370px;
  width: 100%;
  margin: 100px auto 0;
  padding: 20px 24px;
  gap: 24px;
  background-color: #006aa9;
  color: #fff;
  border: 2px solid #006aa9;
  border-radius: 12px;
  transition: background-color 0.3s ease, color 0.3s ease;
}

.p-top-reserve-btn__body {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.p-top-reserve-btn__jp {
  font-size: 24px;
  font-weight: 700;
}
.p-top-reserve-btn__jp-sub {
  font-size: 20px;
  font-weight: 700;
}

.p-top-reserve-btn__en {
  font-size: 12px;
  opacity: 0.9;
}

.p-top-reserve-btn__note {
  font-size: 12px;
  opacity: 0.85;
}

.p-top-reserve-btn__action {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}

.p-top-reserve-btn__arrow {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  border: 1px solid #fff;
  position: relative;
}

.p-top-reserve-btn__arrow::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 22px;
  height: 2px;
  background-color: #fff;
  transform: translate(-50%, -50%);
}

.p-top-reserve-btn__arrow::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 12px;
  height: 12px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: translate(-30%, -50%) rotate(45deg);
}

.p-top-reserve-btn__label {
  font-size: 12px;
}

.p-top-reserve-btn:hover {
  background-color: #fff;
  color: #006aa9;
  border: 2px solid #006aa9;
}

.p-top-reserve-btn:hover .p-top-reserve-btn__arrow {
  border-color: #006aa9;
}

.p-top-reserve-btn:hover .p-top-reserve-btn__arrow::before{
  background-color: #006aa9;
}
.p-top-reserve-btn:hover .p-top-reserve-btn__arrow::after {
  border-top-color: #006aa9;
  border-right-color: #006aa9;
}

/* TOP CAUTION */
.p-top-caution {
  background: #f7dede;
  padding: 40px 0;
  margin: 50px 0;
}

.p-top-caution__inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px;
}

.p-top-caution__label {
  margin: 0 0 12px;
  color: #8b0000;
}

.p-top-caution__cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border: 4px solid #8b0000;
  border-radius: 6px;
  padding: 16px 18px;
  color: #8b0000;
  text-decoration: none;
  background: transparent;
}

.p-top-caution__cta-text {
  font-weight: 800;
  font-size: 18px;
}

.p-top-caution__cta-icon {
  width: 36px;
  height: 36px;
  position: relative;
  flex: 0 0 auto;
  display: inline-block;
  background-image: url("../img/icon-warning.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.p-top-caution-news__inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px;
}

.p-top-caution__body {
  margin-top: 22px;
}

.p-top-caution__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 26px 44px;
}

.p-top-caution__item {
  border-bottom: 1px solid rgba(0,0,0,.55);
  padding-bottom: 12px;
}

.p-top-caution__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  text-decoration: none;
  color: #111;
}

.p-top-caution__meta {
  min-width: 0;
}

.p-top-caution__date {
  display: block;
  color: #8b0000;
  font-weight: 800;
  font-size: 14px;
  margin-bottom: 6px;
}

.p-top-caution__text {
  margin: 0;
  font-size: 14px;
  line-height: 1.6;
}

.p-top-caution__arrow {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 1px solid #8b0000;
  position: relative;
  flex: 0 0 auto;
}

.p-top-caution__arrow::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 4px;
  right: 4px;
  height: 2px;
  background: #8b0000;
  transform: translateY(-50%);
}

.p-top-caution__arrow::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 4px;
  width: 6px;
  height: 6px;
  border-top: 2px solid #8b0000;
  border-right: 2px solid #8b0000;
  transform: translateY(-50%) rotate(45deg);
}

.p-top-caution__more {
  margin-top: 16px;
  display: flex;
  justify-content: flex-end;
}

.p-top-caution__more-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #8b0000;
  text-decoration: none;
  font-weight: 800;
  font-size: 14px;
}

.p-top-caution__more-icon {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid #8b0000;
  position: relative;
}

.p-top-caution__more-icon::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 5px;
  right: 5px;
  height: 2px;
  background: #8b0000;
  transform: translateY(-50%);
}

.p-top-caution__more-icon::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 5px;
  width: 6px;
  height: 6px;
  border-top: 2px solid #8b0000;
  border-right: 2px solid #8b0000;
  transform: translateY(-50%) rotate(45deg);
}

@media (max-width: 768px) {
  .p-top-caution {
    padding: 28px 0;
  }

  .p-top-caution__cta {
    padding: 18px 16px;
    border-width: 3px;
    border-radius: 10px;
  }

  .p-top-caution__cta-text {
    font-size: 18px;
  }

  .p-top-caution__list {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .p-top-caution__item {
    padding-bottom: 14px;
  }

  .p-top-caution__more {
    justify-content: center;
    margin-top: 18px;
  }
}

/* JMA */
.jma-top {
  margin-top: 50px;
}

.jma-top__head {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 16px;
  align-items: baseline;
  justify-content: space-between;
}

.jma-top__title {
  margin: 0 0 16px 0;
  font-size: 18px;
}

.jma-top__updated {
  margin: 0;
  font-size: 12px;
  opacity: .8;
}

.jma-top__legend {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 10px 0;
}

@media (max-width: 768px) {
  .jma-top__legend {
    gap: 6px;
    margin: 0 0 10px 0;
  }
}

.jma-top__body {
  margin-top: 14px;
  display: grid;
  gap: 18px;
}

.jma-pref {
  margin: 0 0 6px;
  font-size: 16px;
}

.jma-area {
  margin: 14px 0 6px;
  font-size: 14px;
  opacity: .9;
}

.jma-top__inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 16px;
}

@media (max-width: 768px) {
  .jma-top__inner {
    max-width: 95%;
  }
}

.jma-tablewrap {
  overflow-x: auto;
}

.jma-table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid #ddd;
  min-width: 720px;
}

.jma-table th,
.jma-table td {
  border: 1px solid #ddd;
  padding: 12px 14px;
  vertical-align: middle;
}

.col-pref {
  background: #f3f3f3;
  width: 140px;
  text-align: center;
}

.col-area {
  background: #fafafa;
  width: 180px;
  text-align: center;
}

.col-city {
  background: #eaf7ff;
  width: 200px;
  text-align: center;
}

.col-warn {
  background: #fff;
}

.badges {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: flex-start;
}

.badge {
  font-size: 12px;
  line-height: 1;
  padding: 6px 10px;
  border-radius: 8px;
  border: 1px solid transparent;
  font-weight: 600;
}

.badge--emg  { background:#111; color:#fff; border-color:#111; }
.badge--warn { background:#d32f2f; color:#fff; border-color:#d32f2f; }
.badge--adv  { background:#f9a825; color:#111; border-color:#f9a825; }
.badge--none { background:#e0e0e0; color:#333; border-color:#e0e0e0; }
.badge--err  { background:#666; color:#fff; border-color:#666; }

@media (max-width: 768px) {
  .jma-table col.col-pref-col { width: 40px; }
  .jma-table col.col-area-col { width: 40px; }
  .jma-table col.col-city-col { width: 28%; }
  .jma-table col.col-warn-col { width: auto; }

  .jma-table .col-pref,
  .jma-table .col-area,
  .jma-table .col-city,
  .jma-table .col-warn {
    width: auto;
  }

  .jma-tablewrap {
    overflow: visible;
  }

  .jma-table {
    width: 100%;
    min-width: 0;
    table-layout: fixed;
    border-collapse: collapse;
  }

  .jma-table th,
  .jma-table td {
    padding: 10px 6px;
    border-width: 1px;
    border-style: solid;
  }

  .jma-table .col-pref,
  .jma-table .col-area {
    width: 18px;
    padding: 2px 10px;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    letter-spacing: 0.08em;
  }

  .jma-table .col-city {
    width: 25%;
    text-align: center;
    font-weight: 600;
  }

  .jma-table .col-warn {
    width: auto;
  }

  .jma-table .badges {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
    justify-content: flex-start;
  }

  .jma-table .badge {
    font-size: 12px;
    padding: 6px 8px;
    line-height: 1;
    border-radius: 8px;
  }
}

/* volcano */
.jma-volcano {
  margin-top: 24px;
}

.jma-volcano__inner {
  width: 100%;
  padding: 20px;
}

@media (max-width: 768px) {
  .jma-volcano__inner {
    width: 100%;
    padding: 16px;
  }
}

.jma-volcano__head {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 16px;
  align-items: baseline;
  justify-content: space-between;
}

.jma-volcano__title {
  margin: 0;
  font-size: 18px;
}

.jma-volcano__updated {
  margin: 0;
  font-size: 12px;
  opacity: .8;
}

.volcano-box {
  border-radius: 10px;
  padding: 12px 14px;
  border: 1px solid #ddd;
}

.volcano-box[data-level="5"] { background:#111; color:#fff; border-color:#111; }
.volcano-box[data-level="4"] { background:#5d4037; color:#fff; border-color:#5d4037; }
.volcano-box[data-level="3"] { background:#d32f2f; color:#fff; border-color:#d32f2f; }
.volcano-box[data-level="2"] { background:#f9a825; color:#111; border-color:#f9a825; }
.volcano-box[data-level="1"] { background:#e0e0e0; color:#111; border-color:#e0e0e0; }
.volcano-box[data-level="0"] { background:#666; color:#fff; border-color:#666; }

.volcano-level {
  margin: 0;
  font-weight: 800;
}

.volcano-note {
  margin: 6px 0 0;
  font-size: 12px;
  opacity: .9;
}

/* ===============================
   TOP alert / volcano grid
================================*/
.p-top-alert-grid {
  margin: 40px 0 56px;
}

.p-top-alert-grid__inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px;
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(320px, 1fr);
  gap: 24px;
  align-items: start;
}

/* 左右のカード共通 */
.weather-wake,
.jma-volcano {
  background: #fff;
  border: 1px solid #dcdcdc;
  border-radius: 14px;
  overflow: hidden;
}

/* ===============================
   wake
================================*/
.weather-wake {
  margin-top: 0;
}

.weather-wake__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 16px;
  padding: 22px 28px 18px;
  border-bottom: 1px solid #e8e8e8;
  flex-wrap: wrap;
}

.weather-wake__title {
  margin: 0;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.4;
  color: #222;
}

.weather-wake__updated {
  margin: 0;
  font-size: 1.3rem;
  color: #666;
  white-space: nowrap;
}

.weather-wake__body {
  padding: 0 20px;
  background: #fff;
}

.weather-wake__list {
  margin: 0;
  padding: 0;
}

.weather-wake__row {
  display: grid;
  grid-template-columns: minmax(220px, 260px) 1fr;
  gap: 20px;
  align-items: center;
  padding: 20px 0;
  border-bottom: 1px solid #ededed;
}

.weather-wake__row:last-child {
  border-bottom: none;
}

.weather-wake__city {
  margin: 0;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.6;
  color: #333;
}

.weather-wake__alerts {
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.weather-wake__badge,
.weather-wake__none {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 1.3rem;
  line-height: 1.4;
}

.weather-wake__none {
  background: #f3f4f6;
  color: #666;
}

.weather-wake__badge.is-emergency {
  background: #d93025;
  color: #fff;
}

.weather-wake__badge.is-warning {
  background: #f29900;
  color: #fff;
}

.weather-wake__badge.is-advisory {
  background: #fff4db;
  color: #9a5b00;
  border: 1px solid #f0cf7a;
}

.weather-wake__badge.is-normal {
  background: #eef3f8;
  color: #445;
}

.weather-wake__empty {
  margin: 0;
  padding: 18px 0 22px;
  border-top: 1px solid #ededed;
  font-size: 1.4rem;
  color: #444;
}

/* ===============================
   volcano
================================*/
.jma-volcano {
  margin-top: 0;
}

.jma-volcano__inner {
  width: 100%;
  padding: 22px 22px 24px;
}

.jma-volcano__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 12px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

.jma-volcano__title {
  margin: 0;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.4;
  color: #222;
}

.jma-volcano__updated {
  margin: 0;
  font-size: 1.3rem;
  color: #666;
  white-space: nowrap;
}

.volcano-box {
  margin-top: 0;
  padding: 18px 18px 16px;
  background: #f7f7f7;
  border: 1px solid #ececec;
  border-radius: 12px;
  min-height: 180px;
}

.volcano-level {
  margin: 0 0 12px;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  color: #222;
}

.volcano-note {
  margin: 0;
  font-size: 1.4rem;
  line-height: 1.8;
  color: #444;
}

/* ===============================
 詳細リンク（丸矢印）
================================*/

/* volcano box */
.volcano-box{
  position:relative;
}

/* 右下 */
.volcano-box__link{
  margin-top:14px;
  text-align:right;
}

/* リンク */
.c-link-circle{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:1.0rem;
  font-weight:600;
  color:#006aa9;
  text-decoration:none;
}

/* 丸 */
.c-link-circle::after{
  content:"";
  width:22px;
  height:22px;
  border-radius:50%;
  background:#006aa9;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  position:relative;
}

/* 矢印 */
.c-link-circle::after{
  content:"→";
  color:#fff;
  font-size:12px;
  font-weight:700;
  line-height:22px;
  text-align:center;
}




/* ===============================
   responsive
================================*/
@media (max-width: 900px) {
  .p-top-alert-grid__inner {
    grid-template-columns: 1fr;
  }

  .volcano-box {
    min-height: auto;
  }
}

@media (max-width: 767px) {
  .p-top-alert-grid {
    margin: 28px 0 40px;
  }

  .p-top-alert-grid__inner {
    padding: 0 16px;
    gap: 16px;
  }

  .weather-wake__head,
  .jma-volcano__inner {
    padding-left: 16px;
    padding-right: 16px;
  }

  .weather-wake__head {
    padding-top: 18px;
    padding-bottom: 14px;
  }

  .weather-wake__body {
    padding: 0 16px;
  }

  .weather-wake__row {
    grid-template-columns: 1fr;
    gap: 10px;
    align-items: start;
    padding: 16px 0;
  }

  .weather-wake__city {
    font-size: 1.5rem;
  }

  .weather-wake__updated,
  .jma-volcano__updated {
    font-size: 1.2rem;
  }

  .weather-wake__badge,
  .weather-wake__none {
    min-height: 32px;
    padding: 5px 12px;
    font-size: 1.2rem;
  }

  .jma-volcano__inner {
    padding-top: 18px;
    padding-bottom: 18px;
  }

  .jma-volcano__title {
    font-size: 1.7rem;
  }

  .volcano-box {
    padding: 16px;
    border-radius: 10px;
    min-height: auto;
  }

  .volcano-level {
    font-size: 1.8rem;
  }

  .volcano-note {
    font-size: 1.3rem;
  }
}
/* ===============================
 alert / volcano サイズ調整
================================*/

/* タイトル */
.weather-wake__title,
.jma-volcano__title{
  font-size: 1.2rem;
  font-weight: 700;
}

/* 更新時間 */
.weather-wake__updated,
.jma-volcano__updated{
  font-size: 0.8rem;
}

/* 市町村 */
.weather-wake__city{
  font-size: 1.1rem;
  font-weight: 600;
}

/* 行の余白 */
.weather-wake__row{
  padding: 16px 0;
}

/* バッジ */
.weather-wake__badge,
.weather-wake__none{
  min-height: 30px;
  padding: 4px 12px;
  font-size: 1.1rem;
}

/* 火山ボックス */
.volcano-box{
  padding: 16px;
}

/* 噴火レベル */
.volcano-level{
  font-size: 1.7rem;
}

/* 警戒事項 */
.volcano-note{
  font-size: 1.3rem;
}

/* INFORMATION */
.p-top-info {
  padding: 40px 0;
  margin-top:100px;
  background-color: #e8f3f7;
}

.p-top-info__inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px;
}

.p-top-info__sec {
  padding: 0 0 80px 0;
}

.p-top-info__title {
  margin: 0 0 18px;
  font-size: 24px;
  font-weight: 800;
  letter-spacing: 0.02em;
}

.p-top-info__cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border: 4px solid #006aa9;
  border-radius: 10px;
  padding: 18px 22px;
  color: #006aa9;
  transition: background-color 0.25s ease, color 0.25s ease, transform 0.25s ease;
}

.p-top-info__cta-text {
  font-size: 18px;
  font-weight: 800;
}

.p-top-info__cta-icon {
  width: 36px;
  height: 36px;
  position: relative;
  flex: 0 0 auto;
  display: inline-block;
  background-image: url("../img/icon-bell.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.p-top-info__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 26px 44px;
}

.p-top-info__item {
  border-bottom: 2px solid rgba(0,0,0,.55);
  padding-bottom: 18px;
}

.p-top-info__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  color: inherit;
}

.p-top-info__meta {
  min-width: 0;
}

.p-top-info__date {
  display: block;
  font-weight: 800;
  font-size: 14px;
  color: #006aa9;
  margin-bottom: 6px;
}

.p-top-info__headline {
  margin: 0 0 6px;
  font-weight: 800;
  color: #006aa9;
  font-size: 18px;
  line-height: 1.35;
}

.p-top-info__text {
  margin: 0;
  font-size: 14px;
  color: #111;
  line-height: 1.6;
}

.p-top-info__arrow {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 2px solid #006aa9;
  position: relative;
  flex: 0 0 auto;
}

.p-top-info__arrow::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 4px;
  right: 4px;
  height: 2px;
  background: #006aa9;
  transform: translateY(-50%);
}

.p-top-info__arrow::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 4px;
  width: 6px;
  height: 6px;
  border-top: 2px solid #006aa9;
  border-right: 2px solid #006aa9;
  transform: translateY(-50%) rotate(45deg);
}

.p-top-info__body {
  margin-top: 56px;
}

.p-top-info__more {
  margin-top: 20px;
  display: flex;
  justify-content: flex-end;
}

.p-top-info__more-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #006aa9;
  font-weight: 800;
  font-size: 14px;
}

.p-top-info__more-arrow {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 2px solid #006aa9;
  position: relative;
}

.p-top-info__more-arrow::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 5px;
  right: 5px;
  height: 2px;
  background: #006aa9;
  transform: translateY(-50%);
}

.p-top-info__more-arrow::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 5px;
  width: 6px;
  height: 6px;
  border-top: 2px solid #006aa9;
  border-right: 2px solid #006aa9;
  transform: translateY(-50%) rotate(45deg);
}

.p-top-info__more-label {
  font-size: 14px;
}

@media (max-width: 767px) {
  .p-top-info {
    padding: 48px 0;
  }

  .p-top-info__grid {
    grid-template-columns: 1fr;
    gap: 22px;
  }

  .p-top-info__list {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .p-top-info__more {
    display: flex;
    justify-content: center;
    padding-top: 0;
  }
}

/* WEATHER */
.p-top-weather {
  background: url("../img/weather-bg.jpg") center/cover no-repeat;
  padding: 80px 0 80px;
  color: #fff;
}

.p-top-weather__inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px;
}

.p-top-weather__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 60px;
}

.p-top-weather__en {
  margin: 0 0 12px;
  font-weight: 800;
  margin-bottom: 30px;
}

.p-top-weather__ja {
  margin: 0 0 10px;
  font-size: 18px;
  font-weight: 800;
}

.p-top-weather__lead {
  margin: 0;
  font-size: 14px;
  line-height: 1.7;
  opacity: .95;
}

.p-top-weather__icon {
  width: 44px;
  height: 44px;
  flex: 0 0 auto;
}

.p-top-weather__body {
  display: flex;
  align-items: center;
  gap: 26px;
}

.p-top-weather__cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 40px;
  flex: 1 1 auto;
}

.p-top-weather__card {
  height: 180px;
  border-radius: 10px;
  background: rgba(255,255,255,.85);
  color: #333;
  text-decoration: none;
  display: grid;
  place-items: center;
}

.p-top-weather__card-title {
  font-weight: 800;
  font-size: 18px;
}

.p-top-weather__more {
  flex: 0 0 auto;
}

.p-top-weather__more-link {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  color: #fff;
  text-decoration: none;
}

.p-top-weather__more-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.9);
  position: relative;
}

.p-top-weather__more-icon::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 18px;
  right: 18px;
  height: 2px;
  background: #fff;
  transform: translateY(-50%);
}

.p-top-weather__more-icon::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 20px;
  width: 8px;
  height: 8px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: translateY(-50%) rotate(45deg);
}

.p-top-weather__more-label {
  font-size: 12px;
  font-weight: 700;
}

@media (max-width: 768px) {
  .p-top-weather {
    padding: 40px 0 48px;
  }

  .p-top-weather__head {
    margin-bottom: 20px;
  }

  .p-top-weather__ja {
    font-size: 20px;
  }

  .p-top-weather__body {
    flex-direction: column;
    align-items: stretch;
    gap: 18px;
  }

  .p-top-weather__cards {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .p-top-weather__card {
    height: 160px;
  }

  .p-top-weather__more {
    align-self: flex-end;
  }
}

/* ライブカメラボタン */
.p-top-weather__camera{
  display:inline-flex;
  align-items:center;
  gap:16px;

  margin-top:32px;
  padding:14px 26px;

  border-radius:40px;
  border:2px solid #fff;

  color:#fff;
  text-decoration:none;

  font-weight:600;
  transition:all .25s ease;
}

.p-top-weather__camera:hover{
  background:#006aa9;
  border-color:#006aa9;
}

/* テキスト */
.p-top-weather__camera-text{
  font-size:18px;
}

/* 丸矢印 */
.p-top-weather__camera-arrow{
  width:28px;
  height:28px;
  border-radius:50%;
  border:2px solid #fff;
  position:relative;
}

/* 矢印 */
.p-top-weather__camera-arrow::before{
  content:"";
  position:absolute;
  top:50%;
  left:7px;
  right:7px;
  height:2px;
  background:#fff;
  transform:translateY(-50%);
}

.p-top-weather__camera-arrow::after{
  content:"";
  position:absolute;
  top:50%;
  right:7px;
  width:7px;
  height:7px;
  border-top:2px solid #fff;
  border-right:2px solid #fff;
  transform:translateY(-50%) rotate(45deg);
}

/* ROUTES MAP */
.p-top-routesmap {
  padding: 80px 0;
}

.p-top-routesmap__inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px;
}

.p-top-routesmap__media {
  position: relative;
  margin: 60px auto;
  width: 663px;
}

.p-top-routesmap__header {
  margin-bottom: 32px;
}

.p-top-routesmap__en {
  margin: 0 0 30px;
}

.p-top-routesmap__ja {
  font-size: 18px;
  font-weight: 800;
  line-height: 1.4;
  margin-bottom: 30px;
}

.p-top-routesmap__visual {
  margin-bottom: 32px;
}

.p-top-routesmap__visual img {
  width: 100%;
  height: auto;
  display: block;
}

.p-top-routesmap__map-area {
  position: relative;
  margin-top: 24px;
}

.p-top-routesmap__map-text {
  position: absolute;
  top: 0px;
  left: 0px;
  z-index: 2;
  max-width: 460px;
}

.p-top-routesmap__map img {
  width: 663px;
  height: auto;
  display: block;
}

.p-top-routesmap__map-lead {
  font-size: 18px;
  font-weight: 800;
  line-height: 1.4;
  color: #006aa9;
  margin: 0 0 20px;
}

.p-top-routesmap__pref-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.p-top-routesmap__pref {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}

.p-top-routesmap__pref-icon {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: transparent;
  flex: 0 0 auto;
}

.p-top-routesmap__pref--yamanashi {
  color: #f28c28;
}

.p-top-routesmap__pref--yamanashi .p-top-routesmap__pref-icon {
  border: 5px solid #f28c28;
}

.p-top-routesmap__pref--shizuoka {
  color: #2f5fb3;
}

.p-top-routesmap__pref--shizuoka .p-top-routesmap__pref-icon {
  border: 5px solid #2f5fb3;
}

.p-top-routesmap__pref-ja {
  font-size: 16px;
  font-weight: 700;
}

.p-top-routesmap__pref-en {
  font-size: 12px;
  letter-spacing: .06em;
}

@media (max-width: 768px) {
  .p-top-routesmap {
    padding: 48px 0 0;
  }

  .p-top-routesmap__ja {
    font-size: 22px;
  }

  .p-top-routesmap__media {
    width: 100%;
  }

  .p-top-routesmap__map-text {
    position: static;
    max-width: none;
    margin-bottom: 16px;
  }

  .p-top-routesmap__map-lead {
    font-size: 20px;
  }

  .p-top-routesmap__pref-ja {
    font-size: 18px;
  }
}

/* COMPARE */
.p-top-compare {
  background: #e9f3f8;
  padding: 90px 0;
}

.p-top-compare__inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px;
}

.p-top-compare__head {
  margin-bottom: 44px;
}

.p-top-compare__en {
  margin: 0 0 30px;
}

.p-top-compare__ja {
  margin: 0 0 60px;
  font-size: 18px;
  font-weight: 800;
}

/* ===============================
   Comparison of Routes 並び順調整
================================*/
.p-top-compare__wrap {
  display: grid;
  grid-template-columns: 3fr 44px 1fr;
  align-items: stretch;
  gap: 0;
}

/* PC: 左に静岡 */
.p-top-compare__group--shizuoka {
  grid-column: 1;
  grid-row: 1;
}

/* PC: 真ん中に点線 */
.p-top-compare__divider {
  grid-column: 2;
  grid-row: 1;
}

/* PC: 右に山梨 */
.p-top-compare__group--yamanashi {
  grid-column: 3;
  grid-row: 1;
}

@media (max-width: 767px) {
  .p-top-compare__wrap {
    grid-template-columns: 1fr;
  }

  /* SP: 静岡を先に */
  .p-top-compare__group--shizuoka {
    grid-column: 1;
    grid-row: 1;
  }

  /* SP: 山梨を最後に */
  .p-top-compare__group--yamanashi {
    grid-column: 1;
    grid-row: 2;
  }

  .p-top-compare__divider {
    display: none;
  }
}

.p-top-compare__divider {
  position: relative;
}

.p-top-compare__divider::before {
  content:"";
  position:absolute;
  top: 0;
  bottom: 0;
  left: 60%;
  width: 2px;
  transform: translateX(-50%);
  background: repeating-linear-gradient(
    to bottom,
    rgba(0,0,0,.28) 0 8px,
    rgba(0,0,0,0) 8px 16px
  );
}

.p-top-compare__group-head {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 0 auto 88px;
  width: max-content;
}

.p-top-compare__pref-icon {
  width: auto;
  height: 56px;
  display: block;
}

.p-top-compare__pref-text {
  display: flex;
  flex-direction: column;
  gap: 0px;
  text-align: center;
}

.p-top-compare__pref-text__yamanashi {
  color: #f28c28;
}

.p-top-compare__pref-text__shizuoka {
  color: #2f5fb3;
}

.p-top-compare__pref-ja {
  font-weight: 900;
  font-size: 18px;
}

.p-top-compare__pref-en {
  font-weight: 900;
  font-size: 11px;
  letter-spacing: .06em;
  opacity: .9;
}

.p-top-compare__cards {
  display: grid;
  justify-items: center;
  align-items: start;
  gap: 30px;
}

.p-top-compare__cards--one {
  grid-template-columns: 1fr;
}

.p-top-compare__cards--three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.p-top-compare__card {
  width: 100%;
  max-width: 236px;
  background: #fff;
  border-radius: 18px;
  border: 6px solid transparent;
  padding: 0 14px 10px;
  box-shadow: 0 10px 24px rgba(0,0,0,.08);
  display: grid;
  justify-items: center;
  gap: 14px;
}

.p-top-compare__route {
  position: relative;
  margin: -44px auto 0;
  width: 100%;
  text-align: center;
  color: #fff;
  font-size: 16px;
  font-weight: 900;
  padding: 8px 10px 0px;
  background: transparent;
  z-index: 3;
}

.p-top-compare__route::before {
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  clip-path: polygon(10% 0%, 90% 0%, 100% 100%, 0% 100%);
  border-radius: 8px 8px 0 0;
  background: #006aa9;
}

.p-top-compare__card-body {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-radius: 12px;
  overflow: hidden;
}

.p-top-compare__cell {
  padding: 10px 8px;
  min-height: 86px;
  display: grid;
  align-content: start;
  gap: 4px;
  text-align: center;
  border-right: 2px solid var(--route-border, rgba(0,0,0,.08));
  border-bottom: 2px solid var(--route-border, rgba(0,0,0,.08));
}

.p-top-compare__cell:nth-child(2n){ border-right: none; }
.p-top-compare__cell:nth-last-child(-n+2){ border-bottom: none; }

.p-top-compare__label{ margin:0; font-size:12px; font-weight:900; }
.p-top-compare__value{ margin:0; font-size:18px; font-weight:900; }
.p-top-compare__sub{ margin:0; font-size:10px; font-weight:800; opacity:.9; line-height:1.35; }

.p-top-compare__label,
.p-top-compare__sub,
.p-top-compare__value {
  overflow-wrap: anywhere;
  word-break: normal;
}

.p-top-compare__pill{
  margin: 6px auto 0;
  display: inline-block;
  font-size: 12px;
  font-weight: 900;
  color: #fff;
  padding: 4px 10px;
  border-radius: 999px;
}
:lang(en) .p-top-compare__pill {
  font-size: 9px;
}

.p-top-compare__more{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: 900;
  font-size: 14px;
}

.p-top-compare__more-icon{
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 2px solid currentColor;
  position: relative;
}

.p-top-compare__more-icon::before{
  content:"";
  position:absolute;
  top:50%;
  left:5px;
  right:5px;
  height:2px;
  background: currentColor;
  transform: translateY(-50%);
}

.p-top-compare__more-icon::after{
  content:"";
  position:absolute;
  top:50%;
  right:5px;
  width:6px;
  height:6px;
  border-top:2px solid currentColor;
  border-right:2px solid currentColor;
  transform: translateY(-50%) rotate(45deg);
}

.p-top-compare__card--orange{ border-color:#f39b12; }
.p-top-compare__card--orange .p-top-compare__route::before{ background:#f39b12; }
.p-top-compare__card--orange .p-top-compare__value{ color:#f39b12; }
.p-top-compare__card--orange .p-top-compare__pill{ background:#f39b12; }
.p-top-compare__more--orange{ color:#f39b12; }

.p-top-compare__card--blue{ border-color:#4b8fd6; }
.p-top-compare__card--blue .p-top-compare__route::before{ background:#4b8fd6; }
.p-top-compare__card--blue .p-top-compare__value{ color:#4b8fd6; }
.p-top-compare__card--blue .p-top-compare__pill{ background:#4b8fd6; }
.p-top-compare__more--blue{ color:#4b8fd6; }

.p-top-compare__card--green{ border-color:#43b06f; }
.p-top-compare__card--green .p-top-compare__route::before{ background:#43b06f; }
.p-top-compare__card--green .p-top-compare__value{ color:#43b06f; }
.p-top-compare__card--green .p-top-compare__pill{ background:#43b06f; }
.p-top-compare__more--green{ color:#43b06f; }

.p-top-compare__card--red{ border-color:#f04d4d; }
.p-top-compare__card--red .p-top-compare__route::before{ background:#f04d4d; }
.p-top-compare__card--red .p-top-compare__value{ color:#f04d4d; }
.p-top-compare__card--red .p-top-compare__pill{ background:#f04d4d; }
.p-top-compare__more--red{ color:#f04d4d; }

.p-top-compare__card--orange{ --route-border: #f39b12; }
.p-top-compare__card--blue  { --route-border: #4b8fd6; }
.p-top-compare__card--green { --route-border: #43b06f; }
.p-top-compare__card--red   { --route-border: #f04d4d; }

@media (max-width: 767px){
  .p-top-compare{
    padding: 48px 0 0;
    background: #fff;
  }
}

@media (max-width: 767px){
  .p-top-compare__wrap{
    grid-template-columns: 1fr;
    padding: 0px 0;
  }

  .p-top-compare__divider{
    display: none;
  }

  .p-top-compare__group-head{
    width: 100%;
    justify-content: flex-start;
    margin: 0 0 70px;
  }

  .p-top-compare__cards--one,
  .p-top-compare__cards--three{
    grid-template-columns: 1fr;
    gap: 70px;
    justify-items: stretch;
  }

  .p-top-compare__card{
    max-width: 360px;
    width: 100%;
    margin-inline: auto;
  }

  .p-top-compare__more{
    justify-content: flex-start;
  }

  .p-top-compare__group--yamanashi{
    background: #fff4e6;
    padding: 32px 16px 64px;
  }

  .p-top-compare__group--shizuoka{
    background: #e9f3f8;
    padding: 32px 16px 64px;
  }

  .p-top-compare__group--yamanashi,
  .p-top-compare__group--shizuoka{
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    width: 100vw;
  }

  .p-top-compare__label{ margin:0; font-size:16px; font-weight:900; }
  .p-top-compare__value{ margin:0; font-size:24px; font-weight:900; }
  .p-top-compare__sub{ margin:0; font-size:14px; font-weight:800; opacity:.9; line-height:1.35; }

  .p-top-compare__route{
    position: relative;
    margin: -44px auto 0;
    width: 78%;
    text-align: center;
    color: #fff;
    font-size: 18px;
    font-weight: 900;
    padding: 8px 10px 0px;
    background: transparent;
    z-index: 3;
  }

  .p-top-compare__route::before{
    content:"";
    position:absolute;
    inset:0;
    z-index:-1;
    clip-path: polygon(10% 0%, 90% 0%, 100% 100%, 0% 100%);
    border-radius: 8px 8px 0 0;
    background: #006aa9;
  }
}

/* RESERVATION */
.p-top-reservation{
  --bg: url("../img/reservation-bg.jpg");
  position: relative;
  background: var(--bg) center/cover no-repeat;
  color: #fff;
  padding: 80px 0;
  overflow: hidden;
}

.p-top-reservation::before{
  content:"";
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.48);
  z-index:0;
}

.p-top-reservation__inner{
  position: relative;
  z-index: 1;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px;
}

.p-top-reservation__head{
  max-width: 600px;
}

.p-top-reservation__en{
  margin: 0 0 12px;
  font-weight: 800;
  margin-bottom: 30px;
}

.p-top-reservation__ja{
  margin: 0 0 10px;
  font-size: 18px;
  font-weight: 800;
}

.p-top-reservation__lead{
  margin: 0;
  font-size: 14px;
  line-height: 1.7;
  opacity: .95;
}

.p-top-reservation__cards{
  margin-top: 38px;
  display: flex;
  justify-content: center;
  gap: 22px;
}

.p-top-reservation__card{
  width: 400px;
  height:auto;
  border-radius: 18px;
  padding: 0;
  overflow: hidden;
  text-decoration: none;
  color: #fff;
  display: grid;
  grid-template-rows: auto 1fr;
  background: transparent;
  border: 5px solid rgba(255,255,255,.15);
  box-shadow: 0 18px 32px rgba(0,0,0,.28);
}

.p-top-reservation__pref{
  display: grid;
  place-items: center;
  width: 100%;
  padding: 18px 12px;
  font-weight: 900;
  font-size: 24px;
  line-height: 1;
  border-radius: 12px 12px 0 0;
}

.p-top-reservation__body{
  padding: 18px 16px 16px;
  background: rgba(0,0,0,.55);
  display: grid;
  gap: 20px;
  justify-items: center;
}

.p-top-reservation__routes{
  text-align: center;
  font-weight: 900;
  line-height: 1.15;
  font-size: 16px;
  margin-top: 6px;
}

.p-top-reservation__cta{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 16px;
  font-weight: 900;
  margin-top: 8px;
}

.p-top-reservation__cta-icon{
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 2px solid currentColor;
  position: relative;
}

.p-top-reservation__cta-icon::before{
  content:"";
  position:absolute;
  top:50%;
  left:5px;
  right:5px;
  height:2px;
  background: currentColor;
  transform: translateY(-50%);
}

.p-top-reservation__cta-icon::after{
  content:"";
  position:absolute;
  top:50%;
  right:5px;
  width:6px;
  height:6px;
  border-top:2px solid currentColor;
  border-right:2px solid currentColor;
  transform: translateY(-50%) rotate(45deg);
}

.p-top-reservation__card--yamanashi{
  border-color: #f39b12;
}
.p-top-reservation__card--yamanashi .p-top-reservation__pref{
  background: #f39b12;
}

.p-top-reservation__card--shizuoka{
  border-color: #2f5fb3;
}
.p-top-reservation__card--shizuoka .p-top-reservation__pref{
  background: #2f5fb3;
}

.p-top-reservation__card:hover{
  transform: translateY(-1px);
  filter: brightness(1.02);
}

@media (max-width: 767px){
  .p-top-reservation{
    padding: 48px 0;
  }

  .p-top-reservation__head{
    max-width: none;
  }

  .p-top-reservation__cards{
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
  }

  .p-top-reservation__card{
    width: 100%;
  }
}

/* VIDEO */
.p-top-video{
  --video-bg: #e8f3f7;
  --video-accent: #006aa9;
  background: var(--video-bg);
  padding: 80px 0 70px;
}

.p-top-video__inner{
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px;
}

.p-top-video__head{
  margin-bottom: 48px;
}

.p-top-video__en{
  margin: 0 0 18px;
  font-size: 22px;
  font-weight: 900;
  margin-bottom:30px;
  color: var(--video-accent);
}

.p-top-video__ja{
  margin: 0;
  font-size: 18px;
  font-weight: 900;
  color: #111;
}

.p-top-video__grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 44px;
  align-items: start;
}

.p-top-video__card{
  background: #fff;
  border: 5px solid var(--video-accent);
  border-radius: 10px;
  overflow: hidden;
}

.p-top-video__link{
  display: grid;
  gap: 18px;
  padding: 18px 18px 14px;
  color: inherit;
  text-decoration: none;
}

.p-top-video__desc{
  margin: 0;
  font-size: 13px;
  line-height: 1.75;
  font-weight: 900;
  color: var(--video-accent);
}

.p-top-video__thumb{
  margin: 0;
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #ddd;
}

.p-top-video__thumb img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.p-top-video__thumb::before{
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(0,0,0,.35);
  z-index: 1;
}

.p-top-video__thumb::after{
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-35%, -50%);
  width: 0;
  height: 0;
  border-left: 16px solid rgba(255,255,255,.85);
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  z-index: 2;
}

.p-top-video__meta{
  display: grid;
  gap: 6px;
}

.p-top-video__date{
  font-size: 12px;
  font-weight: 900;
  color: var(--video-accent);
}

.p-top-video__title{
  margin: 0;
  font-size: 13px;
  font-weight: 900;
  color: var(--video-accent);
}

.p-top-video__more{
  margin-top: 46px;
  display: flex;
  justify-content: center;
}

.p-top-video__more-link{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-weight: 900;
  font-size: 14px;
  color: var(--video-accent);
  text-decoration: none;
}

.p-top-video__more-icon{
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 2px solid currentColor;
  position: relative;
}

.p-top-video__more-icon::before{
  content:"";
  position:absolute;
  top:50%;
  left: 5px;
  right:5px;
  height:2px;
  background: currentColor;
  transform: translateY(-50%);
}

.p-top-video__more-icon::after{
  content:"";
  position:absolute;
  top:50%;
  right:5px;
  width:6px;
  height:6px;
  border-top:2px solid currentColor;
  border-right:2px solid currentColor;
  transform: translateY(-50%) rotate(45deg);
}

.p-top-video__link:hover .p-top-video__thumb::before{
  background: rgba(0,0,0,.45);
}

@media (max-width: 767px){
  .p-top-video{
    padding: 56px 0 54px;
  }

  .p-top-video__head{
    margin-bottom: 26px;
  }

  .p-top-video__en{
    font-size: 22px;
    margin-bottom: 30px;
  }

  .p-top-video__ja{
    font-size: 18px;
  }

  .p-top-video__grid{
    grid-template-columns: 1fr;
    gap: 18px;
  }
}
/* ===============================
   TOP VIDEO - LIVE CAMERA
================================*/
.p-top-video__live {
  margin-top: 56px;
}

.p-top-video__live-head {
  margin-bottom: 22px;
}

.p-top-video__live-title {
  margin: 0 0 18px 0;
  font-size: 22px;
  font-weight: 900;
  color: var(--video-accent);
}

.p-top-video__live-sub {
  margin: 8px 0 40px;
  font-size: 18px;
  line-height: 1.6;
  color: #333;
  font-weight: 700;
}

.p-top-video__live-list {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 16px;
  align-items: start;
}

.p-top-video__live-item {
  display: block;
  text-decoration: none;
  color: inherit;
}

.p-top-video__live-item img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 10px;
  border: 3px solid #fff;
  background: #d9d9d9;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.p-top-video__live-item span {
  display: block;
  margin-top: 8px;
  font-size: 12px;
  line-height: 1.5;
  font-weight: 700;
  color: var(--video-accent);
  text-align: center;
}

.p-top-video__live-item:hover img {
  transform: translateY(-2px);
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.12);
}

@media (max-width: 767px) {
  .p-top-video__live {
    margin-top: 36px;
  }

  .p-top-video__live-title {
    font-size: 20px;
  }

  .p-top-video__live-list {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    padding-bottom: 6px;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x proximity;
  }

  .p-top-video__live-item {
    flex: 0 0 68%;
    scroll-snap-align: start;
  }

  .p-top-video__live-item span {
    font-size: 11px;
  }
}


/* BANNERS */
.p-top-banners{
  padding: 70px 0;
  overflow: hidden;
}

.p-top-banners__inner{
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px;
}

.p-top-banners__wrap{
  position: relative;
  padding: 0 56px;
  overflow: hidden;
}

.p-top-banners__swiper{
  position: relative;
  overflow: hidden;
}

.p-top-banners__swiper.is-hidden{
  display: none !important;
}

.p-top-banners__slide{
  display: block;
  border-radius: 16px;
  overflow: hidden;
  background: #ddd;
}

.p-top-banners__slide img{
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 320 / 86;
  object-fit: cover;
}

.p-top-banners__pagination{
  margin-top: 18px;
  display: flex;
  justify-content: center;
  gap: 10px;
}

.p-top-banners__pagination .swiper-pagination-bullet{
  width: 8px;
  height: 8px;
  opacity: .35;
  margin: 0 !important;
}

.p-top-banners__pagination .swiper-pagination-bullet-active{
  opacity: 1;
}

.p-top-banners__nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 2px solid #006aa9;
  padding: 0;
  cursor: pointer;
  background: rgba(255,255,255,.95);
  box-shadow: 0 6px 16px rgba(0,0,0,.12);
  z-index: 5;
  display: grid;
  place-items: center;
  color: #006aa9;
}

.p-top-banners__nav--prev{ left: 0; }
.p-top-banners__nav--next{ right: 0; }

.p-top-banners__nav::before{
  content:"";
  width: 10px;
  height: 10px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: rotate(45deg);
}

.p-top-banners__nav--prev::before{
  transform: rotate(-135deg);
}

@media (max-width: 767px){
  .p-top-banners{
    padding: 48px 0;
  }

  .p-top-banners__wrap{
    padding: 0;
    overflow: visible;
  }

  .p-top-banners__nav{
    display: none;
  }
}