.guide-hero{
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(0,0,0,.42) 0%, rgba(0,0,0,.36) 100%),
    radial-gradient(circle at 20% 20%, rgba(182,144,59,.18), transparent 26%),
    radial-gradient(circle at 80% 60%, rgba(182,144,59,.10), transparent 24%),
    url("../img/online-guide-hero-bg.jpg") center center / cover no-repeat;
}

.guide-hero-inner{
  max-width: 1240px;
  margin: 0 auto;
  padding: 110px 28px 92px;
  color: #fff;
}

.guide-hero .section-en{
  color: #d7c08a;
  margin-bottom: 12px;
}

.guide-hero h1{
  margin: 0 0 20px;
  font-family: "Noto Serif JP", serif;
  font-size: 50px;
  line-height: 1.38;
  font-weight: 500;
}

.guide-hero-lead{
  max-width: 760px;
  font-size: 15px;
  line-height: 2.05;
  color: rgba(255,255,255,.9);
}

.guide-page{
  max-width: 1240px;
  margin: 0 auto;
  padding: 48px 28px 96px;
}

.breadcrumbs{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 12px;
  color: #7d7d7d;
  margin-bottom: 36px;
}

.breadcrumbs span::after{
  content: "/";
  margin-left: 8px;
}

.breadcrumbs strong{
  font-weight: 500;
  color: #333;
}

.guide-intro{
  display: grid;
  grid-template-columns: minmax(0,1.05fr) minmax(320px,.95fr);
  gap: 42px;
  align-items: center;
  margin-bottom: 72px;
}

.guide-copy h2,
.notes-box h2,
.guide-cta h2{
  margin: 0 0 22px;
  font-family: "Noto Serif JP", serif;
  font-size: 38px;
  line-height: 1.5;
  font-weight: 500;
}

.guide-copy .section-en,
.guide-cta .section-en{
  margin-bottom: 4px;
  color: var(--gold);
}

.guide-cta-inner .section-en{
  margin: 0 auto 4px !important;
}

.guide-cta h2{
  margin: 0 0 14px;
}

.guide-copy p,
.notes-box li,
.guide-cta p,
.flow-card p{
  font-size: 15px;
  line-height: 2.05;
  color: #333;
}

.guide-copy p{
  margin: 0 0 16px;
}

.guide-visual{
  width: 100%;
}

.guide-visual img{
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
  border: 1px solid #d9d2c4;
  background: #f1ebde;
}

.guide-placeholder{
  aspect-ratio: 4 / 3;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #d9d2c4;
  background: linear-gradient(135deg, #faf8f2 0%, #f1ebde 100%);
  color: #8b7a4a;
  font-size: 13px;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.section-head.center{
  justify-content: center;
  text-align: center;
}

.section-head.center h2{
  width: 100%;
}

.flow-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 26px;
}

.flow-card{
  padding: 28px 24px;
  border: 1px solid var(--line);
  background: #fff;
  min-height: 220px;
  display: flex;
  flex-direction: column;
}

.flow-card small{
  display: block;
  margin-bottom: 14px;
  color: var(--gold);
  font-size: 11px;
  letter-spacing: .16em;
}

.flow-step-badge{
  display: inline-block;
  align-self: flex-start;
  margin-bottom: 14px;
  padding: 5px 10px;
  background: var(--gold);
  color: #fff;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .10em;
  line-height: 1.2;
}

.flow-card h3{
  margin: 0 0 12px;
  font-family: "Noto Serif JP", serif;
  font-size: 24px;
  line-height: 1.5;
  font-weight: 500;
}

.flow-card p{
  font-size: 15px;
  line-height: 2.05;
  color: #333;
  margin: 0;
}

.flow-link{
  margin-top: auto !important;
  padding-top: 18px;
}

.flow-link a{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 14px;
  border: 1px solid var(--gold);
  color: #000;
  font-size: 13px;
  letter-spacing: .06em;
  line-height: 1.2;
  transition: .3s ease;
}

.flow-link a:hover{
  background: var(--gold);
  color: #fff;
}

.flow-link a:hover span{
  color: #fff;
}

.compact-notes li:last-child{
  margin-bottom: 0;
}

/* CONTACT右ボタン */
.secondary-button{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 280px;
  height: 52px;
  padding: 0 26px;
  background: transparent;
  color: #111;
  border: 1px solid var(--line);
  font-size: 13px;
  letter-spacing: .08em;
}

.secondary-button:hover{
  background: #f7f4eb;
}

.guide-notes{
  margin-top: 20px;
}

.notes-box.compact-notes{
  padding: 10px 14px !important;
  background: #faf8f2;
  border: 1px solid var(--line);
}

.notice-label{
  margin: 0 0 4px 6px;
  color: var(--gold);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .12em;
  line-height: 1.2;
}

.notes-box.compact-notes .notice-title{
  margin: 0 0 4px 6px !important;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 12px !important;
  line-height: 1.35 !important;
  font-weight: 700;
  color: #666;
}

.notice-list{
  margin: 0 0 4px 6px;
  padding: 0;
  list-style: none;
}

.notice-list li{
  position: relative;
  padding-left: 1em;
  margin-bottom: 1px;
  font-size: 11px;
  line-height: 1.45;
  color: #666;
}

.notice-list li::before{
  content: "※";
  position: absolute;
  left: 0;
  top: 0;
  color: #666;
}

.notice-list li:last-child{
  margin-bottom: 0;
}

.guide-cta{
  margin-top: 72px;
}

.guide-cta-inner{
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 40px 0;
  text-align: center;
}

.guide-cta-inner p{
  max-width: 760px;
  margin: 0 auto 20px;
}

.guide-cta-actions{
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 18px;
  margin-top: 26px;
}

.primary-button{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 280px;
  height: 52px;
  padding: 0 26px;
  background: #06c755;
  border: 1px solid #06c755;
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .08em;
}

.primary-button:hover{
  background: #05b34c;
  border-color: #05b34c;
}

.secondary-link{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  letter-spacing: .08em;
}

.secondary-link span{
  color: var(--gold);
}

@media (max-width: 980px){
  .guide-intro,
  .flow-grid{
    grid-template-columns: 1fr;
  }

  .guide-hero h1,
  .guide-copy h2,
  .notes-box h2,
  .guide-cta h2{
    font-size: 34px;
  }
}

@media (max-width: 640px){
  .guide-hero-inner,
  .guide-page{
    padding-left: 16px;
    padding-right: 16px;
  }

  .guide-hero-inner{
    padding-top: 86px;
    padding-bottom: 72px;
  }

  .guide-hero h1,
  .guide-copy h2,
  .notes-box h2,
  .guide-cta h2{
    font-size: 28px;
    line-height: 1.45;
  }

  .guide-hero-lead,
  .guide-copy p,
  .notes-box li,
  .guide-cta p,
  .flow-card p{
    font-size: 14px;
    line-height: 2;
  }

  .notes-box,
  .flow-card{
    padding: 22px 18px;
  }

  .primary-button{
    width: 100%;
    min-width: 0;
  }
	
  .flow-card{
    padding: 22px 18px;
  }

  .notice-badge-small{
    font-size: 8px;
  }

  .guide-notes{
    margin-top: 16px;
  }

  .notes-box.compact-notes{
    padding: 8px 10px !important;
  }

  .notice-label{
    font-size: 10px;
  }

  .notes-box.compact-notes .notice-title{
    font-size: 11px !important;
  }

  .notice-list li{
    font-size: 10px;
    line-height: 1.4;
  }
}
