/* ============================================================
   Gold Apple — 공통 모바일 하단 퀵메뉴 + 헤더 언어 select(지구본) + 드로어
   적용 대상: mirror/index.html + mirror/web/*.html (10 페이지 공통)
   추가 시점: 2026-04-27 (고객 요청 모바일 최적화)
   ============================================================ */

:root {
  --gan-paper:#f5efe0;
  --gan-canvas:#ebe2cb;
  --gan-line:#d3c7a7;
  --gan-ink:#1a1208;
  --gan-subink:#3a2f1a;
  --gan-gold:#c7a24a;
  --gan-gold-deep:#8c6b1f;
  --gan-gold-bright:#e6c06a;
}

/* ───── 1. 헤더 우측 언어 select(지구본) ─────
   skin-v2 legacy CSS(bootstrap/common/main)의 button 룰을 specificity로 이김.
   selector 기준: body > .goldapple-topnav (legacy-fix.css 와 동일 패턴) */
body > .goldapple-topnav .ga-lang {
  position:relative;
  display:inline-flex;
  align-items:center;
  margin-left:auto;
}
body > .goldapple-topnav .ga-lang > .ga-lang__btn {
  /* skin-v2 의 `body.skin-v2 button { border:0 !important; padding:14px 28px !important; ... }` 를 이기기 위해 !important 매칭 */
  width:40px !important; height:40px !important;
  min-width:40px !important; min-height:40px !important;
  padding:0 !important; margin:0;
  display:inline-flex; align-items:center; justify-content:center;
  background:transparent !important;
  border:1.5px solid rgba(243,239,223,0.85) !important;
  border-radius:50% !important;
  color:#f6efd9;
  box-shadow:none !important;
  box-sizing:border-box;
  cursor:pointer;
  transition:background 180ms ease, border-color 180ms ease, color 180ms ease;
}
body > .goldapple-topnav .ga-lang > .ga-lang__btn:hover {
  background:rgba(243,239,223,0.1);
  border-color:var(--gan-gold-bright);
  color:var(--gan-gold-bright);
}
body > .goldapple-topnav .ga-lang > .ga-lang__btn svg {
  width:20px; height:20px;
  stroke:currentColor; stroke-width:2.1;
}
body > .goldapple-topnav .ga-lang__menu {
  display:none;
  position:absolute; top:48px; right:0;
  width:194px !important; min-width:194px !important; max-width:194px !important;
  background:#fff !important;
  border:1px solid var(--gan-line) !important;
  border-radius:10px !important;
  box-shadow:0 14px 40px rgba(26,18,8,0.12);
  padding:6px !important;
  margin:0 !important;
  z-index:1100;
  box-sizing:border-box !important;
}
body > .goldapple-topnav .ga-lang.is-open .ga-lang__menu { display:block !important; }
/* 2026-04-29: skin-v2 의 `body.skin-v2 button {padding:14px 28px !important; ...}` 룰을
   ga-lang__opt에도 동일하게 무력화 — 14페이지 옵션 사이즈 픽셀 일치 */
body > .goldapple-topnav .ga-lang__opt {
  display:flex !important; align-items:center !important; gap:10px !important;
  padding:10px 14px !important;
  min-width:0 !important; min-height:0 !important;
  width:100% !important; max-width:100% !important;
  font-family:'Pretendard Variable','Pretendard',sans-serif !important;
  font-size:14px !important; line-height:1.4 !important;
  letter-spacing:normal !important; text-transform:none !important;
  color:var(--gan-ink) !important;
  cursor:pointer;
  border-radius:6px !important;
  background:transparent !important;
  border:0 !important;
  margin:0 !important;
  box-shadow:none !important;
  text-align:left !important;
  box-sizing:border-box !important;
}
body > .goldapple-topnav .ga-lang__opt:hover { background:var(--gan-canvas) !important; }
body > .goldapple-topnav .ga-lang__opt[aria-selected="true"] { color:var(--gan-gold-deep) !important; font-weight:600 !important; }
body > .goldapple-topnav .ga-lang__opt-flag { width:20px !important; text-align:center !important; font-size:14px !important; flex:0 0 auto !important; }

/* ───── 1-2. 햄버거 버튼(MENU) — skin-v2 button !important 룰(min-width:80px) 및
   font-family / letter-spacing 차이로 폭이 4px 어긋나는 것까지 차단.
   selector: .nav-burger.nav-burger 로 specificity 31 확보 (legacy 22 우위)
   폭을 50px 로 못박아 14페이지 정렬을 픽셀 단위로 일치시킴. */
body > .goldapple-topnav .nav-burger.nav-burger {
  width:50px !important;
  min-width:50px !important;
  max-width:50px !important;
  height:44px !important;
  min-height:44px !important;
  padding:0 !important;
  background:transparent !important;
  border:none !important;
  border-radius:6px !important;
  box-shadow:none !important;
  box-sizing:border-box;
}
@media (max-width: 380px) {
  body > .goldapple-topnav .nav-burger.nav-burger {
    width:44px !important;
    min-width:44px !important;
    max-width:44px !important;
  }
}

/* ───── 2. 모바일 드로어 (햄버거 클릭) ───── */
/* 2026-04-28: backdrop 강화 — rules 등 모바일에서 hero가 좌측에 그대로 비치던 이슈 해소 */
.ga-drawer {
  position:fixed;
  inset:0;
  background:rgba(26,18,8,0.82);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  opacity:0; pointer-events:none;
  transition:opacity 220ms ease;
  z-index:1200;
}
.ga-drawer.is-open { opacity:1; pointer-events:auto; }
.ga-drawer__panel {
  position:absolute; top:0; right:0; bottom:0;
  width:min(82vw, 360px);
  background:#f5efe0 !important;
  background:var(--gan-paper, #f5efe0) !important;
  isolation:isolate;
  transform:translateX(100%);
  transition:transform 280ms cubic-bezier(0.22,1,0.36,1);
  display:flex; flex-direction:column;
  box-shadow:-12px 0 40px rgba(0,0,0,0.18);
  /* 2026-04-29: panel 자체는 overflow hidden — 메뉴 영역만 스크롤되고 CTA는 늘 하단 노출 */
  overflow:hidden;
  height:100%;
}
.ga-drawer.is-open .ga-drawer__panel { transform:translateX(0); }
.ga-drawer__head {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 22px;
  border-bottom:1px solid var(--gan-line);
  font-family:'JetBrains Mono', ui-monospace, monospace;
  font-size:11px; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--gan-gold-deep);
}
.ga-drawer__close {
  background:transparent; border:0;
  width:36px; height:36px; min-width:36px;
  font-size:22px; color:var(--gan-ink); cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center;
}
.ga-drawer__menu,
body.skin-v2 .ga-drawer__menu { list-style:none !important; margin:0 !important; padding:4px 0 !important; }
.ga-drawer__menu li,
body.skin-v2 .ga-drawer__menu li { list-style:none !important; margin:0 !important; padding:0 !important; background:transparent !important; }
/* 2026-04-30: 사용자 요청 (사진2) — 메뉴 컴팩트 + 활성 표시 'underline + 골드 텍스트', 배경 강조 제거 */
/* 2026-04-30 v3: skin-v2 레거시 페이지(asset_list/buy/transfer/reward/member 등)에서 a 룰이
   min-height/padding/box-sizing/font-size 를 덮어 항목 높이가 40px 로 줄어 회귀(rules 55px 와 차이).
   selector + !important 로 8페이지 픽셀 일치 강제. */
.ga-drawer .ga-drawer__menu a,
body.skin-v2 .ga-drawer .ga-drawer__menu a {
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  padding:9px 22px !important;
  font-family:'Pretendard Variable',sans-serif !important;
  font-size:15.5px !important;
  line-height:1.4 !important;
  color:var(--gan-ink);
  text-decoration:none !important;
  border-bottom:1px solid rgba(211,199,167,0.4) !important;
  min-height:36px !important;
  box-sizing:border-box !important;
  margin:0 !important;
  background:transparent !important;
}
.ga-drawer__menu a[aria-current="page"],
body.skin-v2 .ga-drawer__menu a[aria-current="page"] {
  background:transparent !important;
  color:var(--gan-gold-deep) !important; font-weight:700 !important;
  text-decoration:underline !important;
  text-underline-offset:6px !important;
  text-decoration-thickness:1.5px !important;
  text-decoration-color:var(--gan-gold-deep) !important;
}
/* 이슈 #3 수정: visited/link 일반 상태 underline 제거 — aria-current 만 underline 유지 */
/* 2026-04-30: theme-skin-v2.css의 a[href*="info"]/[href*="referral"] underline 룰을 drawer 안에서 명시 차단 (My Info 항목 강제 underline 회귀) */
.ga-drawer__menu a:link,
.ga-drawer__menu a:visited,
.ga-drawer__menu a[href],
.ga-drawer__menu a[href*="info"],
.ga-drawer__menu a[href*="referral"],
body.skin-v2 .ga-drawer__menu a:link,
body.skin-v2 .ga-drawer__menu a:visited,
body.skin-v2 .ga-drawer__menu a[href],
body.skin-v2 .ga-drawer__menu a[href*="info"],
body.skin-v2 .ga-drawer__menu a[href*="referral"] {
  text-decoration:none !important;
  text-underline-offset:0 !important;
}
/* aria-current 만 underline 유지 (위 룰보다 specific) */
.ga-drawer__menu a[aria-current="page"],
body.skin-v2 .ga-drawer__menu a[aria-current="page"],
.ga-drawer__menu a[aria-current="page"][href*="info"],
body.skin-v2 .ga-drawer__menu a[aria-current="page"][href*="info"] {
  text-decoration:underline !important;
  text-underline-offset:6px !important;
  text-decoration-thickness:1.5px !important;
  text-decoration-color:var(--gan-gold-deep) !important;
  color:var(--gan-gold-deep) !important;
}
/* 이슈 #2 수정: hover/focus/active 골드 톤 강제 — skin-v2 cyan 하이라이트 차단 */
.ga-drawer__menu a:hover,
.ga-drawer__menu a:focus,
.ga-drawer__menu a:active,
body.skin-v2 .ga-drawer__menu a:hover,
body.skin-v2 .ga-drawer__menu a:focus,
body.skin-v2 .ga-drawer__menu a:active {
  background:rgba(199,162,74,0.08) !important;
  color:var(--gan-ink) !important;
  text-decoration:none !important;
  -webkit-tap-highlight-color:rgba(199,162,74,0.12) !important;
}
.ga-drawer__menu .arrow {
  font-family:'JetBrains Mono', monospace;
  color:var(--gan-gold-deep);
  text-decoration:none !important;
}
.ga-drawer__menu a[aria-current="page"] .arrow {
  text-decoration:none !important;
}
.ga-drawer__cta {
  padding:14px 22px 18px;
  border-top:1px solid var(--gan-line);
  margin-top:auto;
  flex-shrink:0;
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:8px;
}
/* 2026-05-04: Login / Sign up / Logout 3분할 — 같은 알약 폭, 위계만 색으로 구분 */
.ga-drawer__cta .ga-drawer__login {
  background:transparent !important;
  color:var(--gan-ink, #1a1208) !important;
  border:1px solid var(--gan-line) !important;
}
.ga-drawer__cta .ga-drawer__login:hover {
  background:var(--gan-canvas, #ebe2cb) !important;
  color:var(--gan-ink, #1a1208) !important;
  border-color:var(--gan-gold-deep, #8c6b1f) !important;
}
.ga-drawer__cta .ga-drawer__logout {
  background:var(--gan-ink, #1a1208) !important;
  color:#f3efdf !important;
  border:1px solid var(--gan-ink, #1a1208) !important;
  font-size:12px !important;
}
.ga-drawer__cta .ga-drawer__logout:hover {
  background:#0e0905 !important;
  color:#f3efdf !important;
  border-color:#0e0905 !important;
}
/* 2026-04-29 (v6): 알약 버튼 추가 축소 — padding/letter-spacing 줄여 콘텐츠 폭 더 컴팩트 (사용자 요청 — 가운데로 더 축소) */
.ga-drawer__cta a {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:0.55em;
  background:var(--gan-gold-bright, #e6c06a) !important;
  color:var(--gan-ink, #1a1208) !important;
  text-align:center !important;
  padding:9px 18px;
  border-radius:999px;
  font-family:'JetBrains Mono', monospace;
  font-size:13px !important; letter-spacing:0.1em; text-transform:uppercase;
  font-weight:700;
  text-decoration:none;
  min-height:38px;
  width:auto;
  max-width:100%;
  border:1px solid var(--gan-gold-bright, #e6c06a) !important;
  transition:background 180ms ease, color 180ms ease;
}
.ga-drawer__cta-text { display:inline-block; }
.ga-drawer__cta-arrow {
  display:inline-block;
  font-weight:700;
  letter-spacing:0;
}
.ga-drawer__cta a:hover {
  background:var(--gan-gold-deep, #8c6b1f) !important;
  color:var(--gan-paper, #f5efe0) !important;
}
/* 메뉴 영역이 길어도 스크롤 가능하면서 CTA가 늘 하단 노출 */
.ga-drawer__menu { flex:1 1 auto; overflow-y:auto; min-height:0; -webkit-overflow-scrolling:touch; }

/* ───── 3. 모바일 하단 fixed 퀵메뉴 (Bottom Nav) ───── */
.ga-bottomnav {
  display:none;
  position:fixed;
  left:0; right:0; bottom:0;
  background:rgba(26,18,8,0.96);
  border-top:1px solid var(--gan-gold-deep);
  z-index:1000;
  padding:6px 0 calc(6px + env(safe-area-inset-bottom));
  backdrop-filter:saturate(140%) blur(12px);
}
.ga-bottomnav__list {
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  list-style:none; margin:0; padding:0;
}
.ga-bottomnav__list a {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:3px;
  padding:8px 4px;
  color:rgba(243,239,223,0.78);
  text-decoration:none;
  font-family:'Pretendard Variable', sans-serif;
  font-size:10.5px; line-height:1.1;
  letter-spacing:0;
  min-height:54px;
  transition:color 180ms ease;
}
.ga-bottomnav__list a:hover,
.ga-bottomnav__list a[aria-current="page"] {
  color:var(--gan-gold-bright);
}
.ga-bottomnav__list svg {
  width:22px; height:22px; flex:none;
  stroke:currentColor;
}
.ga-bottomnav__label { white-space:nowrap; }

/* 모바일에서만 노출 */
@media (max-width: 820px) {
  .ga-bottomnav { display:block; }
  body.ga-has-bottomnav { padding-bottom:74px; }
}
/* 2026-04-28: drawer hide 폭을 hero-nav__menu가 풀로 보이는 폭과 일치시킴
   기존 821px 이상에서 ga-drawer hide → 821~1040px 구간에서 nav-burger는 보이지만 drawer 안 나오는 버그
   theme-renewal.css의 .hero-nav__menu @media (max-width:1040px) display:none 과 일치 */
@media (min-width: 1041px) {
  .ga-drawer { display:none !important; }
}

/* ============================================================
   2026-05-01: 모바일 헤더 재구성 + 폰트 앱 최적화 (수정요청 #1, #8)
   - ☰ 좌측 / 로고 중앙 / 지구본 우측 (order 강제)
   - MENU 텍스트 → ☰ 3선 아이콘
   - hero h1/h2 등 거대 타이포 모바일 최적값으로 축소
   ============================================================ */
@media (max-width: 820px) {
  /* 헤더 컨테이너 — flex 재배치 */
  body > .goldapple-topnav {
    display:flex !important;
    flex-direction:row !important;
    align-items:center !important;
    justify-content:space-between !important;
    gap:8px !important;
    padding:10px 14px !important;
  }
  /* 햄버거 — 좌측 (order:1) + 텍스트 숨기고 ☰ 3선 아이콘 */
  body > .goldapple-topnav .nav-burger.nav-burger {
    order:1 !important;
    margin:0 !important;
    font-size:0 !important;
    color:#f6efd9 !important;
    position:relative;
    border:1.5px solid rgba(243,239,223,0.85) !important;
    border-radius:8px !important;
  }
  body > .goldapple-topnav .nav-burger.nav-burger::before {
    content:"" !important;
    position:absolute;
    left:50%; top:50%;
    transform:translate(-50%, -50%);
    width:20px; height:2px;
    background:currentColor;
    box-shadow:0 -6px 0 currentColor, 0 6px 0 currentColor;
    pointer-events:none;
  }
  /* 로고 — 중앙 (order:2) + flex로 가운데 차지 */
  body > .goldapple-topnav .hero-nav__brand {
    order:2 !important;
    margin:0 !important;
    flex:1 1 auto !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
  }
  /* 데스크톱 메뉴 ul — 모바일 숨김 */
  body > .goldapple-topnav .hero-nav__menu { display:none !important; }
  /* Start Investing CTA — 모바일은 floating(.ga-float-cta)이 따로 있어 헤더 CTA 숨김 */
  body > .goldapple-topnav .hero-cta { display:none !important; }
  /* 지구본 — 우측 (order:3) */
  body > .goldapple-topnav .ga-lang {
    order:3 !important;
    margin-left:0 !important;
    margin-right:0 !important;
  }

  /* ── 모바일 폰트 토큰 — 앱처럼 최적화 (수정요청 #8) ── */
  body { -webkit-text-size-adjust:100%; }
  /* hero 거대 타이포 (Your Portfolio 등) */
  h1, .hero-h1, .ga-hero__title, .hero__title, .swl-h1,
  .s-hero__h, .s-hero h1,
  .ga-hero h1, .ga-hero__h {
    font-size:clamp(26px, 8.2vw, 38px) !important;
    line-height:1.15 !important;
    letter-spacing:-0.01em !important;
  }
  h2, .ga-hero__sub, .ga-section__h, .s-section__h {
    font-size:clamp(20px, 5.6vw, 26px) !important;
    line-height:1.22 !important;
  }
  h3, .ga-card__h, .s-card__h {
    font-size:clamp(17px, 4.6vw, 21px) !important;
    line-height:1.3 !important;
  }
  /* lead/본문 — 너무 작거나 너무 크지 않게 */
  p, li, .ga-lead, .ga-body, .s-lead {
    font-size:15px !important;
    line-height:1.55 !important;
  }
  /* hero subtitle/eyebrow — 작게 */
  .eyebrow, .ga-eyebrow, .s-eyebrow {
    font-size:11px !important;
    letter-spacing:0.18em !important;
  }
}

/* ============================================================
   2026-05-01: PDF 수정요청 #7 — 모든 리스트 1줄=1라인 가로 테이블 강제
   - 회원/출금/구매/리워드 등 .table-01 / .search-table 류
   - 모바일에서 카드형으로 변환되던 페이지별 룰 차단, 가로 테이블 유지
   - 컬럼 많아 좁으면 가로 스크롤로 (모든 항목 1줄로 표시)
   ============================================================ */
@media (max-width: 640px) {
  body.skin-v2 .table-01,
  body.skin-v2 .search-table {
    overflow-x:auto !important;
    -webkit-overflow-scrolling:touch !important;
    border:0 !important;
    background:transparent !important;
  }
  body.skin-v2 .table-01 > table,
  body.skin-v2 .search-table > table,
  body.skin-v2 .table-01 table,
  body.skin-v2 .search-table table {
    display:table !important;
    width:auto !important;
    min-width:100% !important;
    table-layout:auto !important;
    border-collapse:separate !important;
  }
  body.skin-v2 .table-01 thead,
  body.skin-v2 .search-table thead {
    display:table-header-group !important;
  }
  body.skin-v2 .table-01 tbody,
  body.skin-v2 .search-table tbody {
    display:table-row-group !important;
  }
  body.skin-v2 .table-01 tr,
  body.skin-v2 .search-table tr {
    display:table-row !important;
    background:transparent !important;
    border:0 !important;
    border-bottom:1px solid rgba(199,162,74,0.18) !important;
    border-radius:0 !important;
    padding:0 !important;
    margin:0 !important;
    width:auto !important;
  }
  body.skin-v2 .table-01 td,
  body.skin-v2 .table-01 th,
  body.skin-v2 .search-table td,
  body.skin-v2 .search-table th {
    display:table-cell !important;
    width:auto !important;
    min-width:0 !important;
    padding:8px 10px !important;
    text-align:left !important;
    white-space:nowrap !important;
    font-size:12px !important;
    border:0 !important;
    border-bottom:1px solid rgba(199,162,74,0.10) !important;
    vertical-align:middle !important;
  }
  body.skin-v2 .table-01 thead td,
  body.skin-v2 .table-01 thead th,
  body.skin-v2 .search-table thead td,
  body.skin-v2 .search-table thead th {
    background:rgba(199,162,74,0.08) !important;
    font-weight:700 !important;
    color:var(--gan-gold-deep, #8c6b1f) !important;
    font-size:11px !important;
    letter-spacing:0.04em !important;
    text-transform:none !important;
    white-space:normal !important;
    line-height:1.25 !important;
  }
  /* colspan(빈 결과 행) 등 안내 문구는 줄바꿈 허용 */
  body.skin-v2 .table-01 td[colspan],
  body.skin-v2 .search-table td[colspan] {
    text-align:center !important;
    white-space:normal !important;
    padding:20px 12px !important;
  }
}

/* ============================================================
   /web/buy 가로 7컬럼 강제 룰 제거 (2026-05-04)
   사장님 요청: Member 와 동일하게 모든 viewport(PC/iPad/모바일) 카드 모드 통일
   기존 PC 가로테이블 강제 블록은 theme-legacy-dashboard-v3.css 의
   @media all card-mode 와 충돌하여 제거함.
   ============================================================ */

/* ============================================================
   자산 카드 (.assets01~05) — 3줄 가운데 정렬 (라벨 / 숫자 / 단위)
   2026-05-04 사장님 요청 — Available Assets "4,940,436.38 GPAY"를 3줄로
   적용: member, asset_list, buy, reward, transfer, withdrawal, withdrawal_list
   theme-legacy-dashboard-v3.css와 specificity 동등화 (:is + #doc + .mcont01 + .div-cont)
   ============================================================ */
body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list) #doc .mcont01 > .div-cont > .assets01,
body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list) #doc .mcont01 > .div-cont > .assets02,
body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list) #doc .mcont01 > .div-cont > .assets03,
body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list) #doc .mcont01 > .div-cont > .assets04,
body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list) #doc .mcont01 > .div-cont > .assets05 {
  text-align: center !important;
}
body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list) #doc .mcont01 > .div-cont > .assets01 > p,
body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list) #doc .mcont01 > .div-cont > .assets02 > p,
body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list) #doc .mcont01 > .div-cont > .assets03 > p,
body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list) #doc .mcont01 > .div-cont > .assets04 > p,
body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list) #doc .mcont01 > .div-cont > .assets05 > p {
  text-align: center !important;
  width: 100% !important;
}
/* assetcont — flex column 으로 stack (icon / number / unit 각 줄) */
body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list) #doc .mcont01 > .div-cont > .assets01 .assetcont,
body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list) #doc .mcont01 > .div-cont > .assets02 .assetcont,
body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list) #doc .mcont01 > .div-cont > .assets03 .assetcont,
body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list) #doc .mcont01 > .div-cont > .assets04 .assetcont,
body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list) #doc .mcont01 > .div-cont > .assets05 .assetcont {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: clamp(4px, 0.6vw, 8px) !important;
  padding-left: clamp(8px, 2vw, 16px) !important;
  padding-right: clamp(8px, 2vw, 16px) !important;
  text-align: center !important;
  width: 100% !important;
}
/* number span 단독 줄 + 가운데 */
body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list) #doc .mcont01 > .div-cont .assetcont .assets-num,
body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list) #doc .mcont01 > .div-cont .assetcont .assets-num-perf {
  display: block !important;
  width: 100% !important;
  text-align: center !important;
  font-size: clamp(18px, 3.6vw, 36px) !important;
  line-height: 1.15 !important;
  flex: 0 0 auto !important;
}
/* unit p (GPay/Acorns/USDT/PET 등) 단독 줄 + 가운데 + 약간 작게 */
body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list) #doc .mcont01 > .div-cont .assetcont > p {
  display: block !important;
  width: 100% !important;
  text-align: center !important;
  font-size: clamp(10px, 1.4vw, 14px) !important;
  letter-spacing: 0.08em !important;
  margin: 0 !important;
  text-transform: uppercase !important;
  flex: 0 0 auto !important;
}
/* icon 숨김 — 정확히 3줄 (라벨/숫자/단위) 만 표시 (사장님 요청) */
body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list) #doc .mcont01 > .div-cont .assetcont img {
  display: none !important;
}

/* 초소형 viewport (≤360px): nowrap이 셀 폭을 초과하므로 wrap 허용 + 폰트 축소 */
@media (max-width: 360px) {
  body.skin-v2.page-buy #contents .Buy-list li.table-A table tbody tr td {
    white-space: normal !important;
    word-break: break-all !important;
    overflow-wrap: anywhere !important;
    font-size: 7.5px !important;
  }
  body.skin-v2.page-buy #contents .Buy-list li.table-A table tbody tr td:nth-child(2),
  body.skin-v2.page-buy #contents .Buy-list li.table-A table tbody tr td:nth-child(4),
  body.skin-v2.page-buy #contents .Buy-list li.table-A table tbody tr td:nth-child(5),
  body.skin-v2.page-buy #contents .Buy-list li.table-A table tbody tr td:nth-child(6) {
    font-size: 7px !important;
  }
  /* USDT 단위 컬럼(5/6) — 단어 단위 줄바꿈으로 "0.05" / "USDT" 두 줄 분리
     (사장님 요청 2026-05-04: USD/T 중간 절단 금지, USDT는 통째로 다음 줄에) */
  body.skin-v2.page-buy #contents .Buy-list li.table-A table tbody tr td:nth-child(5),
  body.skin-v2.page-buy #contents .Buy-list li.table-A table tbody tr td:nth-child(6) {
    word-break: keep-all !important;
    overflow-wrap: normal !important;
    line-height: 1.3 !important;
  }
  /* 날짜 span은 break 허용 (셀 폭 초과 방지) */
  body.skin-v2.page-buy #contents .Buy-list li.table-A table tbody tr td .ga-tx-date,
  body.skin-v2.page-buy #contents .Buy-list li.table-A table tbody tr td .ga-tx-time {
    white-space: normal !important;
    word-break: break-all !important;
    overflow-wrap: anywhere !important;
  }
  body.skin-v2.page-buy #contents .Buy-list li.table-A table thead tr th {
    font-size: 7px !important;
  }
}

/* ============================================================
   USDT 단위 span — 모든 viewport에서 단어 절대 중간 절단 금지
   사장님 요청 2026-05-04: "0.05 USD/T" 같은 mid-word break 금지,
   USDT는 통째로 한 단어. 셀이 좁으면 number 다음 줄로 깨끗이 wrap.
   ============================================================ */
body.skin-v2.page-buy #contents .Buy-list li.table-A table tbody tr td .ga-tx-unit {
  display: inline-block !important;
  white-space: nowrap !important;
  word-break: keep-all !important;
  overflow-wrap: normal !important;
  /* 2026-05-04 사장님 요청: USDT 단위 텍스트만 셀 폰트보다 3pt 작게 (1pt 추가 축소) */
  font-size: calc(1em - 3px) !important;
}
/* 모바일/태블릿(≤768) 카드모드 + 가로테이블 모두 — USDT를 number 아래 줄로 강제 */
@media (max-width: 768px) {
  body.skin-v2.page-buy #contents .Buy-list li.table-A table tbody tr td:nth-child(5),
  body.skin-v2.page-buy #contents .Buy-list li.table-A table tbody tr td:nth-child(6) {
    white-space: normal !important;
    word-break: keep-all !important;
    overflow-wrap: normal !important;
  }
  body.skin-v2.page-buy #contents .Buy-list li.table-A table tbody tr td:nth-child(5) .ga-tx-unit,
  body.skin-v2.page-buy #contents .Buy-list li.table-A table tbody tr td:nth-child(6) .ga-tx-unit {
    display: block !important;
    margin-top: 1px !important;
    line-height: 1.2 !important;
  }
}

/* ============================================================
   /web/asset_list 카드 그리드 — 그림1(index)처럼 2칸×2 + 1풀폭
   2026-05-03 사장님 요청 #3
   - legacy-fix.css 229행이 .page-asset-list를 grid 적용에서 제외 → 모바일 1열 무너짐
   - body.skin-v2.page-asset-list 클래스 체인으로 specificity 확보
   - 좌우 여백 8px (조금만), 라벨 nowrap (폰트 모두 들어옴)
   ============================================================ */
@media (max-width: 640px) {
  body.skin-v2.page-asset-list #doc .mcont01 > .div-cont {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    grid-template-rows: auto auto auto !important;
    gap: 8px !important;
    padding: 0 8px !important;
    max-width: 100% !important;
    width: 100% !important;
    margin: 0 auto !important;
    box-sizing: border-box !important;
  }
  body.skin-v2.page-asset-list #doc .mcont01 > .div-cont > .assets01 { float: none !important; width: auto !important; margin: 0 !important; grid-column: 1 !important; grid-row: 1 !important; }
  body.skin-v2.page-asset-list #doc .mcont01 > .div-cont > .assets02 { float: none !important; width: auto !important; margin: 0 !important; grid-column: 2 !important; grid-row: 1 !important; }
  body.skin-v2.page-asset-list #doc .mcont01 > .div-cont > .assets03 { float: none !important; width: auto !important; margin: 0 !important; grid-column: 1 !important; grid-row: 2 !important; }
  body.skin-v2.page-asset-list #doc .mcont01 > .div-cont > .assets04 { float: none !important; width: auto !important; margin: 0 !important; grid-column: 2 !important; grid-row: 2 !important; }
  body.skin-v2.page-asset-list #doc .mcont01 > .div-cont > .assets05 { float: none !important; width: auto !important; margin: 0 !important; grid-column: 1 / -1 !important; grid-row: 3 !important; }

  /* 라벨/숫자 폰트 — 좁은 카드에 모두 들어오게 */
  body.skin-v2.page-asset-list #doc .mcont01 > .div-cont > div > p {
    font-size: 11px !important;
    line-height: 1.2 !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
  }
  body.skin-v2.page-asset-list #doc .mcont01 > .div-cont .assetcont {
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: baseline !important;
    justify-content: flex-start !important;
    gap: 6px !important;
    min-width: 0 !important;
    height: auto !important;
  }
  body.skin-v2.page-asset-list #doc .mcont01 > .div-cont .assetcont .assets-num {
    font-size: clamp(15px, 4vw, 22px) !important;
    white-space: nowrap !important;
    overflow: visible !important;
    text-overflow: clip !important;
    min-width: 0 !important;
  }
  body.skin-v2.page-asset-list #doc .mcont01 > .div-cont .assetcont > p {
    font-size: 10px !important;
    white-space: nowrap !important;
  }
  body.skin-v2.page-asset-list #doc .mcont01 > .div-cont .assetcont img {
    width: 18px !important;
    height: 18px !important;
  }
}

/* ============================================================
   /web/member · Member 테이블 — Subscription date 컬럼 가운데 정렬
   2026-05-03 사장님 요청 (24:45 KST)
   - 기본 .table-01 td는 text-align:left
   - 2번째 컬럼(Subscription date)만 가운데 정렬 (PC + 모바일 공통)
   - #contents (ID) 추가해 legacy mobile-fix의 td:left specificity (1ID) 이김
   ============================================================ */
body.skin-v2.page-member #contents .table-01.search-table table thead td:nth-child(2),
body.skin-v2.page-member #contents .table-01.search-table table tbody td:nth-child(2),
body.skin-v2.page-member #contents .table-01 thead td:nth-child(2),
body.skin-v2.page-member #contents .table-01 tbody td:nth-child(2) {
  text-align: center !important;
}

/* ============================================================
   /web/buy · 거래내역 테이블 Purchase/Sale Date 컬럼 — 날짜 위 / 시간 아래 가운데 정렬
   2026-05-04 사장님 요청 (이미지 첨부 — PC view에 인라인으로 보이는 "2026-04-14(20:25:18)"을 2줄 분리)
   - JS(_Js/tx-date-split.js)가 .ga-tx-stack > .ga-tx-date + .ga-tx-time 으로 split 해놨으나
   - PC: 기본 inline 으로 1줄 표시
   - 모바일: theme-legacy-dashboard-v3.css 2446에서 inline-flex row 강제 → 1줄
   - 둘 다 column flex + center로 통일 (PC + 모바일)
   - 셀(td:nth-child(2|4)) text-align: center로 가운데 정렬
   ============================================================ */
body.skin-v2.page-buy #contents .Buy-list li.table-A table tbody td .ga-tx-stack {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 1px !important;
  line-height: 1.2 !important;
  width: 100% !important;
}
body.skin-v2.page-buy #contents .Buy-list li.table-A table tbody td .ga-tx-date {
  display: block !important;
  text-align: center !important;
}
body.skin-v2.page-buy #contents .Buy-list li.table-A table tbody td .ga-tx-time {
  display: block !important;
  text-align: center !important;
  font-size: 0.85em !important;
  opacity: 0.78 !important;
}
/* Purchase Date(2번째 td) + Sale Date(4번째 td) 셀 자체도 center */
body.skin-v2.page-buy #contents .Buy-list li.table-A table thead tr th:nth-child(2),
body.skin-v2.page-buy #contents .Buy-list li.table-A table thead tr th:nth-child(4),
body.skin-v2.page-buy #contents .Buy-list li.table-A table tbody tr td:nth-child(2),
body.skin-v2.page-buy #contents .Buy-list li.table-A table tbody tr td:nth-child(4) {
  text-align: center !important;
}
/* ════════════════════════════════════════════════════════════════
   Customer Fix 2026-05-13 — lean rebuild from 5.11 base
   ────────────────────────────────────────────────────────────────
   #1 모바일 자산카드 균일 사이즈
   #2 모바일 하단 단축메뉴 (.ga-bottomnav, #footer-wrap) 숨김
   #4 (cf-buy-cta 스타일링)
   #5 Buy 페이지 모바일 1-scroll
   #6 인덱스 vs 서브 자산 레이아웃 통일
   #7 자산 영역 컴팩트
   #8 CSS/JS only, HTML/PHP 무수정
   ════════════════════════════════════════════════════════════════ */

/* ───────────────────────────────────────────────────────────────
   #2  모바일 하단 단축메뉴 제거
   ─────────────────────────────────────────────────────────────── */
@media (max-width: 820px) {
  body #footer-wrap,
  body .ga-bottomnav {
    display: none !important;
  }
  /* bottomnav 자리 차지하던 body padding 도 제거 */
  body.ga-has-bottomnav {
    padding-bottom: 0 !important;
  }
}

/* ───────────────────────────────────────────────────────────────
   #1 + #6 + #7  자산 카드 (.mcont01) — 모바일/PC 균일 + 컴팩트
   원칙: 5장 동일 width / 동일 height. 모바일 = 2-col + 마지막 카드 가로 확장 금지.
        PC = 5-col 1행. 모두 컴팩트.
   ─────────────────────────────────────────────────────────────── */

/* 기본 (모든 viewport): grid 자체 컴팩트 */
body.skin-v2 #doc .mcont01 {
  margin: 0 !important;
  padding: 8px 12px !important;
}
body.skin-v2 #doc .mcont01 > .div-cont {
  display: grid !important;
  gap: 8px !important;
  padding: 0 !important;
  margin: 0 auto !important;
  max-width: 1200px !important;
  box-sizing: border-box !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] {
  float: none !important;
  width: auto !important;
  margin: 0 !important;
  padding: 10px 12px !important;
  box-sizing: border-box !important;
  background: #f7f1e3 !important;
  border: 1px solid #e8dcb8 !important;
  border-radius: 10px !important;
  min-height: 80px !important;
  max-height: 100px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  align-items: center !important;
  text-align: center !important;
  gap: 4px !important;
  overflow: hidden !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] > p {
  margin: 0 !important;
  padding: 0 !important;
  font-size: 11px !important;
  letter-spacing: 0.04em !important;
  line-height: 1.2 !important;
  color: #6a4f10 !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assetcont {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  text-align: center !important;
  gap: 2px !important;
  padding: 0 !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assetcont > * {
  margin: 0 !important;
  padding: 0 !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assets-num,
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assets-num-perf {
  font-size: clamp(14px, 2.4vw, 18px) !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  color: #1a1208 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: clip !important;
  max-width: 100% !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assetcont > p {
  font-size: 9.5px !important;
  letter-spacing: 0.05em !important;
  color: #8c6b1f !important;
  text-transform: uppercase !important;
}

/* PC (≥768): 5-col 1행 균일 */
@media (min-width: 768px) {
  body.skin-v2 #doc .mcont01 > .div-cont {
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    grid-template-rows: 96px !important;
    gap: 10px !important;
  }
  body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] {
    min-height: 96px !important;
    max-height: 96px !important;
    grid-row: 1 !important;
  }
  body.skin-v2 #doc .mcont01 > .div-cont > .assets01 { grid-column: 1 !important; }
  body.skin-v2 #doc .mcont01 > .div-cont > .assets02 { grid-column: 2 !important; }
  body.skin-v2 #doc .mcont01 > .div-cont > .assets03 { grid-column: 3 !important; }
  body.skin-v2 #doc .mcont01 > .div-cont > .assets04 { grid-column: 4 !important; }
  body.skin-v2 #doc .mcont01 > .div-cont > .assets05 { grid-column: 5 !important; }
}

/* 모바일 (≤767): 2-col, assets05 도 col 1만 사용 (전폭 금지 — #1 균일) */
@media (max-width: 767px) {
  body.skin-v2 #doc .mcont01 > .div-cont {
    grid-template-columns: 1fr 1fr !important;
    grid-auto-rows: 80px !important;
    gap: 6px !important;
  }
  body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] {
    grid-column: span 1 !important;   /* assets05 도 1칸만 */
    min-height: 80px !important;
    max-height: 80px !important;
    padding: 8px 8px !important;
  }
  body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assets-num,
  body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assets-num-perf {
    font-size: 13px !important;
  }
  body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] > p {
    font-size: 9px !important;
  }
}

/* ───────────────────────────────────────────────────────────────
   #5  Buy 페이지 모바일 1-scroll
   원칙: hero 컴팩트 + .mcont01 숨김 → form이 viewport 1단째에 도달
   ─────────────────────────────────────────────────────────────── */
@media (max-width: 767px) {
  /* .mcont01 은 보존 (#1 정책으로 컴팩트화 됨) — 추가 압축 */
  body.skin-v2.page-buy #doc .mcont01 {
    padding: 4px 12px !important;
  }
  /* page-hero (Trade USDT, own Acorns…) 컴팩트 */
  body.skin-v2.page-buy .ga-v2 .container .hero-head h1.h-en {
    font-size: 22px !important;
    line-height: 1.15 !important;
    margin: 0 0 8px 0 !important;
  }
  body.skin-v2.page-buy .ga-v2 .container .hero-head p.lead-en {
    font-size: 12px !important;
    line-height: 1.4 !important;
    margin: 0 0 8px 0 !important;
    max-height: 4.2em !important;
    overflow: hidden !important;
  }
  body.skin-v2.page-buy .ga-v2 .container .meta-row {
    display: none !important;  /* SECURE / VERIFIED / TRANSPARENT 작은 정보 — 모바일에서 숨김 */
  }
  body.skin-v2.page-buy .ga-v2 .container {
    padding-top: 20px !important;
    padding-bottom: 12px !important;
  }
  body.skin-v2.page-buy .ga-v2 {
    padding: 0 !important;
  }
}

/* ───────────────────────────────────────────────────────────────
   #4  Buy CTA 스타일 (JS가 .cf-buy-cta inject)
   ─────────────────────────────────────────────────────────────── */
.cf-buy-cta {
  width: 100%;
  padding: 24px 16px;
  background: linear-gradient(135deg, #fff7e1 0%, #f5e7b8 100%);
  border-top: 1px solid #e8dcb8;
  border-bottom: 1px solid #e8dcb8;
  text-align: center;
}
.cf-buy-cta__inner {
  max-width: 720px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.cf-buy-cta__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 36px;
  background: #1a1208;
  color: #f5e7b8 !important;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-decoration: none !important;
  border-radius: 999px;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.18);
}
.cf-buy-cta__btn:hover,
.cf-buy-cta__btn:focus {
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.25);
}
.cf-buy-cta__sub {
  margin: 0;
  font-size: 12px;
  color: #6a4f10;
  letter-spacing: 0.04em;
}
@media (max-width: 767px) {
  .cf-buy-cta {
    padding: 16px 12px;
  }
  .cf-buy-cta__btn {
    padding: 12px 24px;
    font-size: 14px;
  }
  .cf-buy-cta__sub {
    font-size: 11px;
  }
}

/* ───────────────────────────────────────────────────────────────
   #3  검증 버튼 (.cf-validate-btn) 스타일
   ─────────────────────────────────────────────────────────────── */
.cf-validate-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 14px;
  margin-left: 8px;
  background: #2a1d10;
  color: #f5e7b8;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  white-space: nowrap;
}
.cf-validate-btn:hover {
  background: #3d2b18;
}
@media (max-width: 480px) {
  .cf-validate-btn {
    padding: 6px 10px;
    font-size: 10px;
    margin-left: 6px;
  }
}
/* ════════════════════════════════════════════════════════════════
   Customer Fix 2026-05-13 — lean rebuild from 5.11 base
   ────────────────────────────────────────────────────────────────
   #1 모바일 자산카드 균일 사이즈
   #2 모바일 하단 단축메뉴 (.ga-bottomnav, #footer-wrap) 숨김
   #4 (cf-buy-cta 스타일링)
   #5 Buy 페이지 모바일 1-scroll
   #6 인덱스 vs 서브 자산 레이아웃 통일
   #7 자산 영역 컴팩트
   #8 CSS/JS only, HTML/PHP 무수정
   ════════════════════════════════════════════════════════════════ */

/* ───────────────────────────────────────────────────────────────
   #2  모바일 하단 단축메뉴 제거
   ─────────────────────────────────────────────────────────────── */
@media (max-width: 820px) {
  body #footer-wrap,
  body .ga-bottomnav {
    display: none !important;
  }
  /* bottomnav 자리 차지하던 body padding 도 제거 */
  body.ga-has-bottomnav {
    padding-bottom: 0 !important;
  }
}

/* ───────────────────────────────────────────────────────────────
   #1 + #6 + #7  자산 카드 (.mcont01) — 모바일/PC 균일 + 컴팩트
   원칙: 5장 동일 width / 동일 height. 모바일 = 2-col + 마지막 카드 가로 확장 금지.
        PC = 5-col 1행. 모두 컴팩트.
   ─────────────────────────────────────────────────────────────── */

/* 기본 (모든 viewport): grid 자체 컴팩트 */
body.skin-v2 #doc .mcont01 {
  margin: 0 !important;
  padding: 8px 12px !important;
}
body.skin-v2 #doc .mcont01 > .div-cont {
  display: grid !important;
  gap: 8px !important;
  padding: 0 !important;
  margin: 0 auto !important;
  max-width: 1200px !important;
  box-sizing: border-box !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] {
  float: none !important;
  width: auto !important;
  margin: 0 !important;
  padding: 10px 12px !important;
  box-sizing: border-box !important;
  background: #f7f1e3 !important;
  border: 1px solid #e8dcb8 !important;
  border-radius: 10px !important;
  min-height: 80px !important;
  max-height: 100px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  align-items: center !important;
  text-align: center !important;
  gap: 4px !important;
  overflow: hidden !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] > p {
  margin: 0 !important;
  padding: 0 !important;
  font-size: 11px !important;
  letter-spacing: 0.04em !important;
  line-height: 1.2 !important;
  color: #6a4f10 !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assetcont {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  text-align: center !important;
  gap: 2px !important;
  padding: 0 !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assetcont > * {
  margin: 0 !important;
  padding: 0 !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assets-num,
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assets-num-perf {
  font-size: clamp(14px, 2.4vw, 18px) !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  color: #1a1208 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: clip !important;
  max-width: 100% !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assetcont > p {
  font-size: 9.5px !important;
  letter-spacing: 0.05em !important;
  color: #8c6b1f !important;
  text-transform: uppercase !important;
}

/* PC (≥768): 5-col 1행 균일 — specificity (1,5,1) 매칭 */
@media (min-width: 768px) {
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont {
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    grid-template-rows: 96px !important;
    gap: 10px !important;
  }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > [class^="assets0"] {
    min-height: 96px !important;
    max-height: 96px !important;
    height: 96px !important;
    grid-row: 1 !important;
  }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > .assets01 { grid-column: 1 !important; }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > .assets02 { grid-column: 2 !important; }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > .assets03 { grid-column: 3 !important; }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > .assets04 { grid-column: 4 !important; }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > .assets05 { grid-column: 5 !important; grid-row: 1 !important; }
}

/* 모바일 (≤767): 2-col, assets05 도 col 1만 사용 (전폭 금지 — #1 균일)
   specificity 매칭으로 theme-legacy-dashboard-v3.css 이김 */
@media (max-width: 767px) {
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont {
    grid-template-columns: 1fr 1fr !important;
    grid-template-rows: none !important;
    grid-auto-rows: 64px !important;
    gap: 6px !important;
  }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > [class^="assets0"] {
    grid-column: span 1 !important;
    grid-row: auto !important;
    min-height: 64px !important;
    max-height: 64px !important;
    height: 64px !important;
    padding: 6px 8px !important;
  }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > .assets05 {
    grid-column: span 1 !important;
    grid-row: auto !important;
  }
  body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assets-num,
  body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assets-num-perf {
    font-size: 12px !important;
  }
  body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] > p {
    font-size: 8.5px !important;
    letter-spacing: 0.03em !important;
  }
  body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assetcont > p {
    font-size: 8px !important;
  }
  /* .ga-dashboard-v3-head (페이지 헤더) 모바일 컴팩트 */
  body.skin-v2 #doc .mcont01 .ga-dashboard-v3-head {
    padding: 6px 12px !important;
    min-height: 0 !important;
  }
  body.skin-v2 #doc .mcont01 .ga-dashboard-v3-head h2 {
    font-size: 16px !important;
    margin: 0 !important;
    line-height: 1.2 !important;
  }
  body.skin-v2 #doc .mcont01 .ga-dashboard-v3-head .eyebrow,
  body.skin-v2 #doc .mcont01 .ga-dashboard-v3-head .meta,
  body.skin-v2 #doc .mcont01 .ga-dashboard-v3-head .meta-line {
    font-size: 9px !important;
    line-height: 1.2 !important;
  }
}

/* ───────────────────────────────────────────────────────────────
   #5  Buy 페이지 모바일 1-scroll
   원칙: hero 컴팩트 + .mcont01 숨김 → form이 viewport 1단째에 도달
   ─────────────────────────────────────────────────────────────── */
@media (max-width: 767px) {
  /* .mcont01 은 보존 (#1 정책으로 컴팩트화 됨) — 추가 압축 */
  body.skin-v2.page-buy #doc .mcont01 {
    padding: 4px 12px !important;
  }
  /* page-hero (Trade USDT, own Acorns…) 컴팩트 */
  body.skin-v2.page-buy .ga-v2 .container .hero-head h1.h-en {
    font-size: 22px !important;
    line-height: 1.15 !important;
    margin: 0 0 8px 0 !important;
  }
  body.skin-v2.page-buy .ga-v2 .container .hero-head p.lead-en {
    font-size: 12px !important;
    line-height: 1.4 !important;
    margin: 0 0 8px 0 !important;
    max-height: 4.2em !important;
    overflow: hidden !important;
  }
  body.skin-v2.page-buy .ga-v2 .container .meta-row {
    display: none !important;  /* SECURE / VERIFIED / TRANSPARENT 작은 정보 — 모바일에서 숨김 */
  }
  body.skin-v2.page-buy .ga-v2 .container {
    padding-top: 20px !important;
    padding-bottom: 12px !important;
  }
  body.skin-v2.page-buy .ga-v2 {
    padding: 0 !important;
  }
}

/* ───────────────────────────────────────────────────────────────
   #4  Buy CTA 스타일 (JS가 .cf-buy-cta inject)
   ─────────────────────────────────────────────────────────────── */
.cf-buy-cta {
  width: 100%;
  padding: 24px 16px;
  background: linear-gradient(135deg, #fff7e1 0%, #f5e7b8 100%);
  border-top: 1px solid #e8dcb8;
  border-bottom: 1px solid #e8dcb8;
  text-align: center;
}
.cf-buy-cta__inner {
  max-width: 720px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.cf-buy-cta__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 36px;
  background: #1a1208;
  color: #f5e7b8 !important;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-decoration: none !important;
  border-radius: 999px;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.18);
}
.cf-buy-cta__btn:hover,
.cf-buy-cta__btn:focus {
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.25);
}
.cf-buy-cta__sub {
  margin: 0;
  font-size: 12px;
  color: #6a4f10;
  letter-spacing: 0.04em;
}
@media (max-width: 767px) {
  .cf-buy-cta {
    padding: 16px 12px;
  }
  .cf-buy-cta__btn {
    padding: 12px 24px;
    font-size: 14px;
  }
  .cf-buy-cta__sub {
    font-size: 11px;
  }
}

/* ───────────────────────────────────────────────────────────────
   #3  검증 버튼 (.cf-validate-btn) 스타일
   ─────────────────────────────────────────────────────────────── */
.cf-validate-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 14px;
  margin-left: 8px;
  background: #2a1d10;
  color: #f5e7b8;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  white-space: nowrap;
}
.cf-validate-btn:hover {
  background: #3d2b18;
}
@media (max-width: 480px) {
  .cf-validate-btn {
    padding: 6px 10px;
    font-size: 10px;
    margin-left: 6px;
  }
}
/* ════════════════════════════════════════════════════════════════
   Customer Fix 2026-05-13 — lean rebuild from 5.11 base
   ────────────────────────────────────────────────────────────────
   #1 모바일 자산카드 균일 사이즈
   #2 모바일 하단 단축메뉴 (.ga-bottomnav, #footer-wrap) 숨김
   #4 (cf-buy-cta 스타일링)
   #5 Buy 페이지 모바일 1-scroll
   #6 인덱스 vs 서브 자산 레이아웃 통일
   #7 자산 영역 컴팩트
   #8 CSS/JS only, HTML/PHP 무수정
   ════════════════════════════════════════════════════════════════ */

/* ───────────────────────────────────────────────────────────────
   #2  모바일 하단 단축메뉴 제거
   ─────────────────────────────────────────────────────────────── */
@media (max-width: 820px) {
  body #footer-wrap,
  body .ga-bottomnav {
    display: none !important;
  }
  /* bottomnav 자리 차지하던 body padding 도 제거 */
  body.ga-has-bottomnav {
    padding-bottom: 0 !important;
  }
}

/* ───────────────────────────────────────────────────────────────
   #1 + #6 + #7  자산 카드 (.mcont01) — 모바일/PC 균일 + 컴팩트
   원칙: 5장 동일 width / 동일 height. 모바일 = 2-col + 마지막 카드 가로 확장 금지.
        PC = 5-col 1행. 모두 컴팩트.
   ─────────────────────────────────────────────────────────────── */

/* 기본 (모든 viewport): grid 자체 컴팩트 */
body.skin-v2 #doc .mcont01 {
  margin: 0 !important;
  padding: 8px 12px !important;
}
body.skin-v2 #doc .mcont01 > .div-cont {
  display: grid !important;
  gap: 8px !important;
  padding: 0 !important;
  margin: 0 auto !important;
  max-width: 1200px !important;
  box-sizing: border-box !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] {
  float: none !important;
  width: auto !important;
  margin: 0 !important;
  padding: 10px 12px !important;
  box-sizing: border-box !important;
  background: #f7f1e3 !important;
  border: 1px solid #e8dcb8 !important;
  border-radius: 10px !important;
  min-height: 80px !important;
  max-height: 100px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  align-items: center !important;
  text-align: center !important;
  gap: 4px !important;
  overflow: hidden !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] > p {
  margin: 0 !important;
  padding: 0 !important;
  font-size: 11px !important;
  letter-spacing: 0.04em !important;
  line-height: 1.2 !important;
  color: #6a4f10 !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assetcont {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  text-align: center !important;
  gap: 2px !important;
  padding: 0 !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assetcont > * {
  margin: 0 !important;
  padding: 0 !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assets-num,
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assets-num-perf {
  font-size: clamp(14px, 2.4vw, 18px) !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  color: #1a1208 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: clip !important;
  max-width: 100% !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assetcont > p {
  font-size: 9.5px !important;
  letter-spacing: 0.05em !important;
  color: #8c6b1f !important;
  text-transform: uppercase !important;
}

/* PC (≥768): 5-col 1행 균일 — specificity (1,5,1) 매칭 */
@media (min-width: 768px) {
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont {
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    grid-template-rows: 96px !important;
    gap: 10px !important;
  }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > [class^="assets0"] {
    min-height: 96px !important;
    max-height: 96px !important;
    height: 96px !important;
    grid-row: 1 !important;
  }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > .assets01 { grid-column: 1 !important; }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > .assets02 { grid-column: 2 !important; }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > .assets03 { grid-column: 3 !important; }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > .assets04 { grid-column: 4 !important; }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > .assets05 { grid-column: 5 !important; grid-row: 1 !important; }
}

/* 모바일 (≤767): 2-col, assets05 도 col 1만 사용 (전폭 금지 — #1 균일)
   specificity 매칭으로 theme-legacy-dashboard-v3.css 이김 */
@media (max-width: 767px) {
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont {
    grid-template-columns: 1fr 1fr !important;
    grid-template-rows: none !important;
    grid-auto-rows: 64px !important;
    gap: 6px !important;
  }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > [class^="assets0"] {
    grid-column: span 1 !important;
    grid-row: auto !important;
    min-height: 64px !important;
    max-height: 64px !important;
    height: 64px !important;
    padding: 6px 8px !important;
  }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > .assets05 {
    grid-column: span 1 !important;
    grid-row: auto !important;
  }
  body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assets-num,
  body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assets-num-perf {
    font-size: 12px !important;
  }
  body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] > p {
    font-size: 8.5px !important;
    letter-spacing: 0.03em !important;
  }
  body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assetcont > p {
    font-size: 8px !important;
  }
  /* .ga-dashboard-v3-head (페이지 헤더) 모바일 컴팩트 */
  body.skin-v2 #doc .mcont01 .ga-dashboard-v3-head {
    padding: 6px 12px !important;
    min-height: 0 !important;
  }
  body.skin-v2 #doc .mcont01 .ga-dashboard-v3-head h2 {
    font-size: 16px !important;
    margin: 0 !important;
    line-height: 1.2 !important;
  }
  body.skin-v2 #doc .mcont01 .ga-dashboard-v3-head .eyebrow,
  body.skin-v2 #doc .mcont01 .ga-dashboard-v3-head .meta,
  body.skin-v2 #doc .mcont01 .ga-dashboard-v3-head .meta-line {
    font-size: 9px !important;
    line-height: 1.2 !important;
  }
}

/* ───────────────────────────────────────────────────────────────
   #5  Buy 페이지 모바일 1-scroll (실제 CONFIRM 까지)
   원칙: buy 모바일에서 form 위 모든 콘텐츠 숨김
        (자산 정보는 form 내 "Withdrawable assets" 행에 이미 표시됨 — 중복)
   ─────────────────────────────────────────────────────────────── */
@media (max-width: 767px) {
  /* hero 전체 숨김 (Trade USDT…, 소개 텍스트) — form에 진입 즉시 가능 */
  body.skin-v2.page-buy .ga-v2 {
    display: none !important;
  }
  /* .mcont01 자산 카드 숨김 — form의 Withdrawable assets 행과 중복 */
  body.skin-v2.page-buy #doc .mcont01 {
    display: none !important;
  }
  /* form section padding 컴팩트 */
  body.skin-v2.page-buy #doc .msec-game,
  body.skin-v2.page-buy #doc .Buy-list,
  body.skin-v2.page-buy #doc #section-farm {
    padding-top: 8px !important;
    padding-bottom: 8px !important;
  }
  /* form row 자체도 컴팩트 — qty-region 등 높이 축소 */
  body.skin-v2.page-buy #doc .qty-region {
    margin: 6px 0 !important;
  }
  body.skin-v2.page-buy #doc .Buy-list .sub-title-01 {
    font-size: 14px !important;
    margin: 4px 0 !important;
  }
}

/* PC 에서는 buy hero 유지 (단지 컴팩트) */
@media (min-width: 768px) {
  body.skin-v2.page-buy .ga-v2 .container .meta-row {
    margin: 12px 0 !important;
  }
}

/* ───────────────────────────────────────────────────────────────
   #4  Buy CTA 스타일 (JS가 .cf-buy-cta inject)
   ─────────────────────────────────────────────────────────────── */
.cf-buy-cta {
  width: 100%;
  padding: 24px 16px;
  background: linear-gradient(135deg, #fff7e1 0%, #f5e7b8 100%);
  border-top: 1px solid #e8dcb8;
  border-bottom: 1px solid #e8dcb8;
  text-align: center;
}
.cf-buy-cta__inner {
  max-width: 720px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.cf-buy-cta__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 36px;
  background: #1a1208;
  color: #f5e7b8 !important;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-decoration: none !important;
  border-radius: 999px;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.18);
}
.cf-buy-cta__btn:hover,
.cf-buy-cta__btn:focus {
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.25);
}
.cf-buy-cta__sub {
  margin: 0;
  font-size: 12px;
  color: #6a4f10;
  letter-spacing: 0.04em;
}
@media (max-width: 767px) {
  .cf-buy-cta {
    padding: 16px 12px;
  }
  .cf-buy-cta__btn {
    padding: 12px 24px;
    font-size: 14px;
  }
  .cf-buy-cta__sub {
    font-size: 11px;
  }
}

/* ───────────────────────────────────────────────────────────────
   #3  검증 버튼 (.cf-validate-btn) 스타일
   ─────────────────────────────────────────────────────────────── */
.cf-validate-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 14px;
  margin-left: 8px;
  background: #2a1d10;
  color: #f5e7b8;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  white-space: nowrap;
}
.cf-validate-btn:hover {
  background: #3d2b18;
}
@media (max-width: 480px) {
  .cf-validate-btn {
    padding: 6px 10px;
    font-size: 10px;
    margin-left: 6px;
  }
}
/* ════════════════════════════════════════════════════════════════
   Customer Fix 2026-05-13 — lean rebuild from 5.11 base
   ────────────────────────────────────────────────────────────────
   #1 모바일 자산카드 균일 사이즈
   #2 모바일 하단 단축메뉴 (.ga-bottomnav, #footer-wrap) 숨김
   #4 (cf-buy-cta 스타일링)
   #5 Buy 페이지 모바일 1-scroll
   #6 인덱스 vs 서브 자산 레이아웃 통일
   #7 자산 영역 컴팩트
   #8 CSS/JS only, HTML/PHP 무수정
   ════════════════════════════════════════════════════════════════ */

/* ───────────────────────────────────────────────────────────────
   #2  모바일 하단 단축메뉴 제거
   ─────────────────────────────────────────────────────────────── */
@media (max-width: 820px) {
  body #footer-wrap,
  body .ga-bottomnav {
    display: none !important;
  }
  /* bottomnav 자리 차지하던 body padding 도 제거 */
  body.ga-has-bottomnav {
    padding-bottom: 0 !important;
  }
}

/* ───────────────────────────────────────────────────────────────
   #1 + #6 + #7  자산 카드 (.mcont01) — 모바일/PC 균일 + 컴팩트
   원칙: 5장 동일 width / 동일 height. 모바일 = 2-col + 마지막 카드 가로 확장 금지.
        PC = 5-col 1행. 모두 컴팩트.
   ─────────────────────────────────────────────────────────────── */

/* 기본 (모든 viewport): grid 자체 컴팩트 */
body.skin-v2 #doc .mcont01 {
  margin: 0 !important;
  padding: 8px 12px !important;
}
body.skin-v2 #doc .mcont01 > .div-cont {
  display: grid !important;
  gap: 8px !important;
  padding: 0 !important;
  margin: 0 auto !important;
  max-width: 1200px !important;
  box-sizing: border-box !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] {
  float: none !important;
  width: auto !important;
  margin: 0 !important;
  padding: 10px 12px !important;
  box-sizing: border-box !important;
  background: #f7f1e3 !important;
  border: 1px solid #e8dcb8 !important;
  border-radius: 10px !important;
  min-height: 80px !important;
  max-height: 100px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  align-items: center !important;
  text-align: center !important;
  gap: 4px !important;
  overflow: hidden !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] > p {
  margin: 0 !important;
  padding: 0 !important;
  font-size: 11px !important;
  letter-spacing: 0.04em !important;
  line-height: 1.2 !important;
  color: #6a4f10 !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assetcont {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  text-align: center !important;
  gap: 2px !important;
  padding: 0 !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assetcont > * {
  margin: 0 !important;
  padding: 0 !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assets-num,
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assets-num-perf {
  font-size: clamp(14px, 2.4vw, 18px) !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  color: #1a1208 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: clip !important;
  max-width: 100% !important;
}
body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assetcont > p {
  font-size: 9.5px !important;
  letter-spacing: 0.05em !important;
  color: #8c6b1f !important;
  text-transform: uppercase !important;
}

/* PC (≥768): 5-col 1행 균일 — specificity (1,5,1) 매칭 */
@media (min-width: 768px) {
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont {
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    grid-template-rows: 96px !important;
    gap: 10px !important;
  }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > [class^="assets0"] {
    min-height: 96px !important;
    max-height: 96px !important;
    height: 96px !important;
    grid-row: 1 !important;
  }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > .assets01 { grid-column: 1 !important; }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > .assets02 { grid-column: 2 !important; }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > .assets03 { grid-column: 3 !important; }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > .assets04 { grid-column: 4 !important; }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > .assets05 { grid-column: 5 !important; grid-row: 1 !important; }
}

/* 모바일 (≤767): 2-col, assets05 도 col 1만 사용 (전폭 금지 — #1 균일)
   specificity 매칭으로 theme-legacy-dashboard-v3.css 이김 */
@media (max-width: 767px) {
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont {
    grid-template-columns: 1fr 1fr !important;
    grid-template-rows: none !important;
    grid-auto-rows: 64px !important;
    gap: 6px !important;
  }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > [class^="assets0"] {
    grid-column: span 1 !important;
    grid-row: auto !important;
    min-height: 64px !important;
    max-height: 64px !important;
    height: 64px !important;
    padding: 6px 8px !important;
  }
  body.skin-v2:is(.page-buy, .page-transfer, .page-reward, .page-member, .page-withdrawal, .page-withdrawal-list, .page-asset-list, .page-join, .page-my-info, .page-notice, .page-rules) #doc .mcont01 > .div-cont > .assets05 {
    grid-column: span 1 !important;
    grid-row: auto !important;
  }
  body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assets-num,
  body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assets-num-perf {
    font-size: 12px !important;
  }
  body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] > p {
    font-size: 8.5px !important;
    letter-spacing: 0.03em !important;
  }
  body.skin-v2 #doc .mcont01 > .div-cont > [class^="assets0"] .assetcont > p {
    font-size: 8px !important;
  }
  /* .ga-dashboard-v3-head 모바일 숨김 — 페이지 hero 가 이미 제목 표시 */
  body.skin-v2 #doc .mcont01 .ga-dashboard-v3-head {
    display: none !important;
  }
}

/* ───────────────────────────────────────────────────────────────
   #5  Buy 페이지 모바일 1-scroll (실제 CONFIRM 까지)
   원칙: buy 모바일에서 form 위 모든 콘텐츠 숨김
        (자산 정보는 form 내 "Withdrawable assets" 행에 이미 표시됨 — 중복)
   ─────────────────────────────────────────────────────────────── */
@media (max-width: 767px) {
  /* hero 전체 숨김 (Trade USDT…, 소개 텍스트) — form에 진입 즉시 가능 */
  body.skin-v2.page-buy .ga-v2 {
    display: none !important;
  }
  /* .mcont01 자산 카드 숨김 — form의 Withdrawable assets 행과 중복 */
  body.skin-v2.page-buy #doc .mcont01 {
    display: none !important;
  }
  /* form section padding 컴팩트 */
  body.skin-v2.page-buy #doc .msec-game,
  body.skin-v2.page-buy #doc .Buy-list,
  body.skin-v2.page-buy #doc #section-farm {
    padding-top: 8px !important;
    padding-bottom: 8px !important;
  }
  /* form row 자체도 컴팩트 — qty-region 등 높이 축소 */
  body.skin-v2.page-buy #doc .qty-region {
    margin: 6px 0 !important;
  }
  body.skin-v2.page-buy #doc .Buy-list .sub-title-01 {
    font-size: 14px !important;
    margin: 4px 0 !important;
  }
}

/* PC 에서는 buy hero 유지 (단지 컴팩트) */
@media (min-width: 768px) {
  body.skin-v2.page-buy .ga-v2 .container .meta-row {
    margin: 12px 0 !important;
  }
}

/* ───────────────────────────────────────────────────────────────
   #4  Buy CTA 스타일 (JS가 .cf-buy-cta inject)
   ─────────────────────────────────────────────────────────────── */
.cf-buy-cta {
  width: 100%;
  padding: 24px 16px;
  background: linear-gradient(135deg, #fff7e1 0%, #f5e7b8 100%);
  border-top: 1px solid #e8dcb8;
  border-bottom: 1px solid #e8dcb8;
  text-align: center;
}
.cf-buy-cta__inner {
  max-width: 720px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.cf-buy-cta__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 36px;
  background: #1a1208;
  color: #f5e7b8 !important;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-decoration: none !important;
  border-radius: 999px;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.18);
}
.cf-buy-cta__btn:hover,
.cf-buy-cta__btn:focus {
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.25);
}
.cf-buy-cta__sub {
  margin: 0;
  font-size: 12px;
  color: #6a4f10;
  letter-spacing: 0.04em;
}
@media (max-width: 767px) {
  .cf-buy-cta {
    padding: 16px 12px;
  }
  .cf-buy-cta__btn {
    padding: 12px 24px;
    font-size: 14px;
  }
  .cf-buy-cta__sub {
    font-size: 11px;
  }
}

/* ───────────────────────────────────────────────────────────────
   #3  검증 버튼 (.cf-validate-btn) 스타일
   ─────────────────────────────────────────────────────────────── */
.cf-validate-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 14px;
  margin-left: 8px;
  background: #2a1d10;
  color: #f5e7b8;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  white-space: nowrap;
}
.cf-validate-btn:hover {
  background: #3d2b18;
}
@media (max-width: 480px) {
  .cf-validate-btn {
    padding: 6px 10px;
    font-size: 10px;
    margin-left: 6px;
  }
}
