:root {
  --program-green: #075d47;
  --program-deep: #063f32;
  --program-mint: #e9f4ef;
  --program-orange: #ff6a1a;
  --program-ink: #18201d;
  --program-muted: #68736e;
  --program-line: #dfe5e2;
  --program-surface: #f6f8f7;
}

html { scroll-behavior: smooth; }
.program-page { background: #fff; color: var(--program-ink); font-family: Pretendard, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; }
.program-page main { overflow: hidden; }
.program-page .guide-container { width: min(1180px, calc(100% - 40px)); margin: 0 auto; }

/* Header + compact sub hero — facilities page rhythm */
.program-header { position: absolute !important; z-index: 20; width: 100%; background: transparent !important; border: 0 !important; }
.program-header .nav-common { height: 78px !important; }
.program-header .header-container-common { padding: 0 28px !important; }
.program-header .nav-links-common { gap: 42px !important; }
.program-header .nav-links-common a { color: #fff !important; font-size: 14px !important; text-shadow: 0 1px 7px rgba(0,0,0,.35); }
.program-header .btn-nav-reserve-common { padding: 0 !important; border: 0 !important; background: transparent !important; }
.program-header .mobile-menu-btn { display: flex !important; width: 46px !important; height: 46px !important; background: var(--program-green) !important; }

.program-hero {
  position: relative;
  display: flex;
  min-height: 500px;
  align-items: flex-end;
  padding-bottom: 65px;
  color: #fff;
  background:
    linear-gradient(90deg, rgba(0,0,0,.82), rgba(0,0,0,.47) 48%, rgba(0,0,0,.12)),
    url('../img/BOULDERING.jpeg') center 48% / cover no-repeat;
}
.program-hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(0deg, rgba(0,0,0,.16), transparent 52%); }
.program-hero-copy { position: relative; z-index: 1; }
.guide-breadcrumb { display: flex; gap: 10px; align-items: center; margin: 0 0 20px; font-size: 13px; }
.guide-breadcrumb a { color: #fff; }
.guide-breadcrumb span { opacity: .55; }
.program-eyebrow { margin: 0 0 9px !important; color: #85d9ba !important; font-size: 12px !important; font-weight: 850; letter-spacing: .14em; }
.program-hero h1 { margin: 0; font-size: 50px; font-weight: 850; line-height: 1.05; letter-spacing: -.05em; }
.program-hero h1 + p { margin: 15px 0 0; color: rgba(255,255,255,.85); font-size: 17px; line-height: 1.7; }

.program-local-nav { position: relative; z-index: 5; margin-top: -22px; }
.program-local-nav .guide-container { display: flex; height: 68px; padding: 0; }
.program-local-nav a { display: flex; flex: 1; align-items: center; justify-content: center; border: 1px solid var(--program-line); border-right: 0; background: #fff; color: #5f6964; font-size: 16px; font-weight: 750; transition: .2s ease; }
.program-local-nav a:first-child { border-radius: 11px 0 0 11px; }
.program-local-nav a:last-child { border-right: 1px solid var(--program-line); border-radius: 0 11px 11px 0; }
.program-local-nav a.active, .program-local-nav a:hover { border-color: var(--program-green); background: var(--program-green); color: #fff; }

/* Intro */
.program-intro { padding: 86px 0 76px; }
.program-intro-grid { display: grid; grid-template-columns: .78fr 1.42fr; gap: 58px; align-items: center; }
.program-intro-copy > span, .program-section-head span, .booking-title > span { color: #078662; font-size: 12px; font-weight: 850; letter-spacing: .14em; }
.program-intro-copy h2 { margin: 16px 0 20px; font-size: 36px; line-height: 1.24; letter-spacing: -.04em; }
.program-intro-copy h2::after { content: ""; display: block; width: 30px; height: 2px; margin-top: 20px; background: var(--program-green); }
.program-intro-copy p { margin: 0; color: var(--program-muted); font-size: 15px; line-height: 1.85; }
.program-strengths { display: grid; grid-template-columns: repeat(4, 1fr); min-height: 205px; padding: 25px 10px; border: 1px solid var(--program-line); border-radius: 12px; background: #fff; box-shadow: 0 12px 28px rgba(17,50,39,.045); }
.program-strengths article { padding: 4px 20px; border-right: 1px solid #e8ecea; }
.program-strengths article:last-child { border-right: 0; }
.program-strengths b { display: grid; width: 43px; height: 43px; place-items: center; border-radius: 50%; background: var(--program-mint); color: var(--program-green); font-size: 13px; }
.program-strengths h3 { margin: 22px 0 10px; font-size: 16px; letter-spacing: -.025em; }
.program-strengths p { margin: 0; color: var(--program-muted); font-size: 13px; line-height: 1.65; }

/* Monthly class — level-grouped course catalog */
.programs-section { padding: 42px 0 94px; background: var(--program-surface); }
.program-section-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 34px; padding-top: 28px; border-top: 1px solid var(--program-line); }
.program-section-head h2 { margin: 9px 0 0; font-size: 31px; letter-spacing: -.045em; }
.program-section-head > p { max-width: 500px; margin: 0; color: var(--program-muted); font-size: 14px; line-height: 1.7; }
.monthly-notice { display: flex; gap: 20px; align-items: center; margin: 28px 0 32px; padding: 16px 21px; border: 1px solid #cfe2d9; border-radius: 10px; background: #edf7f2; color: #486057; font-size: 13px; }
.monthly-notice b { flex: 0 0 auto; color: var(--program-deep); font-size: 14px; }
.monthly-notice p { margin: 0; line-height: 1.6; }

.monthly-level-groups { display: grid; gap: 36px; }
.monthly-level-group { overflow: hidden; border: 1px solid var(--program-line); border-radius: 16px; background: #fff; box-shadow: 0 10px 28px rgba(17,50,39,.04); }
.monthly-level-head { display: grid; grid-template-columns: auto 1fr auto; gap: 18px; align-items: center; padding: 22px 26px; border-bottom: 1px solid var(--program-line); }
.level-beginner .monthly-level-head { background: linear-gradient(90deg, #edf7f2, #fff 58%); }
.level-levelup .monthly-level-head { background: linear-gradient(90deg, #eef3f8, #fff 58%); }
.level-advanced .monthly-level-head { background: linear-gradient(90deg, #f7f0ea, #fff 58%); }
.monthly-level-badge { display: grid; min-width: 72px; height: 72px; place-items: center; border-radius: 14px; background: var(--program-green); color: #fff; font-size: 11px; font-weight: 900; letter-spacing: .08em; line-height: 1.35; text-align: center; }
.level-levelup .monthly-level-badge { background: #2d668e; }
.level-advanced .monthly-level-badge { background: #8a4b1e; }
.monthly-level-head h3 { margin: 0 0 6px; font-size: 22px; letter-spacing: -.03em; }
.monthly-level-head p { margin: 0; color: var(--program-muted); font-size: 13px; line-height: 1.6; }
.monthly-level-count { padding: 7px 12px; border-radius: 999px; background: rgba(255,255,255,.82); color: #5f6964; font-size: 12px; font-weight: 750; white-space: nowrap; }

.monthly-course-list { display: grid; }
.program-card { display: grid; grid-template-columns: 64px minmax(0, 1fr) 190px; gap: 0 22px; align-items: center; min-height: 0; padding: 22px 26px; border-top: 1px solid #edf1ef; background: #fff; transition: background .2s ease; }
.monthly-course-list .program-card:first-child { border-top: 0; }
.program-card:hover { background: #fbfdfc; }
.program-card.featured { background: linear-gradient(90deg, #f3faf6, #fff); }
.card-index { display: grid; width: 52px; height: 52px; place-items: center; border-radius: 12px; background: var(--program-mint); color: var(--program-green); font-size: 15px; font-weight: 900; }
.level-levelup .card-index { background: #ebf1f7; color: #2d668e; }
.level-advanced .card-index { background: #fff0e5; color: #b75217; }
.card-body { min-width: 0; }
.card-top { display: flex; flex-wrap: wrap; gap: 8px 12px; align-items: center; margin-bottom: 8px; }
.level { padding: 5px 10px; border-radius: 999px; font-size: 11px; font-weight: 800; }
.level.beginner { background: #e9f5ef; color: #087653; }
.level.levelup { background: #ebf1f7; color: #2d668e; }
.level.advanced { background: #fff0e5; color: #b75217; }
.level.athlete { background: #f2ebf7; color: #734596; }
.program-card .target { margin: 0; color: var(--program-muted); font-size: 12px; }
.program-card h3 { margin: 0 0 12px; font-size: 19px; letter-spacing: -.03em; }
.card-meta { display: flex; flex-wrap: wrap; gap: 8px 18px; margin: 0; padding: 0; list-style: none; }
.card-meta li { display: inline-flex; gap: 8px; align-items: center; color: #35423d; font-size: 13px; font-weight: 650; }
.card-meta li span { color: #89948f; font-size: 11px; font-weight: 750; letter-spacing: .04em; }
.card-side { display: flex; flex-direction: column; align-items: flex-end; gap: 12px; text-align: right; }
.card-price { display: flex; flex-direction: column; gap: 3px; }
.card-price span { color: var(--program-deep); font-size: 13px; font-weight: 800; line-height: 1.45; }
.card-side > a, .free-grid article > a { display: inline-flex; min-width: 108px; align-items: center; justify-content: center; padding: 10px 16px; border: 0; border-radius: 10px; background: var(--program-green); color: #fff; font-size: 12px; font-weight: 850; transition: .2s ease; }
.card-side > a:hover, .free-grid article > a:hover { background: var(--program-deep); color: #fff; }
.program-card.featured .card-side > a { background: var(--program-orange); }
.program-card.featured .card-side > a:hover { background: #e55a0f; }

/* Experience mosaic — about page visual language */
.experience-section { padding: 86px 0 94px; background: #fff; color: var(--program-ink); }
.experience-section .program-section-head { margin-bottom: 28px; }
.program-section-head.light span { color: #078662; }
.program-section-head.light > p { color: var(--program-muted); }
.feature-program-grid { display: grid; grid-template-columns: 1.18fr .82fr; gap: 10px; }
.feature-program { position: relative; min-height: 430px; overflow: hidden; border-radius: 14px; background: #111; }
.feature-program img { position: absolute; width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.feature-program::after { content: ""; position: absolute; inset: 0; background: linear-gradient(0deg, rgba(2,18,13,.9), rgba(2,18,13,.05) 72%); }
.feature-program:hover img { transform: scale(1.035); }
.feature-overlay { position: absolute; z-index: 2; right: 0; bottom: 0; left: 0; padding: 30px; }
.feature-overlay > span { display: inline-block; padding: 6px 10px; border: 1px solid rgba(255,255,255,.45); border-radius: 999px; color: #fff; font-size: 11px; font-weight: 750; }
.feature-overlay h3 { margin: 14px 0 8px; color: #fff; font-size: 25px; letter-spacing: -.04em; }
.feature-overlay p { max-width: 500px; margin: 0; color: rgba(255,255,255,.77); font-size: 13px; line-height: 1.65; }
.feature-overlay ul { display: flex; flex-wrap: wrap; gap: 7px 16px; margin: 15px 0 20px; padding: 0; list-style: none; color: #fff; font-size: 12px; }
.feature-overlay li::before { content: "✓"; margin-right: 6px; color: #7ed9b6; }
.feature-overlay a { display: inline-flex; padding: 10px 16px; border-radius: 999px; background: #fff; color: var(--program-deep); font-size: 12px; font-weight: 850; }

/* Free use */
.free-section { padding: 78px 0 88px; background: var(--program-surface); }
.free-section .program-section-head { margin-bottom: 25px; }
.free-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.free-grid article { display: grid; grid-template-columns: 62px 1fr auto; gap: 20px; align-items: center; min-height: 230px; padding: 28px; border: 1px solid var(--program-line); border-radius: 12px; background: #fff; }
.free-number { display: grid; width: 58px; height: 58px; place-items: center; border-radius: 50%; background: var(--program-mint); color: var(--program-green); font-size: 13px; font-weight: 900; }
.free-grid article > div:nth-child(2) > span { color: #07845f; font-size: 11px; font-weight: 850; letter-spacing: .12em; }
.free-grid h3 { margin: 7px 0 9px; font-size: 21px; }
.free-grid p { margin: 0; color: var(--program-muted); font-size: 13px; line-height: 1.65; }
.free-grid dl { display: flex; flex-wrap: wrap; gap: 8px 17px; margin: 17px 0 0; }
.free-grid dl div { display: flex; gap: 6px; font-size: 12px; }
.free-grid dt { color: #89948f; }
.free-grid dd { margin: 0; color: #35423d; font-weight: 700; }

/* Booking notes + CTA */
.booking-guide { padding: 82px 0 72px; background: #fff; }
.booking-title { text-align: center; }
.booking-title h2 { margin: 9px 0 12px; font-size: 31px; letter-spacing: -.045em; }
.booking-title p { margin: 0; color: var(--program-muted); font-size: 14px; }
.booking-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 13px; margin-top: 30px; }
.booking-cards article { display: flex; gap: 16px; min-height: 134px; padding: 24px; border: 1px solid var(--program-line); border-radius: 12px; background: #fff; }
.booking-cards i { display: grid; width: 44px; height: 44px; flex: 0 0 44px; place-items: center; border-radius: 50%; background: var(--program-mint); color: var(--program-green); font-size: 17px; font-style: normal; font-weight: 900; }
.booking-cards h3 { margin: 2px 0 8px; font-size: 16px; }
.booking-cards p { margin: 0; color: var(--program-muted); font-size: 13px; line-height: 1.65; }
.program-cta { padding: 0 0 24px; background: #fff; }
.program-cta .guide-container { display: grid; grid-template-columns: 56px 1fr auto; min-height: 94px; align-items: center; gap: 18px; padding: 17px 28px; border-radius: 10px; background: linear-gradient(100deg, #075d47, #064536); color: #fff; }
.program-cta-icon { display: grid; width: 48px; height: 48px; place-items: center; border: 1px solid rgba(255,255,255,.65); border-radius: 12px; font-size: 20px; }
.program-cta h2 { margin: 0 0 6px; font-size: 20px; }
.program-cta p { margin: 0; color: rgba(255,255,255,.72); font-size: 12px; }
.program-cta a { padding: 12px 22px; border-radius: 999px; background: var(--program-orange); color: #fff; font-size: 12px; font-weight: 850; }
.program-page .footer-main { background: linear-gradient(90deg, #075d47, #064536) !important; }

@media (max-width: 1100px) {
  .program-header .nav-links-common { gap: 22px !important; }
  .program-intro-grid { grid-template-columns: 1fr; }
  .program-strengths { max-width: none; }
  .free-grid { grid-template-columns: 1fr; }
  .program-card { grid-template-columns: 52px minmax(0, 1fr) 170px; gap: 0 16px; padding: 20px 22px; }
}

@media (max-width: 768px) {
  .program-header .nav-links-common, .program-header .btn-nav-reserve-common, .program-header #auth-links { display: none !important; }
  .program-header .nav-right-actions-common { display: flex !important; margin-left: auto; }
  .program-header .logo-common { flex-shrink: 0; }
  .program-header .logo-main-text { font-size: 16px; white-space: nowrap; }
  .program-header .logo-sub-text { font-size: 8px; white-space: nowrap; }
  .program-hero { min-height: 420px; padding-bottom: 70px; }
  .program-hero h1 { font-size: 42px; }
  .program-local-nav { overflow-x: auto; scrollbar-width: none; }
  .program-local-nav::-webkit-scrollbar { display: none; }
  .program-local-nav .guide-container { width: max-content; padding: 0 14px !important; }
  .program-local-nav a { min-width: 135px; }
  .program-intro { padding: 64px 0; }
  .program-strengths { grid-template-columns: repeat(2, 1fr); }
  .program-strengths article:nth-child(2) { border-right: 0; }
  .program-strengths article:nth-child(-n+2) { border-bottom: 1px solid #e8ecea; }
  .program-section-head { align-items: flex-start; flex-direction: column; gap: 10px; }
  .monthly-notice { align-items: flex-start; flex-direction: column; gap: 7px; }
  .monthly-level-head { grid-template-columns: auto 1fr; }
  .monthly-level-count { grid-column: 1 / -1; justify-self: start; }
  .program-card { grid-template-columns: 48px 1fr; gap: 14px 16px; align-items: start; padding: 20px 18px; }
  .card-side { grid-column: 1 / -1; flex-direction: row; align-items: center; justify-content: space-between; width: 100%; text-align: left; }
  .card-price { align-items: flex-start; }
  .feature-program-grid, .booking-cards { grid-template-columns: 1fr; }
  .feature-program { min-height: 420px; }
  .program-cta .guide-container { grid-template-columns: 48px 1fr; }
  .program-cta a { grid-column: 1 / -1; text-align: center; }
}

@media (max-width: 560px) {
  .program-page .guide-container { width: min(100% - 28px, 1180px); }
  .program-hero h1 { font-size: 39px; }
  .program-hero h1 + p { font-size: 16px; }
  .program-intro-copy h2, .program-section-head h2, .booking-title h2 { font-size: 29px; }
  .program-strengths { grid-template-columns: 1fr; padding: 0 20px; }
  .program-strengths article { display: grid; grid-template-columns: 48px 105px 1fr; min-height: 88px; align-items: center; padding: 14px 0; border-right: 0; border-bottom: 1px solid #e8ecea !important; }
  .program-strengths article:last-child { border-bottom: 0 !important; }
  .program-strengths h3, .program-strengths p { margin: 0; }
  .monthly-level-head { padding: 18px; gap: 14px; }
  .monthly-level-badge { min-width: 60px; height: 60px; font-size: 10px; }
  .monthly-level-head h3 { font-size: 19px; }
  .program-card h3 { font-size: 17px; }
  .card-side { flex-direction: column; align-items: stretch; gap: 10px; }
  .card-side > a { width: 100%; }
  .feature-program-grid { display: block; }
  .feature-program { min-height: 470px; margin-top: 10px; }
  .feature-overlay { padding: 25px 22px; }
  .free-grid article { grid-template-columns: 54px 1fr; padding: 23px 20px; }
  .free-grid article > a { grid-column: 1 / -1; width: 100%; }
  .program-cta .guide-container { display: block; padding: 25px 22px; }
  .program-cta-icon { margin-bottom: 16px; }
  .program-cta a { display: block; margin-top: 20px; }
}
