/* ============================================================
   Component · Page Hero
   리스트/카탈로그 페이지 상단의 통일된 헤더 블록.
   /store, /exam, /course, /tip, /training 등에서 공유한다.

   Layout:
     <section class="page-hero">
       <div class="gio-container">
         <div class="page-hero__layout">
           <div>
             <span class="page-hero__eyebrow">...</span>
             <h1 class="page-hero__title">...</h1>
             <p class="page-hero__sub">...</p>
           </div>
           <div class="page-hero__aside">{{-- 옵션: pitch 리스트, 카운트 --}}</div>
         </div>
       </div>
     </section>
   ============================================================ */

.gio-site .page-hero {
  padding: 64px 0 40px;
  border-bottom: 1px solid var(--gio-color-divider);
  position: relative;
  /* sticky 헤더 영역까지 그라디언트가 자연스럽게 이어지도록 위쪽만 클리핑 해제. */
  clip-path: inset(-200px 0 0 0);
}

.gio-site .page-hero::before {
  content: '';
  position: absolute;
  top: -200px;
  right: -100px;
  width: 600px;
  height: 600px;
  background: radial-gradient(closest-side,
    color-mix(in oklab, var(--gio-color-action) 14%, transparent),
    transparent);
  pointer-events: none;
  opacity: 0.55;
}

.gio-site .page-hero__layout {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--gio-space-7);
  /* eyebrow → title 순서로 위에서부터 정렬. 페이지마다 sub 줄 수가 달라도
     title의 top 좌표가 변하지 않도록 align-items: start 고정.
     그리고 min-height 로 hero 전체 높이를 페이지 간 통일. */
  align-items: start;
  min-height: 168px;
}
.gio-site .page-hero__layout--single {
  grid-template-columns: 1fr;
}
@media (max-width: 920px) {
  .gio-site .page-hero__layout {
    grid-template-columns: 1fr;
    min-height: 0;
  }
}

.gio-site .page-hero__eyebrow {
  display: inline-block;
  font-size: var(--gio-text-xs);
  font-weight: var(--gio-w-bold);
  letter-spacing: var(--gio-tracking-wide);
  text-transform: uppercase;
  color: var(--gio-color-action);
  margin-bottom: var(--gio-space-3);
}

.gio-site .page-hero__title {
  font-family: var(--gio-font-display);
  font-size: clamp(32px, 4vw, 48px);
  font-weight: var(--gio-w-extrabold);
  letter-spacing: -0.025em;
  color: var(--gio-color-text-strong);
  margin: 0 0 var(--gio-space-3);
  text-wrap: balance;
}

.gio-site .page-hero__sub {
  font-size: var(--gio-text-base);
  color: var(--gio-color-text-muted);
  margin: 0;
  max-width: 56ch;
  line-height: 1.55;
}

/* ── Aside variants ── */
.gio-site .page-hero__pitch {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--gio-space-2);
  font-size: var(--gio-text-sm);
  color: var(--gio-color-text);
}
.gio-site .page-hero__pitch li {
  display: flex;
  align-items: center;
  gap: var(--gio-space-2);
}
.gio-site .page-hero__pitch li::before {
  content: '✓';
  width: 20px;
  height: 20px;
  display: grid;
  place-items: center;
  background: var(--gio-color-success-soft);
  color: var(--gio-color-success);
  border-radius: 50%;
  font-size: 11px;
  font-weight: var(--gio-w-bold);
}

.gio-site .page-hero__meta {
  font-size: var(--gio-text-sm);
  color: var(--gio-color-text-muted);
  text-align: right;
  align-self: end;
}
@media (max-width: 920px) {
  .gio-site .page-hero__meta { text-align: left; }
}

/* page-hero 바로 다음에 오는 .section.gio-container 는 위쪽 패딩을 줄여
   hero와 본문 섹션 간격이 자연스럽게 보이도록 한다.
   page-hero가 padding-bottom 40px + border 를 이미 가지고 있어 추가 간격은 작게. */
.gio-site .page-hero + .section.gio-container,
.gio-site .page-hero + section.gio-container {
  padding-top: var(--gio-space-5);
}
@media (max-width: 720px) {
  .gio-site .page-hero + .section.gio-container,
  .gio-site .page-hero + section.gio-container {
    padding-top: var(--gio-space-4);
  }
}
