@font-face {
  font-family: 'Kinetika';
  src: url('../fonts/kinetika-light.ttf') format('truetype');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
  unicode-range: U+0020-007E, U+00A0-00FF, U+0100-024F, U+2000-206F, U+2070-209F, U+20A0-20CF, U+2100-214F, U+2190-21FF, U+2200-22FF;
}
@font-face {
  font-family: 'Kinetika';
  src: url('../fonts/kinetika-regular.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  unicode-range: U+0020-007E, U+00A0-00FF, U+0100-024F, U+2000-206F, U+2070-209F, U+20A0-20CF, U+2100-214F, U+2190-21FF, U+2200-22FF;
}
@font-face {
  font-family: 'Kinetika';
  src: url('../fonts/kinetika-medium.ttf') format('truetype');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
  unicode-range: U+0020-007E, U+00A0-00FF, U+0100-024F, U+2000-206F, U+2070-209F, U+20A0-20CF, U+2100-214F, U+2190-21FF, U+2200-22FF;
}
@font-face {
  font-family: 'Kinetika';
  src: url('../fonts/kinetika-semi-bold.ttf') format('truetype');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
  unicode-range: U+0020-007E, U+00A0-00FF, U+0100-024F, U+2000-206F, U+2070-209F, U+20A0-20CF, U+2100-214F, U+2190-21FF, U+2200-22FF;
}
@font-face {
  font-family: 'Kinetika';
  src: url('../fonts/kinetika-bold.ttf') format('truetype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
  unicode-range: U+0020-007E, U+00A0-00FF, U+0100-024F, U+2000-206F, U+2070-209F, U+20A0-20CF, U+2100-214F, U+2190-21FF, U+2200-22FF;
}
@font-face {
  font-family: 'Paperlogy';
  src: url('../fonts/Paperlogy-3Light.ttf') format('truetype');
  font-weight: 300; font-style: normal; font-display: swap;
  unicode-range: U+AC00-D7A3, U+1100-11FF, U+3130-318F, U+A960-A97F, U+D7B0-D7FF;
}
@font-face {
  font-family: 'Paperlogy';
  src: url('../fonts/Paperlogy-4Regular.ttf') format('truetype');
  font-weight: 400; font-style: normal; font-display: swap;
  unicode-range: U+AC00-D7A3, U+1100-11FF, U+3130-318F, U+A960-A97F, U+D7B0-D7FF;
}
@font-face {
  font-family: 'Paperlogy';
  src: url('../fonts/Paperlogy-5Medium.ttf') format('truetype');
  font-weight: 500; font-style: normal; font-display: swap;
  unicode-range: U+AC00-D7A3, U+1100-11FF, U+3130-318F, U+A960-A97F, U+D7B0-D7FF;
}
@font-face {
  font-family: 'Paperlogy';
  src: url('../fonts/Paperlogy-6SemiBold.ttf') format('truetype');
  font-weight: 600; font-style: normal; font-display: swap;
  unicode-range: U+AC00-D7A3, U+1100-11FF, U+3130-318F, U+A960-A97F, U+D7B0-D7FF;
}
@font-face {
  font-family: 'Paperlogy';
  src: url('../fonts/Paperlogy-7Bold.ttf') format('truetype');
  font-weight: 700; font-style: normal; font-display: swap;
  unicode-range: U+AC00-D7A3, U+1100-11FF, U+3130-318F, U+A960-A97F, U+D7B0-D7FF;
}
@font-face {
  font-family: 'Paperlogy';
  src: url('../fonts/Paperlogy-8ExtraBold.ttf') format('truetype');
  font-weight: 800; font-style: normal; font-display: swap;
  unicode-range: U+AC00-D7A3, U+1100-11FF, U+3130-318F, U+A960-A97F, U+D7B0-D7FF;
}

@font-face {
  font-family: 'Kinetika-Regular';
  src: url('../fonts/kinetika-regular.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Kinetika-Bold';
  src: url('../fonts/kinetika-bold.ttf') format('truetype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --blue: #FF7F00;
  --blue-dark: #E67200;
  --navy: #111111;
  --bg: #F7F7F9;
  --white: #fff;
  --text: #111111;
  --text-sub: #555;
  --text-light: #888;
  --border: #E5E5EA;
  --radius: 12px;
  --font: 'Kinetika', 'Pretendard Variable', 'Pretendard', -apple-system, sans-serif;
}

html { font-family: var(--font); color: var(--text); background: var(--white); scroll-behavior: smooth; }
body { overflow-x: hidden; }
html.gm-modal-open,
html.gm-modal-open body { overflow: hidden !important; }
a { text-decoration: none; color: inherit; }
img { max-width: 100%; display: block; }

/* ── NAV ── */
.gm-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 900;
  background: rgba(255,255,255,0.95);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
  transition: all 0.3s;
}
.gm-nav-inner {
  max-width: 1440px; margin: 0 auto;
  padding: 0 0px;
  height: 68px;
  display: flex; align-items: center; gap: 40px;
  position: relative;
}
.gm-logo {
  display: flex; align-items: center; margin-left: 40px;
}
.gm-logo-img {
  height: 36px; width: auto; display: block;
}
.gm-logo-img-footer {
  filter: brightness(0) invert(1);
}
.gm-logo-dot { color: var(--blue); }
.gm-logo-ventures { font-weight: 400; color: var(--text); }
.gm-footer-ventures { font-weight: 400; color: rgba(255,255,255,0.85); }
.gm-nav-links {
  display: flex; gap: 32px;
  position: absolute; left: 50%; transform: translateX(-50%);
}
.gm-nav-links a {
  font-size: 16px; font-weight: 500; color: var(--text-sub);
  transition: color 0.2s;
}
.gm-nav-links a:hover { color: var(--blue); }
.gm-nav-right { margin-left: auto; }
.gm-nav-cta {
  display: inline-flex; align-items: center;
  background: var(--blue); color: #fff;
  padding: 14px 24px; border-radius: 8px;
  font-size: 14px; font-weight: 600;
  transition: background 0.2s;
}
.gm-nav-cta:hover { background: var(--blue-dark); }
.gm-hamburger {
  display: none; flex-direction: column; gap: 5px;
  background: none; border: none; cursor: pointer; padding: 4px;
}
.gm-hamburger span {
  display: block; width: 24px; height: 2px;
  background: var(--text); border-radius: 2px;
  transition: all 0.3s;
}
.gm-mobile-menu {
  display: none; flex-direction: column;
  background: #fff; padding: 20px 24px 28px;
  border-top: 1px solid var(--border);
}
.gm-mobile-menu.open { display: flex; }
.gm-mobile-menu a {
  padding: 14px 0; font-size: 16px; font-weight: 500;
  border-bottom: 1px solid var(--border);
  color: var(--text);
}
.gm-mobile-menu .gm-mobile-cta {
  margin-top: 16px; background: var(--blue); color: #fff;
  text-align: center; padding: 14px; border-radius: 8px; border: none;
}

/* ── FOOTER ── */
.gm-footer {
  background: var(--navy); color: rgba(255,255,255,0.85);
  padding: 60px 0 40px;
}
.gm-footer-inner { max-width: 1440px; margin: 0 auto; padding: 0 80px; }
.gm-footer-top {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 40px; border-bottom: 1px solid rgba(255,255,255,0.1);
  margin-bottom: 32px;
}
.gm-footer-logo {
  font-size: 22px; font-weight: 700; color: #fff;
}
.gm-footer-logo span { color: var(--blue); }
.gm-footer-nav { display: flex; gap: 28px; }
.gm-footer-nav a { font-size: 14px; color: rgba(255,255,255,0.6); transition: color 0.2s; }
.gm-footer-nav a:hover { color: #fff; }
.gm-footer-bottom { display: flex; justify-content: space-between; align-items: center; }
.gm-footer-copy { font-size: 14px; color: rgba(255,255,255,0.4); }
.gm-footer-contact { font-size: 14px; color: rgba(255,255,255,0.5); }

/* ── NAV SCROLL STATE ── */
.gm-nav.scrolled {
  background: rgba(255,255,255,0.98);
  box-shadow: 0 1px 12px rgba(0,0,0,0.06);
}

/* ── MAIN ── */
.gm-main { padding-top: 68px; }


.gm-label {
  font-size: 16px; font-weight: 700; letter-spacing: 1px;
  color: var(--blue); text-transform: uppercase; margin-bottom: 12px;
}
.gm-label-light { color: rgba(255,255,255,0.5); }
.gm-section-title {
  font-size: 36px; font-weight: 700; letter-spacing: -0.5px;
  color: var(--text); margin-bottom: 48px; line-height: 1.2;
}
.gm-title-light { color: #fff; }

/* ── BUTTONS ── */
.gm-btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 14px 28px; border-radius: 10px;
  font-size: 16px; font-weight: 600; cursor: pointer;
  transition: all 0.2s; border: none;
}
.gm-btn-primary { background: var(--blue); color: #fff; }
.gm-btn-primary:hover { background: var(--blue-dark); }
.gm-btn-ghost {
  background: transparent; color: var(--text);
  border: 1.5px solid var(--border);
}
.gm-btn-ghost:hover { border-color: var(--blue); color: var(--blue); }

/* ── HERO ── */
.gm-hero {
  position: relative;
  padding: 250px 0 250px;
  background: #000;
  overflow: hidden;
}
#gm-hero-canvas { display: none; }
.gm-hero-bg { display: none; }
.gm-hero-video-wrap {
  position: absolute; inset: 0; z-index: 0;
  pointer-events: none;
}
.gm-hero-video {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
}
.gm-hero-video-block {
  position: absolute; inset: 0; z-index: 1;
  pointer-events: all;
}
.gm-hero-overlay {
  position: absolute; inset: 0; z-index: 2;
  background: rgba(0, 0, 0, 0.52);
  pointer-events: none;
}
.gm-hero-inner {
  max-width: 1440px; margin: 0 auto; padding: 0 80px;
  position: relative; z-index: 2;
  text-align: center;
}
.gm-hero-eyebrow {
  font-size: 14px; font-weight: 700; letter-spacing: 1px;
  color: var(--blue); text-transform: uppercase; margin-bottom: 24px;
}
.gm-hero-title {
  font-size: 56px; font-weight: 700; line-height: 1.15;
  letter-spacing: -1px; color: #fff;
  margin-bottom: 24px;
}
.gm-hero-accent { color: var(--blue); }
.gm-hero-typing-wrap {
  display: inline-block;
}
.gm-cursor {
  display: inline-block;
  color: var(--blue);
  font-weight: 300;
  animation: gm-blink 0.75s step-end infinite;
  margin-left: 2px;
}
@keyframes gm-blink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0; }
}
.gm-hero-tags {
  display: flex; gap: 10px; flex-wrap: wrap; justify-content: center;
  margin-top: 36px;
}
.gm-hero-tag {
  padding: 8px 16px; border-radius: 20px;
  border: 1px solid rgba(255,255,255,0.3);
  background: rgba(255,255,255,0.1);
  font-size: 14px; font-weight: 500; color: rgba(255,255,255,0.85);
  transition: background 0.22s ease, border-color 0.22s ease, color 0.22s ease;
  cursor: default;
}
.gm-hero-tag:hover {
  background: var(--blue);
  border-color: var(--blue);
  color: #fff;
}
.gm-hero-desc {
  font-size: 18px; color: rgba(255,255,255,0.75); line-height: 1.7;
  margin-bottom: 40px;
}
.gm-hero-btns { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; }
.gm-br-pc { display: inline; }
.gm-br-mobile { display: none; }

/* ── PARTNER PROOF STRIP ── */
.gm-proof-strip {
  background: var(--bg);
  padding: 80px max(40px, calc((100vw - 1440px) / 2 + 40px)) 100px;
  border-top: 1px solid var(--border);
}
.gm-proof-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  text-align: center;
}
.gm-proof-badges {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  justify-content: center;
}
.gm-proof-badge {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 6px 16px;
  border-radius: 999px;
}
.gm-proof-badge--left {
  color: var(--text);
  border: 1.5px solid var(--border);
  background: var(--bg);
}
.gm-proof-badge--right {
  color: var(--blue);
  border: 1.5px solid var(--blue);
  background: rgba(255,127,0,0.07);
}
.gm-proof-badge em {
  font-style: normal;
  font-weight: 800;
}
.gm-proof-divider {
  font-size: 14px;
  color: var(--border);
  font-weight: 300;
}
.gm-proof-copy {
  font-size: clamp(14px, 1.5vw, 18px);
  font-weight: 400;
  color: var(--text-sub);
  letter-spacing: -0.2px;
  margin: 0;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.5s ease 0.3s, transform 0.5s ease 0.3s;
}
.gm-proof-taglines {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 8px;
}
.gm-proof-tagline {
  font-size: 36px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: -1px;
  line-height: 1.2;
}
.gm-proof-tagline.gm-impact-grad {
  color: unset;
}
.gm-proof-tagline-plain {
  background: none;
  -webkit-text-fill-color: var(--text);
  color: var(--text);
}
.gm-proof-tagline-div {
  font-size: 32px;
  font-weight: 300;
  color: #ccc;
  line-height: 1;
}
.gm-proof-sub {
  font-size: 18px;
  font-weight: 400;
  color: var(--text-sub);
  margin: 12px 0 0;
  letter-spacing: -0.2px;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 1.5s ease, transform 1s ease;
}
.gm-proof-logo-stage.step-1 ~ .gm-proof-sub {
  opacity: 1;
  transform: translateY(0);
}
.gm-proof-taglines {
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.5s ease 0.9s, transform 0.5s ease 0.9s;
}
.gm-proof-logo-stage.step-3 ~ .gm-proof-taglines {
  opacity: 1;
  transform: translateY(0);
}

.gm-br-360 { display: none; }

@media (max-width: 768px) {
  .gm-proof-tagline { font-size: 24px; letter-spacing: -0.5px; }
  .gm-proof-tagline-div { font-size: 20px; }
  .gm-proof-sub { font-size: 15px; }
}

@media (max-width: 446px) {
  .gm-br-360 { display: block; }
}

/* ── 로고 합체 애니메이션 스테이지 ── */
.gm-proof-logo-stage {
  position: relative;
  width: 100%;
  height: 150px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.gm-proof-logos-pair {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  transition: opacity 0.55s ease, gap 0.7s cubic-bezier(0.4, 0, 0.2, 1);
}
/* 각 로고 초기 상태 */
.gm-proof-logo {
  height: 75px;
  width: auto;
  object-fit: contain;
  opacity: 0;
  transition: opacity 0.6s ease, transform 0.7s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.gm-proof-logo--gomaoh { transform: translateX(50px); height: 85px; }
.gm-proof-logo--n15    { transform: translateX(-50px); height: 70px; }

/* × 기호 (CSS 선으로 구현) */
.gm-proof-cross {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 90px;
  height: 90px;
  opacity: 0;
  transform: scale(0);
  transition: opacity 0.6s ease 0.6s, transform 0.7s cubic-bezier(1, 0.61, 0.36, 1) 0.5s;
  user-select: none;
  flex-shrink: 0;
}
.gm-proof-cross::before,
.gm-proof-cross::after {
  content: '';
  position: absolute;
  width: 70%;
  height: 3px;
  background: #333;
  border-radius: 0px;
}
.gm-proof-cross::before { transform: rotate(45deg); }
.gm-proof-cross::after  { transform: rotate(-45deg); }


/* BI 로고 초기 상태 (숨김) */
.gm-proof-logo-bi {
  position: absolute;
  height: 82px;
  width: auto;
  max-width: 90%;
  object-fit: contain;
  opacity: 0;
  transform: scale(0.92);
  transition: opacity 0.7s ease, transform 0.7s cubic-bezier(0.22, 0.61, 0.36, 1);
  pointer-events: none;
}

/* step-1: 로고 슬라이드인 */
.gm-proof-logo-stage.step-1 .gm-proof-logo {
  opacity: 1;
  transform: translateX(0);
}
.gm-proof-logo-stage.step-1 .gm-proof-cross {
  opacity: 1;
  transform: scale(1);
}
/* step-2: 로고들 가운데로 수렴 후 소멸 */
.gm-proof-logo-stage.step-2 .gm-proof-logos-pair {
  gap: 0;
  opacity: 0;
  transition: opacity 0.5s ease 0.3s, gap 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.gm-proof-logo-stage.step-2 .gm-proof-logo--gomaoh {
  transform: translateX(-60px);
  opacity: 0;
  transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.4s ease 0.2s;
}
.gm-proof-logo-stage.step-2 .gm-proof-logo--n15 {
  transform: translateX(60px);
  opacity: 0;
  transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.4s ease 0.2s;
}
.gm-proof-logo-stage.step-2 .gm-proof-cross {
  opacity: 0;
  transform: scale(0.5);
  transition: opacity 0.3s ease, transform 0.3s ease;
}
/* step-3: BI 로고 등장 */
.gm-proof-logo-stage.step-3 .gm-proof-logo-bi {
  opacity: 1;
  transform: scale(1);
}
.gm-proof-logo-stage.step-3 ~ .gm-proof-copy {
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 768px) {
  .gm-proof-strip { padding: 44px 24px 60px; }
  .gm-proof-logo-stage { height: 80px; }
  .gm-proof-logo { height: 40px; }
  .gm-proof-logo--gomaoh { height: 40px; }
  .gm-proof-logo--n15 { height: 32px; }
  .gm-proof-logos-pair { gap: 0; }
  .gm-proof-cross { width: 50px; height: 50px; }
  .gm-proof-cross::before,
  .gm-proof-cross::after { width: 70%; height: 2px; }
  .gm-proof-logo-bi { height: 44px; }
  .gm-proof-copy { font-size: 14px; }
}

/* ── IMPACT BANNER ── */
.gm-impact {
  padding: 100px max(40px, calc((100vw - 1440px) / 2 + 40px));
  background: var(--bg);
  border-top: none;
  border-bottom: none;
}
.gm-impact-inner {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; gap: 16px;
}
.gm-impact-badge {
  display: inline-block;
  padding: 5px 14px; border-radius: 20px;
  border: 1.5px solid transparent;
  background-image: linear-gradient(white, white), linear-gradient(to right, #FF7F00, #DD1E25);
  background-origin: border-box;
  background-clip: padding-box, border-box;
  font-size: 12px; font-weight: 700; letter-spacing: 1.5px;
}
.gm-impact-badge span {
  background: linear-gradient(to right, #DD1E25, #FF9B37);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.gm-impact-headline {
  font-size: 42px; font-weight: 700; line-height: 1.2;
  letter-spacing: -0.5px; color: var(--text);
}
@keyframes gm-featured-grad {
  0%   { background-position: 0% 0%; }
  100% { background-position: 100% 100%; }
}
@keyframes gm-grad-flow {
  0%   { background-position: 0% 50%; }
  100% { background-position: -200% 50%; }
}
.gm-impact-grad {
  background: linear-gradient(90deg, #DD1E25, #FF9B37, #DD1E25);
  background-size: 200% 100%;
  background-position: 0% 50%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: gm-grad-flow 5s linear infinite;
}
.gm-impact-text {
  font-size: 18px; color: var(--text-sub); line-height: 1.8;
}

/* ── STATS ── */
.gm-stats { padding: 100px max(40px, calc((100vw - 1440px) / 2 + 40px)); background: var(--white); }
.gm-stats-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
}
.gm-stat-card {
  background: var(--bg); border-radius: var(--radius);
  padding: 36px 32px; border: 1px solid var(--border);
}
.gm-stat-num {
  font-size: 24px; font-weight: 700; color: var(--text);
  margin-bottom: 12px; letter-spacing: -0.5px;
}
.gm-stat-num span { color: var(--blue); }
.gm-stat-title-sm {
  font-size: 24px; font-weight: 700; color: var(--text);
  margin-bottom: 10px; line-height: 1.4;
}
.gm-stat-desc { font-size: 16px; color: var(--text-sub); line-height: 1.65; }

/* ── PROCESS ── */
.gm-process { padding: 100px max(40px, calc((100vw - 1440px) / 2 + 40px)); background: var(--bg); }
.gm-process-steps {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
  position: relative;
}
.gm-step { position: relative; padding-right: 24px; }
.gm-step-num {
  font-size: 24px; font-weight: 700; color: var(--blue);
  letter-spacing: 0px; margin-bottom: 12px;
}
.gm-step-line {
  height: 2px; background: var(--blue); margin-bottom: 20px;
  position: relative;
}
.gm-step-line::before { display: none; }
.gm-step-line::after { display: none; }
.gm-step-line-first::before {
  display: block;
  content: ''; position: absolute; left: 0; top: -4px;
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--blue);
}
.gm-step-line-last::after {
  display: block;
  content: '';
  position: absolute; right: -10px; top: -7px;
  width: 0; height: 0;
  border-top: 8px solid transparent;
  border-bottom: 8px solid transparent;
  border-left: 12px solid var(--blue);
}
.gm-step-title {
  font-size: 24px; font-weight: 700; color: var(--text);
  margin-bottom: 10px;
}
.gm-step-desc { font-size: 16px; color: var(--text-sub); line-height: 1.65; }

/* ── CRITERIA (dark) ── */
.gm-criteria {
  padding: 100px max(40px, calc((100vw - 1440px) / 2 + 40px));
  background: var(--navy);
}
.gm-criteria-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
.gm-criteria-card {
  border: 1px solid rgba(255,255,255,0.1); border-radius: var(--radius);
  padding: 36px 32px;
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
.gm-criteria-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 16px 32px rgba(0,0,0,0.4);
  border-color: rgba(255,255,255,0.25);
}
.gm-criteria-icon {
  font-size: 24px; font-weight: 700; color: var(--blue);
  letter-spacing: 1px; margin-bottom: 20px;
}
.gm-criteria-title {
  font-size: 24px; font-weight: 700; color: #fff; margin-bottom: 14px;
}
.gm-criteria-desc { font-size: 16px; color: rgba(255,255,255,0.55); line-height: 1.7; }

/* ── CORE VALUES ── */
.gm-values { padding: 100px max(40px, calc((100vw - 1440px) / 2 + 40px)); background: var(--white); }
.gm-values-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px;
}
.gm-value-item { padding: 36px 32px; background: var(--bg); border-radius: var(--radius); }
.gm-value-tag {
  display: inline-block; padding: 6px 14px;
  background: var(--blue); color: #fff;
  border-radius: 20px; font-size: 16px; font-weight: 700;
  margin-bottom: 18px;
}
.gm-value-desc { font-size: 16px; color: var(--text-sub); line-height: 1.7; }

/* ── PORTFOLIO ── */
.gm-portfolio {
  padding: 100px 0 100px max(40px, calc((100vw - 1440px) / 2 + 40px));
  background: var(--bg);
  overflow: hidden;
}
.gm-portfolio-inner {
  display: flex; align-items: center; gap: 60px;
}
/* 왼쪽 헤드 */
.gm-portfolio-head {
  flex: 0 0 300px; min-width: 260px;
}
.gm-portfolio-head .gm-label { margin-bottom: 16px; }
.gm-portfolio-title {
  font-family: 'Pretendard Variable', 'Pretendard', sans-serif;
  font-size: 32px; font-weight: 700; line-height: 1.25;
  color: var(--text); margin-bottom: 24px;
}
.gm-home-pf-title {
  font-family: 'Pretendard Variable', 'Pretendard', sans-serif;
  font-size: 32px; font-weight: 700; line-height: 1.25;
  color: var(--text); margin-bottom: 24px;
}
.gm-portfolio-viewall {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 16px; font-weight: 500; color: var(--text-sub);
  margin-bottom: 32px;
  transition: color 0.2s;
}
.gm-portfolio-viewall:hover { color: var(--blue); }
.gm-pf-nav {
  display: flex; gap: 12px; margin-top: 24px;
}
.gm-pf-nav--mobile { display: none; }
.gm-pf-prev, .gm-pf-next {
  width: 48px; height: 48px; border-radius: 50%;
  border: 1.5px solid var(--border); background: var(--white);
  font-size: 18px; cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: all 0.2s; color: var(--text);
}
.gm-pf-prev:hover, .gm-pf-next:hover {
  background: var(--blue); border-color: var(--blue); color: #fff;
}
/* 오른쪽 슬라이더 */
.gm-portfolio-slider-wrap {
  flex: 1;
  overflow: hidden;
  padding: 20px 40px 28px 20px;
  margin: -20px -40px -28px -20px;
}
.gm-portfolio-slider {
  display: flex; gap: 20px;
  transition: transform 0.45s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.gm-pf-card {
  flex: 0 0 380px; height: 365px;
  background: var(--white); border: 1px solid var(--border);
  border-radius: 16px; padding: 32px 28px;
  display: flex; flex-direction: column;
  box-shadow: 0 2px 12px rgba(0,0,0,0.04);
  transition: box-shadow 0.3s, transform 0.25s ease;
  user-select: none;
}
.gm-pf-card:hover { box-shadow: 0 12px 32px rgba(0,0,0,0.09); }
.gm-pf-logo-wrap {
  width: 56px; height: 56px; border-radius: 12px;
  background: var(--bg); margin-bottom: 20px;
  display: flex; align-items: center; justify-content: center;
}
.gm-pf-logo-initial {
  font-size: 24px; font-weight: 700; color: var(--blue);
}
.gm-pf-logo-img {
  width: 100%; height: 100%; object-fit: contain; border-radius: 12px;
}
.gm-pf-name {
  font-size: 24px; font-weight: 700; color: var(--text); margin-bottom: 16px;
}
.gm-pf-desc {
  font-size: 16px; color: var(--text-sub); line-height: 1.6;
  margin-bottom: 16px; flex: 1;
}
.gm-pf-tag {
  display: inline-block; padding: 8px 14px; border-radius: 20px;
  background: var(--bg); border: 1px solid var(--border);
  font-size: 14px; color: var(--text-sub); margin-bottom: 20px;
  width: fit-content;
}
.gm-pf-link {
  font-size: 14px; font-weight: 500; color: var(--text-sub);
  display: inline-flex; align-items: center; gap: 6px;
  transition: color 0.2s;
}
.gm-pf-link:hover { color: var(--blue); }

/* ── PROGRAMS ── */
.gm-programs { padding: 100px max(40px, calc((100vw - 1440px) / 2 + 40px)); background: var(--white); }
.gm-programs-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
.gm-prog-card {
  border: 1px solid var(--border); border-radius: var(--radius);
  overflow: hidden;
  transition: transform 0.35s cubic-bezier(0.22, 0.61, 0.36, 1),
              box-shadow 0.35s cubic-bezier(0.22, 0.61, 0.36, 1);
  box-shadow: 0 4px 20px rgba(0,0,0,0.06);
}
.gm-prog-card:hover {
  box-shadow: 0 20px 48px rgba(0,0,0,0.10),
              0 4px 16px rgba(0,0,0,0.06);
}
.gm-prog-img {
  aspect-ratio: 2 / 3;
  width: 100%;
  background: var(--bg);
}
.gm-prog-img-1 { background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); }
.gm-prog-img-2 { background: linear-gradient(135deg, #f093fb 0%, #f5576c 100%); }
.gm-prog-img-3 { background: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%); }

/* ── EVENT POSTER ── */
.gm-event-img-1 { background: #111; }
.gm-event-img-2 { background: #1a1a2e; }
.gm-event-img-3 { background: #0f2027; }
.gm-event-img-photo {
  background-size: cover;
  background-position: center top;
}
.gm-prog-img.gm-event-img-1,
.gm-prog-img.gm-event-img-2,
.gm-prog-img.gm-event-img-3 {
  position: relative; display: flex; align-items: center; justify-content: center;
}
.gm-event-poster {
  text-align: center; padding: 20px;
}
.gm-event-poster-tag {
  display: inline-block; padding: 4px 12px;
  border: 1px solid var(--blue); color: var(--blue);
  border-radius: 20px; font-size: 11px; font-weight: 700;
  letter-spacing: 1px; margin-bottom: 14px;
}
.gm-event-poster-title {
  font-size: 22px; font-weight: 700; color: #fff;
  line-height: 1.3; letter-spacing: -0.5px;
}
.gm-prog-body { padding: 28px 28px 32px; }
.gm-prog-tag {
  display: inline-block; padding: 4px 12px;
  background: rgba(91,106,245,0.1); color: var(--blue);
  border-radius: 20px; font-size: 12px; font-weight: 700;
  margin-bottom: 14px;
}
.gm-prog-title { font-size: 20px; font-weight: 700; color: var(--text); margin-bottom: 10px; }
.gm-prog-desc { font-size: 16px; color: var(--text-sub); line-height: 1.65; margin-bottom: 20px; }
.gm-prog-link { font-size: 14px; font-weight: 600; color: var(--blue); }
.gm-prog-link:hover { text-decoration: underline; }

/* ── FAQ ── */
.gm-faq { padding: 100px max(40px, calc((100vw - 1440px) / 2 + 40px)); background: var(--white); }
.gm-faq-inner { display: grid; grid-template-columns: 1fr 2fr; gap: 60px; align-items: start; }
.gm-faq-head .gm-section-title { margin-bottom: 0; }
.gm-faq-list { display: flex; flex-direction: column; gap: 0; }
.gm-faq-item { border-bottom: 1px solid var(--border); }
.gm-faq-q {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  padding: 22px 0; background: none; border: none; cursor: pointer;
  text-align: left; gap: 16px;
}
.gm-faq-q span { font-size: 16px; font-weight: 600; color: var(--text); }
.gm-faq-arrow { flex-shrink: 0; color: var(--text-sub); transition: transform 0.3s; }
.gm-faq-item.open .gm-faq-arrow { transform: rotate(180deg); }
.gm-faq-a {
  max-height: 0; overflow: hidden; transition: max-height 0.3s ease;
}
.gm-faq-a p { padding-bottom: 22px; font-size: 16px; color: var(--text-sub); line-height: 1.7; }

/* ── CTA BANNER ── */
.gm-cta-banner { padding: 100px max(40px, calc((100vw - 1440px) / 2 + 40px)); background: var(--navy); }
.gm-cta-stats {
  display: flex; gap: 60px; justify-content: center;
  margin-bottom: 60px; flex-wrap: wrap;
}
.gm-cta-stat { text-align: center; }
.gm-cta-num {
  font-size: 52px; font-weight: 700; color: var(--blue);
  letter-spacing: -1px; display: inline;
}
.gm-cta-unit { font-size: 28px; font-weight: 700; color: rgba(255,255,255,0.5); }
.gm-cta-label {
  display: block; font-size: 14px; color: rgba(255,255,255,0.5);
  margin-top: 6px;
}
.gm-cta-content { text-align: center; }
.gm-cta-title {
  font-size: 36px; font-weight: 700; color: #fff;
  margin-bottom: 14px; letter-spacing: -0.5px;
}
.gm-cta-desc { font-size: 17px; color: rgba(255,255,255,0.55); margin-bottom: 36px; }

/* ── NEWSLETTER ── */
.gm-newsletter { padding: 80px max(40px, calc((100vw - 1440px) / 2 + 40px)); background: var(--white); border-top: 1px solid var(--border); }
.gm-nl-inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 40px; flex-wrap: wrap;
}
.gm-nl-title { font-size: 26px; font-weight: 700; color: var(--text); margin-bottom: 8px; }
.gm-nl-desc { font-size: 16px; color: var(--text-sub); }
.gm-nl-form { display: flex; gap: 12px; flex-wrap: wrap; }
.gm-nl-input {
  padding: 14px 20px; border: 1.5px solid var(--border);
  border-radius: 10px; font-size: 16px; font-family: var(--font);
  outline: none; width: 280px; transition: border-color 0.2s;
}
.gm-nl-input:focus { border-color: var(--blue); }

/* ══════════════════════════════════════
   SINGLE POST
══════════════════════════════════════ */

.gm-single {
  max-width: 740px;
  margin: 0 auto;
  padding: 60px 80px 100px;
}

/* Breadcrumb */
.gm-single-breadcrumb {
  display: flex; align-items: center; flex-wrap: wrap; gap: 6px;
  font-size: 14px; color: var(--text-sub);
  margin-bottom: 36px;
}
.gm-single-breadcrumb a {
  color: var(--text-sub); transition: color 0.2s;
}
.gm-single-breadcrumb a:hover { color: var(--blue); }
.gm-single-breadcrumb-sep { color: var(--text-light); }
.gm-single-breadcrumb-cat {
  display: inline-block; padding: 3px 10px;
  background: rgba(249,115,22,0.1); color: var(--blue);
  border-radius: 20px; font-size: 12px; font-weight: 700;
}

/* Header */
.gm-single-header { margin-bottom: 40px; }
.gm-single-title {
  font-size: 40px; font-weight: 700; line-height: 1.3;
  letter-spacing: -0.8px; color: var(--text);
  margin: 0 0 20px;
}
.gm-single-meta {
  display: flex; align-items: center; gap: 10px;
  font-size: 14px; color: var(--text-sub);
}
.gm-single-meta-sep { color: var(--text-light); }
.gm-single-meta-pipe {
  display: inline-block;
  width: 1px; height: 14px;
  background: var(--text-light);
  border-radius: 1px;
  flex-shrink: 0;
}

/* Content */
.gm-single-content {
  font-size: 16px; line-height: 1.85;
  color: var(--text); border-top: 1px solid var(--border);
  padding-top: 36px;
}
.gm-single-content p { margin: 0 0 24px; }
.gm-single-content p:last-child { margin-bottom: 0; }
.gm-single-content h2 { font-size: 24px; font-weight: 700; margin: 40px 0 16px; }
.gm-single-content h3 { font-size: 20px; font-weight: 700; margin: 32px 0 12px; }
.gm-single-content a { color: var(--blue); text-decoration: underline; }
.gm-single-content img { max-width: 100%; border-radius: var(--radius); margin: 24px 0; }
.gm-single-content blockquote {
  border-left: 3px solid var(--blue);
  margin: 24px 0; padding: 12px 20px;
  background: var(--bg); border-radius: 0 8px 8px 0;
  font-style: italic; color: var(--text-sub);
}

/* Footer */
.gm-single-footer { margin-top: 48px; }
.gm-single-divider {
  height: 1px; background: var(--border); margin-bottom: 28px;
}
.gm-single-source {
  font-size: 14px; color: var(--text-sub);
  background: var(--bg); border-radius: 8px;
  padding: 14px 18px; margin-bottom: 32px;
  display: inline-block;
}
.gm-single-source strong { color: var(--text); }
.gm-single-back {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 14px; font-weight: 600; color: var(--blue);
  transition: gap 0.2s;
}
.gm-single-back:hover { gap: 10px; }

/* Mobile */
@media (max-width: 768px) {
  .gm-single { padding: 40px 20px 80px; }
  .gm-single-title { font-size: 28px; }
  .gm-single-content { font-size: 16px; }
}

/* ══════════════════════════════════════
   PORTFOLIO SINGLE
══════════════════════════════════════ */
.gm-pf-single { background: var(--white); }

/* Hero */
.gm-pf-single-hero {
  background: var(--bg);
  padding: 60px max(40px, calc((100vw - 1440px) / 2 + 40px)) 80px;
  border-bottom: 1px solid var(--border);
}
.gm-pf-single-hero-inner { max-width: 1000px; }

/* 브레드크럼 */
.gm-pf-single-breadcrumb {
  display: flex; align-items: center; gap: 8px;
  font-size: 14px; color: var(--text-sub); margin-bottom: 48px;
}
.gm-pf-single-breadcrumb a { color: var(--text-sub); transition: color 0.2s; }
.gm-pf-single-breadcrumb a:hover { color: var(--blue); }
.gm-pf-single-breadcrumb span:last-child { color: var(--text); font-weight: 500; }

/* Hero body */
.gm-pf-single-hero-body {
  display: flex; align-items: flex-start; gap: 48px;
}
.gm-pf-single-logo {
  flex: 0 0 100px; width: 100px; height: 100px;
  border-radius: 20px; background: var(--white);
  border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.gm-pf-single-thumb { width: 100%; height: 100%; object-fit: contain; }
.gm-pf-single-initial { font-size: 40px; font-weight: 700; color: var(--blue); }

.gm-pf-single-info { flex: 1; }
.gm-pf-single-tag {
  display: inline-block; padding: 4px 14px;
  background: rgba(249,115,22,0.1); color: var(--blue);
  border-radius: 20px; font-size: 12px; font-weight: 700;
  letter-spacing: 0.5px; margin-bottom: 16px;
}
.gm-pf-single-title {
  font-size: 36px; font-weight: 700; color: var(--text);
  line-height: 1.2; letter-spacing: -0.5px; margin-bottom: 16px;
}
.gm-pf-single-desc {
  font-size: 16px; color: var(--text-sub); line-height: 1.7;
  margin-bottom: 32px;
}
.gm-pf-single-meta-list {
  display: flex; gap: 40px; flex-wrap: wrap;
}
.gm-pf-single-meta-item dt {
  font-size: 11px; font-weight: 700; color: var(--text-light);
  letter-spacing: 1px; text-transform: uppercase; margin-bottom: 6px;
}
.gm-pf-single-meta-item dd {
  font-size: 16px; font-weight: 600; color: var(--text);
}
.gm-pf-single-meta-item dd a { color: var(--blue); }
.gm-pf-single-meta-item dd a:hover { text-decoration: underline; }

/* Content */
.gm-pf-single-content-section {
  padding: 80px max(40px, calc((100vw - 1440px) / 2 + 40px));
}
.gm-pf-single-content-inner { max-width: 780px; }

/* Back */
.gm-pf-single-back-wrap {
  padding: 0 max(40px, calc((100vw - 1440px) / 2 + 40px)) 100px;
  border-top: 1px solid var(--border);
  padding-top: 40px;
}
.gm-pf-single-back {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 14px; font-weight: 600; color: var(--blue);
  transition: gap 0.2s;
}
.gm-pf-single-back:hover { gap: 10px; }

/* 포트폴리오 페이지 카드 — 링크 처리 */
a.gm-pf-page-card { text-decoration: none; color: inherit; }
a.gm-pf-card      { text-decoration: none; color: inherit; }

@media (max-width: 768px) {
  .gm-pf-single-hero { padding: 40px 20px 60px; }
  .gm-pf-single-hero-body { flex-direction: column; gap: 24px; }
  .gm-pf-single-title { font-size: 26px; }
  .gm-pf-single-content-section { padding: 48px 20px; }
  .gm-pf-single-back-wrap { padding: 32px 20px 80px; }
}

/* ══════════════════════════════════════
   PROGRAM SINGLE
══════════════════════════════════════ */
/* ── 프로그램 단일 페이지 ── */
.gm-prog-single-hero {
  padding: 60px max(20px, calc((100vw - 1440px) / 2 + 40px)) 32px;
  background: var(--white);
  border-bottom: 1px solid var(--border);
}
.gm-prog-single-hero-inner { max-width: 1200px; }

/* 2-column body */
.gm-prog-single-body {
  padding: 100px max(20px, calc((100vw - 1440px) / 2 + 40px)) 100px;
  background: var(--white);
}
.gm-prog-single-body-inner {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 60px;
  align-items: start;
}

/* 왼쪽: 뉴스 형식 */
.gm-prog-single-left { display: flex; flex-direction: column; gap: 24px; overflow: hidden; min-width: 0; }
.gm-prog-single-header { display: flex; flex-direction: column; gap: 6px; }
.gm-prog-single-tag {
  display: inline-block;
  font-size: 18px; font-weight: 700;
  color: var(--blue);
  background: rgba(255,152,0,0.08);
  border: 1px solid rgba(255,152,0,0.3);
  border-radius: 20px;
  padding: 4px 14px;
  width: fit-content;
}
.gm-prog-single-title {
  font-size: clamp(26px, 3vw, 40px);
  font-weight: 800; line-height: 1.25;
  color: var(--text); letter-spacing: -0.5px; margin: 0;
}
.gm-prog-single-meta-row { display: flex; align-items: center; gap: 12px; }
.gm-prog-single-manager { font-size: 18px; color: var(--text-sub); margin: 6px 0 0; }
.gm-prog-single-content { border-top: 1px solid var(--border); padding-top: 32px; }
.gm-prog-single-back-wrap { padding-top: 32px; border-top: 1px solid var(--border); }

/* 오른쪽: 레퍼런스 사이드바 */
.gm-prog-single-right-sticky {
  position: sticky;
  top: 100px;
  padding-top: 92px;
}
.gm-prog-ref-manager { font-size: 16px; color: var(--text-sub); margin: 0 0 4px; }
.gm-prog-ref-title {
  font-size: 24px; font-weight: 800;
  color: var(--text); margin: 0 0 20px;
}
.gm-prog-ref-list { display: flex; flex-direction: column; gap: 12px; }
.gm-prog-ref-card {
  display: flex; gap: 14px; align-items: flex-start;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px;
  text-decoration: none;
  cursor: pointer;
  width: 100%;
  text-align: left;
  font-family: inherit;
  transition: box-shadow 0.2s, transform 0.2s;
}
.gm-prog-ref-card:hover {
  box-shadow: 0 6px 20px rgba(0,0,0,0.08);
  transform: translateY(-2px);
}
.gm-prog-ref-logo-wrap {
  width: 56px; height: 56px;
  border-radius: 10px;
  overflow: hidden;
  background: var(--bg);
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.gm-prog-ref-logo-img { width: 100%; height: 100%; object-fit: cover; }
.gm-prog-ref-logo-initial {
  font-size: 20px; font-weight: 800; color: var(--text-sub);
}
.gm-prog-ref-info { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.gm-prog-ref-name { font-size: 14px; font-weight: 700; color: var(--text); margin: 0; }
.gm-prog-ref-desc {
  font-size: 12px; color: var(--text-sub); margin: 0;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.gm-prog-ref-link { font-size: 12px; font-weight: 600; color: var(--blue); margin-top: 2px; }
.gm-prog-ref-empty { font-size: 14px; color: var(--text-sub); }

@media (max-width: 900px) {
  .gm-prog-single-body-inner { grid-template-columns: 1fr; gap: 0; }
  .gm-prog-single-right-sticky { position: static; margin-top: 0; }
}
@media (max-width: 768px) {
  .gm-prog-single-hero { padding: 48px 20px 24px; }
  .gm-prog-single-body { padding: 40px 20px 72px; }
}

/* ══════════════════════════════════════
   PORTFOLIO PAGE
══════════════════════════════════════ */
/* 공통 base */
.gm-page-hero {
  background: var(--bg);
  padding: 100px max(40px, calc((100vw - 1440px) / 2 + 40px)) 48px;
  border-bottom: 1px solid var(--border);
}
.gm-pf-page-hero-inner,
.gm-portfolio-hero-inner,
.gm-program-hero-inner,
.gm-events-hero-inner,
.gm-team-hero-inner { max-width: 100%; }

/* 포트폴리오 */
.gm-portfolio-hero {}

/* 프로그램 */
.gm-program-hero {}

/* 이벤트 */
.gm-events-hero {}

/* 팀 */
.gm-team-hero {
  background: var(--white);
  border-bottom: none;
}

/* 이전 호환 */
.gm-pf-page-hero {
  background: var(--bg);
  padding: 100px max(40px, calc((100vw - 1440px) / 2 + 40px)) 48px;
  border-bottom: 1px solid var(--border);
}

.gm-pf-hero-top,
.gm-portfolio-hero-top,
.gm-program-hero-top,
.gm-events-hero-top,
.gm-team-hero-top {
  display: flex; align-items: center;
  justify-content: space-between; gap: 40px;
  margin-bottom: 24px;
}
.gm-pf-hero-left,
.gm-portfolio-hero-left,
.gm-program-hero-left,
.gm-events-hero-left,
.gm-team-hero-left { flex: 1; display: flex; flex-direction: column; }
.gm-pf-hero-stats {
  display: flex; gap: 0; flex-shrink: 0;
}
.gm-pf-hero-stat {
  padding: 0 40px;
  border-left: 1px solid var(--border);
}
.gm-pf-hero-stat:first-child { border-left: none; padding-left: 0; }
.gm-pf-hero-stat-label {
  font-size: 14px; color: var(--text-sub); margin-bottom: 8px;
}
.gm-pf-hero-stat-num {
  font-size: 40px; font-weight: 700; color: var(--text);
  letter-spacing: -1px; line-height: 1;
}
.gm-pf-hero-stat-num span:not(.gm-count) {
  font-size: 16px; font-weight: 500; color: var(--text-sub);
  margin-left: 4px; letter-spacing: 0;
}
.gm-pf-filter-row {
  display: flex; align-items: center;
  justify-content: space-between; gap: 16px; flex-wrap: wrap;
}
.gm-pf-filter-row .gm-news-filters { margin-bottom: 0; }
.gm-pf-search-wrap {
  position: relative; flex-shrink: 0;
}
.gm-pf-search-icon {
  position: absolute; left: 14px; top: 50%; transform: translateY(-50%);
  color: var(--text-sub); pointer-events: none;
}
.gm-pf-search {
  padding: 12px 16px 12px 38px;
  border: 1.5px solid var(--border);
  background: var(--white); color: var(--text);
  font-size: 14px; font-family: var(--font);
  outline: none; width: 420px;
  transition: border-color 0.2s;
}
.gm-pf-search::placeholder { color: var(--text-sub); }
.gm-pf-search:focus { border-color: var(--blue); }
.gm-pf-page-title,
.gm-portfolio-title,
.gm-program-title,
.gm-events-title,
.gm-team-title {
  font-size: 48px; font-weight: 700; line-height: 1.2;
  letter-spacing: -1px; color: var(--text);
  margin: 12px 0 28px;
}
.gm-pf-page-desc,
.gm-portfolio-desc,
.gm-program-desc,
.gm-events-desc,
.gm-team-desc {
  font-size: 16px; color: var(--text-sub); line-height: 1.7;
  margin-bottom: 0px;
}
.gm-pf-page-grid-section {
  padding: 60px max(40px, calc((100vw - 1440px) / 2 + 40px)) 80px;
  background: var(--white);
}
.gm-pf-page-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.gm-pf-page-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: 16px; padding: 32px 28px;
  display: flex; flex-direction: column;
  box-shadow: 0 2px 12px rgba(0,0,0,0.04);
  transition: box-shadow 0.3s, transform 0.25s ease;
}
.gm-pf-page-card:hover {
  box-shadow: 0 12px 32px rgba(0,0,0,0.09);
  transform: translateY(-4px);
}
.gm-pf-page-empty {
  grid-column: 1 / -1;
  color: var(--text-sub); padding: 60px 0; text-align: center;
}

@media (max-width: 768px) {
  .gm-page-hero, .gm-pf-page-hero { padding: 60px 20px 40px; }
  .gm-pf-page-title,
  .gm-portfolio-title,
  .gm-program-title,
  .gm-events-title,
  .gm-team-title { font-size: 30px; margin: 12px 0 28px; }
  .gm-pf-page-desc,
  .gm-portfolio-desc { margin-bottom: 40px; },
  .gm-program-desc,
  .gm-team-desc { font-size: 16px; margin-bottom: 0px; }
  .gm-events-desc { font-size: 16px; margin-bottom: 40px; }
  .gm-pf-hero-top,
  .gm-portfolio-hero-top,
  .gm-program-hero-top,
  .gm-events-hero-top,
  .gm-team-hero-top { flex-direction: column; align-items: flex-start; gap: 0px; margin-bottom: 0; }
  .gm-pf-hero-stats { width: 100%; flex-direction: column; gap: 0; margin-top: 0; margin-bottom: 28px; }
  .gm-pf-hero-stat {
    display: flex; flex-direction: row;
    justify-content: space-between; align-items: center;
    padding: 14px 0;
    border-top: 1px solid var(--border);
    border-left: none;
  }
  .gm-pf-hero-stat:first-child { border-top: none; padding-left: 0; }
  .gm-pf-hero-stat-label { font-size: 14px; color: var(--text-sub); margin-bottom: 0; }
  .gm-pf-hero-stat-num { font-size: 32px; letter-spacing: -1px; }
  .gm-pf-page-grid-section { padding: 48px 20px 60px; }
  .gm-pf-page-grid { grid-template-columns: 1fr; gap: 16px; }
  .gm-pf-filter-row { flex-direction: column; align-items: flex-start; }
  .gm-pf-search { width: 100%; }
  .gm-pf-search-wrap { width: 100%; }
}

/* ══════════════════════════════════════
   PORTFOLIO MODAL
══════════════════════════════════════ */
.gm-pf-modal-overlay {
  position: fixed; inset: 0; z-index: 9000;
  background: rgba(0,0,0,0.55);
  display: flex; align-items: center; justify-content: center;
  padding: 24px 16px;
  opacity: 0; pointer-events: none;
  transition: opacity 0.25s ease;
}
.gm-pf-modal-overlay.is-open {
  opacity: 1; pointer-events: auto;
}
.gm-pf-modal {
  background: var(--white);
  border-radius: 16px;
  width: 100%; max-width: 820px;
  max-height: 90vh;
  overflow-y: auto;
  padding: 48px;
  position: relative;
  transform: translateY(24px);
  transition: transform 0.25s ease;
}
.gm-pf-modal-overlay.is-open .gm-pf-modal {
  transform: translateY(0);
}
.gm-pf-modal-close {
  position: absolute; top: 20px; right: 20px;
  width: 36px; height: 36px;
  border-radius: 50%; border: 1.5px solid var(--border);
  background: var(--white); color: var(--text-sub);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: background 0.15s, color 0.15s;
}
.gm-pf-modal-close:hover { background: var(--bg); color: var(--text); }
.gm-pf-modal-header {
  display: flex; gap: 32px; align-items: flex-start;
  margin-bottom: 36px;
}
.gm-pf-modal-logo-wrap {
  flex-shrink: 0;
  width: 140px; height: 140px;
  border: 1px solid var(--border); border-radius: 12px;
  background: var(--bg);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.gm-pf-modal-logo-img {
  width: 100%; height: 100%; object-fit: contain; padding: 12px;
}
.gm-pf-modal-logo-initial {
  font-size: 48px; font-weight: 700; color: var(--text-sub);
}
.gm-pf-modal-info {
  flex: 1; display: flex; flex-direction: column; gap: 10px;
  padding-top: 4px;
}
.gm-pf-modal-tag {
  display: inline-flex; align-items: center;
  padding: 8px 14px; border-radius: 20px;
  background: rgba(249,115,22,0.1); color: var(--blue);
  font-size: 14px; font-weight: 600;
  align-self: flex-start;
}
.gm-pf-modal-title {
  font-size: 28px; font-weight: 700; color: var(--text);
  line-height: 1.3; margin: 0;
}
.gm-pf-modal-desc {
  font-size: 16px; color: var(--text-sub); line-height: 1.65; margin: 0;
}
.gm-pf-modal-body {
  border-top: 1px solid var(--border);
  padding-top: 32px;
  display: flex; flex-direction: column; gap: 32px;
}
.gm-pf-modal-content { font-size: 16px; line-height: 1.85; color: var(--text); border-top: none; padding-top: 0; }
.gm-pf-modal-content p { margin: 0 0 20px; }
.gm-pf-modal-content p:last-child { margin-bottom: 0; }
.gm-pf-modal-content h2 { font-size: 20px; font-weight: 700; margin: 32px 0 12px; }
.gm-pf-modal-content h3 { font-size: 17px; font-weight: 700; margin: 24px 0 10px; }
.gm-pf-modal-content ul, .gm-pf-modal-content ol { padding-left: 20px; margin: 0 0 20px; }
.gm-pf-modal-content li { margin-bottom: 6px; }
.gm-pf-modal-content img { max-width: 100%; border-radius: 8px; margin: 16px 0; }
.gm-pf-modal-content a { color: var(--blue); text-decoration: underline; }
.gm-pf-modal-meta {
  display: flex; flex-direction: column;
  border: 1px solid var(--border); border-radius: 10px;
  overflow: hidden;
}
.gm-pf-modal-meta-item {
  display: flex; align-items: center;
  padding: 14px 20px; gap: 24px;
  border-bottom: 1px solid var(--border);
}
.gm-pf-modal-meta-item:last-child { border-bottom: none; }
.gm-pf-modal-meta-item dt {
  font-size: 14px; font-weight: 700; color: var(--text-sub);
  min-width: 80px; flex-shrink: 0;
}
.gm-pf-modal-meta-item dd { font-size: 14px; color: var(--text); }
.gm-pf-modal-meta-item dd a { color: var(--blue); }
.gm-pf-modal-meta-item dd a:hover { text-decoration: underline; }
@media (max-width: 640px) {
  .gm-pf-modal { padding: 28px 20px; }
  .gm-pf-modal-header { flex-direction: column; gap: 20px; }
  .gm-pf-modal-logo-wrap { width: 100px; height: 100px; }
  .gm-pf-modal-title { font-size: 22px; }
}

/* ══════════════════════════════════════
   NEWS PAGE
══════════════════════════════════════ */

/* Hero */
.gm-news-hero {
  background: var(--bg);
  padding: 100px max(40px, calc((100vw - 1440px) / 2 + 40px)) 48px;
}
.gm-news-hero-inner {
  display: grid;
  grid-template-columns: 1fr minmax(0, 38%);
  grid-template-areas:
    "left     featured"
    "filter   featured";
  column-gap: 48px;
  row-gap: 0;
}
.gm-news-hero-left {
  grid-area: left;
  display: flex; flex-direction: column;
}
.gm-news-featured {
  grid-area: featured;
}
@media (min-width: 769px) {
  .gm-news-featured {
    align-self: stretch;
    margin-top: 36px;
    min-height: 0;
    overflow: hidden;
  }
}
.gm-news-filter-row {
  grid-area: filter;
  display: flex; align-items: center;
  justify-content: space-between; gap: 16px; flex-wrap: wrap;
  padding-bottom: 0;
  align-self: end;
}
.gm-news-hero-title {
  font-size: 48px; font-weight: 700; line-height: 1.2;
  letter-spacing: -1px; color: var(--text);
  margin: 12px 0 28px;
}
.gm-news-filters {
  display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 24px;
}
.gm-news-filter {
  padding: 8px 18px; border-radius: 0;
  border: 1.5px solid var(--border);
  background: var(--white); color: var(--text-sub);
  font-size: 14px; font-weight: 500; cursor: pointer;
  transition: all 0.2s; font-family: var(--font);
}
.gm-news-filter:hover,
.gm-news-filter.active { background: var(--blue); color: #fff; border-color: var(--blue); }
.gm-news-filter[data-filter="philosophy"].active,
.gm-news-filter[data-filter="philosophy"]:hover { background: #6366F1; border-color: #6366F1; }
.gm-news-filter[data-filter="portfolio"].active,
.gm-news-filter[data-filter="portfolio"]:hover  { background: #10B981; border-color: #10B981; }
.gm-news-filter[data-filter="startup"].active,
.gm-news-filter[data-filter="startup"]:hover    { background: #EAB308; border-color: #EAB308; }
.gm-news-filter[data-filter="trend"].active,
.gm-news-filter[data-filter="trend"]:hover      { background: #EC4899; border-color: #EC4899; }
.gm-news-hero-desc {
  font-size: 16px; color: var(--text-sub); line-height: 1.7;
  margin-bottom: 28px;
}
.gm-news-filter-row .gm-news-filters { margin-bottom: 0; }

/* Featured card */
a.gm-news-featured,
.gm-news-featured {
  background: linear-gradient(135deg, #FF7F00, #FFA100, #FF7F00, #FFA100);
  background-size: 400% 400%;
  animation: gm-featured-grad 4s linear infinite;
  border-radius: 16px;
  padding: 32px 32px;
  color: #fff;
  display: flex; flex-direction: column; gap: 8px;
  text-decoration: none;
  transition: opacity 0.2s;
}
a.gm-news-featured:hover { opacity: 0.92; }
.gm-news-featured-tag {
  display: inline-block;
  padding: 5px 14px; border-radius: 20px;
  background: #fff;
  color: #FF7F00;
  font-size: 12px; font-weight: 700; letter-spacing: 1px;
  width: fit-content;
}
.gm-news-featured-top {
  display: flex; justify-content: space-between; align-items: center;
}
.gm-news-featured-date { font-size: 14px; color: rgba(255,255,255,0.75); margin: 0; }
.gm-news-featured-title {
  font-size: 24px; font-weight: 700; line-height: 1.4;
  letter-spacing: -0.3px; margin: 0;
}
.gm-news-featured-desc {
  font-size: 16px; color: rgba(255,255,255,0.75); line-height: 1.7; margin: 0;
}
.gm-news-featured-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 14px; font-weight: 500; color: rgba(255,255,255,0.85);
  margin-top: auto; padding-top: 16px;
  transition: color 0.2s;
}
.gm-news-featured-link:hover { color: #fff; }

/* Grid */
.gm-news-grid-section {
  padding: 60px max(40px, calc((100vw - 1440px) / 2 + 40px)) 80px;
  background: var(--white);
}
.gm-news-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.gm-news-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 36px 32px 32px;
  display: flex; flex-direction: column; gap: 16px;
  min-height: 320px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.04);
  transition: box-shadow 0.3s, transform 0.25s ease;
}
.gm-news-card:hover {
  box-shadow: 0 12px 32px rgba(0,0,0,0.09);
  transform: translateY(-4px);
}
.gm-news-card-top {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
}
.gm-news-tag {
  display: inline-block; padding: 4px 12px; border-radius: 20px;
  font-size: 14px; font-weight: 700;
  background: rgba(249,115,22,0.1); color: #F97316;
}
/* 카테고리별 태그 색상 */
.gm-news-card[data-cat="philosophy"] .gm-news-tag {
  background: rgba(99,102,241,0.1); color: #6366F1;
}
.gm-news-card[data-cat="portfolio"] .gm-news-tag {
  background: rgba(16,185,129,0.1); color: #10B981;
}
.gm-news-card[data-cat="startup"] .gm-news-tag {
  background: rgba(234,179,8,0.12); color: #CA8A04;
}
.gm-news-card[data-cat="trend"] .gm-news-tag {
  background: rgba(236,72,153,0.1); color: #EC4899;
}
.gm-tag-new {
  background: var(--blue) !important; color: #fff !important;
}
.gm-news-date { font-size: 14px; color: var(--text-light); white-space: nowrap; }
.gm-news-card-title {
  font-size: 24px; font-weight: 700; color: var(--text);
  line-height: 1.5; margin: 0;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical;
  overflow: hidden;
}
.gm-news-card-desc {
  font-size: 16px; color: var(--text-sub); line-height: 1.65; margin: 0;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical;
  overflow: hidden;
}
.gm-news-card-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 14px; font-weight: 500; color: var(--text-sub);
  margin-top: auto; align-self: flex-start;
  transition: color 0.2s;
}
.gm-news-card-link:hover { color: var(--blue); }

/* Load more */
.gm-news-load-wrap { text-align: center; margin-top: 48px; }
.gm-news-load-btn {
  padding: 14px 48px; border: 1.5px solid var(--border);
  border-radius: 0; background: var(--white);
  font-size: 16px; font-weight: 600; font-family: var(--font);
  color: var(--text); cursor: pointer; transition: all 0.2s;
}
.gm-news-load-btn:hover { border-color: var(--blue); color: var(--blue); }

/* Newsletter (dark) */
.gm-news-letter {
  background: var(--navy);
  padding: 80px max(40px, calc((100vw - 1440px) / 2 + 40px));
}
.gm-news-letter-inner {
  display: flex; align-items: flex-start;
  justify-content: space-between; gap: 60px; flex-wrap: wrap;
}
.gm-news-letter-title {
  font-size: 36px; font-weight: 700; color: #fff;
  margin: 8px 0 16px; letter-spacing: -0.5px;
}
.gm-news-letter-desc {
  font-size: 16px; color: rgba(255,255,255,0.55); line-height: 1.8;
}
.gm-news-letter-forms {
  display: flex; flex-direction: column; gap: 14px; min-width: 340px;
}
.gm-nl-input-dark {
  background: rgba(255,255,255,0.07);
  border-color: rgba(255,255,255,0.15);
  color: #fff;
}
.gm-nl-input-dark::placeholder { color: rgba(255,255,255,0.45); }
.gm-nl-input-dark:focus { border-color: var(--blue); }
.gm-btn-ghost-light {
  background: transparent; color: #fff;
  border: 1.5px solid rgba(255,255,255,0.3);
}
.gm-btn-ghost-light:hover { border-color: var(--blue); color: var(--blue); }

/* ── NEWS MOBILE ── */
@media (max-width: 768px) {
  .gm-news-hero { padding: 60px 20px 40px; }
  .gm-news-hero-inner {
    display: flex; flex-direction: column; gap: 20px;
  }
  .gm-news-featured { order: 2; margin-top: 0; align-self: auto; }
  .gm-news-filter-row { order: 3; padding-bottom: 0; }
  .gm-news-hero-title { font-size: 30px; margin: 12px 0 28px; }
  .gm-news-hero-desc { margin-bottom: 0; }
  .gm-news-featured { padding: 28px 24px; }
  .gm-news-featured-title { font-size: 24px; }
  .gm-news-grid-section { padding: 48px 20px 60px; }
  .gm-news-grid { grid-template-columns: 1fr; gap: 16px; }
  .gm-news-letter { padding: 60px 20px; }
  .gm-news-letter-inner { flex-direction: column; gap: 32px; }
  .gm-news-letter-title { font-size: 26px; }
  .gm-news-letter-forms { min-width: unset; width: 100%; }
  .gm-nl-form { flex-direction: column; }
  .gm-nl-input-dark { width: 100%; }
}

/* ── RESPONSIVE NAV ── */
@media (max-width: 768px) {
  .gm-nav-inner { padding: 0 20px; gap: 16px; justify-content: flex-start; }
  .gm-logo { margin-left: 0; }
  .gm-nav-links, .gm-nav-right { display: none; }
  .gm-hamburger { display: flex; margin-left: auto; }
  .gm-footer-top { flex-direction: column; align-items: flex-start; gap: 24px; }
  .gm-footer-nav { flex-wrap: wrap; gap: 16px; }
  .gm-footer-bottom { flex-direction: column; align-items: flex-start; gap: 8px; }
  .gm-footer-inner { padding: 0 20px; }

  /* 모바일 좌우 패딩 재설정 */
  .gm-impact,
  .gm-stats,
  .gm-process,
  .gm-criteria,
  .gm-values,
  .gm-portfolio,
  .gm-programs,
  .gm-faq,
  .gm-cta-banner,
  .gm-newsletter {
    padding-left: 20px;
    padding-right: 20px;
  }

  /* HERO */
  .gm-hero { padding: 80px 0 70px; }
  .gm-hero-inner { padding: 0 20px; }
  .gm-hero-eyebrow { font-size: 11px; letter-spacing: 0.5px; word-break: keep-all; }
  .gm-hero-title { font-size: 34px; }
  .gm-hero-sub { font-size: 18px; }
  .gm-hero-desc { font-size: 16px; }
  .gm-br-pc { display: none; }
  .gm-br-mobile { display: inline; }

  /* IMPACT */
  .gm-impact { padding: 42px 42px; }
  .gm-impact-inner { align-items: center; }
  .gm-impact-headline { font-size: 32px; word-break: keep-all; }
  .gm-impact-text { font-size: 16px; word-break: keep-all; }

  /* SHARED */

  .gm-section-title { font-size: 32px; margin-bottom: 32px; }

  /* STATS */
  .gm-stats { padding: 70px 20px; }
  .gm-stats-grid { grid-template-columns: 1fr; gap: 16px; }
  .gm-stat-card { padding: 28px 24px; }
  .gm-stat-num { font-size: 22px; }

  /* PROCESS */
  .gm-process { padding: 70px 20px; }
  .gm-process-steps { grid-template-columns: 1fr; gap: 32px; }
  .gm-step { padding-right: 0; padding-bottom: 0; }
  .gm-step-line { margin-bottom: 16px; }

  /* CRITERIA */
  .gm-criteria { padding: 70px 20px; }
  .gm-criteria-grid { grid-template-columns: 1fr; gap: 16px; }
  .gm-criteria-card { padding: 28px 24px; }

  /* VALUES */
  .gm-values { padding: 70px 20px; }
  .gm-values-grid { grid-template-columns: 1fr; gap: 16px; }
  .gm-value-item { padding: 28px 24px; }

  /* PORTFOLIO */
  .gm-portfolio { padding: 70px 20px; }
  .gm-portfolio-inner { flex-direction: column; gap: 32px; }
  .gm-portfolio-head { flex: none; width: 100%; }
  .gm-portfolio-title { font-size: 32px; }
  .gm-portfolio-slider-wrap { width: calc(100% + 40px); margin-left: -20px; padding: 12px 20px; overflow: hidden; }
  .gm-pf-card { flex: 0 0 260px; height: auto; }
  .gm-pf-nav--desktop { display: none; }
  .gm-pf-nav--mobile { display: flex; margin-top: 20px; justify-content: center; }

  /* PROGRAMS */
  .gm-programs { padding: 70px 20px; }
  .gm-programs-grid { grid-template-columns: 1fr; }

  /* FAQ */
  .gm-faq { padding: 70px 20px; }
  .gm-faq-inner { grid-template-columns: 1fr; gap: 32px; }
  .gm-faq-q span { font-size: 16px; }

  /* CTA */
  .gm-cta-banner { padding: 70px 20px; }
  .gm-cta-stats { gap: 36px; }
  .gm-cta-num { font-size: 40px; }
  .gm-cta-title { font-size: 26px; }

  /* NEWSLETTER */
  .gm-newsletter { padding: 60px 20px; }
  .gm-nl-inner { flex-direction: column; align-items: flex-start; }
  .gm-nl-form { width: 100%; }
  .gm-nl-input { width: 100%; }
}

/* ── CONTACT MODAL ── */
.gm-modal-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,0.5);
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
  opacity: 0; pointer-events: none;
  transition: opacity 0.25s ease;
  overflow-y: auto;
  scrollbar-width: none;
}
.gm-modal-overlay::-webkit-scrollbar { display: none; }
.gm-modal-overlay.is-open {
  opacity: 1; pointer-events: all;
}
.gm-modal {
  background: #fff; border-radius: 16px;
  padding: 48px 48px 40px;
  width: 100%; max-width: 560px;
  max-height: 90vh; overflow-y: auto;
  position: relative;
  transform: translateY(20px);
  transition: transform 0.25s ease;
}
.gm-modal-overlay.is-open .gm-modal {
  transform: translateY(0);
}
.gm-modal-close {
  position: absolute; top: 20px; right: 24px;
  background: none; border: none; cursor: pointer;
  font-size: 24px; color: #999; line-height: 1;
  transition: color 0.15s;
}
.gm-modal-close:hover { color: #111; }
.gm-modal-label {
  font-size: 14px; font-weight: 700; letter-spacing: 0.08em;
  color: var(--blue); margin-bottom: 10px;
}
.gm-modal-title {
  font-size: 28px; font-weight: 700; color: #111;
  margin-bottom: 28px; line-height: 1.3;
}
.gm-modal-cats {
  display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 28px;
}
.gm-modal-cat {
  padding: 6px 14px; border-radius: 999px;
  border: 1.5px solid #e0e0e0; background: #fff;
  font-size: 14px; font-weight: 500; color: #555;
  cursor: pointer; transition: all 0.15s;
}
.gm-modal-cat:hover { border-color: var(--blue); color: var(--blue); }
.gm-modal-cat.active { background: rgba(249,115,22,0.08); border-color: var(--blue); color: var(--blue); font-weight: 600; }
.gm-modal-form { display: flex; flex-direction: column; gap: 20px; }
.gm-modal-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.gm-modal-field { display: flex; flex-direction: column; gap: 12px; }
.gm-modal-field label { font-size: 14px; font-weight: 600; color: #111; }
.gm-modal-req { color: var(--blue); }
.gm-modal-field input,
.gm-modal-field textarea {
  padding: 12px 14px; border: 1.5px solid #e8e8e8;
  border-radius: 10px; font-size: 14px; color: #111;
  background: #f7f7f9; outline: none;
  transition: border-color 0.15s;
  font-family: inherit;
}
.gm-modal-field input:focus,
.gm-modal-field textarea:focus { border-color: var(--blue); background: #fff; }
.gm-modal-field textarea { resize: vertical; min-height: 120px; }
.gm-modal-file-label { display: flex; gap: 6px; align-items: baseline; }
.gm-modal-file-desc { font-size: 12px; font-weight: 400; color: #888; }
.gm-modal-file-row { display: flex; align-items: center; gap: 14px; }
.gm-modal-file-btn {
  display: inline-flex; align-items: center;
  padding: 9px 20px; border-radius: 8px;
  border: 1.5px solid var(--blue); color: var(--blue);
  font-size: 14px; font-weight: 600; cursor: pointer;
  transition: background 0.15s;
}
.gm-modal-file-btn:hover { background: rgba(249,115,22,0.08); }
.gm-modal-file-btn input { display: none; }
.gm-modal-file-name { font-size: 14px; color: #888; }
.gm-modal-submit {
  width: 100%; padding: 18px;
  background: #111; color: #fff; border: none;
  border-radius: 12px; font-size: 16px; font-weight: 700;
  cursor: pointer; transition: background 0.15s;
  font-family: inherit; margin-top: 4px;
}
.gm-modal-submit:hover { background: #333; }
.gm-modal-note { font-size: 14px; color: #999; text-align: center; }
@media (max-width: 600px) {
  .gm-modal { padding: 36px 24px 32px; }
  .gm-modal-row { grid-template-columns: 1fr; }
  .gm-modal-title { font-size: 22px; }
}

/* ══════════════════════════════════════
   TEAM PAGE
══════════════════════════════════════ */
.gm-team-hero {
  background: var(--white);
  border-bottom: none;
}
.gm-team-section {
  padding: 0 0 100px;
  background: var(--white);
  overflow: hidden;
}
.gm-team-inner { max-width: none; }

/* PC: 슬라이더 없이 그리드 */
@media (min-width: 769px) {
  .gm-team-section { padding: 0 40px 100px; overflow: visible; }
  .gm-partner-slider-wrap {
    overflow: visible;
    padding-top: 16px;
    cursor: default;
    user-select: auto;
    -webkit-user-select: auto;
    max-width: 1440px;
    margin: 0 auto;
  }
  .gm-partner-slider {
    display: flex;
    flex-wrap: nowrap;
    gap: 24px;
    justify-content: center;
    transform: none !important;
    transition: none;
  }
  .gm-partner-slider .gm-partner-card {
    flex: 1 1 0;
    min-width: 0;
    max-width: 360px;
  }
}

/* 모바일: 슬라이더 */
@media (max-width: 768px) {
  .gm-partner-slider-wrap {
    overflow: hidden;
    padding: 12px 0 20px;
    margin: -12px 0 -20px;
    cursor: grab;
    user-select: none;
    -webkit-user-select: none;
  }
  .gm-partner-slider-wrap:active { cursor: grabbing; }
  .gm-partner-slider {
    display: flex;
    gap: 24px;
    flex-wrap: nowrap;
    justify-content: flex-start;
    transition: transform 0.45s cubic-bezier(0.22, 0.61, 0.36, 1);
  }
  .gm-partner-slider .gm-partner-card {
    flex: 0 0 calc(100vw - 40px);
  }
}

/* Partner card — 이미지 상단, 텍스트 하단 */
.gm-partner-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  display: flex; flex-direction: column;
  box-shadow: 0 2px 12px rgba(0,0,0,0.04);
  transition: box-shadow 0.3s, transform 0.25s ease;
}
.gm-partner-card:hover {
  box-shadow: 0 12px 32px rgba(0,0,0,0.09);
  transform: translateY(-4px);
}

/* Photo wrap */
.gm-partner-photo-wrap {
  width: 100%;
  aspect-ratio: 670 / 784;
  flex-shrink: 0;
  overflow: hidden;
  background: var(--bg);
  display: flex; align-items: center; justify-content: center;
}
.gm-partner-photo { width: 100%; height: 100%; object-fit: cover; object-position: top center; }
.gm-partner-photo-placeholder {
  font-size: 40px; font-weight: 700;
  color: var(--border); line-height: 1;
}

/* Info panel */
.gm-partner-info {
  padding: 16px 18px 20px;
  display: flex; flex-direction: column; flex: 1;
}
.gm-partner-name-wrap {
  display: flex; flex-direction: column; gap: 2px;
  margin-bottom: 10px;
}
.gm-partner-name {
  font-size: 24px; font-weight: 700; color: var(--text); margin: 0;
  letter-spacing: -0.3px; white-space: nowrap;
}
.gm-partner-name-en {
  font-size: 13px; font-weight: 400; color: var(--text-light); margin: 0;
}
.gm-partner-role {
  font-size: 14px; font-weight: 600; color: var(--blue);
  margin: 0 0 10px;
}
.gm-partner-capital {
  display: inline-block;
  font-size: 12px; font-weight: 600;
  color: var(--text-sub);
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 20px;
  padding: 3px 10px; margin-bottom: 12px;
  width: fit-content;
}
.gm-partner-career {
  list-style: none; padding: 0; margin: 0 0 12px;
  display: flex; flex-direction: column; gap: 3px;
  flex: 1;
  max-height: 220px;
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}
.gm-partner-career::-webkit-scrollbar {
  width: 4px;
}
.gm-partner-career::-webkit-scrollbar-track {
  background: transparent;
}
.gm-partner-career::-webkit-scrollbar-thumb {
  background: var(--border);
  border-radius: 2px;
}
.gm-partner-career li {
  font-size: 14px; color: var(--text-sub); line-height: 1.55;
  padding-left: 12px; position: relative;
}
.gm-partner-career li::before {
  content: '·';
  position: absolute; left: 2px;
  color: var(--blue); font-weight: 700;
}
.gm-partner-message {
  font-size: 14px; font-weight: 600;
  color: var(--text); line-height: 1.5;
  padding: 10px 0 0;
  border-top: 1px solid var(--border);
  margin-top: auto;
}

/* Responsive */
@media (max-width: 1024px) {
  .gm-partner-slider .gm-partner-card { flex: 0 0 320px; }
}
/* 모바일 슬라이더 네비 버튼 */
.gm-team-mobile-nav {
  display: none;
}
@media (max-width: 768px) {
  .gm-team-mobile-nav {
    display: none;
  }
  .gm-team-nav-btn {
    width: 44px; height: 44px;
    border-radius: 50%;
    border: 1.5px solid var(--border);
    background: var(--white);
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    color: var(--text);
    transition: background 0.2s, border-color 0.2s;
  }
  .gm-team-nav-btn:hover:not(:disabled) {
    background: var(--bg);
    border-color: var(--text-sub);
  }
  .gm-team-nav-btn:disabled {
    opacity: 0.3;
    cursor: default;
  }
  .gm-team-nav-counter {
    font-size: 14px;
    color: var(--text-sub);
    min-width: 40px;
    text-align: center;
  }
  .gm-team-section { padding: 0px 20px 72px !important; }
  .gm-team-hero { padding-bottom: 20px !important; }

  /* 2x2 그리드 */
  .gm-partner-slider-wrap { overflow: visible; cursor: default; }
  .gm-partner-slider {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    flex-wrap: unset;
    transform: none !important;
    transition: none !important;
    justify-content: unset;
  }
  .gm-partner-slider .gm-partner-card {
    flex: unset;
    width: 100%;
    cursor: pointer;
  }

  /* 모바일 카드 — 사진 + 이름/직책만 표시 */
  .gm-partner-card .gm-partner-career,
  .gm-partner-card .gm-partner-message,
  .gm-partner-card .gm-partner-capital { display: none; }
  .gm-partner-info { padding: 12px 14px 16px; }
  .gm-partner-name { font-size: 18px; }
  .gm-partner-name-en { font-size: 11px; }
  .gm-partner-role { font-size: 12px; margin-bottom: 6px; }
  .gm-partner-name-wrap { margin-bottom: 4px; }

  /* 모바일 팀원 모달 */
  .gm-team-modal-overlay {
    display: none;
    position: fixed; inset: 0; z-index: 9100;
    background: rgba(0,0,0,0.55);
    align-items: flex-end;
    justify-content: center;
    padding: 0;
  }
  .gm-team-modal-overlay.is-open { display: flex; }
  .gm-team-modal {
    background: var(--white);
    border-radius: 20px 20px 0 0;
    width: 100%;
    max-height: 80vh;
    max-height: 80svh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding: 20px 20px calc(40px + env(safe-area-inset-bottom));
    position: relative;
  }
  .gm-team-modal-handle {
    width: 40px; height: 4px;
    background: var(--border);
    border-radius: 999px;
    margin: 0 auto 20px;
    cursor: pointer;
  }
  .gm-team-modal-content .gm-partner-card {
    border: none; box-shadow: none; border-radius: 0;
    display: flex; flex-direction: column;
  }
  .gm-team-modal-content .gm-partner-photo-wrap {
    width: 100%; aspect-ratio: unset;
    height: auto;
    border-radius: 12px; overflow: hidden;
    margin-bottom: 16px;
  }
  .gm-team-modal-content .gm-partner-photo {
    width: 100%; height: auto;
    object-fit: unset;
  }
  .gm-team-modal-content .gm-partner-career,
  .gm-team-modal-content .gm-partner-message,
  .gm-team-modal-content .gm-partner-capital { display: block !important; }
  .gm-team-modal-content .gm-partner-career { display: flex !important; max-height: none; }
  .gm-team-modal-content .gm-partner-info { padding: 0; }
  .gm-team-modal-content .gm-partner-name { font-size: 22px; }
}

/* ── IN-HOUSE 섹션 ── */
.gm-inhouse-section {
  padding: 100px max(20px, calc((100vw - 1440px) / 2 + 40px)) 100px;
  background: var(--bg);
  border-top: 1px solid var(--border);
}
.gm-inhouse-inner {
  max-width: 860px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0;
}
.gm-inhouse-badge {
  display: inline-block;
  font-size: 12px; font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--blue);
  border: 1.5px solid var(--blue);
  border-radius: 999px;
  padding: 6px 18px;
  margin-bottom: 20px;
}
.gm-inhouse-title {
  font-size: clamp(32px, 4vw, 52px);
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -1px;
  color: var(--text);
  margin: 0 0 28px;
}
.gm-inhouse-title strong { color: var(--blue); font-weight: 800; }
.gm-inhouse-desc {
  font-size: 18px;
  font-weight: 400;
  color: var(--text-sub);
  line-height: 1.5;
  margin: 0 0 16px;
}
.gm-inhouse-desc strong { color: var(--text); font-weight: 700; }
.gm-inhouse-sub {
  font-size: 14px;
  color: var(--text-light);
  line-height: 1.7;
  margin: 0 0 32px;
}
.gm-inhouse-logo {
  width: 320px;
  max-width: 100%;
  height: auto;
  object-fit: contain;
  border-radius: 12px;
  opacity: 0;
  transform: translateY(60px);
  transition: opacity 2s ease, transform 1s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.gm-inhouse-logo.is-visible {
  opacity: 1;
  transform: translateY(0);
}
@media (max-width: 768px) {
  .gm-inhouse-section { padding: 60px 20px 60px; }
  .gm-inhouse-title { font-size: 28px; }
  .gm-inhouse-desc { font-size: 16px; }
}

/* ── 협력 업체 섹션 ── */
.gm-partners-section {
  padding: 80px max(20px, calc((100vw - 1440px) / 2 + 40px)) 100px;
  background: var(--white);
  border-top: 1px solid var(--border);
}
.gm-partners-inner {
  max-width: 1200px;
}
.gm-partners-title {
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -0.5px;
  color: var(--text);
  margin: 12px 0 36px;
}
.gm-partners-logos {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  margin-top: 32px;
}
.gm-partners-logo-item {
  flex: 0 0 calc(16.666% - 17px);
  height: 80px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 12px;
}
@media (max-width: 1024px) {
  .gm-partners-logo-item { flex: 0 0 calc(25% - 15px); }
}
@media (max-width: 768px) {
  .gm-partners-section { padding: 60px 20px 72px; }
  .gm-partners-logo-item { flex: 0 0 calc(33.333% - 14px); }
}

/* ══════════════════════════════════════
   EVENTS PAGE
══════════════════════════════════════ */
.gm-events-section {
  padding: 60px max(20px, calc((100vw - 1440px) / 2 + 40px)) 100px;
  background: var(--white);
}
.gm-events-inner { display: flex; flex-direction: column; gap: 56px; }

/* 그룹 헤더 */
.gm-ev-group-header {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 24px;
  padding-bottom: 16px;
  position: relative;
  justify-content: flex-start;
}
.gm-ev-group-header::after {
  content: '';
  position: absolute; bottom: 0; height: 1px;
  background: var(--border);
  left: 0;
  right: 0;
}
.gm-ev-status {
  font-size: 16px; font-weight: 700; letter-spacing: 0.5px;
  padding: 5px 16px; border-radius: 20px;
}
.gm-ev-status--active  { background: #10B981; color: #fff; }
.gm-ev-status--upcoming { background: var(--blue); color: #fff; }
.gm-ev-status--ended   { background: var(--bg); color: var(--text-sub); border: 1.5px solid var(--border); }
.gm-ev-empty {
  color: var(--text-sub); font-size: 24px;
  display: flex; align-items: center; justify-content: center;
  width: 100%; padding: 80px 0;
  text-align: center;
}
[data-group="종료"] .gm-events-grid { position: relative; }
[data-group="종료"] .gm-event-card {
  position: relative;
  filter: grayscale(40%);
}
[data-group="종료"] .gm-event-card::after {
  content: '';
  position: absolute; inset: 0;
  background: rgba(255,255,255,0.62);
  border-radius: 16px;
  pointer-events: none;
}
.gm-events-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.gm-event-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  display: flex; flex-direction: column;
  box-shadow: 0 2px 12px rgba(0,0,0,0.04);
  transition: box-shadow 0.3s, transform 0.25s ease;
  cursor: pointer;
}
.gm-event-card:hover {
  box-shadow: 0 12px 32px rgba(0,0,0,0.09);
  transform: translateY(-4px);
}
.gm-event-thumb {
  width: 100%;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background: var(--bg);
}
.gm-event-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}
.gm-event-info {
  padding: 16px 18px 20px;
  display: flex; flex-direction: column; gap: 8px;
}
.gm-event-meta { display: flex; align-items: center; gap: 10px; }
.gm-event-tag {
  font-size: 14px; font-weight: 700;
  color: var(--blue);
  background: rgba(255,152,0,0.08);
  border-radius: 20px;
  padding: 3px 10px;
}
.gm-event-date { font-size: 14px; color: var(--text-light); }
.gm-event-title {
  font-size: 24px; font-weight: 700;
  color: var(--text); line-height: 1.4; margin: 0;
}
.gm-event-desc {
  font-size: 14px; color: var(--text-sub);
  line-height: 1.6; margin: 0;
}
@media (max-width: 1024px) {
  .gm-events-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .gm-events-section { padding: 48px 20px 72px; }
  .gm-events-grid { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════
   PROGRAM PAGE
══════════════════════════════════════ */
.gm-prog-section {
  padding: 60px max(20px, calc((100vw - 1440px) / 2 + 40px)) 100px;
  background: var(--white);
}
.gm-prog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  align-items: start;
}
.gm-prog-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  display: flex; flex-direction: column;
  box-shadow: 0 2px 12px rgba(0,0,0,0.04);
  transition: box-shadow 0.3s, transform 0.25s ease;
  text-decoration: none;
}
.gm-prog-card:hover {
  box-shadow: 0 12px 32px rgba(0,0,0,0.09);
  transform: translateY(-4px);
}
.gm-prog-thumb {
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--bg);
  flex-shrink: 0;
}
.gm-prog-img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  transition: transform 0.4s ease;
}
.gm-prog-card:hover .gm-prog-img { transform: scale(1.04); }
.gm-prog-img-placeholder {
  width: 100%; height: 100%;
  background: linear-gradient(135deg, var(--bg), var(--border));
}
.gm-prog-info {
  padding: 28px 26px 32px;
  display: flex; flex-direction: column; gap: 12px;
  flex: 1;
  min-height: 320px;
}
.gm-prog-meta { display: flex; align-items: center; gap: 10px; margin-bottom: 4px; }
.gm-prog-meta .gm-prog-tag {
  font-size: 13px; font-weight: 700;
  color: var(--blue);
  background: rgba(255,152,0,0.08);
  border-radius: 20px;
  padding: 5px 14px;
  margin-bottom: 0;
}
.gm-prog-date { font-size: 15px; font-weight: 600; color: var(--text-sub); line-height: 1; }
.gm-prog-title {
  font-size: 26px; font-weight: 800;
  color: var(--text); line-height: 1.3; margin: 0;
}
.gm-prog-desc {
  font-size: 16px; color: var(--text-sub);
  line-height: 1.75; margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.gm-prog-link {
  font-size: 13px; font-weight: 600;
  color: var(--blue); margin-top: 4px;
}
.gm-prog-empty {
  grid-column: 1 / -1;
  color: var(--text-sub); padding: 60px 0; text-align: center;
}
@media (max-width: 768px) {
  .gm-prog-section { padding: 48px 20px 72px; }
  .gm-prog-grid { grid-template-columns: 1fr; gap: 16px; }
}
