﻿/* ═══════════════════════════════════════════════════
   SOLUTION COMMON — magellan 등 솔루션 페이지 공통
═══════════════════════════════════════════════════ */

.page-solution #sub-main { padding-top: 0; background: var(--us-ink-000); }

/* ── 섹션 공통 padding ── */
.mg-about,
.mg-arch,
.mg-manager,
.mg-env,
.mg-pricing {
  padding: 80px 0 120px 0;
}

/* keyframes·reveal·hero-inner: main.css 공통 유틸리티로 통합 */


/* ═══════════════════════════════════════════════════
   ① HERO
═══════════════════════════════════════════════════ */

.mg-hero-inner { animation: none; }
.mg-hero-inner::before {
  background: url('../imgs/solution/mg-hero-bg.webp') right / cover no-repeat;
  animation: subHeroZoomOut 2.0s cubic-bezier(0.16, 1, 0.3, 1) both;
}

/* .mg-hero-text { max-width: 640px; } */

.mg-hero-label {
  font-weight: 600;
  color: var(--bg-magellan);
  margin-bottom: 20px;
}

.mg-hero-visual {
  flex: 0 0 42%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mg-hero-visual img {
  width: 100%;
  height: auto;
  display: block;
}


/* ═══════════════════════════════════════════════════
   ② 마이슈트 마젤란 (소개 + 카드 그리드)
═══════════════════════════════════════════════════ */

.mg-label {
  font-weight: 700;
  color: var(--us-blue-700);
  margin-bottom: 14px;
}

.mg-card {
  align-items: center;
  transition: opacity 0.9s var(--ease-out), transform 0.9s var(--ease-out),
              border-color 0.3s var(--ease-out), box-shadow 0.3s var(--ease-out);
}

.mg-card:last-child { grid-column: 1 / -1; }

.mg-card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.mg-card-icon img { width: 52px; height: 52px; }

.mg-card-title {
  font-size: var(--fs-body-lg);
  font-weight: 500;
  margin: 0;
  letter-spacing: var(--ls);
  flex: 1;
}

.mg-card-desc {
  font-size: var(--fs-body-sm);
  color: var(--us-ink-500);
  line-height: 1.75;
  margin: 0;
  letter-spacing: var(--ls);
}


/* ═══════════════════════════════════════════════════
   ③ 서비스 구성도
═══════════════════════════════════════════════════ */

.mg-arch-img-wrap {
  width: 100%;
  border-radius: var(--r-lg);
  overflow: hidden;
}

.mg-arch-img-wrap img {
  width: 100%;
  height: auto;
  display: block;
}

/* ── ③ 서비스 구성도 다이어그램 ── */
.mg-archdiag-wrap {
  display: flex;
  align-items: stretch;
  gap: 0;
  position: relative;
}

.mg-archdiag-fallback { display: none; width: 100%; height: auto; }

/* 좌측 패널 */
.mg-archdiag-lpanel {
  flex: 0 0 38%;
  background: #EEF2FF;
  border: 1.5px dashed var(--bg-magellan);
  border-radius: var(--r-xl);
  padding: 24px 20px 20px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.mg-archdiag-lphd {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-bottom: 14px;
}

.mg-archdiag-logo,
.mg-mgrdiag-logo {
  border-radius: var(--r-pill);
  overflow: hidden;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mg-archdiag-logo img,
.mg-mgrdiag-logo img { width: 100%; height: 100%; object-fit: cover; display: block; }

.mg-archdiag-logo { width: 40px; height: 40px; background: var(--us-ink-000); }

.mg-archdiag-lphd-title {
  font-size: var(--fs-body-lg);
  font-weight: 700;
  color: var(--bg-magellan);
  letter-spacing: var(--ls);
  margin: 0;
}

/* 바디: 노드 + 항목 */
.mg-archdiag-lbody {
  display: flex;
  gap: 14px;
  flex: 1;
}

.mg-archdiag-nodes,
.mg-archdiag-dbleft {
  flex: 0 0 160px;
  width: 160px;
}

.mg-archdiag-nodes {
  display: flex;
  flex-direction: column;
  gap: 12px;
  justify-content: space-around;
}

.mg-archdiag-dbleft {
  display: flex;
  align-items: center;
  gap: 10px;
}

.mg-archdiag-node {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 10px;
}

.mg-archdiag-node-bg {
  width: 72px;
  height: 72px;
  border-radius: var(--r-pill);
  background: #DDE3FF;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.mg-archdiag-node-bg img {
  width: 52px;
  height: 52px;
  object-fit: contain;
  display: block;
}

.mg-archdiag-node-label {
  font-size: var(--fs-body);
  font-weight: 600;
  color: var(--bg-magellan);
  letter-spacing: var(--ls);
  line-height: 1.35;
  text-align: center;
}

.mg-archdiag-litems {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 5px;
  justify-content: space-between;
}

.mg-archdiag-litem,
.mg-archdiag-api-item,
.mg-archdiag-storage-item {
  background: var(--us-ink-000);
  border: 1px solid var(--us-ink-150);
  border-radius: var(--r-sm);
  padding: 10px;
  font-size: var(--fs-body);
  text-align: center;
  letter-spacing: var(--ls);
}
.mg-archdiag-litem,
.mg-archdiag-api-item {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* 하단 Database 행: [아이콘] [Database] [PostgreSQL 박스] */
.mg-archdiag-dbrow {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 14px;
  padding-top: 12px;
}

.mg-archdiag-dbrow .mg-archdiag-node-label {
  flex: 1;
  white-space: nowrap;
}

/* PostgreSQL 박스 */
.mg-archdiag-db {
  flex: 1;
  border: 1.5px dashed var(--us-ink-300);
  border-radius: var(--r-md);
  padding: 10px 14px;
  background: var(--us-ink-000);
  text-align: center;
  font-size: var(--fs-body);
  letter-spacing: var(--ls);
}

.mg-archdiag-db p              { display: block; margin: 0; }
.mg-archdiag-db p:last-child   { color: var(--us-ink-500); margin-top: 2px; }

/* 중앙 커넥터 */
.mg-archdiag-connector {
  flex: 0 0 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.mg-archdiag-connector-label,
.mg-archdiag-method-label {
  color: var(--bg-eform);
  font-size: var(--lh-body-sm);
  font-weight: 700;
  letter-spacing: var(--ls);
  position: absolute;
  top: calc(50% - 24px);
  z-index: 2;
  white-space: nowrap;
}

.mg-archdiag-connector-label { padding: 2px 6px; }
.mg-archdiag-method-label    { padding: 2px 5px; }

/* 우측 패널 */
.mg-archdiag-rpanel {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.mg-archdiag-rtitle {
  font-size: var(--fs-body-lg);
  color: var(--us-ink-600);
  letter-spacing: var(--ls);
  margin: 0 0 14px;
}

/* Report & e-Form Container / Storage 공통 */
.mg-archdiag-rcontainer,
.mg-archdiag-storage {
  border: 1.5px dashed var(--bg-eform);
  border-radius: var(--r-xl);
  background: var(--us-paper-warm);
  padding: 20px;
}

.mg-archdiag-rcontainer { flex: 1; }

.mg-archdiag-rcontainer-body {
  display: flex;
  align-items: center;
  gap: 30px;
  height: calc(100% - 42px);
}

/* API Management */
.mg-archdiag-api {
  flex: 1;
  border: 1.5px dashed var(--bg-eform);
  border-radius: var(--r-lg);
  overflow: hidden;
  align-self: stretch;
  display: flex;
  flex-direction: column;
}

.mg-archdiag-api-hd {
  background: var(--bg-eform);
  color: var(--fg-white);
  font-size: var(--fs-body);
  padding: 8px 14px;
  text-align: center;
  letter-spacing: var(--ls);
}

.mg-archdiag-api-items {
  padding: 10px;
  display: flex;
  flex-direction: column;
  gap: 5px;
  flex: 1;
  justify-content: space-between;
}

/* Method call */
.mg-archdiag-method {
  flex: 0 0 52px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}


/* Main Service */
.mg-archdiag-service {
  flex: 0 0 150px;
  background: var(--us-ink-000);
  border: 1.5px dashed var(--bg-eform);
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  align-self: stretch;
}

.mg-archdiag-service p {
  font-size: var(--fs-body);
  line-height: 1.55;
  margin: 0;
  letter-spacing: var(--ls);
}

/* 수직 화살표 */
.mg-archdiag-varrow {
  height: 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  flex-shrink: 0;
}


/* Storage */

.mg-archdiag-storage-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}




/* ═══════════════════════════════════════════════════
   ④ 매니저 앱
═══════════════════════════════════════════════════ */

.mg-mgrdiag-wrap {
  display: grid;
  grid-template-columns: 1.7fr 1fr;
  grid-template-rows: auto;
  row-gap: 0;
  column-gap: 20px;
  position: relative;
}

.mg-mgrdiag-img-fallback {
  display: none;
  width: 100%;
  height: auto;
}

/* ── 헤더 셀 ── */
.mg-mgrdiag-lhd,
.mg-mgrdiag-rhd {
  padding: 24px 24px 16px;
}

/* 좌측 패널 시각: lhd + lrow 전체를 왼쪽 border로 감쌈 */
.mg-mgrdiag-lhd {
  background: #EEF2FF;
  border: 1.5px dashed var(--bg-magellan);
  border-bottom: none;
  border-radius: var(--r-xl) var(--r-xl) 0 0;
}

.mg-mgrdiag-lrow {
  background: #EEF2FF;
  border-left: 1.5px dashed var(--bg-magellan);
  border-right: 1.5px dashed var(--bg-magellan);
  padding: 0 24px 8px;
}

.mg-mgrdiag-lrow--last {
  border-bottom: 1.5px dashed var(--bg-magellan);
  border-radius: 0 0 var(--r-xl) var(--r-xl);
  padding-bottom: 20px;
}

/* 우측 패널 시각 */
.mg-mgrdiag-rhd {
  background: var(--us-paper-warm);
  border: 1.5px dashed var(--bg-eform);
  border-bottom: none;
  border-radius: var(--r-xl) var(--r-xl) 0 0;
}

.mg-mgrdiag-rcell {
  background: var(--us-paper-warm);
  border-left: 1.5px dashed var(--bg-eform);
  border-right: 1.5px dashed var(--bg-eform);
  padding: 0 24px 8px;
  display: flex;
  align-items: center;
}

.mg-mgrdiag-rcell--last {
  border-bottom: 1.5px dashed var(--bg-eform);
  border-radius: 0 0 var(--r-xl) var(--r-xl);
  padding-bottom: 20px;
}

@keyframes mgLineDash {
  to { stroke-dashoffset: -18; }
}

/* ── ③ 서비스 구성도 뷰포트 진입 애니메이션 ── */
.mg-archdiag-lpanel,
.mg-archdiag-connector,
.mg-archdiag-rpanel {
  opacity: 0;
  transition: opacity 0.65s var(--ease-out), transform 0.65s var(--ease-out);
}
.mg-archdiag-lpanel   { transform: translateX(-24px); }
.mg-archdiag-connector { transform: translateY(10px); }
.mg-archdiag-rpanel   { transform: translateX(24px); }

.mg-archdiag-wrap.active .mg-archdiag-lpanel,
.mg-archdiag-wrap.active .mg-archdiag-connector,
.mg-archdiag-wrap.active .mg-archdiag-rpanel {
  opacity: 1;
  transform: none;
}

/* ── ④ 매니저앱 뷰포트 진입 애니메이션 ── */
.mg-mgrdiag-lhd,
.mg-mgrdiag-lrow {
  opacity: 0;
  transform: translateX(-36px);
  transition: opacity 1.0s var(--ease-out), transform 1.0s var(--ease-out);
}

.mg-mgrdiag-rhd,
.mg-mgrdiag-rcell {
  opacity: 0;
  transform: translateX(36px);
  transition: opacity 1.0s var(--ease-out), transform 1.0s var(--ease-out);
}

.mg-mgrdiag-wrap.active .mg-mgrdiag-lhd,
.mg-mgrdiag-wrap.active .mg-mgrdiag-lrow,
.mg-mgrdiag-wrap.active .mg-mgrdiag-rhd,
.mg-mgrdiag-wrap.active .mg-mgrdiag-rcell {
  opacity: 1;
  transform: none;
}

/* ── 패널 헤더 ── */
.mg-mgrdiag-phd {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 12px;
}

.mg-mgrdiag-logo { width: 52px; height: 52px; }

.mg-mgrdiag-phd-title {
  font-size: var(--fs-body-lg);
  font-weight: 700;
  letter-spacing: var(--ls);
  margin: 0;
}

.mg-mgrdiag-phd-sub {
  font-size: var(--fs-body-sm);
  color: var(--us-ink-500);
  letter-spacing: var(--ls);
}

/* ── 행 내부 row ── */
.mg-mgrdiag-row {
  display: flex;
  align-items: stretch;
  gap: 16px;
  background: var(--us-ink-000);
  border-radius: var(--r-lg);
  padding: 16px 20px;
}

.mg-mgrdiag-row-info {
  flex: 1;
  min-width: 0;
}

.mg-mgrdiag-row-info h4 {
  font-size: var(--fs-body);
  font-weight: 600;
  color: var(--us-blue-700);
  letter-spacing: var(--ls);
  margin: 0 0 5px;
  line-height: 1.45;
}

.mg-mgrdiag-row-info p {
  font-size: var(--fs-body-sm);
  color: var(--us-ink-500);
  letter-spacing: var(--ls);
  margin: 0;
  line-height: 1.5;
}

.mg-mgrdiag-row-feat {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  max-width: 320px;
  background: #EEF2FF;
  border-radius: var(--r-md);
  padding: 10px 12px;
}

.mg-mgrdiag-feat-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 52px;
  height: 52px;
}

.mg-mgrdiag-feat-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.mg-mgrdiag-feat-label {
  font-size: var(--fs-body-sm);
  font-weight: 700;
  color: var(--us-blue-700);
  text-align: center;
  line-height: 1.4;
  min-width: 72px;
  white-space: nowrap;
}

.mg-mgrdiag-feat-list {
  list-style: none;
  padding: 0;
  margin: 0;
  border-left: 1px solid var(--us-blue-200);
  padding-left: 16px;
}

.mg-mgrdiag-feat-list li,
.mg-mgrdiag-card-list li {
  font-size: var(--fs-body-sm);
  color: var(--us-ink-600);
  letter-spacing: var(--ls);
  line-height: 1.75;
  padding-left: 10px;
  position: relative;
}

.mg-mgrdiag-feat-list li::before,
.mg-mgrdiag-card-list li::before {
  content: '-';
  position: absolute;
  left: 0;
  color: var(--us-ink-400);
}

/* ── Intro (rhd 안) ── */
.mg-mgrdiag-intro {
  padding-top: 12px;
}

.mg-mgrdiag-tag {
  display: inline-block;
  background: #FFD6E8;
  color: var(--bg-eform);
  font-size: 14px;
  font-weight: 600;
  padding: 3px 14px;
  border-radius: 20px;
  border: 1.5px solid var(--bg-eform);
  margin-bottom: 10px;
  letter-spacing: var(--ls);
}

.mg-mgrdiag-intro > p {
  font-size: var(--fs-body-sm);
  color: var(--us-ink-700);
  letter-spacing: var(--ls);
  line-height: 1.65;
  margin: 0;
}

/* ── 우측 카드 ── */
.mg-mgrdiag-card {
  display: flex;
  align-items: center;
  gap: 16px;
  background: var(--us-ink-000);
  border: 1.5px dashed var(--bg-eform);
  border-radius: var(--r-md);
  padding: 16px 20px;
  width: 100%;
}

.mg-mgrdiag-card-title {
  font-size: var(--fs-body-sm);
  font-weight: 700;
  color: var(--bg-eform);
  line-height: 1.4;
  flex-shrink: 0;
  min-width: 72px;
  text-align: center;
}

.mg-mgrdiag-card-list {
  list-style: none;
  padding: 0;
  margin: 0;
  border-left: 1px solid #FFD6E8;
  padding-left: 16px;
}



/* ═══════════════════════════════════════════════════
   ⑤ 지원환경
═══════════════════════════════════════════════════ */

.mg-env { background: var(--us-paper-warm); }

.mg-env-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  /* 6 rows: img / title / desc / spec×3 — shared across both cards */
  grid-template-rows: auto auto auto auto auto auto;
  column-gap: 20px;
}

.mg-env-card {
  background: var(--us-ink-000);
  border: 1.5px solid var(--us-ink-150);
  border-radius: var(--r-lg);
  overflow: hidden;
  grid-row: 1 / 7;
  display: grid;
  grid-template-rows: subgrid;
}

.mg-env-img {
  width: 100%;
  overflow: hidden;
  padding: 32px;
  box-sizing: border-box;
}

.mg-env-img img {
  width: 100%;
  max-width: 420px;
  height: auto;
  display: block;
  margin: 0 auto;
}

.mg-env-body {
  padding: 28px 32px 32px;
  grid-row: span 5;
  display: grid;
  grid-template-rows: subgrid;
}

.mg-env-title {
  font-size: var(--fs-h4);
  font-weight: 700;
  letter-spacing: var(--ls);
  margin: 16px 0 0;
  align-self: start;
}

.mg-env-desc {
  font-size: var(--fs-body);
  color: var(--us-ink-500);
  letter-spacing: var(--ls);
  margin: 0 0 20px;
  align-self: start;
}

.mg-env-specs {
  grid-row: span 3;
  display: grid;
}

.mg-env-spec-row {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  align-self: start;
  padding-top: 10px;
}

.mg-env-spec-row:first-child {
  padding-top: 0;
}

.mg-env-spec-row dt {
  flex-shrink: 0;
  width: 88px;
  text-align: center;
  font-size: 14px;
  font-weight: 600;
  color: var(--us-ink-500);
  background: var(--us-ink-100);
  border-radius: var(--r-sm);
  padding: 3px 8px;
  letter-spacing: var(--ls);
  white-space: nowrap;
  line-height: 1.6;
  box-sizing: border-box;
}

.mg-env-spec-row dd {
  font-size: var(--fs-body-sm);
  color: var(--us-ink-500);
  letter-spacing: var(--ls);
  line-height: 1.7;
  margin: 0;
}

/* ═══════════════════════════════════════════════════
   ⑥ 비용
═══════════════════════════════════════════════════ */

.mg-pricing .mg-section-header { text-align: center; }
.mg-title-light { font-weight: 200; }


.mg-pricing-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1.5px solid var(--us-ink-150);
  border-radius: var(--r-lg);
  overflow: hidden;
}

.mg-pricing-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 48px 28px 40px;
  border-right: 1.5px solid var(--us-ink-150);
}

.mg-pricing-card:last-child { border-right: none; }

.mg-pricing-img {
  width: 100%;
  max-width: 180px;
  aspect-ratio: 1 / 1;
  border-radius: var(--r-md);
  overflow: hidden;
  margin-bottom: 36px;
}

.mg-pricing-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.mg-pricing-body { display: flex; flex-direction: column; align-items: center; gap: 16px; }

.mg-pricing-title-wrap { display: flex; flex-direction: column; align-items: center; gap: 6px; }

.mg-pricing-title {
  font-size: var(--fs-h3);
  font-weight: 700;
  letter-spacing: var(--ls);
  margin: 0;
}

.mg-pricing-en {
  font-size: var(--fs-body-sm);
  color: var(--us-ink-400);
}

.mg-pricing-desc {
  font-size: var(--fs-body-lg);
  color: var(--us-ink-500);
  letter-spacing: var(--ls);
  margin: 16px 0 0;
}

.mg-pricing-desc strong { color: var(--bg-magellan); font-weight: 700; }



/* ═══════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════ */

/* 기본: 웹/태블릿에서 줄바꿈 숨김 */
.mg-hero-desc br { display: none; }
.mg-pricing .mg-title br { display: none; }

@media (max-width: 1024px) {
  /* ① Hero */
  .mg-hero-title { font-size: clamp(32px, 4vw, 56px); }
  .mg-hero-inner { gap: 40px; }
  .mg-hero-text { flex: 0 0 55%; }
  .mg-hero-visual { flex: 0 0 40%; }

  /* ③ 서비스 구성도 */
  .mg-archdiag-wrap { display: block; }
  .mg-archdiag-lpanel,
  .mg-archdiag-connector,
  .mg-archdiag-rpanel { display: none; }
  .mg-archdiag-fallback { display: block; }

  /* ④ 매니저 앱 */
  .mg-mgrdiag-wrap { display: block; }
  .mg-mgrdiag-lhd,
  .mg-mgrdiag-lrow,
  .mg-mgrdiag-rhd,
  .mg-mgrdiag-rcell { display: none; }
  .mg-mgrdiag-img-fallback { display: block; width: 100%; }
}

@media (max-width: 820px) {
  /* 공통 */
  .mg-inner,
  .mg-hero-inner { padding: 0 24px; }
  .mg-about,
  .mg-arch,
  .mg-manager,
  .mg-env,
  .mg-pricing { padding: 80px 0; }
  .mg-section-header { margin-bottom: 48px; }

  /* ① Hero */
  .mg-hero { padding: calc(var(--header-h) + 0px) 0 0; }
  .mg-hero-inner { padding: 40px 24px; border-radius: var(--r-none); background-size: cover; }
  .mg-hero-inner .prod-breadcrumb { display: none; }
  .mg-hero-title { margin: 20px 0 0 0; }
  .mg-hero-desc { margin: 0 0 8px; }

  /* ② 마이슈트 마젤란 카드 */
  .mg-card-grid { grid-template-columns: 1fr; }
  .mg-card:last-child { grid-column: auto; }

  /* ③ 서비스 구성도 */
  .mg-arch-img-wrap { display: block; width: 100%; height: auto; }

  /* ⑤ 지원환경 */
  .mg-env-grid { grid-template-columns: 1fr; grid-template-rows: none; gap: 20px; }
  .mg-env-card { grid-row: auto; display: flex; flex-direction: column; }
  .mg-env-body { display: flex; flex-direction: column; flex: 1; }
  .mg-env-specs { display: flex; flex-direction: column; gap: 10px; margin: auto 0 0; }
  .mg-env-spec-row { padding-top: 0; align-self: auto; }

  /* ⑥ 비용 */
  .mg-pricing-grid { grid-template-columns: repeat(2, 1fr); }
  .mg-pricing-card:nth-child(2) { border-right: none; }
  .mg-pricing-card:nth-child(1),
  .mg-pricing-card:nth-child(2) { border-bottom: 1.5px solid var(--us-ink-150); }
}

@media (max-width: 480px) {
  /* ① Hero */
  .mg-hero-inner { padding: 28px 20px; }
  .mg-hero-btns { flex-direction: column; align-items: flex-start; }
  .mg-hero-desc br { display: inline; }

  /* 공통 */
  .mg-title br { display: none; }

  /* ⑤ 지원환경 */
  .mg-env-spec-row { display: block; }

  /* ⑥ 비용 */
  .mg-pricing .mg-title br { display: inline; }
  .mg-pricing-grid { grid-template-columns: 1fr; }
  .mg-pricing-card {
    flex-direction: row;
    align-items: flex-end;
    padding: 24px 20px;
    border-right: none;
    border-bottom: 1.5px solid var(--us-ink-150);
  }
  .mg-pricing-card:last-child { border-bottom: none; }
  .mg-pricing-img {
    order: 2;
    flex-shrink: 0;
    width: 30%;
    margin-bottom: 0;
    align-self: flex-end;
  }
  .mg-pricing-body {
    order: 1;
    flex: 1;
    align-items: flex-start;
    text-align: left;
  }
  .mg-pricing-title-wrap {
    flex-direction: row;
    align-items: baseline;
    gap: 8px;
  }
  .mg-pricing-en { display: none; }
  .mg-pricing-desc { margin: 0; }
}
