/* ============================================================
   GlobalGameTrade — shared chrome (nav, footer, common components)
   Load AFTER tokens.css on every page.
   ============================================================ */

.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 var(--pad-x); }
html.theme-switching, html.theme-switching * { transition: none !important; }

/* ---------- Ledger direction (grotesk display) ---------- */
html.ggt-ledger .display,
html.ggt-ledger h1, html.ggt-ledger h2, html.ggt-ledger h3,
html.ggt-ledger .gcard__t, html.ggt-ledger .block-h,
html.ggt-ledger .sec__head h2, html.ggt-ledger .hero h1,
html.ggt-ledger .pdp__title, html.ggt-ledger .gbanner__cap h1,
html.ggt-ledger .focal-card__cap .t, html.ggt-ledger .trust__in .n,
html.ggt-ledger .quote blockquote, html.ggt-ledger .gstatement .q {
  font-weight: 600;
  letter-spacing: -0.02em;
}
html.ggt-ledger .hero h1 em,
html.ggt-ledger .gstatement .q em { font-style: normal; }
a { color: inherit; }
body { display: flex; flex-direction: column; min-height: 100vh; }
main { flex: 1; }

/* ---------- nav ---------- */
.nav { position: sticky; top: 0; z-index: 50; background: color-mix(in srgb, var(--bg) 86%, transparent); border-bottom: 1px solid var(--hairline); backdrop-filter: blur(10px); }
.nav__in { display: flex; align-items: center; gap: var(--s-5); height: 68px; }
.brand { display: flex; align-items: center; gap: 10px; min-width: 0; text-decoration: none; color: var(--fg); }
.brand__mark { width: 26px; height: 26px; flex: none; }
.brand__name { min-width: 0; overflow: hidden; text-overflow: ellipsis; font-family: var(--font-display); font-size: 22px; font-weight: var(--w-medium); letter-spacing: .01em; white-space: nowrap; }
.brand__name b { font-weight: var(--w-medium); color: var(--accent); }
[data-theme="dark"] .brand__name b { color: var(--accent-bright); }
.nav__links { display: flex; gap: var(--s-5); margin-left: var(--s-4); }
.nav__links a { text-decoration: none; color: var(--fg-2); font-size: var(--t-body); transition: color var(--dur-fast) var(--ease); position: relative; }
.nav__links a:hover { color: var(--fg); }
.nav__links a[aria-current="page"] { color: var(--fg); }
.nav__links a[aria-current="page"]::after { content: ""; position: absolute; left: 0; right: 0; bottom: -22px; height: 1px; background: var(--accent); }
[data-theme="dark"] .nav__links a[aria-current="page"]::after { background: var(--accent-bright); }
.nav__spacer { flex: 1; }
.nav__tools { display: flex; flex: none; align-items: center; gap: var(--s-3); }

.seg { display: inline-flex; border: 1px solid var(--hairline); border-radius: var(--r-pill); padding: 3px; }
.seg button { font-family: var(--font-body); font-size: var(--t-caption); color: var(--fg-2); background: transparent; border: 0; border-radius: var(--r-pill); padding: 6px 11px; cursor: pointer; transition: color var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease); display: inline-grid; place-items: center; }
.seg button[aria-pressed="true"] { background: var(--surface-2); color: var(--fg); }

/* ---------- language dropdown ---------- */
.langdd { position: relative; }
.langdd__btn { display: inline-flex; align-items: center; gap: 6px; height: 40px; padding: 0 11px; border: 1px solid var(--hairline); border-radius: var(--r-pill); background: transparent; color: var(--fg-2); font-family: var(--font-body); font-size: var(--t-caption); cursor: pointer; transition: color var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease); }
.langdd__btn:hover { color: var(--fg); border-color: var(--hairline-hi); }
.langdd__btn svg { stroke: currentColor; fill: none; stroke-width: 1.5; }
.langdd__btn .globe { width: 15px; height: 15px; flex: none; }
.langdd__btn .chev { width: 11px; height: 11px; flex: none; transition: transform var(--dur-fast) var(--ease); }
.langdd__btn[aria-expanded="true"] .chev { transform: rotate(180deg); }
.langdd__menu { position: absolute; top: calc(100% + 8px); right: 0; min-width: 168px; background: var(--surface); border: 1px solid var(--hairline-hi); border-radius: var(--r-m); padding: 6px; z-index: 80; display: grid; gap: 2px; }
.langdd__menu[hidden] { display: none; }
.langdd__menu button { display: flex; align-items: center; justify-content: space-between; gap: var(--s-4); width: 100%; text-align: left; background: transparent; border: 0; border-radius: var(--r-s); padding: 9px 10px; font-family: var(--font-body); font-size: var(--t-body); color: var(--fg-2); cursor: pointer; transition: background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease); }
.langdd__menu button:hover { background: var(--surface-2); color: var(--fg); }
.langdd__menu button .code { font-size: var(--t-caption); color: var(--fg-3); letter-spacing: var(--track-label); }
.langdd__menu button[aria-selected="true"] { color: var(--fg); }
.langdd__menu button[aria-selected="true"] .code { color: var(--accent); }
[data-theme="dark"] .langdd__menu button[aria-selected="true"] .code { color: var(--accent-bright); }

.icon-btn { width: 40px; height: 40px; display: inline-grid; place-items: center; border: 1px solid var(--hairline); border-radius: var(--r-pill); background: transparent; cursor: pointer; color: var(--fg-2); text-decoration: none; transition: color var(--dur-fast), border-color var(--dur-fast); }
.icon-btn:hover { color: var(--fg); border-color: var(--hairline-hi); }
.icon-btn svg { width: 18px; height: 18px; stroke: currentColor; fill: none; stroke-width: 1.5; }
.nav__burger { display: none; }
.nav__mobile { border-top: 1px solid var(--hairline); background: var(--bg); }
.nav__mobile nav { display: grid; gap: 2px; padding: var(--s-3) var(--pad-x) var(--s-4); }
.nav__mobile a { text-decoration: none; color: var(--fg); font-size: var(--t-body-l); padding: 12px 0; border-bottom: 1px solid var(--hairline); }
.nav__mobile a:last-child { border-bottom: 0; }
.nav__mobile-lang { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--s-2); padding: var(--s-3) var(--pad-x) 0; }
.nav__mobile-lang button { display: flex; align-items: center; justify-content: space-between; gap: 6px; min-width: 0; min-height: 40px; border: 1px solid var(--hairline); border-radius: var(--r-pill); background: transparent; color: var(--fg-2); font-family: var(--font-body); font-size: var(--t-caption); padding: 0 10px; cursor: pointer; }
.nav__mobile-lang button[aria-selected="true"] { border-color: var(--accent); color: var(--fg); background: var(--accent-tint); }
.nav__mobile-lang button span { color: var(--fg-3); font-size: var(--t-micro); letter-spacing: var(--track-label); }
[data-theme="dark"] .nav__mobile-lang button[aria-selected="true"] { border-color: var(--accent-bright); }
.cart-count { position: absolute; top: -4px; right: -4px; min-width: 16px; height: 16px; padding: 0 4px; border-radius: var(--r-pill); background: var(--accent); color: #fff; font-size: 10px; display: grid; place-items: center; font-family: var(--font-body); }
[data-theme="dark"] .cart-count { background: var(--accent-bright); color: #0c0c0e; }

/* ---------- breadcrumb ---------- */
.crumb { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; color: var(--fg-3); font-size: var(--t-caption); padding: var(--s-5) 0 0; }
.crumb a { text-decoration: none; color: var(--fg-3); transition: color var(--dur-fast); }
.crumb a:hover { color: var(--fg); }
.crumb .sep { opacity: .6; }
.crumb .here { color: var(--fg-2); }

/* ---------- duotone placeholder cover (art, not UI — dark in both modes) ---------- */
.duo { position: relative; overflow: hidden; border-radius: var(--r-m); background: #0d1211; }
.ph { width: 100%; height: 100%; position: relative; display: flex; align-items: flex-end; padding: 22px;
  background:
    radial-gradient(135% 100% at 24% -8%, color-mix(in srgb, var(--accent) 42%, transparent), transparent 58%),
    repeating-linear-gradient(135deg, rgba(255,255,255,.05) 0 1px, transparent 1px 11px),
    linear-gradient(155deg, #1b2725 0%, #0d1211 100%); }
.ph::before { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 34%, rgba(5,8,7,.62)); }
.ph span { position: relative; font-family: var(--font-display); font-size: clamp(22px, 3vw, 36px); color: rgba(245, 247, 245, .95); font-weight: var(--w-medium); letter-spacing: .01em; line-height: 1.08; text-shadow: 0 1px 22px rgba(0,0,0,.4); }
.ph--sm span { font-size: clamp(18px, 2vw, 24px); }

/* ---------- footer ---------- */
.foot { border-top: 1px solid var(--hairline); padding: var(--s-9) 0 var(--s-7); margin-top: var(--s-9); }
.foot__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: var(--s-6); }
.foot h4 { font-size: var(--t-caption); text-transform: uppercase; letter-spacing: var(--track-label); color: var(--fg-3); margin-bottom: var(--s-4); font-weight: var(--w-medium); }
.foot ul { list-style: none; margin: 0; padding: 0; display: grid; gap: var(--s-3); }
.foot a { color: var(--fg-2); text-decoration: none; font-size: var(--t-body); }
.foot a:hover { color: var(--fg); }
.foot__brand p { color: var(--fg-2); line-height: var(--lh-loose); max-width: 34ch; margin-top: var(--s-3); }
.foot__bottom { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: var(--s-4); margin-top: var(--s-8); padding-top: var(--s-5); border-top: 1px solid var(--hairline); }
.pay { display: flex; gap: var(--s-3); align-items: center; color: var(--fg-3); font-size: var(--t-caption); flex-wrap: wrap; }
.pay span { border: 1px solid var(--hairline); border-radius: var(--r-s); padding: 4px 9px; }
.foot__legal { color: var(--fg-3); font-size: var(--t-caption); }

/* ---------- quiet chat fab ---------- */
.chat-fab { position: fixed; right: 22px; bottom: 22px; z-index: 60; display: inline-flex; align-items: center; gap: 9px; background: var(--surface); border: 1px solid var(--hairline-hi); border-radius: var(--r-pill); padding: 10px 16px 10px 14px; cursor: pointer; color: var(--fg); font-size: var(--t-caption); transition: border-color var(--dur-fast), transform var(--dur-fast); font-family: var(--font-body); }
.chat-fab:hover { border-color: var(--fg); transform: translateY(-1px); }
.chat-fab svg { width: 17px; height: 17px; stroke: currentColor; fill: none; stroke-width: 1.5; }
.chat-fab .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--ok); }

/* ---------- search ---------- */
.search { display: flex; align-items: center; gap: var(--s-3); border: 1px solid var(--hairline); border-radius: var(--r-pill); padding: 6px 6px 6px 18px; background: var(--surface); transition: border-color var(--dur-fast); }
.search:focus-within { border-color: var(--accent); box-shadow: 0 0 0 3px var(--focus-ring); }
.search svg { width: 18px; height: 18px; stroke: var(--fg-3); fill: none; stroke-width: 1.5; flex: none; }
.search input { flex: 1; border: 0; background: transparent; font-family: var(--font-body); font-size: var(--t-body); color: var(--fg); outline: none; min-width: 0; }
.search input::placeholder { color: var(--fg-3); }

/* ---------- section header ---------- */
.sec { padding: var(--s-9) 0; }
.sec__head { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--s-5); margin-bottom: var(--s-7); }
.sec__head h2 { font-family: var(--font-display); font-size: var(--t-h1); font-weight: var(--w-regular); letter-spacing: var(--track-tight); }
.sec__head p { color: var(--fg-2); margin-top: 8px; max-width: 52ch; line-height: var(--lh-loose); }
.sec__head .more { color: var(--fg-2); text-decoration: none; font-size: var(--t-body); white-space: nowrap; border-bottom: 1px solid var(--hairline-hi); padding-bottom: 3px; transition: color var(--dur-fast), border-color var(--dur-fast); }
.sec__head .more:hover { color: var(--fg); border-color: var(--fg); }

/* ---------- compliance overlays ---------- */
.ggt-age { position: fixed; inset: 0; z-index: 120; display: none; align-items: center; justify-content: center; padding: var(--pad-x); background: color-mix(in srgb, var(--bg) 78%, transparent); backdrop-filter: blur(14px); }
.ggt-age.on { display: flex; }
.ggt-age__box { width: min(440px, 100%); background: var(--surface); border: 1px solid var(--hairline-hi); border-radius: var(--r-l); padding: clamp(26px, 5vw, 44px); text-align: center; box-shadow: 0 24px 80px rgba(0,0,0,.12); }
.ggt-age__box .brand__mark { width: 40px; height: 40px; margin: 0 auto var(--s-5); }
.ggt-age__box h2 { font-family: var(--font-display); font-size: var(--t-h2); font-weight: var(--w-medium); letter-spacing: var(--track-tight); }
.ggt-age__box p { color: var(--fg-2); line-height: var(--lh-loose); margin-top: var(--s-3); }
.ggt-age__box small { display: block; color: var(--fg-3); font-size: var(--t-caption); margin-top: var(--s-4); }
.ggt-age__actions { display: grid; gap: var(--s-3); margin-top: var(--s-6); }
.ggt-age.locked .ggt-age__box { border-color: color-mix(in srgb, var(--danger) 38%, var(--hairline)); }

.ggt-cookie { position: fixed; left: 0; right: 0; bottom: 0; z-index: 95; display: none; background: color-mix(in srgb, var(--bg) 94%, transparent); backdrop-filter: blur(14px); border-top: 1px solid var(--hairline); }
.ggt-cookie.on { display: block; }
.ggt-cookie__in { display: flex; align-items: center; gap: var(--s-5); padding: var(--s-4) 0; }
.ggt-cookie p { color: var(--fg-2); font-size: var(--t-caption); line-height: var(--lh-loose); flex: 1; min-width: 260px; }
.ggt-cookie__actions { display: flex; gap: var(--s-3); flex-wrap: wrap; }

/* ---------- responsive nav ---------- */
@media (max-width: 860px) {
  .nav__links { display: none; }
  .nav__burger { display: inline-grid; }
  .seg[data-seg="currency"] { display: none; }
  .foot__grid { grid-template-columns: 1fr 1fr; gap: var(--s-6) var(--s-5); }
  .foot__brand { grid-column: span 2; }
  .sec__head { flex-direction: column; align-items: flex-start; gap: var(--s-3); }
}

@media (max-width: 640px) {
  .nav__in { height: 64px; gap: var(--s-3); }
  .nav__tools { gap: var(--s-2); }
  .nav__tools .langdd,
  .nav__tools > .seg:not([data-seg="currency"]),
  .nav__tools > .icon-btn[href="08 Account.html"] { display: none; }
  .brand__name { max-width: min(190px, calc(100vw - 188px)); font-size: 18px; }
  .chat-fab { right: 14px; bottom: 14px; width: 46px; height: 46px; padding: 0; justify-content: center; gap: 0; font-size: 0; }
  .chat-fab .dot { position: absolute; right: 10px; bottom: 10px; }
  .ggt-cookie__in { align-items: stretch; flex-direction: column; }
  .ggt-cookie__actions { width: 100%; }
  .ggt-cookie__actions .btn { flex: 1; }
}

@media (max-width: 360px) {
  .brand__name { max-width: calc(100vw - 188px); font-size: 17px; }
  .icon-btn { width: 38px; height: 38px; }
}
