.site-header { position: sticky; top: 0; z-index: 50; background: var(--theme-primary, #121b2d); box-shadow: 0 12px 28px rgba(var(--theme-primary-rgb, 18,27,45), .18); }
.site-header,
.site-header * { font-family: inherit; }
.nav-wrap { min-height: 76px; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.brand { display: inline-flex; align-items: center; gap: 10px; min-width: 0; color: #fff; font-weight: 800; letter-spacing: .03em; font-size: 1.7rem; }
.brand img { width: 42px; height: 42px; flex: 0 0 auto; object-fit: contain; border-radius: 8px; background: #fff; }
.brand span { min-width: 0; }
.nav-toggle { display: none; min-width: 44px; height: 44px; border: 0; border-radius: 12px; background: rgba(255,255,255,.08); color: #fff; font-size: 1.25rem; cursor: pointer; }
.nav { display: flex; align-items: center; gap: 28px; flex-wrap: wrap; color: rgba(255,255,255,.92); font-weight: 600; }
.nav a { white-space: nowrap; }
.nav a:hover { color: #fff; text-shadow: 0 0 18px rgba(var(--theme-secondary-rgb, 109,136,215), .38); }
.hero-section { padding-top: 0; }
.hero-media { min-height: 760px; width: 100%; background-size: cover; background-position: center; }
.hero-grid { min-height: 760px; display: grid; grid-template-columns: minmax(0, 1fr) 260px; gap: 32px; align-items: start; padding: 18px 0 32px; }
.hero-grid.solo { grid-template-columns: minmax(0, 1fr); }
.hero-copy { padding-top: 232px; max-width: 720px; color: #fff; }
.hero-copy h1 { margin: 16px 0; font-size: clamp(2.7rem, 5vw, 4.6rem); line-height: 1.02; letter-spacing: -0.04em; max-width: 12ch; }
.hero-copy p { margin: 0; font-size: 1.25rem; line-height: 1.7; max-width: 34ch; color: rgba(255,255,255,.88); }
.banner-rail-section { padding: 30px 0 18px; }
.banner-rail { display: grid; grid-auto-flow: column; grid-auto-columns: minmax(340px, 440px); gap: 18px; overflow-x: auto; padding: 6px 2px 20px; scroll-snap-type: x proximity; cursor: grab; user-select: none; }
.banner-rail.is-dragging { cursor: grabbing; }
.banner-rail::-webkit-scrollbar { height: 10px; }
.banner-rail::-webkit-scrollbar-thumb { background: rgba(18,27,45,.18); border-radius: 999px; }
.banner-card { scroll-snap-align: start; position: relative; min-height: 100%; border-radius: 28px; overflow: hidden; box-shadow: 0 18px 40px rgba(20,26,40,.12); }
.banner-card.image-only { display: block; aspect-ratio: 1.05 / 1; }
.banner-card.image-only img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s ease; }
.banner-card:hover img { transform: scale(1.04); }
.banner-overlay { position: absolute; inset: auto 0 0 0; padding: 22px; background: linear-gradient(180deg, rgba(7,13,25,0) 0%, rgba(7,13,25,.82) 70%, rgba(7,13,25,.94) 100%); color: #fff; }
.banner-overlay strong { display: block; font-size: 1.5rem; line-height: 1.15; }
.banner-overlay p { margin: 10px 0 0; color: rgba(255,255,255,.84); line-height: 1.55; }
.banner-rail--minimal { grid-auto-columns: minmax(300px, 380px); }
.banner-rail--minimal .banner-card { border-radius: 8px; box-shadow: none; border: 1px solid rgba(15, 23, 42, .08); }
.banner-rail--minimal .banner-card.image-only { aspect-ratio: 1.45 / 1; }
.banner-rail--minimal .banner-overlay { position: static; min-height: 112px; background: #fff; color: #14233f; padding: 18px; }
.banner-rail--minimal .banner-overlay p { color: #5c677d; }
.banner-rail--accent { grid-auto-columns: minmax(420px, 560px); gap: 24px; }
.banner-rail--accent .banner-card { border-radius: 8px; box-shadow: 0 22px 50px rgba(var(--theme-primary-rgb, 18, 27, 45), .18); }
.banner-rail--accent .banner-card.image-only { aspect-ratio: 1.75 / 1; }
.banner-rail--accent .banner-overlay { top: 0; right: auto; width: min(68%, 360px); display: flex; flex-direction: column; justify-content: flex-end; background: linear-gradient(90deg, rgba(var(--theme-primary-rgb, 18, 27, 45), .94) 0%, rgba(var(--theme-primary-rgb, 18, 27, 45), .72) 72%, rgba(var(--theme-primary-rgb, 18, 27, 45), 0) 100%); }
.banner-dots { display: flex; justify-content: center; gap: 10px; margin-top: 8px; }
.banner-dot { width: 10px; height: 10px; border: 0; border-radius: 999px; background: rgba(18,27,45,.18); cursor: pointer; transition: transform .2s ease, background-color .2s ease, width .2s ease; }
.banner-dot.is-active { width: 28px; background: var(--theme-primary, #121b2d); }
.home-page main { scroll-snap-type: y mandatory; }
.home-panel { min-height: calc(100vh - 76px); display: flex; align-items: center; scroll-snap-align: start; }
.home-panel .shell,
.home-panel .page-shell { width: min(1280px, calc(100% - 48px)); }
.page-section { padding: 48px 0 80px; }
.page-hero { min-height: 360px; display: grid; align-items: end; border-radius: 32px; overflow: hidden; background-size: cover; background-position: center; box-shadow: 0 26px 50px rgba(20,26,40,.14); margin-bottom: 24px; }
.page-hero-overlay { min-height: 100%; display: grid; align-items: end; padding: 40px; background: linear-gradient(180deg, rgba(14,22,38,.08) 0%, rgba(14,22,38,.58) 100%); }
.page-hero-copy { display: grid; gap: 12px; max-width: 760px; color: #fff; }
.page-hero-copy h1 { margin: 0; color: #fff; font-size: clamp(2.8rem, 4vw, 4.6rem); line-height: .98; letter-spacing: -.06em; text-wrap: balance; word-break: keep-all; }
.page-hero-copy p { margin: 0; color: rgba(255,255,255,.88); font-size: clamp(1rem, 1.6vw, 1.18rem); line-height: 1.75; text-wrap: pretty; word-break: keep-all; }
.home-panel.hero-section { display: block; }
.home-panel.hero-section .hero-media { min-height: calc(100vh - 76px); }
.home-panel.content-section { padding: 32px 0; }
.home-panel .content-card { width: 100%; }
.home-panel .content-card:not(.image-card) { min-height: calc(100vh - 180px); display: flex; flex-direction: column; justify-content: center; }
.home-panel .feature-grid .content-card,
.home-panel .feature-grid .image-card { min-height: calc(100vh - 180px); }
.feature-grid, .page-grid { display: grid; gap: 24px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.image-card { padding: 0; overflow: hidden; }
.image-card img { width: 100%; height: 100%; min-height: 420px; object-fit: cover; }
.wide-banner { display: grid; grid-template-columns: 340px minmax(0, 1fr); gap: 22px; align-items: center; background: #fff; border-radius: 24px; padding: 18px; box-shadow: 0 18px 40px rgba(20,26,40,.08); }
.wide-banner img { width: 100%; height: 220px; object-fit: cover; border-radius: 18px; }
.center-card { text-align: center; }
.center-card h2 { font-size: clamp(2rem, 4vw, 3.6rem); }
.center-card p { max-width: 760px; margin: 0 auto; }
.stats-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; margin-top: 24px; }
.stat-box { padding: 24px; border-radius: 18px; background: #f7f9fc; text-align: center; }
.stat-box strong { display: block; font-size: 2rem; color: var(--theme-primary, #121b2d); }
.stat-box span { display: block; margin-top: 8px; color: #5c677d; }
.location-address-card { display: grid; grid-template-columns: minmax(0, 1fr) auto; align-items: center; gap: 18px; margin: 14px 0 0; padding: 16px 18px; border: 1px solid #e2e8f0; border-radius: 18px; background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%); box-shadow: 0 10px 24px rgba(20,26,40,.05); }
.location-address-copy { min-width: 0; display: grid; gap: 5px; }
.location-address-label { width: fit-content; padding: 4px 9px; border-radius: 999px; background: rgba(var(--theme-secondary-rgb, 109, 136, 215), .14); color: var(--theme-primary, #121b2d); font-size: .78rem; font-weight: 800; line-height: 1; }
.location-address { margin: 0 !important; font-weight: 800; color: #14233f !important; line-height: 1.45; }
.location-copy-button { flex: 0 0 auto; appearance: none; min-height: 42px; border: 0; border-radius: 999px; background: var(--theme-primary, #121b2d); color: #fff; cursor: pointer; font: inherit; font-size: .9rem; font-weight: 800; line-height: 1; padding: 0 16px; box-shadow: 0 8px 18px rgba(var(--theme-primary-rgb, 18, 27, 45), .18); transition: background-color .18s ease, transform .18s ease, box-shadow .18s ease; }
.location-copy-button:hover { transform: translateY(-1px); box-shadow: 0 12px 22px rgba(var(--theme-primary-rgb, 18, 27, 45), .22); }
.location-copy-button.is-copied { background: #15803d; box-shadow: 0 8px 18px rgba(21,128,61,.18); }
.location-copy-button:focus-visible { outline: 3px solid rgba(var(--theme-secondary-rgb, 109, 136, 215), .32); outline-offset: 2px; }
.location-copy-status { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; }
.map-box { margin-top: 0; height: 420px; border-radius: 18px; overflow: hidden; background: #edf2f7; }
.map-fallback { height: 100%; display: grid; place-items: center; color: #5c677d; background: linear-gradient(180deg, #f9fbfd 0%, #edf2f7 100%); }
.site-footer { background: var(--theme-primary, #121b2d); color: #fff; margin-top: auto; }
.footer-wrap { padding: 22px 0; display: flex; justify-content: space-between; gap: 24px; align-items: flex-start; }
.footer-wrap strong { display: block; line-height: 1.35; }
.footer-wrap p { margin: 0; font-size: .92rem; color: rgba(255,255,255,.86); }
.footer-info { display: grid; row-gap: 6px; margin-top: 8px; }
.footer-info p { display: grid; grid-template-columns: max-content minmax(0, 1fr); column-gap: 14px; align-items: baseline; line-height: 1.35; }
.footer-info span { color: rgba(255,255,255,.58); font-weight: 700; white-space: nowrap; }
.footer-socials { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 18px; }
.footer-social { display: inline-flex; align-items: center; justify-content: center; width: 42px; height: 42px; border-radius: 999px; background: rgba(255,255,255,.08); color: #fff; transition: background-color .18s ease, transform .18s ease; }
.footer-social:hover { background: rgba(255,255,255,.16); transform: translateY(-1px); }
.footer-social svg { width: 18px; height: 18px; fill: currentColor; }
.footer-social--kakao { background: #fee500; color: #181600; }
.footer-social--kakao:hover { background: #f6da00; }
.footer-social--instagram { background: linear-gradient(135deg, #f58529 0%, #dd2a7b 45%, #8134af 75%, #515bd4 100%); }
.footer-social--instagram:hover { background: linear-gradient(135deg, #f58529 0%, #dd2a7b 45%, #8134af 75%, #515bd4 100%); }
.footer-social--blog { background: #03c75a; }
.footer-social--blog:hover { background: #02b451; }
.footer-social--facebook { background: #1877f2; }
.footer-social--facebook:hover { background: #1266d4; }
.copyright { font-size: .9rem; color: rgba(255,255,255,.86); }
.popup-stack { position: fixed; top: 24px; right: 24px; z-index: 90; display: flex; flex-direction: column; gap: 10px; align-items: flex-end; }
.popup-layer { position: relative; background: #fff; border-radius: 20px; overflow: hidden; box-shadow: 0 24px 60px rgba(0,0,0,.28); }
.popup-close { position: absolute; top: 12px; right: 12px; width: 36px; height: 36px; border: 0; border-radius: 999px; background: rgba(18,27,45,.82); color: #fff; cursor: pointer; z-index: 2; }
.popup-link { display: block; }
.popup-image { width: 100%; height: 220px; object-fit: cover; }
.popup-body { padding: 20px; color: #222; }
.popup-body strong { display: block; margin-bottom: 10px; font-size: 1.35rem; }
.popup-hide { display: flex; align-items: center; gap: 8px; width: 100%; padding: 0 20px 18px; border: 0; background: transparent; font: inherit; font-size: .94rem; color: #475569; text-align: left; cursor: pointer; }
.home-hero { padding: 44px 0 24px; background: radial-gradient(circle at top left, rgba(200,221,255,.7), rgba(238,242,248,0) 46%), linear-gradient(180deg, #f5f8fc 0%, #eef2f8 100%); }
.home-hero-fullpage { padding: 0; background: #08111f; }
.home-hero-stack { display: grid; gap: 24px; }
.home-hero-item { min-height: calc(100vh - 120px); display: flex; align-items: center; }
.home-hero-item--fullpage { min-height: calc(100vh - 78px); }
.home-hero-fullpage .home-hero-stack { gap: 0; }
.home-hero-fullpage .home-hero-item > .home-section-card { width: 100%; }
.hero-slider { position: relative; }
.hero-slide { display: none; }
.hero-slide.is-active { display: block; }
.hero-slider-controls { display: flex; justify-content: center; gap: 10px; margin-top: 16px; }
.hero-slider-dot { width: 10px; height: 10px; border: 0; border-radius: 999px; background: rgba(18,27,45,.16); cursor: pointer; transition: width .2s ease, background-color .2s ease; }
.hero-slider-dot.is-active { width: 30px; background: var(--theme-primary, #121b2d); }
.home-section-card { overflow: hidden; border-radius: 28px; background: linear-gradient(180deg, #ffffff 0%, #f5f8fe 100%); border: 1px solid #e1e7f0; box-shadow: 0 18px 40px rgba(20,26,40,.08); }
.home-section-cover { min-height: 160px; background: linear-gradient(135deg, rgba(var(--theme-secondary-rgb, 109,136,215), .22) 0%, rgba(var(--theme-secondary-rgb, 109,136,215), .08) 100%); background-size: cover; background-position: center; }
.home-section-inner { display: grid; gap: 18px; padding: 22px; }
.home-section-copy { display: grid; gap: 12px; }
.home-section-copy--center { text-align: center; justify-items: center; }
.home-section-copy--right { text-align: right; justify-items: end; }
.home-section-copy h1,
.home-section-copy h2 { margin: 0; font-size: var(--section-title-size, 44px); line-height: 1.02; letter-spacing: -.045em; text-wrap: balance; word-break: keep-all; text-shadow: none; }
.home-section-copy p { margin: 0; font-size: var(--section-body-size, 18px); color: #5c677d; line-height: 1.65; text-wrap: pretty; word-break: keep-all; }
.home-section-side { min-height: 120px; border-radius: 20px; background: linear-gradient(135deg, #dce4f3 0%, #eef2f8 100%); background-size: cover; background-position: center; }
.home-section-side--empty { display: none; }
.home-section-actions { display: flex; }
.home-section-actions--center { justify-content: center; }
.home-section-actions--right { justify-content: flex-end; }
.home-section-actions .button { margin-top: 0; }
.home-section-board-list { display: grid; gap: 12px; }
.home-section-board-item { display: grid; grid-template-columns: 84px minmax(0, 1fr); gap: 12px; align-items: center; padding: 14px; border-radius: 18px; background: #f7f9fc; border: 1px solid #e2e8f1; }
.home-section-board-item--no-thumb { grid-template-columns: minmax(0, 1fr); }
.home-section-board-thumb { width: 84px; height: 84px; border-radius: 14px; background-size: cover; background-position: center; }
.home-section-board-copy { min-width: 0; display: grid; gap: 6px; }
.home-section-board-copy strong { font-size: 1rem; line-height: 1.45; color: #172033; word-break: keep-all; }
.home-section-board-copy span { color: #6b768b; font-size: .92rem; white-space: nowrap; }
.home-section-card--hero .home-section-inner { margin-top: -48px; }
.home-section-card--hero .home-section-copy,
.home-section-card--promo .home-section-copy,
.home-section-card--inquiry_banner .home-section-copy { padding: 16px; border-radius: 22px; background: rgba(255,255,255,.94); backdrop-filter: blur(8px); }
.home-section-card--hero .home-section-cover { min-height: 210px; }
.home-section-card--hero-fullpage { position: relative; min-height: calc(100vh - 78px); border-radius: 0; border: 0; box-shadow: none; background: #08111f; color: #fff; }
.home-section-card--hero-fullpage .home-section-cover { position: absolute; inset: 0; min-height: 100%; filter: brightness(.42) saturate(.92); }
.home-section-card--hero-fullpage .home-section-cover::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(8, 17, 31, .78) 0%, rgba(8, 17, 31, .48) 38%, rgba(8, 17, 31, .18) 68%, rgba(8, 17, 31, .38) 100%); }
.home-section-card--hero-fullpage .home-section-inner { position: relative; z-index: 1; min-height: calc(100vh - 78px); max-width: min(1240px, calc(100% - 80px)); margin: 0 auto; padding: clamp(40px, 7vw, 92px) 0; align-content: center; }
.home-section-card--hero-fullpage .home-section-copy { gap: 18px; max-width: min(640px, 100%); padding: clamp(22px, 3vw, 34px); border-radius: 28px; background: linear-gradient(180deg, rgba(7, 14, 26, .72) 0%, rgba(7, 14, 26, .56) 100%); backdrop-filter: blur(8px); box-shadow: 0 24px 60px rgba(0, 0, 0, .22); }
.home-section-card--hero-fullpage .home-section-copy h1 { font-size: clamp(3rem, 6.4vw, 5.5rem); line-height: .96; letter-spacing: -.06em; color: #fff; text-shadow: 0 14px 36px rgba(0, 0, 0, .24); }
.home-section-card--hero-fullpage .home-section-copy p { max-width: 34ch; font-size: clamp(1rem, 1.45vw, 1.14rem); color: rgba(255,255,255,.88); line-height: 1.72; }
.home-section-card--hero-fullpage .home-section-actions { margin-top: 8px; }
.home-section-card--hero-fullpage .home-section-actions .button { min-height: 52px; padding-inline: 24px; border-radius: 999px; background: rgba(255,255,255,.98); color: #0f172a; box-shadow: 0 18px 34px rgba(0,0,0,.18); }
.home-section-card--hero-fullpage.home-section-card--minimal .home-section-actions .button,
.home-section-card--hero-fullpage.home-section-card--accent .home-section-actions .button,
.home-section-card--hero-fullpage.home-section-card--editorial .home-section-actions .button { background: rgba(255,255,255,.98); color: #0f172a; box-shadow: 0 18px 34px rgba(0,0,0,.18); }
.home-section-card--image_text .home-section-inner { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); align-items: stretch; gap: 24px; }
.home-section-card--image_text .home-section-copy { align-content: center; }
.home-section-card--image_text .home-section-side { min-height: 320px; }
.home-section-card--board_preview .home-section-side { min-height: 220px; }
.home-section-card--board_preview.home-section-card--minimal .home-section-side,
.home-section-card--board_preview.home-section-card--accent .home-section-side,
.home-section-card--board_preview.home-section-card--editorial .home-section-side { display: none; }
.home-section-card--image_text .home-section-actions,
.home-section-card--image_text .home-section-stats { grid-column: 1 / -1; }
.home-section-card--image_text .home-section-inner,
.home-section-card--history .home-section-inner,
.home-section-card--board_preview .home-section-inner { margin-top: 0; }
.home-section-card--promo .home-section-side,
.home-section-card--inquiry_banner .home-section-side,
.home-section-card--history .home-section-side,
.home-section-card--board_preview .home-section-side,
.home-section-card--hero .home-section-side { display: none; }
.home-section-card--history .home-section-cover,
.home-section-card--promo .home-section-cover,
.home-section-card--inquiry_banner .home-section-cover,
.home-section-card--board_preview .home-section-cover { min-height: 92px; }
.home-section-card--minimal { border-radius: 18px; background: #fff; border-color: #dfe6f1; box-shadow: none; }
.home-section-card--minimal .home-section-cover { min-height: 88px; background: linear-gradient(180deg, #f8fafd 0%, #eef3f8 100%); }
.home-section-card--minimal .home-section-inner { gap: 14px; padding: 18px; }
.home-section-card--minimal .home-section-copy { gap: 8px; }
.home-section-card--minimal .home-section-copy h1,
.home-section-card--minimal .home-section-copy h2 { letter-spacing: -.03em; }
.home-section-card--minimal .home-section-copy p { color: #667389; }
.home-section-card--minimal .home-section-side { border-radius: 16px; background: #f3f6fb; }
.home-section-card--minimal .home-section-actions .button { min-height: 42px; border-radius: 12px; background: rgba(var(--theme-secondary-rgb, 109,136,215), .12); color: var(--theme-primary, #12213d); box-shadow: inset 0 0 0 1px rgba(var(--theme-secondary-rgb, 109,136,215), .28); }
.home-section-card--minimal.home-section-card--hero .home-section-inner,
.home-section-card--minimal.home-section-card--promo .home-section-inner,
.home-section-card--minimal.home-section-card--inquiry_banner .home-section-inner { margin-top: 0; }
.home-section-card--minimal.home-section-card--hero .home-section-copy,
.home-section-card--minimal.home-section-card--promo .home-section-copy,
.home-section-card--minimal.home-section-card--inquiry_banner .home-section-copy { padding: 0; border-radius: 0; background: transparent; backdrop-filter: none; }
.home-section-card--minimal.home-section-card--image_text .home-section-inner { grid-template-columns: minmax(0, 1.2fr) minmax(220px, .8fr); gap: 18px; }
.home-section-card--minimal .home-section-board-item { padding: 12px 0; border: 0; border-radius: 0; background: transparent; border-bottom: 1px solid #e7edf5; }
.home-section-card--minimal .home-section-board-item:last-child { border-bottom: 0; padding-bottom: 0; }
.home-section-card--minimal .home-section-board-thumb { border-radius: 12px; }
.home-section-card--accent {
  background:
    radial-gradient(circle at top right, rgba(var(--theme-secondary-rgb, 109,136,215), .28), transparent 34%),
    linear-gradient(135deg, var(--theme-primary, #12213d) 0%, rgba(var(--theme-primary-rgb, 18,33,61), .86) 100%);
  color: #fff;
}
.home-section-card--accent .home-section-cover { filter: brightness(.72) saturate(1.02); }
.home-section-card--accent .home-section-copy {
  border: 1px solid rgba(255,255,255,.1);
  background: linear-gradient(180deg, rgba(var(--theme-primary-rgb, 18,33,61), .86) 0%, rgba(var(--theme-primary-rgb, 18,33,61), .7) 100%);
  box-shadow: 0 18px 34px rgba(var(--theme-primary-rgb, 18,33,61), .24);
}
.home-section-card--accent .home-section-copy h1,
.home-section-card--accent .home-section-copy h2 { color: #fff; }
.home-section-card--accent .home-section-copy p { color: rgba(255,255,255,.8); }
.home-section-card--accent .section-eyebrow.dark { background: rgba(255,255,255,.14); color: #fff; }
.home-section-card--accent .button {
  background: #fff;
  color: var(--theme-primary, #12213d);
  box-shadow: 0 10px 24px rgba(var(--theme-primary-rgb, 18,33,61), .18);
}
.home-section-card--accent.home-section-card--hero .home-section-copy,
.home-section-card--accent.home-section-card--promo .home-section-copy,
.home-section-card--accent.home-section-card--inquiry_banner .home-section-copy { backdrop-filter: blur(10px); }
.home-section-card--accent.home-section-card--hero .home-section-inner,
.home-section-card--accent.home-section-card--promo .home-section-inner,
.home-section-card--accent.home-section-card--inquiry_banner .home-section-inner { gap: 20px; }
.home-section-stats { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.home-stat-box { padding: 22px; border-radius: 18px; background: #f7f9fc; text-align: center; }
.home-stat-box strong { display: block; font-size: 2rem; color: var(--theme-primary, #121b2d); }
.home-stat-box span { display: block; margin-top: 8px; color: #5c677d; }
.home-section-history { display: grid; gap: 22px; }
.home-history-list { display: grid; gap: 22px; }
.page-history-intro { margin-bottom: 48px; }
.page-history-intro > :first-child { margin-top: 0; }
.page-history-intro + .home-section-history { margin-top: 12px; }
.home-history-entry { position: relative; display: grid; gap: 10px; padding: 18px 20px; border-radius: 20px; background: #f7f9fc; border: 1px solid #e3eaf4; }
.home-history-entry strong { font-size: 2rem; line-height: 1; letter-spacing: -.04em; color: var(--theme-secondary, #6d88d7); }
.home-history-items { display: grid; gap: 8px; }
.home-history-items span { color: #22324d; line-height: 1.6; }
.home-section-history--editorial .home-history-list { position: relative; gap: 28px; }
.home-section-history--editorial .home-history-list::before { content: ""; position: absolute; left: 50%; top: 0; bottom: 0; width: 2px; background: #8d8d8d; transform: translateX(-50%); }
.home-section-history--editorial .home-history-entry { width: calc(50% - 24px); background: transparent; border: 0; padding: 8px 20px 8px 0; border-radius: 0; text-align: right; justify-items: end; }
.home-section-history--editorial .home-history-entry:nth-child(even) { margin-left: auto; padding: 8px 0 8px 20px; text-align: left; justify-items: start; }
.home-section-history--editorial .home-history-entry::before { content: ""; position: absolute; top: 18px; right: -31px; width: 10px; height: 10px; border-radius: 999px; background: var(--theme-primary, #5b5b5b); }
.home-section-history--editorial .home-history-entry:nth-child(even)::before { left: -31px; right: auto; }
.home-section-history--minimal .home-history-list { border-left: 2px solid #d8dfec; padding-left: 18px; }
.home-section-history--minimal .home-history-entry { background: transparent; border: 0; border-radius: 0; padding: 0 0 0 10px; }
.home-section-history--minimal .home-history-entry::before { content: ""; position: absolute; left: -24px; top: 10px; width: 10px; height: 10px; border-radius: 999px; background: var(--theme-secondary, #6d88d7); }
.home-section-history--accent { grid-template-columns: minmax(0, 1.1fr) minmax(280px, .9fr); align-items: start; }
.home-section-history--accent .home-history-list { gap: 16px; }
.home-section-history--accent .home-history-entry { background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.12); }
.home-section-history--accent .home-history-entry strong { color: var(--theme-secondary, #b7cbff); }
.home-section-history--accent .home-history-items span { color: rgba(255,255,255,.88); }
.home-history-media { min-height: 340px; border-radius: 24px; background-size: cover; background-position: center; }
.section-heading { display: flex; justify-content: space-between; align-items: end; gap: 18px; margin-bottom: 18px; }
.section-heading h2 { margin: 8px 0 0; font-size: clamp(1.5rem, 2.5vw, 2rem); line-height: 1.2; letter-spacing: -0.03em; text-shadow: none; }
.board-list-cards { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 20px; }
.board-card { display: grid; overflow: hidden; border-radius: 20px; background: #fff; box-shadow: 0 14px 30px rgba(20,26,40,.08); }
.board-card-media img { width: 100%; height: 240px; object-fit: cover; }
.board-card-body { display: grid; gap: 10px; padding: 20px; }
.board-card-body strong { font-size: 1.05rem; line-height: 1.5; }
.board-card-body span { color: #6b768b; font-size: .92rem; }
.board-list-table { display: grid; gap: 12px; }
.board-list-row { display: grid; grid-template-columns: minmax(0, 1fr) 72px; gap: 22px; align-items: center; }
.board-list-row:not(:has(.board-list-thumb)) { grid-template-columns: minmax(0, 1fr); }
.board-list-body { display: grid; gap: 12px; }
.board-list-row { padding: 16px 8px; border-top: 1px solid #edf2f8; color: #172033; }
.board-list-row:first-child { border-top: 0; }
.board-list-thumb { width: 72px; height: 72px; justify-self: end; border-radius: 18px; overflow: hidden; background: #eef2f8; box-shadow: inset 0 0 0 1px #dfe6f1; }
.board-list-thumb img { width: 100%; height: 100%; object-fit: cover; }
.board-list-text { min-width: 0; display: grid; gap: 8px; align-content: center; }
.board-list-title { min-width: 0; max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 1.06rem; line-height: 1.5; word-break: keep-all; }
.board-list-date { color: #4c5d78; font-weight: 600; justify-self: start; text-align: left; white-space: nowrap; }
.board-list-rows { display: grid; gap: 14px; }
.board-list-rows .board-card { grid-template-columns: 180px minmax(0, 1fr); align-items: stretch; border-radius: 18px; }
.board-list-rows .board-card-media img { height: 100%; min-height: 140px; }
.board-list-rows .board-card-body { align-content: center; }
.board-list-rows .board-card:not(:has(.board-card-media)) { grid-template-columns: 1fr; }
.board-pagination { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; margin-top: 28px; }
.board-page-link { display: inline-flex; align-items: center; justify-content: center; min-width: 44px; height: 44px; padding: 0 14px; border-radius: 999px; background: rgba(var(--theme-secondary-rgb, 109,136,215), .12); color: var(--theme-primary, #12213d); font-weight: 700; }
.board-page-link.is-active { background: var(--theme-primary, #121b2d); color: #fff; }
.post-date { margin: 6px 0 18px !important; color: #6b768b !important; font-size: .95rem; }
.post-cover { margin-top: 18px; overflow: hidden; border-radius: 22px; }
.post-cover img { width: 100%; max-height: 520px; object-fit: cover; }
.post-content { margin-top: 28px; color: #243552; line-height: 1.9; }
.post-content p { margin: 0 0 1.2em; }
.post-content img { width: 100%; border-radius: 18px; margin: 14px 0; }

@media (max-width: 1100px) {
  .hero-grid, .feature-grid, .page-grid, .wide-banner, .stats-grid { grid-template-columns: 1fr; }
  .hero-grid { min-height: auto; padding: 28px 0 36px; }
  .hero-copy { padding-top: 120px; }
  .home-panel, .home-panel.hero-section .hero-media { min-height: auto; }
  .home-panel .content-card,
  .home-panel .feature-grid .content-card,
  .home-panel .feature-grid .image-card { min-height: auto; }
  .board-list-cards { grid-template-columns: 1fr; }
  .board-list-row { grid-template-columns: minmax(0, 1fr) 72px; gap: 14px 16px; align-items: center; }
  .board-list-row:not(:has(.board-list-thumb)) { grid-template-columns: 1fr; }
  .board-list-text { grid-column: 1; }
  .board-list-thumb { grid-column: 2; grid-row: 1; }
  .board-list-date { justify-self: start; text-align: left; }
  .board-list-head { display: none; }
  .board-list-row { padding: 14px 0; }
  .board-list-summary { grid-column: 1; }
  .board-list-date { justify-self: start; text-align: left; font-size: .92rem; }
  .board-list-rows .board-card,
  .board-list-rows .board-card:not(:has(.board-card-media)) { grid-template-columns: 1fr; }
  .home-section-card--image_text .home-section-inner,
  .home-section-stats { grid-template-columns: 1fr; }
  .home-section-card--image_text .home-section-side { order: -1; min-height: 220px; }
  .home-section-board-item { grid-template-columns: 1fr; }
  .home-section-board-thumb { width: 100%; height: 180px; }
  .home-section-history--editorial .home-history-list::before { left: 0; transform: none; }
  .home-section-history--editorial .home-history-entry,
  .home-section-history--editorial .home-history-entry:nth-child(even) { width: 100%; margin-left: 0; padding: 0 0 0 24px; }
  .home-section-history--editorial .home-history-entry::before,
  .home-section-history--editorial .home-history-entry:nth-child(even)::before { left: -5px; right: auto; }
  .home-section-history--accent { grid-template-columns: 1fr; }
  .home-history-media { min-height: 220px; order: -1; }
  .page-hero { min-height: 300px; }
  .page-hero-overlay { padding: 32px; }
}

@media (max-width: 900px) {
  .home-section-history--editorial .home-history-list::before { left: 0; transform: none; }
  .home-section-history--editorial .home-history-entry,
  .home-section-history--editorial .home-history-entry:nth-child(even) {
    width: 100%;
    margin-left: 0;
    padding: 0 0 0 24px;
    text-align: left;
    justify-items: start;
  }
  .home-section-history--editorial .home-history-entry::before,
  .home-section-history--editorial .home-history-entry:nth-child(even)::before {
    left: -5px;
    right: auto;
  }
}

@media (max-width: 768px) {
  .nav-wrap { position: relative; flex-direction: row; align-items: center; }
  .footer-wrap { flex-direction: column; align-items: flex-start; }
  .nav-toggle { display: inline-flex; align-items: center; justify-content: center; }
  .nav { display: none; position: absolute; top: calc(100% + 10px); right: 0; min-width: 220px; padding: 14px; border-radius: 18px; background: var(--theme-primary, #121b2d); box-shadow: 0 18px 40px rgba(0,0,0,.22); flex-direction: column; align-items: flex-start; gap: 10px; }
  .nav.is-open { display: flex; }
  .nav a { width: 100%; }
  .hero-media { min-height: auto; }
  .hero-grid { padding-top: 0; }
  .hero-copy { padding-top: 64px; max-width: 100%; }
  .hero-copy h1 { font-size: 2.35rem; max-width: 9ch; }
  .hero-copy p { font-size: 1rem; }
  .home-hero { padding-top: 22px; }
  .home-hero-fullpage .home-hero-stack { gap: 0; }
  .home-hero-item { min-height: auto; }
  .home-hero-item--fullpage,
  .home-section-card--hero-fullpage,
  .home-section-card--hero-fullpage .home-section-inner { min-height: auto; }
  .home-section-inner { padding: 18px; }
  .home-section-copy h1,
  .home-section-copy h2 { font-size: calc(var(--section-title-size, 44px) * .68); }
  .home-section-copy p { font-size: calc(var(--section-body-size, 18px) * .88); }
  .home-section-card--hero .home-section-cover { min-height: 150px; }
  .home-section-card--hero .home-section-inner { margin-top: -28px; }
  .home-section-card--hero-fullpage .home-section-inner { max-width: calc(100% - 32px); padding: 26px 0 34px; align-content: end; }
  .home-section-card--hero-fullpage .home-section-copy { padding: 18px; border-radius: 22px; }
  .home-section-card--hero-fullpage .home-section-copy h1 { font-size: clamp(2.1rem, 11vw, 3.4rem); }
  .home-section-card--hero-fullpage .home-section-copy p { max-width: 100%; }
  .home-section-card--image_text .home-section-side { min-height: 180px; }
  .banner-rail { grid-auto-columns: minmax(280px, 86vw); }
  .banner-card.image-only { aspect-ratio: 1 / 1.08; }
  .banner-overlay strong { font-size: 1.2rem; }
  .popup-stack { left: 14px; right: 14px; top: 80px; align-items: stretch; }
  .popup-layer { width: auto !important; }
  .home-page main { scroll-snap-type: none; }
  .home-panel { min-height: auto; display: block; }
  .home-panel .page-shell, .home-panel .shell { width: min(100% - 28px, 100%); }
  .home-panel .content-card,
  .home-panel .feature-grid .content-card,
  .home-panel .feature-grid .image-card { min-height: auto; }
  .page-section { padding: 32px 0 56px; }
  .page-hero { min-height: 240px; border-radius: 24px; }
  .page-hero-overlay { padding: 24px; }
  .page-hero-copy h1 { font-size: clamp(2rem, 10vw, 2.8rem); }
  .page-hero-copy p { font-size: .98rem; }
  .location-address-card { grid-template-columns: 1fr; align-items: stretch; gap: 12px; padding: 14px; }
  .location-copy-button { width: 100%; }
  .feature-grid { gap: 18px; }
  .image-card img { min-height: 260px; }
  .center-card h2 { font-size: 1.95rem; }
  .stats-grid { gap: 12px; }
  .stat-box { padding: 16px; }
  .banner-rail-section { padding: 18px 0 8px; }
}
