﻿@font-face {
  font-family: 'DizhiChaLogo';
  src: url('/static/dizhicha_logo.woff2') format('woff2');
  font-display: swap;
}
:root {
  --bg: #f3f1ea;
  --ink: #17211f;
  --muted: #5e6a66;
  --panel: #fffdf7;
  --line: #ded6c8;
  --accent: #0d775f;
  --accent-2: #d58936;
  --danger: #9a3d33;
  --warning: #8f5f00;
  --shadow: 0 18px 50px rgba(27, 37, 34, 0.08);
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: radial-gradient(circle at top right, rgba(213,137,54,0.12), transparent 24%), radial-gradient(circle at left 20%, rgba(13,119,95,0.12), transparent 26%), var(--bg);
  color: var(--ink);
  font-family: "Segoe UI", "PingFang SC", "Microsoft YaHei", sans-serif;
  line-height: 1.6;
}
.home-page {
  background:
    radial-gradient(circle at 18% 18%, rgba(151, 223, 214, 0.36), transparent 22%),
    radial-gradient(circle at 82% 14%, rgba(255, 220, 182, 0.30), transparent 20%),
    radial-gradient(circle at 78% 76%, rgba(181, 210, 255, 0.30), transparent 24%),
    linear-gradient(180deg, #f4fff9 0%, #f9fffd 34%, #f8fbff 100%);
}
.home-page .site-header {
  background: rgba(244, 255, 249, 0.74);
  border-bottom: 1px solid rgba(195, 225, 216, 0.7);
}
a { color: inherit; text-decoration: none; }
.container { width: min(1120px, calc(100% - 32px)); margin: 0 auto; }
.site-header { position: sticky; top: 0; z-index: 10; backdrop-filter: blur(14px); background: rgba(243, 241, 234, 0.82); border-bottom: 1px solid rgba(222, 214, 200, 0.9); }
.nav-row { min-height: 72px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.brand { font-size: 1.2rem; font-weight: 800; letter-spacing: 0.04em; }
.nav-links { display: flex; gap: 18px; color: var(--muted); }
.nav-links a:hover { color: var(--accent); }
.hero { padding: 72px 0 48px; }
.hero-grid { display: grid; grid-template-columns: 1.25fr 0.85fr; gap: 28px; align-items: stretch; }
.eyebrow { margin: 0 0 8px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--accent); font-size: 0.86rem; font-weight: 700; }
h1, h2 { margin: 0; line-height: 1.1; }
h1 { font-size: clamp(2.2rem, 5vw, 4.4rem); max-width: 10ch; }
h2 { font-size: 1.15rem; }
.lead { color: var(--muted); font-size: 1.04rem; max-width: 60ch; margin: 18px 0 0; }
.compact { margin-top: 8px; }
.hero-card, .panel, .metric-card, .search-panel { background: var(--panel); border: 1px solid var(--line); box-shadow: var(--shadow); }
.hero-card { border-radius: 28px; padding: 28px; align-self: end; }
.mini-label { color: var(--accent-2); font-weight: 700; margin-bottom: 14px; }
.feature-list { margin: 0; padding-left: 18px; display: grid; gap: 12px; }
.search-panel { margin-top: 28px; border-radius: 24px; padding: 12px; display: grid; grid-template-columns: 1fr auto; gap: 12px; }
.search-panel input, .inline-search input, .quote-form input { width: 100%; min-height: 52px; border-radius: 16px; border: 1px solid var(--line); background: #ffffff; padding: 0 16px; font-size: 1rem; outline: none; }
button { min-height: 52px; border: 0; border-radius: 16px; padding: 0 20px; background: linear-gradient(135deg, var(--accent), #0f5b7c); color: #fff; font-size: 1rem; font-weight: 700; cursor: pointer; }
button:hover { filter: brightness(1.04); }
.site-footer { padding: 32px 0 40px; color: var(--muted); }
.footer-text { text-align: center; }
.page-shell { padding: 36px 0 56px; display: grid; gap: 20px; }
.narrow-shell { max-width: 860px; }
.page-heading { display: flex; align-items: end; justify-content: space-between; gap: 18px; }
.inline-search { display: grid; grid-template-columns: 1fr auto; gap: 10px; min-width: min(460px, 100%); }
.metrics-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
.metric-card { border-radius: 22px; padding: 18px; display: grid; gap: 8px; }
.metric-label, .token-meta, .empty-state, .sr-only, .muted { color: var(--muted); }
.metric-card strong, .quote-result strong { font-size: 1.2rem; }
.metric-card small { color: var(--muted); }
.content-grid { display: grid; gap: 18px; }
.two-col { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.panel { border-radius: 24px; padding: 22px; }
.panel-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 16px; }
.token-list, .stack-list { display: grid; gap: 12px; }
.token-row, .stack-row { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 12px 0; border-top: 1px solid rgba(222, 214, 200, 0.7); }
.token-row:first-child, .stack-row:first-child { border-top: 0; padding-top: 0; }
.stack-row-block { align-items: start; flex-direction: column; }
.token-title { font-weight: 700; }
.align-right { text-align: right; }
.keys-list { display: flex; flex-wrap: wrap; gap: 8px; }
.key-pill, .tag { display: inline-flex; align-items: center; border-radius: 999px; padding: 4px 10px; font-size: 0.88rem; font-weight: 700; }
.key-pill { background: rgba(13, 119, 95, 0.08); color: var(--accent); }
.permission-row { width: 100%; }
.permission-keys-list {
  width: 100%;
  flex-direction: column;
  gap: 6px;
}
.permission-key {
  width: 100%;
  display: block;
  padding: 8px 10px;
  border-radius: 14px;
  background: rgba(13, 119, 95, 0.08);
  color: var(--accent);
  font-size: 0.82rem;
  font-weight: 700;
  font-family: Consolas, Monaco, monospace;
  line-height: 1.45;
  word-break: break-all;
  overflow-wrap: anywhere;
}
.table-wrap { overflow-x: auto; }
table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: 12px 10px; border-top: 1px solid rgba(222, 214, 200, 0.75); white-space: nowrap; }
th { color: var(--muted); font-weight: 700; font-size: 0.92rem; }
.tag-in { background: rgba(13, 119, 95, 0.12); color: var(--accent); }
.tag-out { background: rgba(154, 61, 51, 0.12); color: var(--danger); }
.alert { border-radius: 18px; padding: 14px 16px; border: 1px solid; }
.alert + .alert { margin-top: -8px; }
.alert-error { background: rgba(154, 61, 51, 0.08); border-color: rgba(154, 61, 51, 0.25); color: var(--danger); }
.alert-warning { background: rgba(143, 95, 0, 0.08); border-color: rgba(143, 95, 0, 0.24); color: var(--warning); }
.quote-form { display: grid; gap: 10px; }
.quote-row { display: grid; grid-template-columns: 1fr auto; gap: 12px; }
.quote-result { margin-top: 18px; display: grid; gap: 16px; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.address-box { margin-top: 12px; padding: 18px; border-radius: 20px; background: #f9f6ef; border: 1px dashed var(--line); font-family: Consolas, Monaco, monospace; word-break: break-all; }
.empty-state { margin: 0; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }
.home-hero {
  position: relative;
  overflow: hidden;
  min-height: calc(100vh - 72px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 64px 0 72px;
}
.home-center-wrap {
  position: relative;
  z-index: 2;
  display: grid;
  gap: 26px;
  justify-items: center;
  text-align: center;
}
.home-copy {
  display: grid;
  gap: 12px;
  justify-items: center;
}
.home-title {
  max-width: 11ch;
  font-size: clamp(2.7rem, 6vw, 5.4rem);
  letter-spacing: -0.04em;
}
.home-subtitle {
  max-width: 52rem;
  margin: 0;
  color: #4f6761;
  font-size: clamp(1rem, 1.8vw, 1.14rem);
}
.home-search-shell {
  width: min(860px, 100%);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  padding: 12px;
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.8);
  border: 1px solid rgba(185, 220, 208, 0.85);
  box-shadow: 0 24px 60px rgba(44, 82, 73, 0.14);
  backdrop-filter: blur(10px);
}
.home-search-shell input {
  min-height: 60px;
  border-radius: 18px;
  border: 1px solid rgba(196, 222, 214, 0.95);
  background: rgba(255, 255, 255, 0.92);
  padding: 0 22px;
  font-size: 1.02rem;
  outline: none;
}
.home-search-shell input:focus {
  border-color: rgba(62, 144, 122, 0.8);
  box-shadow: 0 0 0 4px rgba(102, 191, 167, 0.14);
}
.home-search-shell button {
  min-width: 150px;
  min-height: 60px;
  border-radius: 18px;
  background: linear-gradient(135deg, #36a383, #3c73ad);
  box-shadow: 0 14px 30px rgba(52, 120, 144, 0.24);
}
.home-feature-row {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.home-feature-card {
  padding: 18px 18px 16px;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(203, 225, 219, 0.9);
  box-shadow: 0 18px 44px rgba(62, 91, 84, 0.08);
  text-align: left;
}
.home-feature-card strong {
  display: block;
  margin-bottom: 6px;
  font-size: 1.05rem;
}
.home-feature-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.95rem;
}
.home-feature-kicker {
  display: inline-block;
  margin-bottom: 8px;
  color: #2f8b72;
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.home-alert-wrap {
  width: min(860px, 100%);
}
.home-orb {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  border-radius: 999px;
  filter: blur(0.2px);
  opacity: 0.72;
}
.home-orb-left {
  left: 25%;
  width: min(32vw, 430px);
  height: min(32vw, 430px);
  background: radial-gradient(circle at 50% 50%, rgba(101, 174, 210, 0.34), rgba(101, 174, 210, 0.08) 72%, transparent 74%);
}
.home-orb-mid {
  left: 50%;
  width: min(35vw, 470px);
  height: min(35vw, 470px);
  transform: translate(-50%, -50%);
  background: radial-gradient(circle at 50% 50%, rgba(108, 207, 186, 0.28), rgba(108, 207, 186, 0.08) 72%, transparent 74%);
}
.home-orb-right {
  right: 25%;
  width: min(32vw, 430px);
  height: min(32vw, 430px);
  background: radial-gradient(circle at 50% 50%, rgba(148, 160, 255, 0.26), rgba(148, 160, 255, 0.08) 72%, transparent 74%);
}
.home-footer {
  padding-top: 8px;
}
@media (max-width: 920px) {
  .hero-grid, .two-col, .metrics-grid, .quote-result, .page-heading, .inline-search, .quote-row, .home-feature-row { grid-template-columns: 1fr; }
  .page-heading, .nav-row, .token-row, .stack-row { align-items: start; flex-direction: column; }
  .search-panel, .home-search-shell { grid-template-columns: 1fr; }
  .align-right { text-align: left; }
  .home-hero {
    min-height: auto;
    padding: 34px 0 48px;
  }
  .home-title {
    max-width: 8ch;
  }
  .home-search-shell button {
    width: 100%;
  }
  .home-orb-left {
    left: -10%;
  }
  .home-orb-right {
    right: -10%;
  }
}
.address-page {
  background:
    radial-gradient(circle at 18% 18%, rgba(160, 222, 213, 0.18), transparent 22%),
    linear-gradient(180deg, #f8fbfb 0%, #f7faf8 100%);
}
.address-shell {
  padding: 30px 0 56px;
  display: grid;
  gap: 18px;
}
.address-hero {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 20px;
}
.address-hero-copy {
  display: grid;
  gap: 8px;
}
.address-title {
  max-width: 100%;
  font-size: clamp(2.1rem, 4.3vw, 3.4rem);
  letter-spacing: -0.04em;
  word-break: break-all;
}
.address-meta-line {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  color: var(--muted);
}
.address-meta-label {
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.address-search {
  min-width: min(420px, 100%);
}
.address-primary-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(360px, 0.95fr);
  gap: 18px;
}
.address-secondary-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
.panel-head-tight {
  margin-bottom: 12px;
}
.overview-panel {
  padding: 24px;
}
.overview-main-row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: start;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(222, 214, 200, 0.75);
}
.overview-label {
  color: var(--muted);
  font-size: 0.92rem;
}
.overview-amount {
  margin-top: 6px;
  font-size: clamp(2rem, 4vw, 2.8rem);
  font-weight: 800;
  line-height: 1;
}
.overview-sub {
  margin-top: 8px;
  color: #4d6761;
}
.overview-chip-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: end;
}
.overview-chip {
  border-radius: 999px;
  padding: 8px 12px;
  background: rgba(57, 136, 114, 0.08);
  color: #2e7763;
  font-weight: 700;
  white-space: nowrap;
}
.overview-metrics-grid {
  margin-top: 18px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.overview-metric {
  border-radius: 18px;
  padding: 14px 16px;
  background: rgba(248, 251, 248, 0.95);
  border: 1px solid rgba(224, 232, 225, 0.9);
  display: grid;
  gap: 6px;
}
.overview-metric span,
.overview-metric small {
  color: var(--muted);
}
.overview-metric strong {
  font-size: 1.24rem;
}
.asset-panel,
.compact-panel {
  padding: 22px;
}
.asset-scroll-list {
  display: grid;
  gap: 10px;
  max-height: 360px;
  overflow: auto;
  padding-right: 4px;
}
.asset-row {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
  padding: 12px 0;
  border-top: 1px solid rgba(222, 214, 200, 0.7);
}
.asset-row:first-child {
  border-top: 0;
  padding-top: 0;
}
.asset-amount {
  font-weight: 700;
}
.compact-list {
  max-height: 310px;
  overflow: auto;
  padding-right: 4px;
}
.transfer-panel {
  padding: 22px;
}
.transfer-head {
  align-items: end;
}
.transfer-table-wrap {
  margin-top: 8px;
}
.transfer-amount-cell {
  font-weight: 700;
}
@media (max-width: 1080px) {
  .address-primary-grid,
  .address-secondary-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 920px) {
  .address-hero,
  .overview-main-row {
    align-items: start;
    flex-direction: column;
  }
  .address-search {
    min-width: 100%;
  }
  .overview-chip-wrap {
    justify-content: start;
  }
  .overview-metrics-grid {
    grid-template-columns: 1fr;
  }
}
.brand-logo-font {
  font-family: "DizhiChaLogo", "Segoe UI", "PingFang SC", "Microsoft YaHei", sans-serif;
}
.brand-rich {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.brand-icon {
  width: 34px;
  height: 34px;
  object-fit: contain;
}
.brand-word {
  font-size: 1.65rem;
  letter-spacing: 0.02em;
}
.brand-version {
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.78rem;
  font-weight: 700;
}
.address-page {
  background:
    radial-gradient(circle at 14% 16%, rgba(149, 225, 209, 0.16), transparent 24%),
    radial-gradient(circle at 84% 10%, rgba(100, 159, 255, 0.10), transparent 22%),
    linear-gradient(180deg, #f4f7fb 0%, #f6f8fb 100%);
}
.address-site-header {
  background: transparent;
  border-bottom: 0;
}
.address-site-header-fill {
  width: 100%;
  background: rgba(39, 41, 45, 0.92);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.address-nav-row {
  min-height: 76px;
  gap: 20px;
}
.address-site-header .brand,
.address-site-header .nav-links a,
.address-site-header .nav-links {
  color: #ffffff;
}
.address-nav-row > .nav-links,
.address-nav-row > .header-music-player,
.address-nav-row > .header-search {
  margin-left: auto;
}
.nav-links-light {
  align-items: center;
}
.nav-inline-icon {
  width: 18px;
  height: 18px;
}
.nav-links-light a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: rgba(255, 255, 255, 0.84);
}
.nav-links-light a:hover {
  color: #ffffff;
}
.header-search {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  min-width: min(460px, 100%);
  margin-left: auto;
}
.header-search input {
  min-height: 46px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  padding: 0 18px;
  outline: none;
}
.header-search input::placeholder {
  color: rgba(255, 255, 255, 0.55);
}
.header-search button {
  min-height: 46px;
  border-radius: 999px;
  padding: 0 18px;
  box-shadow: none;
}
.address-shell {
  padding: 24px 0 56px;
  gap: 20px;
}
.address-hero-panel {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(220px, 260px);
  gap: 24px;
  padding: 24px;
  align-items: stretch;
}
.address-hero-main {
  display: grid;
  gap: 18px;
}
.address-hero-heading {
  display: flex;
  align-items: center;
  gap: 16px;
}
.wallet-hero-icon {
  width: 56px;
  height: 56px;
  object-fit: contain;
}
.address-meta-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.meta-chip {
  display: inline-grid;
  gap: 4px;
  min-width: 180px;
  padding: 12px 14px;
  border-radius: 18px;
  background: #f7fafc;
  border: 1px solid rgba(224, 229, 237, 0.95);
}
.meta-chip span {
  color: var(--muted);
  font-size: 0.82rem;
}
.meta-chip strong {
  font-size: 0.96rem;
}
.address-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.ghost-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 44px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid rgba(38, 49, 61, 0.12);
  background: #fff;
  color: #1f2b2c;
  font-size: 0.95rem;
  font-weight: 700;
  box-shadow: none;
}
.ghost-action:hover {
  color: var(--accent);
  border-color: rgba(13, 119, 95, 0.25);
}
.ghost-action img {
  width: 18px;
  height: 18px;
}
.is-copied {
  color: #fff;
  background: linear-gradient(135deg, #2f8b72, #4078b6);
  border-color: transparent;
}
.qr-card {
  display: grid;
  justify-items: center;
  gap: 16px;
  padding: 18px;
  border-radius: 24px;
  background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
  border: 1px solid rgba(224, 229, 237, 0.95);
}
.qr-card-head {
  display: grid;
  gap: 4px;
  width: 100%;
  text-align: center;
}
.qr-card-head span {
  color: var(--muted);
  font-size: 0.88rem;
}
.qr-image {
  width: 196px;
  height: 196px;
  border-radius: 20px;
  background: #fff;
  padding: 10px;
  border: 1px solid rgba(224, 229, 237, 0.95);
}
.overview-table {
  margin-top: 18px;
  display: grid;
}
.overview-table-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 0;
  border-top: 1px solid rgba(222, 214, 200, 0.75);
}
.overview-table-key {
  color: #101010;
  font-size: 0.95rem;
}
.overview-table-value {
  text-align: right;
  color: #101010;
}
.overview-table-value-icons {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.transfer-split {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.transfer-split img {
  width: 18px;
  height: 18px;
}
.transfer-summary-split {
  gap: 10px;
}
.transfer-summary-label {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 0.9rem;
  font-weight: 700;
  line-height: 1.2;
}
.transfer-summary-label.stat-positive {
  background: rgba(46, 173, 101, 0.12);
}
.transfer-summary-label.stat-negative {
  background: rgba(235, 71, 71, 0.12);
}
.inline-action-link {
  margin-left: 8px;
  color: #386ec8;
  font-weight: 700;
}
.asset-row-rich {
  align-items: flex-start;
}
.asset-token-main,
.approval-main,
.transfer-token-cell {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}
.token-logo {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  object-fit: cover;
  background: #f5f8fb;
  border: 1px solid rgba(225, 232, 240, 0.95);
  flex: 0 0 auto;
}
.token-logo-sm {
  width: 22px;
  height: 22px;
}
.token-logo-xs {
  width: 18px;
  height: 18px;
}
.token-title-rich {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}
.token-title-rich a:hover,
.table-wrap a:hover,
.approval-row a:hover {
  color: var(--accent);
}
.token-type-pill {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(34, 39, 46, 0.08);
  color: #39414a;
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
}
.token-id-line {
  word-break: break-all;
}
.approval-row,
.project-row {
  align-items: center;
}
.transfer-stats-bar {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin: 6px 0 16px;
}
.transfer-stat-card {
  display: grid;
  gap: 6px;
  padding: 14px 16px;
  border-radius: 18px;
  background: #f8fafc;
  border: 1px solid rgba(224, 229, 237, 0.95);
}
.transfer-stat-card span {
  color: var(--muted);
  font-size: 0.88rem;
}
.transfer-stat-card strong {
  font-size: 1.24rem;
}
.transfer-token-cell {
  min-width: 180px;
}
.stat-positive {
  color: #2ead65;
}
.stat-negative {
  color: #eb4747;
}
.transfer-amount-cell.stat-positive,
.transfer-amount-cell.stat-negative {
  font-weight: 800;
}
.transfer-filter-form {
  margin: 10px 0 18px;
}
.transfer-filter-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 12px;
}
.transfer-filter-field {
  display: grid;
  gap: 6px;
}
.transfer-filter-field span {
  color: var(--muted);
  font-size: 0.84rem;
}
.transfer-filter-field input,
.transfer-filter-field select {
  min-height: 44px;
  width: 100%;
  padding: 0 14px;
  border-radius: 14px;
  border: 1px solid rgba(201, 210, 223, 0.95);
  background: #ffffff;
  color: #172130;
  outline: none;
}
.transfer-filter-field input:focus,
.transfer-filter-field select:focus {
  border-color: rgba(63, 130, 201, 0.72);
  box-shadow: 0 0 0 4px rgba(99, 161, 227, 0.16);
}
.transfer-filter-actions {
  display: flex;
  align-items: flex-end;
  gap: 10px;
}
.transfer-filter-actions .ghost-action,
.transfer-filter-actions button {
  min-height: 44px;
}
.filter-reset-link {
  min-width: 92px;
}
.transfer-stat-card small {
  color: var(--muted);
  font-size: 0.82rem;
}
.transfer-pagination {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
  margin-top: 18px;
}
.page-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  min-height: 42px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(197, 206, 220, 0.95);
  background: #ffffff;
  color: #172130;
  font-weight: 700;
}
.page-link:hover {
  color: var(--accent);
  border-color: rgba(13, 119, 95, 0.35);
}
.page-link-active {
  background: linear-gradient(135deg, #2f8b72, #4078b6);
  border-color: transparent;
  color: #ffffff;
}
.page-link-disabled,
.page-link-ellipsis {
  color: var(--muted);
  background: #f8fafc;
}
.page-link-disabled {
  opacity: 0.7;
}
@media (max-width: 1180px) {
  .address-nav-row {
    display: grid;
    grid-template-columns: 1fr;
    padding: 14px 0;
  }
  .header-search {
    margin-left: 0;
  }
}
@media (max-width: 1080px) {
  .address-hero-panel,
  .address-primary-grid,
  .address-secondary-grid,
  .transfer-stats-bar {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 920px) {
  .address-hero-heading,
  .address-action-row,
  .overview-table-row,
  .overview-table-value-icons {
    align-items: flex-start;
    flex-direction: column;
  }
  .brand-word {
    font-size: 1.4rem;
  }
  .nav-links-light {
    flex-wrap: wrap;
  }
  .header-search {
    grid-template-columns: 1fr;
    min-width: 100%;
  }
  .qr-image {
    width: min(196px, 100%);
    height: auto;
  }
}
html {
  -webkit-text-size-adjust: 100%;
}
body {
  overflow-x: hidden;
}
img {
  max-width: 100%;
}
input,
button {
  font: inherit;
}
.table-wrap {
  -webkit-overflow-scrolling: touch;
}
.transfer-table-wrap table {
  min-width: 860px;
}
@media (max-width: 1024px) {
  .container {
    width: min(100%, calc(100% - 24px));
  }
  .nav-row {
    min-height: auto;
  }
  .address-nav-row {
    gap: 14px;
  }
  .nav-links-light {
    width: 100%;
    justify-content: flex-start;
  }
  .address-hero-panel {
    grid-template-columns: 1fr;
    padding: 20px;
  }
  .qr-card {
    justify-items: start;
  }
  .qr-card-head {
    text-align: left;
  }
  .address-secondary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .transfer-stats-bar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .home-feature-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .quote-result {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 768px) {
  .container {
    width: min(100%, calc(100% - 20px));
  }
  .site-header {
    position: static;
    backdrop-filter: none;
  }
  .nav-row,
  .address-nav-row,
  .page-heading,
  .address-hero-heading,
  .overview-main-row,
  .overview-table-row,
  .overview-table-value-icons,
  .approval-row,
  .project-row,
  .stack-row,
  .asset-row,
  .token-row {
    align-items: flex-start;
    flex-direction: column;
  }
  .brand-rich {
    width: 100%;
  }
  .address-site-header {
    display: block;
    width: 100%;
    max-width: 100%;
    left: 0;
    right: 0;
    overflow-x: clip;
  }
  .address-site-header-fill {
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    padding-left: env(safe-area-inset-left, 0);
    padding-right: env(safe-area-inset-right, 0);
    overflow-x: clip;
    box-sizing: border-box;
  }
  .address-site-header .container.address-nav-row {
    width: 100% !important;
    max-width: none;
    margin: 0;
    padding-top: calc(12px + env(safe-area-inset-top, 0px));
    padding-right: max(10px, env(safe-area-inset-right, 0px));
    padding-bottom: 12px;
    padding-left: max(10px, env(safe-area-inset-left, 0px));
  }
  .address-nav-row {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 10px;
    box-sizing: border-box;
  }
  .address-nav-row > * {
    width: 100%;
    min-width: 0;
    max-width: 100%;
    margin-left: 0 !important;
  }
  .address-nav-row .brand-rich {
    justify-content: flex-start;
  }
  .nav-links,
  .nav-links-light {
    width: 100%;
    gap: 12px;
    flex-wrap: wrap;
  }
  .address-nav-row .nav-links a,
  .address-nav-row .nav-links-light a {
    margin-left: 0;
  }
  .address-nav-row .header-music-player,
  .address-nav-row .header-search {
    width: 100%;
    min-width: 0;
  }
  .header-search,
  .home-search-shell,
  .search-panel,
  .inline-search,
  .quote-row,
  .quote-result,
  .home-feature-row,
  .metrics-grid,
  .two-col,
  .address-primary-grid,
  .address-secondary-grid,
  .transfer-stats-bar,
  .overview-metrics-grid {
    grid-template-columns: 1fr;
  }
  .header-search,
  .address-search {
    min-width: 100%;
  }
  .home-hero {
    padding: 28px 0 42px;
    min-height: auto;
  }
  .home-center-wrap {
    gap: 18px;
  }
  .home-title {
    max-width: 100%;
    font-size: clamp(2.1rem, 10vw, 3.3rem);
  }
  .home-subtitle,
  .lead {
    font-size: 0.96rem;
  }
  .panel,
  .hero-card,
  .metric-card,
  .search-panel,
  .address-hero-panel,
  .overview-panel,
  .asset-panel,
  .compact-panel,
  .transfer-panel {
    padding: 18px;
    border-radius: 20px;
  }
  .address-shell {
    padding: 18px 0 40px;
  }
  .address-title {
    font-size: clamp(1.9rem, 9vw, 2.8rem);
  }
  .meta-chip {
    min-width: 0;
    width: 100%;
  }
  .address-action-row {
    width: 100%;
  }
  .address-action-row > * {
    width: 100%;
  }
  .ghost-action,
  .home-search-shell button,
  .header-search button,
  button {
    width: 100%;
  }
  .qr-card {
    justify-items: center;
  }
  .qr-card-head {
    text-align: center;
  }
  .qr-image {
    width: min(196px, 72vw);
    height: auto;
  }
  .overview-amount {
    font-size: clamp(1.8rem, 10vw, 2.5rem);
  }
  .overview-chip-wrap {
    width: 100%;
    justify-content: flex-start;
  }
  .overview-table-value,
  .align-right {
    text-align: left;
  }
  .asset-scroll-list,
  .compact-list {
    max-height: none;
    overflow: visible;
    padding-right: 0;
  }
  .asset-token-main,
  .approval-main,
  .transfer-token-cell {
    width: 100%;
  }
  .token-id-line {
    font-size: 0.82rem;
  }
  .transfer-head {
    align-items: flex-start;
  }
  th,
  td {
    padding: 10px 8px;
    font-size: 0.9rem;
  }
  .address-box {
    font-size: 0.92rem;
    padding: 14px;
  }
}
@media (max-width: 540px) {
  .brand-word {
    font-size: 1.18rem;
  }
  .brand-version {
    font-size: 0.72rem;
    padding: 3px 7px;
  }
  .wallet-hero-icon {
    width: 44px;
    height: 44px;
  }
  .eyebrow {
    font-size: 0.76rem;
    letter-spacing: 0.1em;
  }
  .token-title-rich {
    align-items: flex-start;
  }
  .token-type-pill {
    font-size: 0.72rem;
  }
  .transfer-table-wrap table {
    min-width: 720px;
  }
  .transfer-stat-card strong,
  .metric-card strong,
  .quote-result strong {
    font-size: 1.08rem;
  }
  .home-feature-card,
  .transfer-stat-card,
  .overview-metric {
    padding: 14px;
  }
}
@media (max-width: 768px) {
  .header-music-player {
    width: 100%;
    min-width: 0;
    margin-left: 0;
  }
  .transfer-filter-actions {
    grid-column: 1 / -1;
    flex-direction: column;
    align-items: stretch;
  }
  .transfer-pagination {
    justify-content: flex-start;
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 4px;
  }
  .page-link {
    flex: 0 0 auto;
  }
}
@media (max-width: 520px) {
  .transfer-filter-grid {
    grid-template-columns: 1fr;
  }
}
/* address page density tune */
.address-page {
  font-size: 15px;
}
.address-page .container {
  width: min(1110px, calc(100% - 28px));
}
.address-page .panel {
  border-radius: 20px;
  box-shadow: 0 14px 34px rgba(34, 46, 58, 0.08);
}
.address-page .panel-head {
  margin-bottom: 12px;
}
.address-page h2 {
  font-size: 1.04rem;
}
.address-site-header {
  backdrop-filter: none;
}
.address-nav-row {
  min-height: 62px;
  gap: 16px;
}
.brand-rich {
  gap: 8px;
}
.brand-icon {
  width: 30px;
  height: 30px;
}
.brand-word {
  font-size: 1.48rem;
}
.brand-version {
  padding: 3px 7px;
  font-size: 0.74rem;
}
.nav-links {
  gap: 16px;
}
.nav-links-light a {
  gap: 6px;
  font-size: 0.95rem;
}
.header-search {
  min-width: min(430px, 100%);
  gap: 8px;
  margin-left: 0;
}
.header-search input,
.header-search button {
  min-height: 40px;
}
.header-search input {
  padding: 0 14px;
  font-size: 0.94rem;
}
.header-search button {
  padding: 0 16px;
  border-radius: 14px;
  font-size: 0.94rem;
}
.header-music-player {
  flex: 0 0 256px;
  min-width: 256px;
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 0 12px 0 10px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.10);
  background: rgba(255, 255, 255, 0.08);
  color: #ffffff;
  margin-left: auto;
}
.header-music-player audio {
  display: none;
}
.header-music-player.is-loading {
  box-shadow: 0 0 0 1px rgba(145, 214, 209, 0.18), 0 8px 18px rgba(51, 116, 115, 0.18);
}
.header-music-player.is-playing {
  border-color: rgba(139, 220, 201, 0.36);
  background: linear-gradient(135deg, rgba(89, 172, 154, 0.24), rgba(80, 125, 191, 0.18));
}
.music-controls {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex: 0 0 auto;
}
.music-nav,
.music-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  box-shadow: none;
}
.music-nav {
  width: 28px;
  min-width: 28px;
  min-height: 28px;
  height: 28px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.92);
  font-size: 1.08rem;
  font-weight: 700;
}
.music-nav:hover {
  filter: none;
  color: #ffffff;
  box-shadow: 0 6px 14px rgba(77, 121, 176, 0.18);
}
.music-toggle {
  flex: 0 0 32px;
  width: 32px;
  min-width: 32px;
  min-height: 32px;
  height: 32px;
  border-radius: 12px;
  background: linear-gradient(135deg, #41a38a, #4179b8);
}
.music-toggle:hover {
  filter: none;
  box-shadow: 0 6px 16px rgba(65, 121, 184, 0.26);
}
.music-bars {
  display: inline-flex;
  align-items: flex-end;
  justify-content: center;
  gap: 3px;
  height: 12px;
}
.music-bars i {
  display: block;
  width: 3px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  transform-origin: center bottom;
}
.music-bars i:nth-child(1) {
  height: 7px;
}
.music-bars i:nth-child(2) {
  height: 12px;
}
.music-bars i:nth-child(3) {
  height: 9px;
}
.header-music-player.is-playing .music-bars i:nth-child(1) {
  animation: musicBar 0.95s ease-in-out infinite;
}
.header-music-player.is-playing .music-bars i:nth-child(2) {
  animation: musicBar 1.05s ease-in-out infinite 0.12s;
}
.header-music-player.is-playing .music-bars i:nth-child(3) {
  animation: musicBar 0.9s ease-in-out infinite 0.24s;
}
.music-meta {
  min-width: 0;
  flex: 1 1 auto;
  display: grid;
  gap: 1px;
}
.music-title {
  font-size: 0.82rem;
  font-weight: 800;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.music-status {
  color: rgba(255, 255, 255, 0.66);
  font-size: 0.7rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.header-music-player.is-playing .music-status {
  color: rgba(225, 255, 246, 0.88);
}
@keyframes musicBar {
  0%, 100% {
    transform: scaleY(0.58);
    opacity: 0.72;
  }
  50% {
    transform: scaleY(1.18);
    opacity: 1;
  }
}
.address-shell {
  padding: 16px 0 36px;
  gap: 14px;
}
.address-hero-panel {
  grid-template-columns: minmax(0, 1.32fr) 236px;
  gap: 18px;
  padding: 18px 20px;
}
.address-hero-main {
  gap: 14px;
}
.address-hero-heading {
  gap: 12px;
  align-items: flex-start;
}
.wallet-hero-icon {
  width: 42px;
  height: 42px;
}
.eyebrow {
  margin-bottom: 6px;
  font-size: 0.78rem;
  letter-spacing: 0.14em;
}
.address-title {
  font-size: clamp(1.9rem, 3.4vw, 2.85rem);
  line-height: 1.02;
  letter-spacing: -0.045em;
}
.address-meta-strip {
  gap: 10px;
}
.meta-chip {
  min-width: 156px;
  padding: 10px 12px;
  border-radius: 14px;
}
.meta-chip span {
  font-size: 0.76rem;
}
.meta-chip strong {
  font-size: 0.92rem;
}
.address-action-row {
  gap: 10px;
}
.ghost-action {
  min-height: 38px;
  padding: 0 14px;
  font-size: 0.9rem;
  font-weight: 600;
}
.qr-card {
  gap: 12px;
  padding: 14px;
  border-radius: 20px;
}
.qr-card-head strong {
  font-size: 1rem;
}
.qr-card-head span {
  font-size: 0.82rem;
}
.qr-image {
  width: 164px;
  height: 164px;
  padding: 8px;
  border-radius: 16px;
}
.address-primary-grid {
  gap: 14px;
  grid-template-columns: minmax(0, 1fr) minmax(330px, 0.96fr);
}
.address-secondary-grid {
  gap: 14px;
}
.overview-panel,
.asset-panel,
.compact-panel,
.transfer-panel {
  padding: 18px;
}
.overview-main-row {
  gap: 12px;
  padding-bottom: 14px;
}
.overview-label {
  font-size: 0.84rem;
}
.overview-amount {
  margin-top: 4px;
  font-size: clamp(1.75rem, 3vw, 2.35rem);
}
.overview-sub {
  margin-top: 4px;
  font-size: 0.92rem;
}
.overview-chip-wrap {
  gap: 8px;
}
.overview-chip {
  padding: 6px 10px;
  font-size: 0.88rem;
}
.overview-table {
  margin-top: 12px;
}
.overview-table-row {
  padding: 11px 0;
}
.overview-table-key,
.overview-table-value {
  font-size: 0.92rem;
}
.asset-scroll-list {
  gap: 6px;
  max-height: 302px;
}
.asset-row {
  gap: 10px;
  padding: 10px 0;
}
.asset-amount {
  font-size: 1rem;
}
.compact-list {
  max-height: 260px;
}
.address-secondary-grid .stack-row {
  padding: 10px 0;
}
.token-logo {
  width: 22px;
  height: 22px;
}
.token-logo-sm {
  width: 18px;
  height: 18px;
}
.token-logo-xs {
  width: 16px;
  height: 16px;
}
.token-title-rich {
  gap: 4px;
}
.token-title-rich a,
.approval-row strong,
.stack-row strong {
  font-size: 0.98rem;
}
.token-id-line,
.token-meta {
  font-size: 0.84rem;
  line-height: 1.35;
}
.token-type-pill {
  padding: 2px 7px;
  font-size: 0.72rem;
}
.panel-head-tight {
  margin-bottom: 10px;
}
.transfer-head {
  align-items: flex-start;
}
.transfer-head > div {
  display: grid;
  gap: 2px;
}
.transfer-head > span {
  color: var(--muted);
  font-size: 0.88rem;
}
.transfer-filter-form {
  margin: 6px 0 12px;
}
.transfer-filter-grid {
  grid-template-columns: 1.1fr 1.1fr 0.95fr 0.95fr 0.68fr 0.82fr auto;
  gap: 8px;
}
.transfer-filter-field {
  gap: 4px;
}
.transfer-filter-field span {
  font-size: 0.76rem;
}
.transfer-filter-field input,
.transfer-filter-field select {
  min-height: 38px;
  padding: 0 12px;
  border-radius: 10px;
  font-size: 0.9rem;
}
.transfer-filter-actions {
  gap: 8px;
}
.transfer-filter-actions .ghost-action,
.transfer-filter-actions button {
  min-height: 38px;
}
.filter-reset-link {
  min-width: 72px;
}
.transfer-stats-bar {
  gap: 8px;
  margin: 0 0 12px;
}
.transfer-stat-card {
  gap: 3px;
  padding: 10px 12px;
  border-radius: 14px;
}
.transfer-stat-card span {
  font-size: 0.78rem;
}
.transfer-stat-card strong {
  font-size: 1.02rem;
}
.transfer-stat-card small {
  font-size: 0.76rem;
}
.transfer-table-wrap {
  margin-top: 0;
}
.transfer-table-wrap table {
  min-width: 820px;
}
.transfer-table-wrap th,
.transfer-table-wrap td {
  padding: 10px 8px;
  font-size: 0.88rem;
}
.transfer-table-wrap th {
  font-size: 0.82rem;
}
.transfer-token-cell {
  min-width: 160px;
  gap: 8px;
}
.tag {
  padding: 3px 8px;
  font-size: 0.74rem;
}
.transfer-pagination {
  gap: 8px;
  margin-top: 12px;
}
.page-link {
  min-width: 34px;
  min-height: 34px;
  padding: 0 11px;
  font-size: 0.88rem;
}
@media (max-width: 1180px) {
  .header-music-player {
    min-width: min(240px, 100%);
  }
  .address-page .transfer-filter-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .address-page .transfer-filter-actions {
    grid-column: 1 / -1;
    justify-content: flex-end;
  }
}
@media (max-width: 920px) {
  .address-page .address-shell {
    padding: 14px 0 28px;
  }
  .address-page .address-hero-panel,
  .address-page .overview-panel,
  .address-page .asset-panel,
  .address-page .compact-panel,
  .address-page .transfer-panel {
    padding: 16px;
  }
  .address-page .address-title {
    font-size: clamp(1.7rem, 8vw, 2.45rem);
  }
  .address-page .transfer-filter-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 540px) {
  .address-page .container {
    width: min(100%, calc(100% - 16px));
  }
  .address-page .brand-word {
    font-size: 1.24rem;
  }
  .header-music-player {
    width: 100%;
    min-width: 0;
  }
  .address-page .brand-version {
    font-size: 0.68rem;
  }
  .address-page .meta-chip {
    min-width: 0;
    width: 100%;
  }
}
/* address panel distribution */
.address-page .address-primary-grid {
  grid-template-columns: minmax(0, 1.16fr) minmax(300px, 0.84fr) minmax(250px, 0.72fr);
  align-items: start;
}
.address-page .address-side-rail {
  display: grid;
  gap: 14px;
  align-content: start;
}
.address-page .address-side-rail .compact-panel {
  padding: 16px;
}
.address-page .address-side-rail .compact-list {
  max-height: 156px;
}
.address-page .address-side-rail .stack-row {
  padding: 9px 0;
}
.address-page .asset-panel {
  min-height: 100%;
}
.address-page .asset-panel .asset-scroll-list {
  max-height: 470px;
}
.address-page .overview-panel {
  min-height: 100%;
}
@media (max-width: 1180px) {
  .address-page .address-primary-grid {
    grid-template-columns: minmax(0, 1fr) minmax(280px, 0.92fr);
  }
  .address-page .address-side-rail {
    grid-column: 1 / -1;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .address-page .address-side-rail .compact-list {
    max-height: 190px;
  }
}
@media (max-width: 920px) {
  .address-page .address-primary-grid,
  .address-page .address-side-rail {
    grid-template-columns: 1fr;
  }
}
/* address equal columns and compact hero */
.address-page .container {
  width: min(1180px, calc(100% - 24px));
}
.address-page .address-hero-panel {
  grid-template-columns: minmax(0, 1fr) 214px;
  gap: 14px;
  padding: 16px 18px;
}
.address-page .address-hero-main {
  min-width: 0;
}
.address-page .address-title {
  max-width: none;
  font-size: clamp(1.58rem, 2.55vw, 2.38rem);
  line-height: 1.04;
  letter-spacing: -0.055em;
  white-space: nowrap;
  word-break: normal;
  overflow-wrap: normal;
}
.address-page .qr-card {
  gap: 10px;
  padding: 12px;
  border-radius: 18px;
}
.address-page .qr-card-head strong {
  font-size: 0.96rem;
}
.address-page .qr-card-head span {
  font-size: 0.8rem;
}
.address-page .qr-image {
  width: 142px;
  height: 142px;
  padding: 7px;
  border-radius: 14px;
}
.address-page .address-primary-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: stretch;
}
.address-page .overview-panel,
.address-page .asset-panel,
.address-page .address-side-rail {
  min-height: 100%;
}
.address-page .address-side-rail {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: repeat(2, minmax(0, 1fr));
  gap: 14px;
  align-content: stretch;
  height: 100%;
}
.address-page .address-side-rail .compact-panel {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}
.address-page .address-side-rail .panel-head {
  margin-bottom: 10px;
}
.address-page .address-side-rail .compact-list,
.address-page .address-side-rail .stack-list {
  flex: 1 1 auto;
  min-height: 0;
  max-height: none;
  overflow: auto;
}
.address-page .address-side-rail .empty-state {
  margin-top: 2px;
}
.address-page .asset-panel .asset-scroll-list {
  max-height: none;
  height: calc(100% - 32px);
}
@media (max-width: 1260px) {
  .address-page .container {
    width: min(100%, calc(100% - 20px));
  }
  .address-page .address-title {
    font-size: clamp(1.46rem, 2.3vw, 2.16rem);
  }
  .address-page .address-hero-panel {
    grid-template-columns: minmax(0, 1fr) 198px;
  }
  .address-page .qr-image {
    width: 132px;
    height: 132px;
  }
}
@media (max-width: 1180px) {
  .address-page .address-primary-grid {
    grid-template-columns: 1fr 1fr;
  }
  .address-page .address-side-rail {
    grid-column: 1 / -1;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: none;
    height: auto;
  }
  .address-page .address-title {
    white-space: normal;
  }
}
@media (max-width: 920px) {
  .address-page .address-primary-grid,
  .address-page .address-side-rail {
    grid-template-columns: 1fr;
  }
  .address-page .address-hero-panel {
    grid-template-columns: 1fr;
  }
  .address-page .address-title {
    white-space: normal;
  }
}
/* address panel height normalization */
.address-page {
  --address-main-column-height: 396px;
}
.address-page .address-primary-grid {
  align-items: start;
}
.address-page .overview-panel,
.address-page .asset-panel,
.address-page .address-side-rail {
  height: var(--address-main-column-height);
  min-height: var(--address-main-column-height);
  max-height: var(--address-main-column-height);
}
.address-page .overview-panel,
.address-page .asset-panel,
.address-page .address-side-rail .compact-panel {
  overflow: hidden;
}
.address-page .overview-panel,
.address-page .asset-panel {
  display: flex;
  flex-direction: column;
}
.address-page .overview-table {
  flex: 1 1 auto;
}
.address-page .asset-panel .asset-scroll-list {
  flex: 1 1 auto;
  height: auto;
  min-height: 0;
  max-height: none;
  overflow: auto;
  padding-right: 6px;
  scrollbar-gutter: stable;
}
.address-page .address-side-rail {
  grid-template-rows: repeat(2, minmax(0, 1fr));
}
.address-page .address-side-rail .compact-panel {
  min-height: 0;
}
.address-page .address-side-rail .compact-list,
.address-page .address-side-rail .stack-list {
  flex: 1 1 auto;
  min-height: 0;
  max-height: none;
  overflow: auto;
  padding-right: 6px;
  scrollbar-gutter: stable;
}
.address-page .address-side-rail .empty-state {
  overflow: hidden;
}
@media (max-width: 1180px) {
  .address-page .overview-panel,
  .address-page .asset-panel,
  .address-page .address-side-rail {
    height: auto;
    min-height: 0;
    max-height: none;
  }
  .address-page .address-side-rail {
    grid-template-rows: none;
  }
  .address-page .asset-panel .asset-scroll-list,
  .address-page .address-side-rail .compact-list,
  .address-page .address-side-rail .stack-list {
    max-height: 220px;
  }
}
@media (max-width: 920px) {
  .address-page {
    --address-main-column-height: auto;
  }
  .address-page .asset-panel .asset-scroll-list,
  .address-page .address-side-rail .compact-list,
  .address-page .address-side-rail .stack-list {
    max-height: 200px;
  }
}

/* address overview chip overflow fix */
.address-page .overview-main-row {
  flex-wrap: wrap;
}
.address-page .overview-main-row > :first-child {
  min-width: 0;
}
.address-page .overview-chip-wrap {
  width: 100%;
  flex: 0 0 100%;
  min-width: 0;
  max-width: 100%;
  margin-left: 0;
  justify-content: flex-start;
  align-content: flex-start;
}
.address-page .overview-chip {
  max-width: 100%;
  white-space: normal;
  word-break: break-word;
  text-align: center;
}

/* swap page */
.swap-page {
  background:
    radial-gradient(circle at 18% 18%, rgba(151, 223, 214, 0.32), transparent 22%),
    radial-gradient(circle at 82% 14%, rgba(255, 220, 182, 0.26), transparent 20%),
    radial-gradient(circle at 78% 76%, rgba(181, 210, 255, 0.26), transparent 24%),
    linear-gradient(180deg, #f4fff9 0%, #f9fffd 34%, #f8fbff 100%);
}
.swap-shell {
  width: min(640px, calc(100% - 24px));
  margin: 0 auto;
  padding: 24px 0 56px;
  display: grid;
  gap: 10px;
}
.swap-title-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin: 6px auto 16px;
  text-align: center;
}
.swap-title-icon {
  width: 34px;
  height: 34px;
  object-fit: contain;
}
.swap-title {
  font-size: clamp(2rem, 4.8vw, 3rem);
  letter-spacing: -0.04em;
}
.swap-alert {
  margin-bottom: 2px;
  transition: opacity 0.24s ease, transform 0.24s ease, max-height 0.24s ease, margin 0.24s ease, padding 0.24s ease;
  overflow: hidden;
  max-height: 96px;
}
.swap-alert.is-hidden {
  opacity: 0;
  transform: translateY(-6px);
  max-height: 0;
  margin: 0;
  padding-top: 0;
  padding-bottom: 0;
  border-width: 0;
}
.swap-quote-card,
.swap-address-card,
.swap-guide-card {
  border-radius: 16px;
  background: #ffffff;
  border-color: rgba(214, 220, 231, 0.95);
  box-shadow: 0 14px 36px rgba(42, 56, 87, 0.08);
}
.swap-quote-card {
  transition: box-shadow 0.22s ease, border-color 0.22s ease, transform 0.22s ease;
}
.swap-quote-card.is-loading {
  border-color: rgba(104, 153, 233, 0.28);
  box-shadow: 0 18px 40px rgba(81, 134, 222, 0.12);
}
.swap-quote-form {
  display: grid;
  gap: 18px;
}
.swap-field-block {
  display: grid;
  gap: 10px;
}
.swap-field-label {
  text-align: center;
  font-weight: 600;
  color: #2b2b2d;
}
.swap-field-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 74px;
  border: 1px solid rgba(209, 215, 227, 1);
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
}
.swap-amount-input {
  width: 100%;
  min-height: 50px;
  border: 0;
  background: #fff;
  padding: 0 16px;
  font-size: 1.16rem;
  color: #1f2b2c;
  outline: none;
}
.swap-amount-input::-webkit-outer-spin-button,
.swap-amount-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.swap-amount-input[type=number] {
  -moz-appearance: textfield;
}
.swap-amount-output {
  background: #fafcff;
  font-weight: 700;
  transition: background-color 0.22s ease, box-shadow 0.22s ease, color 0.22s ease;
}
.swap-amount-output.is-loading {
  color: #7f8aa3;
  background: linear-gradient(90deg, rgba(245, 248, 255, 0.96), rgba(236, 244, 255, 0.96), rgba(245, 248, 255, 0.96));
}
.swap-amount-output.is-updated {
  background: #f3fbf7;
  box-shadow: inset 0 0 0 1px rgba(46, 173, 101, 0.18);
}
.swap-field-addon {
  display: flex;
  align-items: center;
  justify-content: center;
  border-left: 1px solid rgba(209, 215, 227, 1);
  background: #fbfcfe;
  color: #202733;
  font-weight: 700;
}
.swap-address-card {
  display: grid;
  gap: 12px;
  text-align: center;
}
.swap-deposit-box {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  max-width: 100%;
  min-height: 34px;
  padding: 6px 18px;
  border: 1px solid rgba(214, 220, 231, 1);
  border-radius: 8px;
  background: #fff;
  font-family: Consolas, Monaco, monospace;
  font-size: 0.98rem;
  font-weight: 700;
  color: #2b2b2d;
  word-break: break-all;
}
.swap-deposit-note {
  margin: 0;
  color: #4d5562;
}
.swap-copy-button {
  width: 100%;
  min-height: 44px;
  border: 0;
  border-radius: 10px;
  background: linear-gradient(135deg, #567cf0, #4370ea);
  color: #fff;
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
}
.swap-guide-card {
  padding: 0;
  overflow: hidden;
}
.swap-guide-head {
  margin: 0;
  padding: 18px 22px;
  justify-content: center;
  border-bottom: 1px solid rgba(222, 226, 235, 0.9);
}
.swap-guide-body {
  display: grid;
  gap: 18px;
  padding: 18px 26px 26px;
}
.swap-guide-list {
  display: grid;
  gap: 6px;
  color: #202733;
}
.swap-guide-list p {
  margin: 0;
}
.swap-contact-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  min-height: 42px;
  border: 1px solid rgba(214, 220, 231, 1);
  border-radius: 10px;
  background: #fff;
  color: #202733;
  font-weight: 700;
}
.swap-contact-button:hover {
  color: #2b6fdc;
  border-color: rgba(67, 112, 234, 0.25);
}
.swap-contact-button img {
  width: 20px;
  height: 20px;
}
@media (max-width: 920px) {
  .swap-shell {
    width: min(100%, calc(100% - 16px));
    padding: 18px 0 40px;
  }
  .swap-title-row {
    gap: 10px;
    margin-bottom: 12px;
  }
  .swap-title-icon {
    width: 28px;
    height: 28px;
  }
  .swap-quote-card,
  .swap-address-card,
  .swap-guide-card {
    border-radius: 14px;
  }
  .swap-guide-body {
    padding: 16px 18px 18px;
  }
}

/* address animated ad banner */
.address-page {
  --address-ad-height: max(66px, calc(var(--address-main-column-height) / 6));
  --promo-banner-height: calc(var(--address-ad-height) * 2);
}
.ad-banner-panel {
  position: relative;
  display: block;
  width: 100%;
  min-height: var(--address-ad-height);
  height: var(--address-ad-height);
  padding: 0;
  overflow: hidden;
  border-radius: 18px;
  background:
    radial-gradient(circle at 14% 30%, rgba(138, 222, 199, 0.34), transparent 28%),
    radial-gradient(circle at 86% 40%, rgba(170, 214, 255, 0.28), transparent 24%),
    linear-gradient(135deg, #f4fffb 0%, #eefaf7 48%, #f5fbff 100%);
  border: 1px solid rgba(178, 223, 212, 0.95);
  box-shadow: 0 16px 34px rgba(74, 130, 120, 0.10);
}
.ad-banner-panel:hover {
  border-color: rgba(102, 181, 161, 0.95);
  box-shadow: 0 18px 42px rgba(66, 124, 118, 0.16);
}
.ad-banner-inner {
  position: relative;
  z-index: 2;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 0 20px;
}
.ad-banner-copy {
  display: flex;
  align-items: center;
  gap: 18px;
  min-width: 0;
}
.ad-banner-kicker {
  flex: 0 0 auto;
  color: #57a38c;
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.ad-banner-art {
  display: flex;
  align-items: center;
  gap: 8px;
}
.ad-banner-char {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.66);
  border: 1px solid rgba(176, 224, 213, 0.96);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.95), 0 10px 18px rgba(124, 185, 172, 0.16);
  backdrop-filter: blur(8px);
  animation: adFloat 3.8s ease-in-out infinite;
}
.ad-banner-char:nth-child(2) {
  animation-delay: 0.2s;
}
.ad-banner-char:nth-child(3) {
  animation-delay: 0.4s;
}
.ad-banner-char:nth-child(4) {
  animation-delay: 0.6s;
}
.ad-banner-char:nth-child(5) {
  animation-delay: 0.8s;
}
.ad-banner-char i {
  font-style: normal;
  font-size: 1.26rem;
  font-weight: 900;
  line-height: 1;
  color: #1b5f57;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.9);
  animation: adGlow 3.8s ease-in-out infinite;
}
.ad-banner-side {
  display: grid;
  justify-items: end;
  gap: 6px;
  flex: 0 0 auto;
}
.ad-banner-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(76, 171, 146, 0.14);
  color: #287466;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.04em;
}
.ad-banner-hint {
  color: #5d7c77;
  font-size: 0.82rem;
  white-space: nowrap;
}
.ad-banner-bg {
  position: absolute;
  border-radius: 999px;
  filter: blur(0.4px);
  opacity: 0.64;
}
.ad-banner-bg-left {
  left: -24px;
  top: 10px;
  width: 126px;
  height: 126px;
  background: radial-gradient(circle at 50% 50%, rgba(110, 216, 183, 0.26), rgba(110, 216, 183, 0.06) 68%, transparent 70%);
  animation: adOrbLeft 11s linear infinite;
}
.ad-banner-bg-right {
  right: -18px;
  bottom: -34px;
  width: 158px;
  height: 158px;
  background: radial-gradient(circle at 50% 50%, rgba(121, 182, 255, 0.20), rgba(121, 182, 255, 0.04) 70%, transparent 72%);
  animation: adOrbRight 13s linear infinite;
}
.ad-banner-shine {
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, transparent 18%, rgba(255, 255, 255, 0.08) 32%, rgba(255, 255, 255, 0.52) 48%, rgba(255, 255, 255, 0.08) 64%, transparent 78%);
  transform: translateX(-135%);
  animation: adSweep 4.8s ease-in-out infinite;
}
@keyframes adFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-5px); }
}
@keyframes adGlow {
  0%, 100% { opacity: 0.94; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.05); }
}
@keyframes adSweep {
  0% { transform: translateX(-135%); }
  55% { transform: translateX(135%); }
  100% { transform: translateX(135%); }
}
@keyframes adOrbLeft {
  0% { transform: translate3d(0, 0, 0); }
  50% { transform: translate3d(12px, 6px, 0); }
  100% { transform: translate3d(0, 0, 0); }
}
@keyframes adOrbRight {
  0% { transform: translate3d(0, 0, 0); }
  50% { transform: translate3d(-14px, -8px, 0); }
  100% { transform: translate3d(0, 0, 0); }
}
@media (max-width: 1180px) {
  .ad-banner-panel {
    min-height: 72px;
    height: 72px;
  }
}
@media (max-width: 920px) {
  .ad-banner-panel {
    min-height: 84px;
    height: auto;
  }
  .ad-banner-inner {
    min-height: 84px;
    padding: 10px 14px;
    gap: 12px;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
  }
  .ad-banner-copy {
    gap: 12px;
    width: 100%;
    justify-content: space-between;
  }
  .ad-banner-side {
    justify-items: start;
    gap: 4px;
  }
  .ad-banner-hint {
    white-space: normal;
  }
}
@media (max-width: 640px) {
  .ad-banner-kicker {
    display: none;
  }
  .ad-banner-char {
    width: 40px;
    height: 40px;
    border-radius: 14px;
  }
  .ad-banner-char i {
    font-size: 1.08rem;
  }
}


.promo-banner-panel {
  position: relative;
  display: block;
  width: 100%;
  min-height: var(--promo-banner-height);
  height: var(--promo-banner-height);
  max-height: var(--promo-banner-height);
  padding: 0;
  overflow: hidden;
  border-radius: 24px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.98) 0%, rgba(241, 247, 255, 0.98) 36%, rgba(234, 243, 255, 0.98) 100%);
  border: 1px solid rgba(181, 204, 240, 0.95);
  box-shadow: 0 20px 44px rgba(63, 102, 164, 0.14);
}
.promo-banner-panel:hover {
  border-color: rgba(111, 152, 229, 0.92);
  box-shadow: 0 24px 52px rgba(55, 102, 178, 0.20);
}
.promo-banner-grid {
  position: relative;
  z-index: 2;
  height: 100%;
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  padding: 12px 20px 12px 20px;
}
.promo-banner-main {
  min-width: 0;
  display: grid;
  gap: 6px;
}
.promo-banner-topline {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 8px;
}
.promo-banner-topline-text,
.promo-banner-brand,
.promo-rotator-line,
.promo-banner-reserve,
.promo-banner-tag {
  position: relative;
  z-index: 2;
}
.promo-banner-topline-text,
.promo-banner-brand,
.promo-rotator-line {
  color: #ffffff;
  -webkit-text-stroke: 1px rgba(103, 149, 236, 0.64);
  text-shadow:
    0 1px 0 rgba(255, 255, 255, 0.92),
    0 3px 0 rgba(115, 152, 214, 0.76),
    0 7px 18px rgba(60, 108, 185, 0.18);
}
.promo-banner-topline-text {
  font-size: clamp(1.52rem, 3vw, 2.28rem);
  font-weight: 1000;
  letter-spacing: 0.03em;
}
.promo-banner-brand {
  font-size: clamp(2.22rem, 4.3vw, 3.48rem);
  font-weight: 1000;
  letter-spacing: 0.015em;
  animation: promoPulse 2.8s ease-in-out infinite;
}
.promo-banner-reserve {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  max-width: 100%;
  padding: 7px 14px;
  border-radius: 999px;
  background: linear-gradient(135deg, #5f9cff, #4d76e6);
  color: #f9fdff;
  font-size: 0.84rem;
  font-weight: 800;
  box-shadow: 0 10px 20px rgba(79, 118, 230, 0.18);
}
.promo-banner-rotator {
  position: relative;
  min-height: 30px;
  display: grid;
  align-items: center;
}
.promo-rotator-line {
  grid-area: 1 / 1;
  font-size: clamp(1.08rem, 2.2vw, 1.54rem);
  font-weight: 1000;
  letter-spacing: 0.03em;
  opacity: 0;
  transform: translateY(10px);
}
.promo-rotator-line-one {
  animation: promoLineOne 6.4s ease-in-out infinite;
}
.promo-rotator-line-two {
  animation: promoLineTwo 6.4s ease-in-out infinite;
}
.promo-banner-tags {
  display: grid;
  gap: 8px;
  justify-items: end;
}
.promo-banner-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 112px;
  padding: 8px 14px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(74, 122, 229, 0.95), rgba(78, 142, 255, 0.88));
  color: #ffffff;
  font-size: 0.92rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.28), 0 10px 18px rgba(72, 111, 187, 0.16);
  transform: translate3d(0, 0, 0);
  transform-origin: center center;
  will-change: transform;
  backface-visibility: hidden;
  animation: promoTagFloat 4.8s cubic-bezier(0.22, 0.61, 0.36, 1) infinite;
}
.promo-banner-tag:nth-child(2) {
  animation-delay: 0.18s;
}
.promo-banner-tag:nth-child(3) {
  animation-delay: 0.36s;
}
.promo-banner-tag:nth-child(4) {
  animation-delay: 0.54s;
}
.promo-banner-glow {
  position: absolute;
  border-radius: 999px;
  filter: blur(0.2px);
  opacity: 0.82;
}
.promo-banner-glow-left {
  left: -48px;
  top: -36px;
  width: 240px;
  height: 240px;
  background: radial-gradient(circle at 50% 50%, rgba(132, 179, 255, 0.28), rgba(132, 179, 255, 0.08) 64%, transparent 68%);
  animation: promoGlowLeft 10s ease-in-out infinite;
}
.promo-banner-glow-right {
  right: -54px;
  bottom: -56px;
  width: 300px;
  height: 300px;
  background: radial-gradient(circle at 50% 50%, rgba(91, 140, 235, 0.22), rgba(91, 140, 235, 0.06) 66%, transparent 70%);
  animation: promoGlowRight 12s ease-in-out infinite;
}
.promo-banner-shine {
  position: absolute;
  inset: 0;
  background: linear-gradient(104deg, transparent 18%, rgba(255, 255, 255, 0.08) 32%, rgba(255, 255, 255, 0.78) 48%, rgba(255, 255, 255, 0.10) 64%, transparent 78%);
  transform: translateX(-135%);
  animation: promoSweep 4.9s ease-in-out infinite;
}
@keyframes promoSweep {
  0% { transform: translateX(-135%); }
  55% { transform: translateX(135%); }
  100% { transform: translateX(135%); }
}
@keyframes promoPulse {
  0%, 100% {
    transform: translateY(0);
    filter: saturate(1);
  }
  50% {
    transform: translateY(-2px);
    filter: saturate(1.12);
  }
}
@keyframes promoLineOne {
  0%, 8% {
    opacity: 0;
    transform: translateY(10px);
  }
  14%, 42% {
    opacity: 1;
    transform: translateY(0);
  }
  50%, 100% {
    opacity: 0;
    transform: translateY(-10px);
  }
}
@keyframes promoLineTwo {
  0%, 46% {
    opacity: 0;
    transform: translateY(10px);
  }
  54%, 84% {
    opacity: 1;
    transform: translateY(0);
  }
  92%, 100% {
    opacity: 0;
    transform: translateY(-10px);
  }
}
@keyframes promoTagFloat {
  0%, 100% { transform: translate3d(0, 0, 0); }
  18% { transform: translate3d(0, -0.5px, 0); }
  42% { transform: translate3d(0, -2px, 0); }
  64% { transform: translate3d(0, -2.8px, 0); }
  82% { transform: translate3d(0, -1px, 0); }
}
@keyframes promoGlowLeft {
  0%, 100% { transform: translate3d(0, 0, 0); }
  50% { transform: translate3d(12px, 10px, 0); }
}
@keyframes promoGlowRight {
  0%, 100% { transform: translate3d(0, 0, 0); }
  50% { transform: translate3d(-14px, -12px, 0); }
}
@media (max-width: 1180px) {
  .promo-banner-panel {
    min-height: 144px;
    height: auto;
    max-height: none;
  }
  .promo-banner-grid {
    grid-template-columns: 1fr;
    justify-items: start;
  }
  .promo-banner-tags {
    grid-template-columns: repeat(4, minmax(0, auto));
    grid-auto-flow: column;
    justify-items: start;
  }
}
@media (max-width: 920px) {
  .promo-banner-panel {
    min-height: 156px;
    height: auto;
    max-height: none;
  }
  .promo-banner-grid {
    min-height: 0;
    padding: 16px 16px 18px;
    gap: 14px;
  }
  .promo-banner-topline {
    gap: 8px;
  }
  .promo-banner-reserve {
    width: 100%;
    font-size: 0.84rem;
    text-align: center;
  }
  .promo-banner-tags {
    width: 100%;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-auto-flow: row;
    gap: 8px;
  }
  .promo-banner-tag {
    min-width: 0;
    width: 100%;
    font-size: 0.92rem;
    letter-spacing: 0.12em;
  }
  .promo-rotator-line {
    font-size: clamp(1.06rem, 4vw, 1.42rem);
  }
}


.address-page .overview-main-row {
  padding-bottom: 10px;
  border-bottom: 0;
}
.address-page .overview-table {
  margin-top: 8px;
}
.address-page .overview-table-row:first-child {
  border-top: 0;
  padding-top: 0;
}


.address-page .overview-main-row {
  padding-bottom: 8px;
  border-bottom: 0 !important;
}
.address-page .overview-table {
  margin-top: 6px;
}
.address-page .overview-table-row:first-child {
  border-top: 0 !important;
  padding-top: 0;
}
.address-page .permission-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}
.address-page .permission-summary .key-pill {
  background: rgba(13, 119, 95, 0.08);
  color: var(--accent);
}
.address-page .promo-banner-panel {
  min-height: var(--promo-banner-height);
  height: var(--promo-banner-height);
  max-height: var(--promo-banner-height);
}
.address-page .promo-banner-grid {
  grid-template-columns: minmax(0, 1fr) 132px;
  gap: 18px;
  padding: 12px 18px;
}
.address-page .promo-banner-main {
  grid-template-columns: minmax(210px, 0.92fr) minmax(180px, 1.08fr);
  gap: 8px 16px;
  align-content: center;
}
.address-page .promo-banner-topline {
  grid-column: 1 / -1;
}
.address-page .promo-banner-reserve {
  grid-column: 1 / 2;
  width: 100%;
}
.address-page .promo-banner-rotator {
  grid-column: 2 / 3;
  min-height: 34px;
  align-self: center;
}
.address-page .promo-banner-topline-text,
.address-page .promo-banner-brand,
.address-page .promo-rotator-line {
  color: #eef4ff;
  -webkit-text-stroke: 1px rgba(96, 139, 225, 0.82);
  text-shadow:
    0 1px 0 rgba(255, 255, 255, 0.96),
    0 2px 0 rgba(124, 158, 228, 0.86),
    0 8px 18px rgba(69, 104, 184, 0.20);
}
.address-page .promo-banner-topline-text {
  font-size: clamp(1.4rem, 2.8vw, 2.02rem);
}
.address-page .promo-banner-brand {
  font-size: clamp(2.02rem, 4vw, 3.02rem);
}
.address-page .promo-banner-reserve {
  padding: 6px 12px;
  font-size: 0.8rem;
}
.address-page .promo-rotator-line {
  font-size: clamp(1rem, 2vw, 1.38rem);
}
.address-page .promo-banner-tags {
  align-content: center;
  gap: 7px;
}
.address-page .promo-banner-tag {
  min-width: 104px;
  padding: 8px 12px;
  font-size: 0.88rem;
  letter-spacing: 0.12em;
}
@media (max-width: 1180px) {
  .address-page .promo-banner-panel {
    min-height: 144px;
    height: auto;
    max-height: none;
  }
  .address-page .promo-banner-grid {
    grid-template-columns: 1fr;
  }
  .address-page .promo-banner-main {
    grid-template-columns: 1fr 1fr;
  }
  .address-page .promo-banner-tags {
    width: 100%;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    justify-items: stretch;
  }
  .address-page .promo-banner-tag {
    width: 100%;
    min-width: 0;
  }
}
@media (max-width: 920px) {
  .address-page .promo-banner-panel {
    min-height: 156px;
    height: auto;
    max-height: none;
  }
  .address-page .promo-banner-main {
    grid-template-columns: 1fr;
  }
  .address-page .promo-banner-reserve,
  .address-page .promo-banner-rotator {
    grid-column: auto;
  }
}


.address-page .permission-summary {
  margin-top: 8px;
}
.address-page .permission-keys-list {
  width: 100%;
  display: grid;
  gap: 6px;
  margin-top: 8px;
}
.address-page .permission-key {
  display: block;
  width: 100%;
  padding: 8px 10px;
  border-radius: 14px;
  background: rgba(13, 119, 95, 0.08);
  color: var(--accent);
  font-size: 0.82rem;
  font-weight: 700;
  font-family: Consolas, Monaco, monospace;
  line-height: 1.45;
  word-break: break-all;
  overflow-wrap: anywhere;
}
.address-page .promo-banner-panel {
  min-height: var(--promo-banner-height);
  height: var(--promo-banner-height);
  max-height: var(--promo-banner-height);
}
.address-page .promo-banner-grid {
  grid-template-columns: minmax(0, 1fr) 118px;
  gap: 14px;
  height: 100%;
  padding: 10px 16px;
}
.address-page .promo-banner-main {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  min-height: 0;
}
.address-page .promo-banner-topline {
  grid-column: auto;
  gap: 8px;
}
.address-page .promo-banner-topline-text {
  font-size: clamp(1.28rem, 2.4vw, 1.86rem);
}
.address-page .promo-banner-brand {
  font-size: clamp(1.88rem, 3.5vw, 2.72rem);
}
.address-page .promo-banner-reserve {
  width: fit-content;
  max-width: 100%;
  padding: 6px 12px;
  font-size: 0.78rem;
}
.address-page .promo-banner-rotator {
  min-height: 22px;
}
.address-page .promo-rotator-line {
  font-size: clamp(0.92rem, 1.8vw, 1.22rem);
  line-height: 1.15;
}
.address-page .promo-banner-tags {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: stretch;
  gap: 6px;
}
.address-page .promo-banner-tag {
  min-width: 0;
  width: 100%;
  padding: 7px 10px;
  font-size: 0.84rem;
  letter-spacing: 0.1em;
}
@media (max-width: 1180px) {
  .address-page .promo-banner-panel {
    min-height: 140px;
    height: auto;
    max-height: none;
  }
  .address-page .promo-banner-grid {
    grid-template-columns: 1fr;
  }
  .address-page .promo-banner-main {
    display: flex;
  }
  .address-page .promo-banner-tags {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
@media (max-width: 920px) {
  .address-page .promo-banner-panel {
    min-height: 152px;
    height: auto;
    max-height: none;
  }
  .address-page .promo-banner-grid {
    padding: 14px 14px 16px;
  }
  .address-page .promo-banner-tags {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}


.address-page .overview-panel {
  padding-bottom: 12px;
}
.address-page .overview-table {
  margin-top: 4px;
  overflow: auto;
  padding-right: 4px;
}
.address-page .overview-table-row {
  padding: 8px 0;
}
.address-page .overview-table-row:first-child {
  padding-top: 0;
}
.address-page .permission-summary {
  margin-top: 8px;
  margin-bottom: 2px;
}
.address-page .permission-keys-list {
  margin-top: 6px;
  max-height: 84px;
  overflow: auto;
  padding-right: 4px;
}
.address-page .promo-banner-panel {
  min-height: var(--promo-banner-height);
  height: var(--promo-banner-height);
  max-height: var(--promo-banner-height);
}
.address-page .promo-banner-grid {
  grid-template-columns: minmax(0, 1fr) 108px;
  gap: 12px;
  height: 100%;
  padding: 9px 14px;
}
.address-page .promo-banner-main {
  display: grid;
  align-content: center;
  gap: 4px;
  min-height: 0;
}
.address-page .promo-banner-topline {
  gap: 6px;
  line-height: 1;
}
.address-page .promo-banner-topline-text {
  font-size: clamp(1.08rem, 2.1vw, 1.46rem);
  line-height: 1;
}
.address-page .promo-banner-brand {
  font-size: clamp(1.62rem, 3.1vw, 2.28rem);
  line-height: 1;
}
.address-page .promo-banner-reserve {
  width: fit-content;
  max-width: 100%;
  padding: 5px 10px;
  font-size: 0.72rem;
  box-shadow: 0 8px 16px rgba(79, 118, 230, 0.16);
}
.address-page .promo-banner-rotator {
  display: grid;
  gap: 2px;
  min-height: 0;
}
.address-page .promo-rotator-line {
  grid-area: auto;
  opacity: 1 !important;
  transform: none !important;
  animation: none !important;
  font-size: clamp(0.86rem, 1.55vw, 1.04rem);
  line-height: 1.08;
  letter-spacing: 0.02em;
}
.address-page .promo-banner-tags {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
}
.address-page .promo-banner-tag {
  min-width: 0;
  width: 100%;
  padding: 6px 8px;
  font-size: 0.8rem;
  letter-spacing: 0.08em;
}
@media (max-width: 1180px) {
  .address-page .promo-banner-panel {
    min-height: 138px;
    height: auto;
    max-height: none;
  }
  .address-page .promo-banner-grid {
    grid-template-columns: 1fr;
  }
  .address-page .promo-banner-tags {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
@media (max-width: 920px) {
  .address-page .promo-banner-panel {
    min-height: 148px;
    height: auto;
    max-height: none;
  }
  .address-page .promo-banner-grid {
    padding: 12px 12px 14px;
  }
  .address-page .promo-banner-tags {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}


.address-page .overview-panel {
  padding: 14px 16px 10px;
}
.address-page .overview-panel .panel-head {
  margin-bottom: 8px;
}
.address-page .overview-main-row {
  gap: 8px;
  padding-bottom: 4px !important;
}
.address-page .overview-amount {
  margin-top: 2px;
  font-size: clamp(1.52rem, 2.5vw, 2.1rem);
}
.address-page .overview-sub {
  margin-top: 2px;
  font-size: 0.88rem;
}
.address-page .overview-chip-wrap {
  gap: 6px;
}
.address-page .overview-chip {
  padding: 5px 8px;
  font-size: 0.82rem;
}
.address-page .overview-table {
  margin-top: 2px;
  overflow: visible;
  padding-right: 0;
}
.address-page .overview-table-row {
  padding: 6px 0;
}
.address-page .overview-table-key,
.address-page .overview-table-value {
  font-size: 0.9rem;
}
.address-page .promo-banner-panel {
  min-height: var(--promo-banner-height);
  height: var(--promo-banner-height);
  max-height: var(--promo-banner-height);
}
.address-page .promo-banner-grid {
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr) 176px;
  gap: 14px;
  height: 100%;
  padding: 10px 16px;
  align-items: center;
}
.address-page .promo-banner-brand-block,
.address-page .promo-banner-copy-block {
  min-width: 0;
  display: grid;
  align-content: center;
  gap: 6px;
}
.address-page .promo-banner-topline {
  gap: 6px;
  line-height: 1;
}
.address-page .promo-banner-topline-text {
  font-size: clamp(1.06rem, 2vw, 1.4rem);
  line-height: 1;
}
.address-page .promo-banner-brand {
  font-size: clamp(1.72rem, 3vw, 2.34rem);
  line-height: 1;
}
.address-page .promo-banner-reserve {
  width: fit-content;
  max-width: 100%;
  padding: 5px 10px;
  font-size: 0.72rem;
  box-shadow: 0 8px 16px rgba(79, 118, 230, 0.14);
}
.address-page .promo-banner-copy-block {
  gap: 8px;
}
.address-page .promo-copy-line {
  color: #eef4ff;
  -webkit-text-stroke: 1px rgba(96, 139, 225, 0.82);
  text-shadow:
    0 1px 0 rgba(255, 255, 255, 0.96),
    0 2px 0 rgba(124, 158, 228, 0.86),
    0 8px 18px rgba(69, 104, 184, 0.20);
  font-size: clamp(0.92rem, 1.65vw, 1.18rem);
  font-weight: 1000;
  line-height: 1.12;
  letter-spacing: 0.02em;
}
.address-page .promo-copy-line-strong {
  font-size: clamp(1.04rem, 1.9vw, 1.34rem);
}
.address-page .promo-banner-tags {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  align-content: center;
}
.address-page .promo-banner-tag {
  min-width: 0;
  width: 100%;
  padding: 8px 8px;
  font-size: 0.78rem;
  letter-spacing: 0.06em;
}
@media (max-width: 1180px) {
  .address-page .promo-banner-panel {
    min-height: 142px;
    height: auto;
    max-height: none;
  }
  .address-page .promo-banner-grid {
    grid-template-columns: 1fr;
  }
  .address-page .promo-banner-tags {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
@media (max-width: 920px) {
  .address-page .promo-banner-panel {
    min-height: 152px;
    height: auto;
    max-height: none;
  }
  .address-page .promo-banner-grid {
    padding: 12px 12px 14px;
  }
  .address-page .promo-banner-tags {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}


.address-page .promo-banner-grid {
  grid-template-columns: minmax(210px, 0.74fr) minmax(300px, 1.26fr) 142px;
  gap: 10px;
  padding: 10px 14px 10px 12px;
}
.address-page .promo-banner-brand-block {
  justify-self: start;
}
.address-page .promo-banner-copy-block {
  justify-self: start;
  width: 100%;
  max-width: 420px;
  margin-left: -14px;
}
.address-page .promo-banner-tags {
  justify-self: start;
  width: 142px;
  margin-left: -12px;
  gap: 6px;
}
.address-page .promo-banner-tag {
  padding: 8px 6px;
}
@media (max-width: 1180px) {
  .address-page .promo-banner-copy-block {
    margin-left: 0;
    max-width: none;
  }
  .address-page .promo-banner-tags {
    width: 100%;
    margin-left: 0;
  }
}


.address-page .promo-banner-copy-block {
  max-width: 452px;
  margin-left: -20px;
  gap: 10px;
}
.address-page .promo-copy-line {
  font-size: clamp(1.02rem, 1.9vw, 1.34rem);
  line-height: 1.14;
}
.address-page .promo-copy-line-strong {
  font-size: clamp(1.22rem, 2.25vw, 1.62rem);
}
@media (max-width: 1180px) {
  .address-page .promo-banner-copy-block {
    max-width: none;
    margin-left: 0;
  }
}


.address-page .promo-banner-grid {
  grid-template-columns: minmax(220px, 0.84fr) minmax(0, 1.16fr) 142px;
}
.address-page .promo-banner-copy-block {
  justify-self: stretch;
  align-content: center;
  justify-items: center;
  width: 100%;
  max-width: none;
  margin-left: 0;
  padding: 0 8px;
  gap: 10px;
  text-align: center;
}
.address-page .promo-copy-line {
  width: 100%;
  text-align: center;
}
@media (max-width: 1180px) {
  .address-page .promo-banner-copy-block {
    padding: 0;
  }
}


.address-page .promo-banner-grid {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 14px;
}
.address-page .promo-banner-brand-block {
  flex: 0 1 320px;
  max-width: 320px;
}
.address-page .promo-banner-copy-block {
  flex: 0 1 368px;
  justify-self: auto;
  align-content: center;
  justify-items: center;
  width: auto;
  max-width: 368px;
  margin: 0;
  padding: 0;
  gap: 8px;
  text-align: center;
}
.address-page .promo-banner-tags {
  flex: 0 0 124px;
  width: 124px;
  margin-left: 0;
  gap: 6px;
}
.address-page .promo-copy-line {
  width: 100%;
  text-align: center;
}
@media (max-width: 1180px) {
  .address-page .promo-banner-grid {
    display: grid;
    grid-template-columns: 1fr;
    justify-content: initial;
  }
  .address-page .promo-banner-brand-block,
  .address-page .promo-banner-copy-block,
  .address-page .promo-banner-tags {
    flex: initial;
    max-width: none;
    width: 100%;
  }
}


.address-page .promo-banner-grid {
  gap: 8px;
  padding: 10px 16px 10px 18px;
}
.address-page .promo-banner-brand-block {
  flex: 0 1 332px;
  max-width: 332px;
  padding-left: 10px;
  transform: translateY(-4px);
}
.address-page .promo-banner-topline {
  gap: 8px;
}
.address-page .promo-banner-topline-text {
  font-size: clamp(1.14rem, 2.15vw, 1.52rem);
}
.address-page .promo-banner-brand {
  font-size: clamp(1.9rem, 3.25vw, 2.62rem);
}
.address-page .promo-banner-reserve {
  margin-top: 2px;
  padding: 6px 12px;
  font-size: 0.78rem;
}
.address-page .promo-banner-copy-block {
  flex: 0 1 392px;
  max-width: 392px;
  gap: 10px;
}
.address-page .promo-copy-line {
  font-size: clamp(1.14rem, 2.05vw, 1.5rem);
  line-height: 1.14;
}
.address-page .promo-copy-line-strong {
  font-size: clamp(1.34rem, 2.45vw, 1.82rem);
}


.address-page .promo-banner-grid {
  justify-content: flex-start;
  gap: 10px;
}
.address-page .promo-banner-brand-block,
.address-page .promo-banner-copy-block {
  min-height: 90px;
}
.address-page .promo-banner-copy-block {
  flex: 0 1 438px;
  max-width: 438px;
  margin-left: -10px;
  justify-content: center;
  gap: 12px;
}
.address-page .promo-copy-line {
  font-size: clamp(1.22rem, 2.22vw, 1.62rem);
  line-height: 1.12;
}
.address-page .promo-copy-line-strong {
  font-size: clamp(1.46rem, 2.72vw, 2rem);
}
.address-page .promo-banner-tags {
  margin-left: auto;
}
@media (max-width: 1180px) {
  .address-page .promo-banner-grid {
    justify-content: initial;
  }
  .address-page .promo-banner-brand-block,
  .address-page .promo-banner-copy-block {
    min-height: 0;
  }
  .address-page .promo-banner-copy-block {
    margin-left: 0;
  }
  .address-page .promo-banner-tags {
    margin-left: 0;
  }
}


.address-page .promo-banner-icons {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto;
  margin-left: 2px;
}
.address-page .promo-banner-icon-wrap {
  width: 58px;
  height: 58px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.16);
  box-shadow: 0 10px 22px rgba(93, 116, 170, 0.14);
  perspective: 720px;
}
.address-page .promo-banner-icon-flip {
  position: relative;
  width: 58px;
  height: 58px;
  transform-style: preserve-3d;
  will-change: transform;
  animation: promo-badge-3d-flip 4.8s cubic-bezier(0.45, 0.05, 0.55, 0.95) infinite;
}
.address-page .promo-banner-icon-wrap:nth-child(2) .promo-banner-icon-flip {
  animation-delay: 0.42s;
}
.address-page .promo-banner-icon-wrap:nth-child(3) .promo-banner-icon-flip {
  animation-delay: 0.84s;
}
.address-page .promo-banner-icon-face {
  position: absolute;
  inset: 0;
  width: 58px;
  height: 58px;
  display: block;
  object-fit: contain;
  filter: drop-shadow(0 6px 12px rgba(77, 96, 150, 0.14));
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}
.address-page .promo-banner-icon-face-back {
  transform: rotateY(180deg);
}
@keyframes promo-badge-3d-flip {
  0%,
  14% {
    transform: rotateY(0deg);
  }
  36%,
  64% {
    transform: rotateY(180deg);
  }
  86%,
  100% {
    transform: rotateY(360deg);
  }
}
@media (prefers-reduced-motion: reduce) {
  .address-page .promo-banner-icon-flip {
    animation: none;
  }
}
@media (max-width: 1180px) {
  .address-page .promo-banner-icons {
    justify-content: center;
    margin-left: 0;
  }
}

@supports (padding: max(0px)) {
  @media (max-width: 768px) {
    .address-site-header-fill {
      padding-left: max(0px, env(safe-area-inset-left, 0px));
      padding-right: max(0px, env(safe-area-inset-right, 0px));
    }
    .address-site-header .container.address-nav-row {
      padding-left: max(12px, env(safe-area-inset-left, 0px));
      padding-right: max(12px, env(safe-area-inset-right, 0px));
    }
  }
}
/* headerrefresh-final-20260322 */
.address-page .site-header,
.swap-page .site-header {
  background: rgba(244, 255, 249, 0.78);
  border-bottom: 1px solid rgba(195, 225, 216, 0.74);
  backdrop-filter: blur(14px);
}
.address-page .address-site-header,
.swap-page .address-site-header {
  background: rgba(244, 255, 249, 0.78);
  border-bottom: 1px solid rgba(195, 225, 216, 0.74);
}
.address-page .address-nav-row,
.swap-page .address-nav-row {
  min-height: 72px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 12px 16px;
  padding: 12px 0;
}
.address-page .address-site-header .brand,
.address-page .address-site-header .nav-links,
.address-page .address-site-header .nav-links a,
.swap-page .address-site-header .brand,
.swap-page .address-site-header .nav-links,
.swap-page .address-site-header .nav-links a {
  color: #1e2a30;
}
.address-page .address-nav-row > .brand-rich,
.swap-page .address-nav-row > .brand-rich {
  flex: 0 0 auto;
}
.address-page .address-nav-row > .nav-links,
.swap-page .address-nav-row > .nav-links {
  flex: 0 1 auto;
  margin-left: auto;
}
.address-page .address-nav-row > .header-music-player,
.address-page .address-nav-row > .header-search,
.swap-page .address-nav-row > .header-search {
  margin-left: 0;
}
.address-page .nav-links-light,
.swap-page .nav-links-light {
  align-items: center;
  gap: 12px 16px;
}
.address-page .nav-links-light a,
.swap-page .nav-links-light a {
  color: #5f7077;
}
.address-page .nav-links-light a:hover,
.swap-page .nav-links-light a:hover {
  color: #0f6e78;
}
.address-page .header-search,
.swap-page .header-search {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  flex: 1 1 340px;
  min-width: min(360px, 100%);
  max-width: 430px;
  gap: 8px;
}
.address-page .header-search input,
.swap-page .header-search input {
  min-height: 42px;
  border: 1px solid rgba(195, 225, 216, 0.92);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.96);
  color: #1f2b30;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.88);
}
.address-page .header-search input::placeholder,
.swap-page .header-search input::placeholder {
  color: #8ba0a8;
}
.address-page .header-search button,
.swap-page .header-search button {
  min-height: 42px;
  border-radius: 14px;
  padding: 0 16px;
  background: linear-gradient(135deg, #65c3b2, #4d8fdc);
  color: #ffffff;
  box-shadow: 0 10px 24px rgba(77, 143, 220, 0.18);
}
.address-page .header-music-player {
  flex: 1 1 260px;
  max-width: 320px;
  min-width: 240px;
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 0 12px 0 10px;
  border-radius: 16px;
  border: 1px solid rgba(195, 225, 216, 0.92);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(241, 250, 247, 0.98));
  color: #213038;
  box-shadow: 0 10px 24px rgba(94, 148, 160, 0.12);
}
.address-page .header-music-player.is-loading {
  box-shadow: 0 0 0 1px rgba(117, 196, 186, 0.20), 0 12px 26px rgba(94, 148, 160, 0.16);
}
.address-page .header-music-player.is-playing {
  border-color: rgba(110, 202, 185, 0.48);
  background: linear-gradient(135deg, rgba(243, 255, 251, 0.98), rgba(236, 246, 255, 0.98));
}
.address-page .music-title {
  color: #1f2b30;
}
.address-page .music-status {
  color: #70838b;
}
.address-page .music-meta {
  min-width: 0;
}
.address-page .music-title,
.address-page .music-status {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.address-page .music-nav,
.address-page .music-toggle {
  background: rgba(101, 195, 178, 0.12);
  color: #2d5f6d;
}
.address-page .music-nav:hover,
.address-page .music-toggle:hover {
  background: rgba(101, 195, 178, 0.2);
}
.address-page .music-bars i {
  background: linear-gradient(180deg, #65c3b2, #4d8fdc);
}
@media (max-width: 920px) {
  .address-page .address-nav-row,
  .swap-page .address-nav-row {
    gap: 10px 12px;
  }
  .address-page .address-nav-row > .nav-links,
  .swap-page .address-nav-row > .nav-links {
    margin-left: 0;
  }
  .address-page .header-music-player,
  .address-page .header-search,
  .swap-page .header-search {
    max-width: none;
  }
}
@media (max-width: 768px) {
  .address-page .site-header,
  .swap-page .site-header {
    position: static;
    backdrop-filter: none;
  }
  .address-page .address-site-header,
  .swap-page .address-site-header {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
  }
  .address-page .address-nav-row,
  .swap-page .address-nav-row {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    width: 100%;
    min-height: 0;
    padding: 12px 0 14px;
    gap: 10px;
  }
  .address-page .address-nav-row > *,
  .swap-page .address-nav-row > * {
    width: 100%;
    min-width: 0;
    max-width: 100%;
    margin-left: 0 !important;
  }
  .address-page .address-nav-row .brand-rich,
  .swap-page .address-nav-row .brand-rich {
    justify-content: flex-start;
  }
  .address-page .nav-links,
  .address-page .nav-links-light,
  .swap-page .nav-links,
  .swap-page .nav-links-light {
    width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 10px 12px;
  }
  .address-page .header-music-player,
  .address-page .header-search,
  .swap-page .header-search {
    flex: 0 1 auto;
    min-width: 0;
    max-width: none;
    width: 100%;
  }
  .address-page .header-search,
  .swap-page .header-search {
    grid-template-columns: minmax(0, 1fr) auto;
  }
}
@media (max-width: 540px) {
  .address-page .header-search,
  .swap-page .header-search {
    grid-template-columns: minmax(0, 1fr) 92px;
  }
  .address-page .header-search button,
  .swap-page .header-search button {
    padding: 0 12px;
  }
}
/* premium rotating ad slot: 9g / no / rebate */
.address-page .ad-banner-panel-premium {
  isolation: isolate;
  border-color: rgba(215, 170, 91, 0.38);
  background:
    radial-gradient(circle at 16% 18%, rgba(255, 214, 132, 0.22), transparent 26%),
    radial-gradient(circle at 84% 74%, rgba(255, 202, 88, 0.18), transparent 24%),
    linear-gradient(135deg, #060606 0%, #12100d 46%, #1b140a 100%);
  box-shadow: 0 18px 36px rgba(22, 15, 7, 0.28);
}
.address-page .ad-banner-panel-premium:hover {
  border-color: rgba(242, 201, 116, 0.58);
  box-shadow: 0 22px 42px rgba(22, 15, 7, 0.34);
}
.address-page .ad-banner-panel-premium .premium-ad-noise,
.address-page .ad-banner-panel-premium .premium-ad-aura,
.address-page .ad-banner-panel-premium .premium-ad-curve,
.address-page .ad-banner-panel-premium .premium-ad-sheen {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.address-page .ad-banner-panel-premium .premium-ad-noise {
  opacity: 0.3;
  background-image:
    radial-gradient(circle at 18% 32%, rgba(255, 255, 255, 0.16) 0 1px, transparent 1.8px),
    radial-gradient(circle at 72% 58%, rgba(255, 209, 120, 0.16) 0 1px, transparent 2px),
    radial-gradient(circle at 48% 20%, rgba(255, 225, 166, 0.14) 0 1px, transparent 1.8px);
  background-size: 130px 100%, 180px 100%, 220px 100%;
  mix-blend-mode: screen;
}
.address-page .ad-banner-panel-premium .premium-ad-aura {
  border-radius: 999px;
  filter: blur(0.4px);
  opacity: 0.84;
}
.address-page .ad-banner-panel-premium .premium-ad-aura-left {
  inset: auto auto -54px -30px;
  width: 168px;
  height: 168px;
  background: radial-gradient(circle at 50% 50%, rgba(247, 199, 102, 0.34), rgba(247, 199, 102, 0.06) 62%, transparent 70%);
  animation: premiumAdAuraLeft 10.5s ease-in-out infinite;
}
.address-page .ad-banner-panel-premium .premium-ad-aura-right {
  inset: -58px -26px auto auto;
  width: 176px;
  height: 176px;
  background: radial-gradient(circle at 50% 50%, rgba(255, 214, 110, 0.26), rgba(255, 214, 110, 0.05) 60%, transparent 70%);
  animation: premiumAdAuraRight 12s ease-in-out infinite;
}
.address-page .ad-banner-panel-premium .premium-ad-curve {
  background-repeat: no-repeat;
  opacity: 0.62;
}
.address-page .ad-banner-panel-premium .premium-ad-curve-top {
  background-image: linear-gradient(90deg, transparent 0%, rgba(238, 188, 94, 0.82) 18%, rgba(238, 188, 94, 0.18) 54%, transparent 88%);
  background-size: 52% 1px;
  background-position: right 12px top 16px;
}
.address-page .ad-banner-panel-premium .premium-ad-curve-bottom {
  background-image:
    linear-gradient(90deg, transparent 0%, rgba(238, 188, 94, 0.72) 12%, rgba(238, 188, 94, 0.16) 54%, transparent 96%),
    linear-gradient(90deg, transparent 0%, rgba(238, 188, 94, 0.56) 10%, rgba(238, 188, 94, 0.10) 54%, transparent 96%);
  background-size: 44% 1px, 56% 1px;
  background-position: left 28px bottom 12px, left 12px bottom 18px;
}
.address-page .ad-banner-panel-premium .premium-ad-inner {
  position: relative;
  z-index: 2;
  height: 100%;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 0 16px 0 12px;
}
.address-page .ad-banner-panel-premium .premium-ad-brand {
  position: relative;
  flex: 0 0 72px;
  width: 72px;
  height: 46px;
  display: grid;
  justify-items: center;
  align-content: center;
}
.address-page .ad-banner-panel-premium .premium-ad-brand-mark {
  position: relative;
  z-index: 2;
  font-size: 2.2rem;
  font-weight: 1000;
  line-height: 1;
  letter-spacing: -0.08em;
  color: rgba(255, 255, 255, 0.08);
  text-shadow: 0 10px 22px rgba(0, 0, 0, 0.34);
}
.address-page .ad-banner-panel-premium .premium-ad-brand-base {
  position: absolute;
  left: 10px;
  right: 10px;
  bottom: 4px;
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(255, 220, 140, 0.02), rgba(255, 220, 140, 0.24), rgba(255, 220, 140, 0.02));
  filter: blur(0.2px);
}
.address-page .ad-banner-panel-premium .premium-ad-carousel {
  position: relative;
  flex: 1 1 auto;
  min-width: 0;
  height: 42px;
  overflow: hidden;
}
.address-page .ad-banner-panel-premium .premium-ad-slide {
  position: absolute;
  inset: 0;
  display: grid;
  align-content: center;
  gap: 3px;
  opacity: 0;
  transform: translate3d(0, 14px, 0) scale(0.985);
  animation: premiumAdSlide 12s cubic-bezier(0.35, 0.08, 0.28, 1) infinite;
}
.address-page .ad-banner-panel-premium .premium-ad-slide-2 {
  animation-delay: 4s;
}
.address-page .ad-banner-panel-premium .premium-ad-slide-3 {
  animation-delay: 8s;
}
.address-page .ad-banner-panel-premium .premium-ad-title {
  display: flex;
  align-items: baseline;
  gap: 8px;
  min-width: 0;
  color: #fff9ea;
  font-size: clamp(1rem, 1.9vw, 1.42rem);
  font-weight: 900;
  line-height: 1.02;
  white-space: nowrap;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.36);
}
.address-page .ad-banner-panel-premium .premium-ad-title-gold {
  background: linear-gradient(180deg, #fff2b8 0%, #f7d37c 45%, #d89c38 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.address-page .ad-banner-panel-premium .premium-ad-sub {
  min-width: 0;
  color: rgba(250, 236, 198, 0.94);
  font-size: clamp(0.66rem, 1.05vw, 0.84rem);
  line-height: 1.15;
  letter-spacing: 0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.address-page .ad-banner-panel-premium .premium-ad-medals {
  position: relative;
  flex: 0 0 108px;
  width: 108px;
  height: 52px;
}
.address-page .ad-banner-panel-premium .premium-ad-medal {
  position: absolute;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  min-height: 42px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(255, 223, 151, 0.4);
  background: radial-gradient(circle at 30% 28%, rgba(255, 250, 228, 0.98), rgba(244, 205, 118, 0.96) 44%, rgba(182, 116, 31, 0.98) 100%);
  color: #231203;
  font-size: 0.86rem;
  font-weight: 1000;
  line-height: 1;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.28);
  animation: premiumAdMedalFloat 4.8s ease-in-out infinite;
}
.address-page .ad-banner-panel-premium .premium-ad-medal-logo {
  left: 0;
  bottom: 0;
  min-width: 44px;
}
.address-page .ad-banner-panel-premium .premium-ad-medal-usdt {
  left: 34px;
  top: 0;
  width: 42px;
  height: 42px;
  padding: 0;
  animation-delay: 0.35s;
}
.address-page .ad-banner-panel-premium .premium-ad-medal-usdt img {
  width: 32px;
  height: 32px;
  object-fit: contain;
  filter: drop-shadow(0 4px 10px rgba(0, 0, 0, 0.18));
}
.address-page .ad-banner-panel-premium .premium-ad-medal-rate {
  right: 0;
  bottom: 4px;
  min-width: 54px;
  animation-delay: 0.7s;
}
.address-page .ad-banner-panel-premium .premium-ad-sheen {
  background: linear-gradient(105deg, transparent 12%, rgba(255, 214, 129, 0.08) 28%, rgba(255, 244, 214, 0.42) 46%, rgba(255, 214, 129, 0.08) 62%, transparent 80%);
  transform: translateX(-140%);
  animation: premiumAdSweep 5.4s ease-in-out infinite;
}
@keyframes premiumAdSlide {
  0%, 8% {
    opacity: 0;
    transform: translate3d(0, 14px, 0) scale(0.985);
  }
  12%, 28% {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }
  33%, 100% {
    opacity: 0;
    transform: translate3d(0, -14px, 0) scale(1.015);
  }
}
@keyframes premiumAdMedalFloat {
  0%,
  100% {
    transform: translate3d(0, 0, 0) rotate(0deg);
  }
  50% {
    transform: translate3d(0, -4px, 0) rotate(-4deg);
  }
}
@keyframes premiumAdSweep {
  0% {
    transform: translateX(-140%);
  }
  58% {
    transform: translateX(140%);
  }
  100% {
    transform: translateX(140%);
  }
}
@keyframes premiumAdAuraLeft {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
  }
  50% {
    transform: translate3d(10px, -4px, 0);
  }
}
@keyframes premiumAdAuraRight {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
  }
  50% {
    transform: translate3d(-10px, 6px, 0);
  }
}
@media (max-width: 920px) {
  .address-page .ad-banner-panel-premium {
    min-height: 104px;
    height: auto;
  }
  .address-page .ad-banner-panel-premium .premium-ad-inner {
    min-height: 104px;
    padding: 12px 14px;
    align-items: flex-start;
    flex-direction: column;
    justify-content: center;
    gap: 10px;
  }
  .address-page .ad-banner-panel-premium .premium-ad-brand {
    display: none;
  }
  .address-page .ad-banner-panel-premium .premium-ad-carousel {
    width: 100%;
    height: 58px;
  }
  .address-page .ad-banner-panel-premium .premium-ad-title,
  .address-page .ad-banner-panel-premium .premium-ad-sub {
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
  }
  .address-page .ad-banner-panel-premium .premium-ad-medals {
    width: 100%;
    height: 42px;
  }
  .address-page .ad-banner-panel-premium .premium-ad-medal-logo {
    left: 0;
  }
  .address-page .ad-banner-panel-premium .premium-ad-medal-usdt {
    left: 44px;
  }
  .address-page .ad-banner-panel-premium .premium-ad-medal-rate {
    left: 92px;
    right: auto;
    bottom: 0;
  }
}
@media (max-width: 620px) {
  .address-page .ad-banner-panel-premium .premium-ad-carousel {
    height: 64px;
  }
  .address-page .ad-banner-panel-premium .premium-ad-title {
    gap: 6px;
    font-size: 1rem;
  }
  .address-page .ad-banner-panel-premium .premium-ad-sub {
    font-size: 0.72rem;
  }
}
@media (prefers-reduced-motion: reduce) {
  .address-page .ad-banner-panel-premium .premium-ad-aura-left,
  .address-page .ad-banner-panel-premium .premium-ad-aura-right,
  .address-page .ad-banner-panel-premium .premium-ad-medal,
  .address-page .ad-banner-panel-premium .premium-ad-sheen,
  .address-page .ad-banner-panel-premium .premium-ad-slide {
    animation: none;
  }
  .address-page .ad-banner-panel-premium .premium-ad-slide {
    opacity: 0;
    transform: none;
  }
  .address-page .ad-banner-panel-premium .premium-ad-slide-1 {
    opacity: 1;
  }
}

/* premium ad layout v2: left copy, center icons, right card fan */
.address-page .ad-banner-panel-premium .premium-ad-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 136px 162px;
  align-items: center;
  gap: 12px;
  padding: 0 16px 0 18px;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-wrap {
  position: relative;
  min-width: 0;
  height: 100%;
  display: grid;
  align-items: center;
}
.address-page .ad-banner-panel-premium .premium-ad-watermark {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  font-size: 2.25rem;
  font-weight: 1000;
  line-height: 1;
  letter-spacing: -0.08em;
  color: rgba(255, 245, 215, 0.08);
  text-shadow: 0 10px 22px rgba(0, 0, 0, 0.34);
  pointer-events: none;
}
.address-page .ad-banner-panel-premium .premium-ad-carousel {
  position: relative;
  z-index: 1;
  min-width: 0;
  height: 46px;
  padding-left: 72px;
  overflow: hidden;
}
.address-page .ad-banner-panel-premium .premium-ad-slide {
  gap: 4px;
}
.address-page .ad-banner-panel-premium .premium-ad-title {
  gap: 10px;
  font-size: clamp(1rem, 1.8vw, 1.48rem);
}
.address-page .ad-banner-panel-premium .premium-ad-sub {
  font-size: clamp(0.68rem, 1vw, 0.86rem);
}
.address-page .ad-banner-panel-premium .premium-ad-icon-stage {
  position: relative;
  width: 136px;
  height: 62px;
}
.address-page .ad-banner-panel-premium .premium-ad-icon {
  position: absolute;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid rgba(255, 219, 138, 0.48);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.28);
  will-change: transform;
}
.address-page .ad-banner-panel-premium .premium-ad-icon-gold,
.address-page .ad-banner-panel-premium .premium-ad-icon-black {
  width: 44px;
  height: 44px;
  font-size: 0.92rem;
  font-weight: 1000;
  line-height: 1;
}
.address-page .ad-banner-panel-premium .premium-ad-icon-gold {
  left: 0;
  top: 12px;
  background: radial-gradient(circle at 32% 28%, rgba(255, 252, 234, 0.98), rgba(242, 204, 110, 0.96) 46%, rgba(170, 109, 26, 0.98) 100%);
  color: #241303;
  animation: premiumAdIconSpin 8.6s linear infinite;
}
.address-page .ad-banner-panel-premium .premium-ad-icon-usdt {
  left: 42px;
  top: 2px;
  width: 50px;
  height: 50px;
  padding: 0;
  background: radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.95), rgba(244, 248, 245, 0.82) 42%, rgba(143, 196, 163, 0.55) 100%);
  animation: premiumAdIconFlip 5.2s ease-in-out infinite;
}
.address-page .ad-banner-panel-premium .premium-ad-icon-usdt img {
  width: 38px;
  height: 38px;
  object-fit: contain;
  filter: drop-shadow(0 4px 10px rgba(0, 0, 0, 0.2));
}
.address-page .ad-banner-panel-premium .premium-ad-icon-black {
  right: 0;
  top: 14px;
  background: radial-gradient(circle at 34% 26%, rgba(86, 70, 34, 0.98), rgba(33, 28, 20, 0.98) 56%, rgba(10, 10, 10, 1) 100%);
  color: #f0ca78;
  animation: premiumAdIconTilt 4.8s ease-in-out infinite;
}
.address-page .ad-banner-panel-premium .premium-ad-card-fan {
  position: relative;
  width: 162px;
  height: 72px;
  justify-self: end;
}
.address-page .ad-banner-panel-premium .premium-ad-card {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 44px;
  height: 62px;
  border-radius: 10px;
  display: grid;
  align-content: space-between;
  padding: 7px 6px 6px;
  background:
    linear-gradient(155deg, rgba(255, 230, 168, 0.16) 0%, rgba(255, 230, 168, 0.03) 18%, rgba(0, 0, 0, 0) 19%),
    linear-gradient(135deg, #0b0a09 0%, #17130e 56%, #2a2012 100%);
  border: 1px solid rgba(228, 181, 92, 0.42);
  box-shadow:
    inset 0 1px 0 rgba(255, 235, 187, 0.18),
    0 12px 22px rgba(0, 0, 0, 0.28);
  transform-origin: bottom center;
}
.address-page .ad-banner-panel-premium .premium-ad-card::before {
  content: '';
  position: absolute;
  inset: 4px;
  border-radius: 8px;
  border: 1px solid rgba(233, 191, 101, 0.22);
  pointer-events: none;
}
.address-page .ad-banner-panel-premium .premium-ad-card::after {
  content: '';
  position: absolute;
  left: 7px;
  right: 7px;
  top: 17px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(233, 191, 101, 0.38), transparent);
}
.address-page .ad-banner-panel-premium .premium-ad-card strong,
.address-page .ad-banner-panel-premium .premium-ad-card i {
  position: relative;
  z-index: 1;
  font-style: normal;
  line-height: 1;
}
.address-page .ad-banner-panel-premium .premium-ad-card strong {
  color: #f3d48c;
  font-size: 0.92rem;
  font-weight: 1000;
}
.address-page .ad-banner-panel-premium .premium-ad-card i {
  justify-self: end;
  color: rgba(243, 212, 140, 0.74);
  font-size: 0.72rem;
  font-weight: 900;
}
.address-page .ad-banner-panel-premium .premium-ad-card-10 { right: 112px; transform: rotate(-24deg) translateY(8px); }
.address-page .ad-banner-panel-premium .premium-ad-card-j { right: 84px; transform: rotate(-13deg) translateY(4px); }
.address-page .ad-banner-panel-premium .premium-ad-card-q { right: 56px; transform: rotate(-2deg); }
.address-page .ad-banner-panel-premium .premium-ad-card-k { right: 28px; transform: rotate(9deg) translateY(4px); }
.address-page .ad-banner-panel-premium .premium-ad-card-a { right: 0; transform: rotate(20deg) translateY(8px); }
.address-page .ad-banner-panel-premium .premium-ad-card-fan:hover .premium-ad-card-10 { transform: rotate(-28deg) translateY(6px); }
.address-page .ad-banner-panel-premium .premium-ad-card-fan:hover .premium-ad-card-j { transform: rotate(-16deg) translateY(2px); }
.address-page .ad-banner-panel-premium .premium-ad-card-fan:hover .premium-ad-card-q { transform: rotate(-3deg) translateY(-2px); }
.address-page .ad-banner-panel-premium .premium-ad-card-fan:hover .premium-ad-card-k { transform: rotate(11deg) translateY(2px); }
.address-page .ad-banner-panel-premium .premium-ad-card-fan:hover .premium-ad-card-a { transform: rotate(24deg) translateY(6px); }
@keyframes premiumAdIconSpin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}
@keyframes premiumAdIconFlip {
  0%, 100% { transform: rotateY(0deg) translateY(0); }
  50% { transform: rotateY(180deg) translateY(-2px); }
}
@keyframes premiumAdIconTilt {
  0%, 100% { transform: rotate(0deg) translateY(0); }
  50% { transform: rotate(-8deg) translateY(-4px); }
}
@media (max-width: 920px) {
  .address-page .ad-banner-panel-premium .premium-ad-inner {
    grid-template-columns: 1fr;
    padding: 12px 14px;
    gap: 10px;
  }
  .address-page .ad-banner-panel-premium .premium-ad-copy-wrap,
  .address-page .ad-banner-panel-premium .premium-ad-icon-stage,
  .address-page .ad-banner-panel-premium .premium-ad-card-fan {
    width: 100%;
    justify-self: start;
  }
  .address-page .ad-banner-panel-premium .premium-ad-carousel {
    height: 58px;
    padding-left: 64px;
  }
  .address-page .ad-banner-panel-premium .premium-ad-icon-stage {
    height: 52px;
  }
  .address-page .ad-banner-panel-premium .premium-ad-card-fan {
    width: 156px;
    margin-top: 2px;
  }
}
@media (max-width: 620px) {
  .address-page .ad-banner-panel-premium .premium-ad-carousel {
    height: 64px;
    padding-left: 0;
  }
  .address-page .ad-banner-panel-premium .premium-ad-watermark {
    display: none;
  }
  .address-page .ad-banner-panel-premium .premium-ad-title,
  .address-page .ad-banner-panel-premium .premium-ad-sub {
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
  }
}
@media (prefers-reduced-motion: reduce) {
  .address-page .ad-banner-panel-premium .premium-ad-icon-gold,
  .address-page .ad-banner-panel-premium .premium-ad-icon-usdt,
  .address-page .ad-banner-panel-premium .premium-ad-icon-black {
    animation: none;
  }
}

/* premium ad layout v3: three copy lanes + right fan cards */
.address-page .ad-banner-panel-premium {
  border-color: rgba(202, 154, 68, 0.42);
  background:
    radial-gradient(circle at 20% 18%, rgba(255, 212, 120, 0.18), transparent 24%),
    radial-gradient(circle at 84% 70%, rgba(255, 191, 84, 0.14), transparent 22%),
    linear-gradient(135deg, #050505 0%, #120f0a 48%, #21190d 100%);
}
.address-page .ad-banner-panel-premium .premium-ad-inner-triple {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr) 176px;
  align-items: stretch;
  gap: 0;
  height: 100%;
  padding: 0 12px 0 10px;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-lane {
  position: relative;
  min-width: 0;
  display: grid;
  align-content: center;
  gap: 4px;
  padding: 0 18px;
  overflow: hidden;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-lane::before {
  content: '';
  position: absolute;
  inset: 12px 8px;
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255, 223, 159, 0.05), rgba(255, 223, 159, 0.01));
  opacity: 0.72;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-lane::after {
  content: '';
  position: absolute;
  right: 0;
  top: 50%;
  width: 1px;
  height: 52px;
  transform: translateY(-50%);
  background: linear-gradient(180deg, transparent, rgba(236, 186, 94, 0.54), transparent);
}
.address-page .ad-banner-panel-premium .premium-ad-copy-lane-3::after {
  display: none;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-kicker,
.address-page .ad-banner-panel-premium .premium-ad-copy-title,
.address-page .ad-banner-panel-premium .premium-ad-copy-sub {
  position: relative;
  z-index: 1;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-kicker {
  color: #f5cb77;
  font-size: 0.94rem;
  font-weight: 1000;
  line-height: 1;
  letter-spacing: 0.01em;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.36);
}
.address-page .ad-banner-panel-premium .premium-ad-copy-title {
  color: #fff6dd;
  font-size: 0.98rem;
  font-weight: 900;
  line-height: 1.08;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.36);
}
.address-page .ad-banner-panel-premium .premium-ad-copy-sub {
  color: rgba(246, 227, 181, 0.92);
  font-size: 0.72rem;
  line-height: 1.15;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-lane-1 {
  animation: premiumAdCopyPulse 5.2s ease-in-out infinite;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-lane-2 {
  animation: premiumAdCopyPulse 5.2s ease-in-out infinite 0.45s;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-lane-3 {
  animation: premiumAdCopyPulse 5.2s ease-in-out infinite 0.9s;
}
.address-page .ad-banner-panel-premium .premium-ad-card-fan {
  position: relative;
  width: 176px;
  height: 74px;
  align-self: center;
  justify-self: end;
  margin-right: 2px;
}
.address-page .ad-banner-panel-premium .premium-ad-card {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 46px;
  height: 64px;
  border-radius: 10px;
  display: grid;
  align-content: space-between;
  padding: 7px 6px 6px;
  background:
    linear-gradient(152deg, rgba(255, 232, 172, 0.18) 0%, rgba(255, 232, 172, 0.02) 18%, rgba(0, 0, 0, 0) 19%),
    linear-gradient(135deg, #0a0907 0%, #17120d 56%, #261d11 100%);
  border: 1px solid rgba(228, 181, 92, 0.46);
  box-shadow: inset 0 1px 0 rgba(255, 235, 187, 0.18), 0 12px 22px rgba(0, 0, 0, 0.28);
  transform-origin: bottom center;
  transition: transform 180ms ease;
}
.address-page .ad-banner-panel-premium .premium-ad-card::before {
  content: '';
  position: absolute;
  inset: 4px;
  border-radius: 8px;
  border: 1px solid rgba(233, 191, 101, 0.22);
}
.address-page .ad-banner-panel-premium .premium-ad-card strong,
.address-page .ad-banner-panel-premium .premium-ad-card i {
  position: relative;
  z-index: 1;
  font-style: normal;
  line-height: 1;
}
.address-page .ad-banner-panel-premium .premium-ad-card strong {
  color: #f3d48c;
  font-size: 0.92rem;
  font-weight: 1000;
}
.address-page .ad-banner-panel-premium .premium-ad-card i {
  justify-self: end;
  color: rgba(243, 212, 140, 0.7);
  font-size: 0.62rem;
  font-weight: 900;
}
.address-page .ad-banner-panel-premium .premium-ad-card-10 { right: 120px; transform: rotate(-25deg) translateY(8px); }
.address-page .ad-banner-panel-premium .premium-ad-card-j { right: 92px; transform: rotate(-14deg) translateY(4px); }
.address-page .ad-banner-panel-premium .premium-ad-card-q { right: 62px; transform: rotate(-3deg); }
.address-page .ad-banner-panel-premium .premium-ad-card-k { right: 32px; transform: rotate(9deg) translateY(4px); }
.address-page .ad-banner-panel-premium .premium-ad-card-a { right: 2px; transform: rotate(20deg) translateY(8px); }
.address-page .ad-banner-panel-premium:hover .premium-ad-card-10 { transform: rotate(-29deg) translateY(6px); }
.address-page .ad-banner-panel-premium:hover .premium-ad-card-j { transform: rotate(-17deg) translateY(2px); }
.address-page .ad-banner-panel-premium:hover .premium-ad-card-q { transform: rotate(-4deg) translateY(-2px); }
.address-page .ad-banner-panel-premium:hover .premium-ad-card-k { transform: rotate(11deg) translateY(2px); }
.address-page .ad-banner-panel-premium:hover .premium-ad-card-a { transform: rotate(24deg) translateY(6px); }
@keyframes premiumAdCopyPulse {
  0%, 100% {
    transform: translateY(0);
    filter: brightness(0.98);
  }
  50% {
    transform: translateY(-2px);
    filter: brightness(1.08);
  }
}
@media (max-width: 1100px) {
  .address-page .ad-banner-panel-premium .premium-ad-inner-triple {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    padding: 8px 12px 10px;
    row-gap: 8px;
  }
  .address-page .ad-banner-panel-premium .premium-ad-card-fan {
    grid-column: 1 / -1;
    justify-self: center;
  }
  .address-page .ad-banner-panel-premium .premium-ad-copy-lane::after {
    display: none;
  }
}
@media (max-width: 760px) {
  .address-page .ad-banner-panel-premium {
    min-height: 156px;
    height: auto;
  }
  .address-page .ad-banner-panel-premium .premium-ad-inner-triple {
    grid-template-columns: 1fr;
    padding: 12px;
    gap: 8px;
  }
  .address-page .ad-banner-panel-premium .premium-ad-copy-lane {
    padding: 8px 10px;
  }
  .address-page .ad-banner-panel-premium .premium-ad-copy-sub {
    white-space: normal;
  }
  .address-page .ad-banner-panel-premium .premium-ad-card-fan {
    width: 172px;
    margin-top: 4px;
  }
}
@media (prefers-reduced-motion: reduce) {
  .address-page .ad-banner-panel-premium .premium-ad-copy-lane {
    animation: none;
  }
}

/* premium ad card fan motion v4 */
.address-page .ad-banner-panel-premium .premium-ad-card {
  will-change: transform;
}
.address-page .ad-banner-panel-premium .premium-ad-card-10 {
  animation: premiumAdCard10 4.8s ease-in-out infinite;
}
.address-page .ad-banner-panel-premium .premium-ad-card-j {
  animation: premiumAdCardJ 4.8s ease-in-out infinite 0.18s;
}
.address-page .ad-banner-panel-premium .premium-ad-card-q {
  animation: premiumAdCardQ 4.8s ease-in-out infinite 0.36s;
}
.address-page .ad-banner-panel-premium .premium-ad-card-k {
  animation: premiumAdCardK 4.8s ease-in-out infinite 0.54s;
}
.address-page .ad-banner-panel-premium .premium-ad-card-a {
  animation: premiumAdCardA 4.8s ease-in-out infinite 0.72s;
}
@keyframes premiumAdCard10 {
  0%, 100% { transform: rotate(-25deg) translateY(8px); }
  50% { transform: rotate(-29deg) translateY(4px); }
}
@keyframes premiumAdCardJ {
  0%, 100% { transform: rotate(-14deg) translateY(4px); }
  50% { transform: rotate(-18deg) translateY(1px); }
}
@keyframes premiumAdCardQ {
  0%, 100% { transform: rotate(-3deg) translateY(0); }
  50% { transform: rotate(-6deg) translateY(-3px); }
}
@keyframes premiumAdCardK {
  0%, 100% { transform: rotate(9deg) translateY(4px); }
  50% { transform: rotate(13deg) translateY(1px); }
}
@keyframes premiumAdCardA {
  0%, 100% { transform: rotate(20deg) translateY(8px); }
  50% { transform: rotate(25deg) translateY(4px); }
}
@media (prefers-reduced-motion: reduce) {
  .address-page .ad-banner-panel-premium .premium-ad-card-10,
  .address-page .ad-banner-panel-premium .premium-ad-card-j,
  .address-page .ad-banner-panel-premium .premium-ad-card-q,
  .address-page .ad-banner-panel-premium .premium-ad-card-k,
  .address-page .ad-banner-panel-premium .premium-ad-card-a {
    animation: none;
  }
}

/* premium ad layout v5: tighter copy + rose gold icon pair */
.address-page .ad-banner-panel-premium .premium-ad-inner-triple {
  grid-template-columns: minmax(0, 1.14fr) minmax(0, 0.92fr) minmax(0, 0.9fr) 94px 176px;
  padding: 0 12px 0 8px;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-lane {
  padding: 0 14px;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-lane-1 {
  padding-left: 16px;
  padding-right: 12px;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-lane-2 {
  padding-left: 10px;
  padding-right: 10px;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-lane-3 {
  padding-left: 8px;
  padding-right: 8px;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-lane-2 .premium-ad-copy-kicker,
.address-page .ad-banner-panel-premium .premium-ad-copy-lane-3 .premium-ad-copy-kicker {
  letter-spacing: -0.01em;
}
.address-page .ad-banner-panel-premium .premium-ad-icon-pair {
  position: relative;
  width: 94px;
  height: 70px;
  align-self: center;
  justify-self: center;
}
.address-page .ad-banner-panel-premium .premium-ad-rose-icon {
  position: absolute;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  filter: drop-shadow(0 10px 18px rgba(0, 0, 0, 0.28));
  will-change: transform;
}
.address-page .ad-banner-panel-premium .premium-ad-rose-icon-usdt {
  left: 6px;
  bottom: 4px;
  width: 36px;
  height: 36px;
  border-radius: 999px;
  background:
    radial-gradient(circle at 30% 28%, rgba(255, 245, 238, 0.96), rgba(236, 178, 164, 0.95) 42%, rgba(176, 102, 92, 0.98) 100%);
  border: 1px solid rgba(255, 216, 207, 0.46);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.46), inset 0 -2px 6px rgba(120, 57, 49, 0.28);
  animation: premiumRoseUsdtSpin 4.6s linear infinite;
}
.address-page .ad-banner-panel-premium .premium-ad-rose-coin-face {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  border: 1px solid rgba(255, 235, 228, 0.34);
  color: #fff3ea;
  font-size: 0.95rem;
  font-weight: 1000;
  line-height: 1;
  text-shadow: 0 1px 6px rgba(91, 33, 25, 0.28);
}
.address-page .ad-banner-panel-premium .premium-ad-rose-icon-gift {
  right: 6px;
  top: 2px;
  width: 42px;
  height: 42px;
  border-radius: 12px;
  background: linear-gradient(145deg, rgba(255, 244, 240, 0.94), rgba(229, 172, 158, 0.95) 46%, rgba(176, 101, 91, 0.98) 100%);
  border: 1px solid rgba(255, 224, 215, 0.48);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.42), inset 0 -2px 6px rgba(120, 57, 49, 0.26);
  animation: premiumRoseGiftSpin 5.2s ease-in-out infinite;
}
.address-page .ad-banner-panel-premium .premium-ad-gift-box,
.address-page .ad-banner-panel-premium .premium-ad-gift-ribbon,
.address-page .ad-banner-panel-premium .premium-ad-gift-bow {
  position: absolute;
  display: block;
}
.address-page .ad-banner-panel-premium .premium-ad-gift-box {
  left: 9px;
  right: 9px;
  bottom: 8px;
  height: 18px;
  border-radius: 5px;
  background: linear-gradient(180deg, rgba(255, 234, 228, 0.92), rgba(214, 142, 129, 0.96));
  border: 1px solid rgba(255, 236, 230, 0.38);
}
.address-page .ad-banner-panel-premium .premium-ad-gift-ribbon {
  left: 50%;
  top: 8px;
  width: 6px;
  height: 24px;
  transform: translateX(-50%);
  border-radius: 999px;
  background: linear-gradient(180deg, #fff1ed, #e7b3a5 48%, #c16f5f 100%);
}
.address-page .ad-banner-panel-premium .premium-ad-gift-bow {
  top: 6px;
  width: 12px;
  height: 12px;
  border: 3px solid rgba(255, 239, 233, 0.9);
  border-bottom-color: transparent;
  border-right-color: transparent;
  border-radius: 12px 12px 0 12px;
}
.address-page .ad-banner-panel-premium .premium-ad-gift-bow-left {
  left: 9px;
  transform: rotate(-36deg);
}
.address-page .ad-banner-panel-premium .premium-ad-gift-bow-right {
  right: 9px;
  transform: scaleX(-1) rotate(-36deg);
}
@keyframes premiumRoseUsdtSpin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}
@keyframes premiumRoseGiftSpin {
  0%, 100% { transform: rotate(0deg) scale(1); }
  50% { transform: rotate(360deg) scale(1.04); }
}
@media (max-width: 1100px) {
  .address-page .ad-banner-panel-premium .premium-ad-inner-triple {
    grid-template-columns: repeat(3, minmax(0, 1fr)) 94px;
  }
  .address-page .ad-banner-panel-premium .premium-ad-card-fan {
    grid-column: 1 / -1;
    justify-self: center;
  }
}
@media (max-width: 760px) {
  .address-page .ad-banner-panel-premium .premium-ad-inner-triple {
    grid-template-columns: 1fr;
  }
  .address-page .ad-banner-panel-premium .premium-ad-icon-pair,
  .address-page .ad-banner-panel-premium .premium-ad-card-fan {
    justify-self: start;
  }
}
@media (prefers-reduced-motion: reduce) {
  .address-page .ad-banner-panel-premium .premium-ad-rose-icon-usdt,
  .address-page .ad-banner-panel-premium .premium-ad-rose-icon-gift {
    animation: none;
  }
}

/* premium ad icons v6: dark gold theme + more spacing */
.address-page .ad-banner-panel-premium .premium-ad-inner-triple {
  grid-template-columns: minmax(0, 1.14fr) minmax(0, 0.92fr) minmax(0, 0.9fr) 108px 162px;
}
.address-page .ad-banner-panel-premium .premium-ad-icon-pair {
  width: 108px;
  height: 74px;
  justify-self: start;
  margin-left: -6px;
}
.address-page .ad-banner-panel-premium .premium-ad-card-fan {
  margin-right: 8px;
}
.address-page .ad-banner-panel-premium .premium-ad-rose-icon {
  filter: drop-shadow(0 12px 18px rgba(0, 0, 0, 0.32));
}
.address-page .ad-banner-panel-premium .premium-ad-rose-icon-usdt {
  left: 2px;
  bottom: 6px;
  width: 38px;
  height: 38px;
  background:
    radial-gradient(circle at 30% 28%, rgba(255, 245, 214, 0.96), rgba(214, 168, 82, 0.94) 42%, rgba(103, 69, 18, 0.98) 100%);
  border: 1px solid rgba(247, 222, 153, 0.42);
  box-shadow:
    inset 0 1px 0 rgba(255, 248, 229, 0.42),
    inset 0 -3px 7px rgba(78, 52, 12, 0.34),
    0 10px 20px rgba(0, 0, 0, 0.18);
}
.address-page .ad-banner-panel-premium .premium-ad-rose-coin-face {
  width: 25px;
  height: 25px;
  border: 1px solid rgba(255, 240, 198, 0.34);
  color: #fff3cf;
  text-shadow: 0 1px 6px rgba(70, 46, 10, 0.34);
}
.address-page .ad-banner-panel-premium .premium-ad-rose-icon-gift {
  right: 10px;
  top: 0;
  width: 46px;
  height: 46px;
  border-radius: 10px;
  background:
    linear-gradient(145deg, rgba(255, 247, 223, 0.96) 0%, rgba(224, 184, 95, 0.96) 40%, rgba(139, 97, 28, 0.98) 100%);
  border: 1px solid rgba(248, 222, 156, 0.44);
  box-shadow:
    inset -3px -4px 8px rgba(92, 58, 13, 0.28),
    inset 2px 2px 6px rgba(255, 248, 226, 0.38),
    0 12px 22px rgba(0, 0, 0, 0.18);
}
.address-page .ad-banner-panel-premium .premium-ad-gift-box {
  left: 10px;
  right: 10px;
  bottom: 8px;
  height: 18px;
  border-radius: 4px;
  background: linear-gradient(180deg, rgba(255, 240, 201, 0.98), rgba(199, 154, 66, 0.98));
  border: 1px solid rgba(255, 236, 187, 0.34);
  box-shadow: inset 0 -2px 4px rgba(117, 75, 18, 0.24);
}
.address-page .ad-banner-panel-premium .premium-ad-gift-ribbon {
  top: 7px;
  width: 7px;
  height: 25px;
  background: linear-gradient(180deg, #fff5d9, #e6c06e 45%, #a8751d 100%);
  box-shadow: inset 0 1px 0 rgba(255, 248, 220, 0.34);
}
.address-page .ad-banner-panel-premium .premium-ad-gift-bow {
  top: 4px;
  width: 13px;
  height: 13px;
  border: 3px solid rgba(255, 245, 210, 0.9);
  border-bottom-color: transparent;
  border-right-color: transparent;
  box-shadow: 0 1px 4px rgba(96, 61, 15, 0.18);
}
.address-page .ad-banner-panel-premium .premium-ad-gift-bow-left {
  left: 10px;
}
.address-page .ad-banner-panel-premium .premium-ad-gift-bow-right {
  right: 10px;
}
@media (max-width: 1100px) {
  .address-page .ad-banner-panel-premium .premium-ad-inner-triple {
    grid-template-columns: repeat(3, minmax(0, 1fr)) 108px;
  }
}
@media (max-width: 760px) {
  .address-page .ad-banner-panel-premium .premium-ad-icon-pair {
    width: 108px;
    margin-left: 0;
  }
  .address-page .ad-banner-panel-premium .premium-ad-card-fan {
    margin-right: 0;
  }
}

/* premium ad icons v7: equal copy widths + card-grade icon treatment */
.address-page .ad-banner-panel-premium .premium-ad-inner-triple {
  grid-template-columns: repeat(3, minmax(0, 1fr)) 126px 156px;
  padding: 0 12px 0 10px;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-lane,
.address-page .ad-banner-panel-premium .premium-ad-copy-lane-1,
.address-page .ad-banner-panel-premium .premium-ad-copy-lane-2,
.address-page .ad-banner-panel-premium .premium-ad-copy-lane-3 {
  padding-left: 12px;
  padding-right: 12px;
}
.address-page .ad-banner-panel-premium .premium-ad-icon-pair {
  width: 126px;
  height: 76px;
  justify-self: start;
  margin-left: -12px;
}
.address-page .ad-banner-panel-premium .premium-ad-card-fan {
  margin-right: 10px;
}
.address-page .ad-banner-panel-premium .premium-ad-rose-icon {
  filter: drop-shadow(0 14px 22px rgba(0, 0, 0, 0.34));
}
.address-page .ad-banner-panel-premium .premium-ad-rose-icon-usdt {
  left: 0;
  bottom: 8px;
  width: 42px;
  height: 42px;
  background:
    linear-gradient(145deg, rgba(255, 243, 204, 0.96) 0%, rgba(210, 168, 77, 0.96) 36%, rgba(123, 86, 24, 0.98) 72%, rgba(51, 38, 14, 1) 100%);
  border: 1px solid rgba(243, 214, 137, 0.4);
  box-shadow:
    inset 0 1px 0 rgba(255, 248, 226, 0.42),
    inset -3px -4px 8px rgba(72, 50, 13, 0.34),
    inset 3px 3px 8px rgba(255, 237, 183, 0.14);
  animation: premiumDarkGoldSpin 5.2s linear infinite;
}
.address-page .ad-banner-panel-premium .premium-ad-rose-coin-face {
  width: 28px;
  height: 28px;
  border: 1px solid rgba(255, 240, 198, 0.26);
  background: radial-gradient(circle at 34% 30%, rgba(255, 244, 212, 0.16), rgba(0, 0, 0, 0) 70%);
  color: #f7df9f;
  text-shadow: 0 1px 6px rgba(55, 37, 8, 0.4);
}
.address-page .ad-banner-panel-premium .premium-ad-rose-icon-gift {
  right: 6px;
  top: 0;
  width: 50px;
  height: 50px;
  border-radius: 12px;
  background:
    linear-gradient(145deg, rgba(255, 242, 204, 0.96) 0%, rgba(210, 168, 77, 0.96) 34%, rgba(118, 81, 22, 0.98) 74%, rgba(48, 36, 14, 1) 100%);
  border: 1px solid rgba(243, 214, 137, 0.4);
  box-shadow:
    inset 0 1px 0 rgba(255, 247, 223, 0.4),
    inset -4px -5px 9px rgba(70, 49, 14, 0.34),
    inset 3px 3px 8px rgba(255, 235, 180, 0.14);
  transform-style: preserve-3d;
  animation: premiumDarkGoldGiftSpin 6s linear infinite;
}
.address-page .ad-banner-panel-premium .premium-ad-gift-box {
  left: 9px;
  right: 9px;
  bottom: 8px;
  height: 20px;
  border-radius: 4px;
  background: linear-gradient(180deg, rgba(255, 236, 190, 0.98), rgba(182, 138, 50, 0.98));
  border: 1px solid rgba(244, 223, 166, 0.28);
  box-shadow:
    inset 0 1px 0 rgba(255, 244, 212, 0.28),
    inset 0 -3px 5px rgba(91, 62, 16, 0.28),
    0 4px 8px rgba(0, 0, 0, 0.14);
  transform: translateZ(4px);
}
.address-page .ad-banner-panel-premium .premium-ad-gift-ribbon {
  top: 6px;
  width: 8px;
  height: 29px;
  background: linear-gradient(180deg, #fff3cb, #ddb45d 42%, #8d6217 100%);
  box-shadow: inset 0 1px 0 rgba(255, 245, 211, 0.28);
  transform: translateX(-50%) translateZ(10px);
}
.address-page .ad-banner-panel-premium .premium-ad-gift-bow {
  top: 4px;
  width: 15px;
  height: 15px;
  border: 3px solid rgba(255, 241, 200, 0.88);
  border-bottom-color: transparent;
  border-right-color: transparent;
  box-shadow:
    0 2px 6px rgba(60, 40, 10, 0.22),
    inset 0 1px 0 rgba(255, 247, 218, 0.2);
  transform: translateZ(12px);
}
.address-page .ad-banner-panel-premium .premium-ad-gift-bow-left {
  left: 11px;
}
.address-page .ad-banner-panel-premium .premium-ad-gift-bow-right {
  right: 11px;
}
@keyframes premiumDarkGoldSpin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}
@keyframes premiumDarkGoldGiftSpin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}
@media (max-width: 1100px) {
  .address-page .ad-banner-panel-premium .premium-ad-inner-triple {
    grid-template-columns: repeat(3, minmax(0, 1fr)) 126px;
  }
}
@media (max-width: 760px) {
  .address-page .ad-banner-panel-premium .premium-ad-icon-pair {
    width: 126px;
    margin-left: 0;
  }
  .address-page .ad-banner-panel-premium .premium-ad-card-fan {
    margin-right: 0;
  }
}
@media (prefers-reduced-motion: reduce) {
  .address-page .ad-banner-panel-premium .premium-ad-rose-icon-usdt,
  .address-page .ad-banner-panel-premium .premium-ad-rose-icon-gift {
    animation: none;
  }
}

/* premium ad icon v8: single dark-gold diamond usdt */
.address-page .ad-banner-panel-premium .premium-ad-inner-triple {
  grid-template-columns: repeat(3, minmax(0, 1fr)) 88px 166px;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-lane,
.address-page .ad-banner-panel-premium .premium-ad-copy-lane-1,
.address-page .ad-banner-panel-premium .premium-ad-copy-lane-2,
.address-page .ad-banner-panel-premium .premium-ad-copy-lane-3 {
  padding-left: 12px;
  padding-right: 12px;
}
.address-page .ad-banner-panel-premium .premium-ad-icon-solo {
  position: relative;
  width: 88px;
  height: 76px;
  align-self: center;
  justify-self: center;
}
.address-page .ad-banner-panel-premium .premium-ad-diamond-usdt {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 44px;
  height: 44px;
  transform: translate(-50%, -50%) rotate(45deg);
  border-radius: 10px;
  background:
    linear-gradient(145deg, rgba(255, 246, 214, 0.98) 0%, rgba(218, 179, 82, 0.96) 34%, rgba(126, 89, 25, 0.98) 72%, rgba(52, 39, 14, 1) 100%);
  border: 1px solid rgba(243, 214, 137, 0.42);
  box-shadow:
    inset 0 1px 0 rgba(255, 248, 226, 0.42),
    inset -4px -5px 10px rgba(72, 50, 13, 0.32),
    inset 3px 3px 8px rgba(255, 236, 182, 0.16),
    0 12px 20px rgba(0, 0, 0, 0.34);
}
.address-page .ad-banner-panel-premium .premium-ad-diamond-usdt::before,
.address-page .ad-banner-panel-premium .premium-ad-diamond-usdt::after {
  content: '';
  position: absolute;
  inset: 5px;
  border-radius: 8px;
}
.address-page .ad-banner-panel-premium .premium-ad-diamond-usdt::before {
  border: 1px solid rgba(255, 239, 194, 0.24);
}
.address-page .ad-banner-panel-premium .premium-ad-diamond-usdt::after {
  inset: 8px;
  background: linear-gradient(180deg, rgba(255, 247, 220, 0.24), rgba(0, 0, 0, 0) 66%);
}
.address-page .ad-banner-panel-premium .premium-ad-diamond-core {
  position: absolute;
  inset: 9px;
  border-radius: 6px;
  background: linear-gradient(180deg, rgba(255, 244, 206, 0.24), rgba(96, 68, 18, 0.22));
  border: 1px solid rgba(255, 237, 188, 0.18);
}
.address-page .ad-banner-panel-premium .premium-ad-diamond-glyph {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) rotate(-45deg);
  color: #f6df9c;
  font-size: 1.08rem;
  font-weight: 1000;
  line-height: 1;
  text-shadow: 0 1px 8px rgba(55, 37, 8, 0.42);
}
@media (max-width: 1100px) {
  .address-page .ad-banner-panel-premium .premium-ad-inner-triple {
    grid-template-columns: repeat(3, minmax(0, 1fr)) 88px;
  }
}
@media (max-width: 760px) {
  .address-page .ad-banner-panel-premium .premium-ad-inner-triple {
    grid-template-columns: 1fr;
  }
  .address-page .ad-banner-panel-premium .premium-ad-icon-solo,
  .address-page .ad-banner-panel-premium .premium-ad-card-fan {
    justify-self: start;
  }
}

/* premium ad icon v9: move single diamond left from card fan */
.address-page .ad-banner-panel-premium .premium-ad-inner-triple {
  grid-template-columns: repeat(3, minmax(0, 1fr)) 112px 154px;
}
.address-page .ad-banner-panel-premium .premium-ad-icon-solo {
  width: 112px;
  justify-self: start;
}
.address-page .ad-banner-panel-premium .premium-ad-diamond-usdt {
  left: 38%;
}
.address-page .ad-banner-panel-premium .premium-ad-card-fan {
  margin-right: 14px;
}
@media (max-width: 1100px) {
  .address-page .ad-banner-panel-premium .premium-ad-inner-triple {
    grid-template-columns: repeat(3, minmax(0, 1fr)) 112px;
  }
}
@media (max-width: 760px) {
  .address-page .ad-banner-panel-premium .premium-ad-icon-solo {
    width: 88px;
  }
  .address-page .ad-banner-panel-premium .premium-ad-diamond-usdt {
    left: 50%;
  }
  .address-page .ad-banner-panel-premium .premium-ad-card-fan {
    margin-right: 0;
  }
}

/* premium ad icon v10: tether-like shield shape */
.address-page .ad-banner-panel-premium .premium-ad-diamond-usdt {
  width: 48px;
  height: 54px;
  left: 36%;
  border-radius: 0;
  clip-path: polygon(18% 0, 82% 0, 100% 36%, 50% 100%, 0 36%);
  transform: translate(-50%, -50%);
  background:
    linear-gradient(150deg, rgba(255, 248, 220, 0.98) 0%, rgba(221, 183, 88, 0.96) 34%, rgba(129, 93, 26, 0.98) 70%, rgba(49, 37, 13, 1) 100%);
  border: 0;
  box-shadow:
    inset 0 1px 0 rgba(255, 247, 223, 0.48),
    inset -4px -6px 10px rgba(77, 54, 14, 0.34),
    inset 3px 3px 8px rgba(255, 236, 182, 0.16),
    0 12px 18px rgba(0, 0, 0, 0.34);
}
.address-page .ad-banner-panel-premium .premium-ad-diamond-usdt::before {
  inset: 2px;
  border: 1px solid rgba(255, 237, 188, 0.22);
  border-radius: 0;
  clip-path: polygon(18% 0, 82% 0, 100% 36%, 50% 100%, 0 36%);
  background: none;
}
.address-page .ad-banner-panel-premium .premium-ad-diamond-usdt::after {
  inset: 5px 8px 18px;
  border-radius: 999px 999px 18px 18px;
  background: linear-gradient(180deg, rgba(255, 248, 226, 0.18), rgba(0, 0, 0, 0));
  clip-path: none;
}
.address-page .ad-banner-panel-premium .premium-ad-diamond-core {
  left: 50%;
  top: 40%;
  width: 34px;
  height: 10px;
  inset: auto;
  transform: translate(-50%, -50%);
  border-radius: 999px;
  background: transparent;
  border: 2px solid rgba(255, 240, 196, 0.82);
  box-shadow: 0 1px 0 rgba(64, 43, 10, 0.22);
}
.address-page .ad-banner-panel-premium .premium-ad-diamond-glyph {
  left: 50%;
  top: 48%;
  transform: translate(-50%, -50%);
  color: #fff0bd;
  font-size: 1.18rem;
  font-weight: 1000;
  text-shadow: 0 1px 8px rgba(55, 37, 8, 0.42);
}
@media (max-width: 760px) {
  .address-page .ad-banner-panel-premium .premium-ad-diamond-usdt {
    left: 50%;
  }
}

/* premium ad icon v11: animated dark-gold dice */
.address-page .ad-banner-panel-premium .premium-ad-inner-triple {
  grid-template-columns: repeat(3, minmax(0, 1fr)) 108px 160px;
}
.address-page .ad-banner-panel-premium .premium-ad-dice-pair {
  position: relative;
  width: 108px;
  height: 78px;
  align-self: center;
  justify-self: center;
}
.address-page .ad-banner-panel-premium .premium-ad-die {
  position: absolute;
  display: block;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background:
    linear-gradient(145deg, rgba(255, 245, 210, 0.96) 0%, rgba(219, 179, 82, 0.95) 34%, rgba(126, 89, 25, 0.98) 72%, rgba(50, 38, 14, 1) 100%);
  border: 1px solid rgba(244, 214, 136, 0.38);
  box-shadow:
    inset 0 1px 0 rgba(255, 247, 220, 0.42),
    inset -3px -4px 8px rgba(72, 50, 13, 0.34),
    inset 2px 2px 6px rgba(255, 236, 182, 0.14),
    0 12px 18px rgba(0, 0, 0, 0.30);
  transform-style: preserve-3d;
}
.address-page .ad-banner-panel-premium .premium-ad-die::before {
  content: '';
  position: absolute;
  inset: 3px;
  border-radius: 6px;
  border: 1px solid rgba(255, 238, 190, 0.18);
}
.address-page .ad-banner-panel-premium .premium-ad-die::after {
  content: '';
  position: absolute;
  left: 5px;
  right: 5px;
  top: 5px;
  height: 9px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(255, 248, 224, 0.24), rgba(0, 0, 0, 0));
}
.address-page .ad-banner-panel-premium .premium-ad-die-one {
  left: 18px;
  top: 6px;
  animation: premiumAdDieOne 4.6s ease-in-out infinite;
}
.address-page .ad-banner-panel-premium .premium-ad-die-two {
  left: 50px;
  top: 26px;
  animation: premiumAdDieTwo 4.9s ease-in-out infinite;
}
.address-page .ad-banner-panel-premium .premium-ad-pip {
  position: absolute;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: radial-gradient(circle at 30% 30%, rgba(46, 32, 12, 0.96), rgba(17, 12, 5, 1));
  box-shadow: inset 0 1px 0 rgba(255, 239, 194, 0.12);
}
.address-page .ad-banner-panel-premium .premium-ad-pip.pip-top-left {
  left: 7px;
  top: 7px;
}
.address-page .ad-banner-panel-premium .premium-ad-pip.pip-top-right {
  right: 7px;
  top: 7px;
}
.address-page .ad-banner-panel-premium .premium-ad-pip.pip-center {
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
.address-page .ad-banner-panel-premium .premium-ad-pip.pip-bottom-left {
  left: 7px;
  bottom: 7px;
}
.address-page .ad-banner-panel-premium .premium-ad-pip.pip-bottom-right {
  right: 7px;
  bottom: 7px;
}
@keyframes premiumAdDieOne {
  0%, 100% {
    transform: rotate(-10deg) translateY(0);
  }
  50% {
    transform: rotate(8deg) translateY(-5px);
  }
}
@keyframes premiumAdDieTwo {
  0%, 100% {
    transform: rotate(12deg) translateY(0);
  }
  50% {
    transform: rotate(-6deg) translateY(-4px);
  }
}
@media (max-width: 1100px) {
  .address-page .ad-banner-panel-premium .premium-ad-inner-triple {
    grid-template-columns: repeat(3, minmax(0, 1fr)) 108px;
  }
}
@media (max-width: 760px) {
  .address-page .ad-banner-panel-premium .premium-ad-inner-triple {
    grid-template-columns: 1fr;
  }
  .address-page .ad-banner-panel-premium .premium-ad-dice-pair,
  .address-page .ad-banner-panel-premium .premium-ad-card-fan {
    justify-self: start;
  }
}
@media (prefers-reduced-motion: reduce) {
  .address-page .ad-banner-panel-premium .premium-ad-die-one,
  .address-page .ad-banner-panel-premium .premium-ad-die-two {
    animation: none;
  }
}

/* premium ad icon v12: move dice between copy and cards */
.address-page .ad-banner-panel-premium .premium-ad-inner-triple {
  grid-template-columns: repeat(3, minmax(0, 1fr)) 132px 148px;
}
.address-page .ad-banner-panel-premium .premium-ad-dice-pair {
  width: 132px;
  justify-self: start;
  margin-left: -10px;
}
.address-page .ad-banner-panel-premium .premium-ad-card-fan {
  justify-self: end;
  margin-right: 12px;
}
@media (max-width: 1100px) {
  .address-page .ad-banner-panel-premium .premium-ad-inner-triple {
    grid-template-columns: repeat(3, minmax(0, 1fr)) 132px;
  }
}
@media (max-width: 760px) {
  .address-page .ad-banner-panel-premium .premium-ad-dice-pair {
    width: 108px;
    margin-left: 0;
  }
  .address-page .ad-banner-panel-premium .premium-ad-card-fan {
    margin-right: 0;
  }
}

/* premium ad icon v13: move dice a bit more left */
.address-page .ad-banner-panel-premium .premium-ad-dice-pair {
  margin-left: -24px;
}
@media (max-width: 760px) {
  .address-page .ad-banner-panel-premium .premium-ad-dice-pair {
    margin-left: 0;
  }
}

/* third banner: 7t.com slot machine */
.address-page .slot7-banner-panel {
  position: relative;
  overflow: hidden;
  border-color: rgba(161, 217, 255, 0.82);
  background:
    radial-gradient(circle at 8% 22%, rgba(132, 205, 255, 0.34), transparent 26%),
    radial-gradient(circle at 84% 18%, rgba(138, 194, 255, 0.26), transparent 20%),
    linear-gradient(135deg, #f5fcff 0%, #f2fbff 42%, #f8fdff 100%);
  box-shadow: 0 18px 36px rgba(92, 155, 201, 0.14);
}
.address-page .slot7-banner-panel:hover {
  border-color: rgba(103, 182, 241, 0.92);
  box-shadow: 0 22px 42px rgba(92, 155, 201, 0.18);
}
.address-page .slot7-banner-glow {
  position: absolute;
  border-radius: 999px;
  filter: blur(0.4px);
  opacity: 0.72;
}
.address-page .slot7-banner-glow-left {
  left: -20px;
  top: 8px;
  width: 132px;
  height: 132px;
  background: radial-gradient(circle at 50% 50%, rgba(122, 209, 255, 0.26), rgba(122, 209, 255, 0.05) 68%, transparent 70%);
}
.address-page .slot7-banner-glow-right {
  right: -14px;
  bottom: -38px;
  width: 176px;
  height: 176px;
  background: radial-gradient(circle at 50% 50%, rgba(120, 176, 255, 0.24), rgba(120, 176, 255, 0.04) 68%, transparent 70%);
}
.address-page .slot7-banner-grid {
  position: relative;
  z-index: 2;
  height: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1.16fr) minmax(0, 0.94fr) 220px;
  gap: 14px;
  align-items: center;
  padding: 10px 14px 10px 12px;
}
.address-page .slot7-brand-block,
.address-page .slot7-trust-block {
  min-width: 0;
}
.address-page .slot7-brand-lockup {
  display: grid;
  grid-template-columns: 88px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
}
.address-page .slot7-logo-mark {
  position: relative;
  width: 88px;
  height: 64px;
}
.address-page .slot7-logo-shield {
  position: absolute;
  left: 0;
  top: 4px;
  width: 54px;
  height: 54px;
  border-radius: 12px;
  background: linear-gradient(150deg, #9cd2ff 0%, #61b4f2 48%, #3e8fd8 100%);
  clip-path: polygon(16% 0, 84% 0, 100% 34%, 50% 100%, 0 34%);
  box-shadow: 0 10px 20px rgba(72, 148, 209, 0.22);
}
.address-page .slot7-logo-seven {
  position: absolute;
  left: 16px;
  top: 8px;
  color: #ffffff;
  font-size: 2.1rem;
  font-weight: 1000;
  line-height: 1;
}
.address-page .slot7-logo-ring {
  position: absolute;
  left: 12px;
  top: 28px;
  width: 32px;
  height: 10px;
  border-radius: 999px;
  border: 2px solid rgba(255, 255, 255, 0.96);
}
.address-page .slot7-logo-t {
  position: absolute;
  left: 23px;
  top: 26px;
  color: #ffffff;
  font-size: 1rem;
  font-weight: 1000;
  line-height: 1;
}
.address-page .slot7-brand-copy {
  display: grid;
  gap: 3px;
}
.address-page .slot7-brand-title,
.address-page .slot7-trust-title {
  display: flex;
  align-items: baseline;
  gap: 8px;
  min-width: 0;
  color: #1f3854;
  font-size: 1.06rem;
  font-weight: 900;
  line-height: 1.05;
}
.address-page .slot7-brand-name,
.address-page .slot7-trust-mark {
  color: #67b8f4;
}
.address-page .slot7-brand-name {
  font-size: 1.96rem;
  letter-spacing: 0.01em;
}
.address-page .slot7-brand-sub,
.address-page .slot7-trust-sub {
  color: #426175;
  font-size: 0.84rem;
  font-weight: 700;
  line-height: 1.15;
}
.address-page .slot7-trust-block {
  display: grid;
  gap: 6px;
  align-content: center;
}
.address-page .slot7-trust-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.address-page .slot7-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 5px 10px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(90, 178, 245, 0.16), rgba(92, 197, 255, 0.12));
  color: #5aaef1;
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.03em;
}
.address-page .slot7-machine-block {
  display: grid;
  justify-items: end;
}
.address-page .slot7-machine-shell {
  position: relative;
  width: 200px;
  padding: 6px 10px 8px 10px;
  border-radius: 18px;
  background: linear-gradient(180deg, #fefefe 0%, #edf8ff 30%, #dcefff 100%);
  border: 1px solid rgba(132, 194, 246, 0.76);
  box-shadow: 0 16px 28px rgba(92, 152, 201, 0.18);
}
.address-page .slot7-machine-head {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 76px;
  min-height: 24px;
  margin-left: 4px;
  border-radius: 999px;
  background: linear-gradient(135deg, #6f5dff, #4eb5ff);
  color: #ffffff;
  font-size: 0.72rem;
  font-weight: 1000;
  letter-spacing: 0.08em;
}
.address-page .slot7-machine-body {
  position: relative;
  margin-top: 8px;
  min-height: 76px;
  padding: 10px 26px 10px 10px;
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(110, 173, 255, 0.18), rgba(255, 255, 255, 0.98));
  border: 1px solid rgba(157, 205, 247, 0.86);
}
.address-page .slot7-reels {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.address-page .slot7-reel-window {
  height: 56px;
  overflow: hidden;
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(229, 244, 255, 0.96));
  border: 1px solid rgba(154, 205, 247, 0.78);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.96);
}
.address-page .slot7-reel-track {
  display: grid;
  justify-items: center;
  gap: 8px;
  padding: 6px 0;
}
.address-page .slot7-reel-track-a {
  animation: slot7SpinA 2.2s linear infinite;
}
.address-page .slot7-reel-track-b {
  animation: slot7SpinB 1.9s linear infinite;
}
.address-page .slot7-reel-track-c {
  animation: slot7SpinC 2.5s linear infinite;
}
.address-page .slot7-mini-icon {
  position: relative;
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
}
.address-page .slot7-mini-icon-shield {
  color: #ffffff;
  font-size: 0.9rem;
  font-weight: 1000;
  background: linear-gradient(150deg, #8fd0ff 0%, #58afea 48%, #3d8dd5 100%);
  clip-path: polygon(16% 0, 84% 0, 100% 34%, 50% 100%, 0 34%);
}
.address-page .slot7-mini-icon-chip {
  border-radius: 999px;
  background: linear-gradient(145deg, #f6dd98 0%, #dfb25c 42%, #a97016 100%);
  color: #fff8e2;
  font-size: 0.88rem;
  font-weight: 1000;
}
.address-page .slot7-mini-icon-diamond {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  transform: rotate(45deg);
  background: linear-gradient(145deg, #9fd9ff 0%, #6dbef5 36%, #4477ff 100%);
}
.address-page .slot7-machine-lever {
  position: absolute;
  right: 8px;
  top: 8px;
  width: 18px;
  height: 60px;
  transform-origin: top center;
  animation: slot7LeverPull 3.6s ease-in-out infinite;
}
.address-page .slot7-machine-lever::before {
  content: '';
  position: absolute;
  left: 7px;
  top: 0;
  width: 4px;
  height: 40px;
  border-radius: 999px;
  background: linear-gradient(180deg, #c9d7e5, #8797a8);
}
.address-page .slot7-machine-knob {
  position: absolute;
  left: 1px;
  bottom: 0;
  width: 16px;
  height: 16px;
  border-radius: 999px;
  background: linear-gradient(145deg, #ff9fb9, #ff6f97);
  box-shadow: 0 4px 8px rgba(255, 98, 144, 0.26);
}
.address-page .slot7-machine-base {
  margin-top: 7px;
  text-align: center;
  color: #e1aa2d;
  font-size: 0.78rem;
  font-weight: 1000;
  letter-spacing: 0.02em;
}
.address-page .slot7-banner-shine {
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, transparent 14%, rgba(255, 255, 255, 0.06) 28%, rgba(255, 255, 255, 0.4) 44%, rgba(255, 255, 255, 0.06) 62%, transparent 80%);
  transform: translateX(-140%);
  animation: slot7Sweep 5.6s ease-in-out infinite;
}
@keyframes slot7SpinA {
  0% { transform: translateY(0); }
  100% { transform: translateY(-96px); }
}
@keyframes slot7SpinB {
  0% { transform: translateY(-32px); }
  100% { transform: translateY(-128px); }
}
@keyframes slot7SpinC {
  0% { transform: translateY(-64px); }
  100% { transform: translateY(-160px); }
}
@keyframes slot7LeverPull {
  0%, 100% { transform: rotate(0deg); }
  18% { transform: rotate(18deg); }
  36% { transform: rotate(24deg); }
  60% { transform: rotate(2deg); }
}
@keyframes slot7Sweep {
  0% { transform: translateX(-140%); }
  58% { transform: translateX(140%); }
  100% { transform: translateX(140%); }
}
@media (max-width: 1180px) {
  .address-page .slot7-banner-grid {
    grid-template-columns: 1fr;
    padding: 12px;
  }
  .address-page .slot7-machine-block {
    justify-items: start;
  }
}
@media (max-width: 760px) {
  .address-page .slot7-brand-lockup {
    grid-template-columns: 72px 1fr;
  }
  .address-page .slot7-brand-title,
  .address-page .slot7-trust-title {
    flex-wrap: wrap;
  }
  .address-page .slot7-brand-name {
    font-size: 1.54rem;
  }
  .address-page .slot7-machine-shell {
    width: min(100%, 210px);
  }
}
@media (prefers-reduced-motion: reduce) {
  .address-page .slot7-reel-track-a,
  .address-page .slot7-reel-track-b,
  .address-page .slot7-reel-track-c,
  .address-page .slot7-machine-lever,
  .address-page .slot7-banner-shine {
    animation: none;
  }
}

/* third banner v14: prevent slot layout clipping */
.address-page .slot7-banner-panel {
  min-height: 118px;
  height: auto;
}
.address-page .slot7-banner-grid {
  min-height: 118px;
  align-items: stretch;
  padding: 12px 16px 12px 14px;
}
.address-page .slot7-brand-block,
.address-page .slot7-trust-block,
.address-page .slot7-machine-block {
  display: grid;
  align-content: center;
}
.address-page .slot7-machine-block {
  justify-items: end;
}
@media (max-width: 1180px) {
  .address-page .slot7-banner-panel {
    min-height: 176px;
  }
  .address-page .slot7-banner-grid {
    min-height: 176px;
  }
}
@media (max-width: 760px) {
  .address-page .slot7-banner-panel {
    min-height: 210px;
  }
  .address-page .slot7-banner-grid {
    min-height: 210px;
  }
}

/* third banner v15: compact strip layout + animated jackpot digits */
.address-page .slot7-banner-panel {
  min-height: var(--address-ad-height);
  height: var(--address-ad-height);
}
.address-page .slot7-banner-grid {
  min-height: 100%;
  height: 100%;
  grid-template-columns: minmax(0, 1fr) 220px;
  gap: 10px;
  align-items: center;
  padding: 4px 10px;
}
.address-page .slot7-copy-strip {
  min-width: 0;
  height: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(0, 0.92fr) minmax(0, 1fr);
  border-radius: 15px;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(242, 250, 255, 0.82));
  border: 1px solid rgba(163, 210, 245, 0.72);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.96);
}
.address-page .slot7-copy-card {
  position: relative;
  min-width: 0;
  display: grid;
  align-content: center;
  gap: 2px;
  padding: 5px 12px;
}
.address-page .slot7-copy-card::after {
  content: '';
  position: absolute;
  right: 0;
  top: 50%;
  width: 1px;
  height: 38px;
  transform: translateY(-50%);
  background: linear-gradient(180deg, transparent, rgba(104, 180, 235, 0.58), transparent);
}
.address-page .slot7-copy-card-trust::after {
  display: none;
}
.address-page .slot7-copy-card-brand {
  background: linear-gradient(90deg, rgba(125, 199, 246, 0.10), rgba(255, 255, 255, 0));
}
.address-page .slot7-brand-lockup {
  display: grid;
  grid-template-columns: 68px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
}
.address-page .slot7-logo-mark {
  width: 68px;
  height: 44px;
}
.address-page .slot7-logo-shield {
  left: 0;
  top: 2px;
  width: 42px;
  height: 40px;
  border-radius: 10px;
  box-shadow: 0 8px 16px rgba(72, 148, 209, 0.18);
}
.address-page .slot7-logo-seven {
  left: 13px;
  top: 4px;
  font-size: 1.64rem;
}
.address-page .slot7-logo-ring {
  left: 9px;
  top: 19px;
  width: 24px;
  height: 8px;
  border-width: 2px;
}
.address-page .slot7-logo-t {
  left: 18px;
  top: 17px;
  font-size: 0.8rem;
}
.address-page .slot7-brand-copy {
  gap: 2px;
}
.address-page .slot7-brand-wordmark {
  color: #5db5f3;
  font-size: 1.48rem;
  font-weight: 1000;
  line-height: 0.95;
  letter-spacing: 0.01em;
}
.address-page .slot7-brand-slogan {
  color: #233344;
  font-size: 0.76rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.22em;
  white-space: nowrap;
}
.address-page .slot7-license-head {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 1px;
}
.address-page .slot7-license-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 18px;
  font-weight: 1000;
  line-height: 1;
}
.address-page .slot7-license-badge-shield {
  width: 18px;
  color: #ffffff;
  font-size: 0.72rem;
  background: linear-gradient(150deg, #98d1ff 0%, #60b4f2 48%, #3d8fd8 100%);
  clip-path: polygon(16% 0, 84% 0, 100% 34%, 50% 100%, 0 34%);
}
.address-page .slot7-license-badge-gcb {
  min-width: 36px;
  padding: 0 6px;
  border-radius: 5px;
  color: #ffffff;
  font-size: 0.72rem;
  background: linear-gradient(135deg, #2f6f2d, #4a9e42);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.22);
}
.address-page .slot7-copy-title,
.address-page .slot7-trust-title {
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
  color: #5db5f3;
  font-size: 0.82rem;
  font-weight: 1000;
  line-height: 1.02;
}
.address-page .slot7-copy-sub,
.address-page .slot7-trust-sub {
  color: #406075;
  font-size: 0.71rem;
  font-weight: 800;
  line-height: 1.05;
}
.address-page .slot7-trust-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 6px;
  background: linear-gradient(150deg, #98d1ff 0%, #60b4f2 48%, #3d8fd8 100%);
  color: #ffffff;
  font-size: 0.7rem;
  font-weight: 1000;
}
.address-page .slot7-trust-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 1px;
}
.address-page .slot7-tag {
  padding: 2px 6px;
  border-radius: 999px;
  font-size: 0.58rem;
  font-weight: 1000;
  letter-spacing: 0.02em;
}
.address-page .slot7-machine-block {
  display: grid;
  justify-items: end;
}
.address-page .slot7-machine-shell {
  width: 220px;
  display: grid;
  gap: 3px;
  padding: 2px 8px 0;
  border-radius: 16px;
  box-shadow: 0 14px 24px rgba(92, 152, 201, 0.14);
}
.address-page .slot7-machine-head {
  min-width: 72px;
  min-height: 18px;
  margin-left: 0;
  padding: 0 10px;
  font-size: 0.62rem;
  letter-spacing: 0.06em;
}
.address-page .slot7-machine-body {
  margin-top: 0;
  min-height: auto;
  padding: 6px 20px 6px 6px;
  border-radius: 12px;
}
.address-page .slot7-reels {
  gap: 6px;
}
.address-page .slot7-reel-window {
  height: 34px;
  border-radius: 10px;
}
.address-page .slot7-reel-track {
  gap: 4px;
  padding: 4px 0;
}
.address-page .slot7-reel-track-a {
  animation: slot7SpinACompact 1.9s linear infinite;
}
.address-page .slot7-reel-track-b {
  animation: slot7SpinBCompact 1.65s linear infinite;
}
.address-page .slot7-reel-track-c {
  animation: slot7SpinCCompact 2.15s linear infinite;
}
.address-page .slot7-mini-icon {
  width: 18px;
  height: 18px;
}
.address-page .slot7-mini-icon-shield {
  font-size: 0.7rem;
}
.address-page .slot7-mini-icon-chip {
  font-size: 0.64rem;
}
.address-page .slot7-mini-icon-diamond {
  width: 15px;
  height: 15px;
  border-radius: 4px;
}
.address-page .slot7-machine-lever {
  right: 6px;
  top: 4px;
  width: 14px;
  height: 40px;
  animation: slot7LeverPullCompact 3.3s ease-in-out infinite;
}
.address-page .slot7-machine-lever::before {
  left: 5px;
  width: 3px;
  height: 26px;
}
.address-page .slot7-machine-knob {
  left: 0;
  width: 11px;
  height: 11px;
}
.address-page .slot7-machine-base {
  margin-top: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  color: #f34f4f;
  font-size: 0.86rem;
  font-weight: 1000;
  letter-spacing: 0.02em;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.95), 0 4px 8px rgba(243, 79, 79, 0.18);
}
.address-page .slot7-machine-base span {
  display: inline-block;
  animation: slot7JackpotHop 1.15s ease-in-out infinite;
}
.address-page .slot7-machine-base span:nth-child(2) { animation-delay: 0.05s; }
.address-page .slot7-machine-base span:nth-child(3) { animation-delay: 0.1s; }
.address-page .slot7-machine-base span:nth-child(4) { animation-delay: 0.15s; }
.address-page .slot7-machine-base span:nth-child(5) { animation-delay: 0.2s; }
.address-page .slot7-machine-base span:nth-child(6) { animation-delay: 0.25s; }
.address-page .slot7-machine-base span:nth-child(7) { animation-delay: 0.3s; }
.address-page .slot7-machine-base span:nth-child(8) { animation-delay: 0.35s; }
.address-page .slot7-machine-base span:nth-child(9) { animation-delay: 0.4s; }
.address-page .slot7-machine-base span:nth-child(10) { animation-delay: 0.45s; }
.address-page .slot7-machine-base span:nth-child(11) { animation-delay: 0.5s; }
.address-page .slot7-machine-base span:nth-child(12) { animation-delay: 0.55s; }
.address-page .slot7-machine-base span:nth-child(13) { animation-delay: 0.6s; }
@keyframes slot7SpinACompact {
  0% { transform: translateY(0); }
  100% { transform: translateY(-66px); }
}
@keyframes slot7SpinBCompact {
  0% { transform: translateY(-22px); }
  100% { transform: translateY(-88px); }
}
@keyframes slot7SpinCCompact {
  0% { transform: translateY(-44px); }
  100% { transform: translateY(-110px); }
}
@keyframes slot7LeverPullCompact {
  0%, 100% { transform: rotate(0deg); }
  18% { transform: rotate(14deg); }
  34% { transform: rotate(18deg); }
  56% { transform: rotate(2deg); }
}
@keyframes slot7JackpotHop {
  0%, 100% {
    transform: translateY(0) scale(1);
  }
  30% {
    transform: translateY(-2px) scale(1.05);
  }
  55% {
    transform: translateY(1px) scale(0.98);
  }
}
@media (max-width: 1180px) {
  .address-page .slot7-banner-panel {
    min-height: 116px;
    height: auto;
  }
  .address-page .slot7-banner-grid {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 8px 10px 10px;
  }
  .address-page .slot7-copy-strip {
    min-height: 62px;
  }
  .address-page .slot7-machine-block {
    justify-items: start;
  }
}
@media (max-width: 760px) {
  .address-page .slot7-banner-panel {
    min-height: 182px;
  }
  .address-page .slot7-copy-strip {
    height: auto;
    grid-template-columns: 1fr;
  }
  .address-page .slot7-copy-card {
    padding: 8px 10px;
  }
  .address-page .slot7-copy-card::after {
    display: none;
  }
  .address-page .slot7-brand-wordmark {
    font-size: 1.34rem;
  }
  .address-page .slot7-brand-slogan {
    white-space: normal;
    letter-spacing: 0.12em;
  }
  .address-page .slot7-machine-shell {
    width: min(100%, 220px);
  }
}
@media (prefers-reduced-motion: reduce) {
  .address-page .slot7-reel-track-a,
  .address-page .slot7-reel-track-b,
  .address-page .slot7-reel-track-c,
  .address-page .slot7-machine-lever,
  .address-page .slot7-machine-base span {
    animation: none;
  }
}

/* third banner v16: unified background + more text room */
.address-page .slot7-banner-grid {
  grid-template-columns: minmax(0, 1fr) 188px;
  gap: 8px;
  padding: 4px 8px;
}
.address-page .slot7-copy-strip {
  grid-template-columns: minmax(0, 1.22fr) minmax(0, 1fr) minmax(0, 1.04fr);
  border-radius: 14px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.94), rgba(244, 251, 255, 0.92) 42%, rgba(239, 248, 255, 0.9) 100%);
  border-color: rgba(163, 210, 245, 0.62);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.98), inset 0 -1px 0 rgba(177, 218, 247, 0.18);
}
.address-page .slot7-copy-card {
  gap: 1px;
  padding: 4px 10px;
  background: transparent;
  overflow: visible;
}
.address-page .slot7-copy-card::after {
  width: 0;
  background: none;
}
.address-page .slot7-brand-lockup {
  grid-template-columns: 62px minmax(0, 1fr);
  gap: 8px;
}
.address-page .slot7-logo-mark {
  width: 62px;
  height: 40px;
}
.address-page .slot7-logo-shield {
  width: 38px;
  height: 36px;
}
.address-page .slot7-logo-seven {
  left: 12px;
  top: 4px;
  font-size: 1.48rem;
}
.address-page .slot7-logo-ring {
  left: 8px;
  top: 17px;
  width: 22px;
  height: 7px;
}
.address-page .slot7-logo-t {
  left: 17px;
  top: 16px;
  font-size: 0.74rem;
}
.address-page .slot7-brand-wordmark {
  font-size: 1.28rem;
}
.address-page .slot7-brand-slogan {
  font-size: 0.68rem;
  letter-spacing: 0.16em;
}
.address-page .slot7-license-head {
  gap: 5px;
}
.address-page .slot7-license-badge {
  height: 16px;
}
.address-page .slot7-license-badge-shield {
  width: 16px;
  font-size: 0.64rem;
}
.address-page .slot7-license-badge-gcb {
  min-width: 32px;
  font-size: 0.64rem;
}
.address-page .slot7-copy-title,
.address-page .slot7-trust-title {
  gap: 5px;
  font-size: 0.74rem;
  line-height: 1;
}
.address-page .slot7-copy-sub,
.address-page .slot7-trust-sub {
  font-size: 0.62rem;
  line-height: 1.02;
}
.address-page .slot7-trust-mark {
  width: 16px;
  height: 16px;
  font-size: 0.64rem;
}
.address-page .slot7-trust-tags {
  gap: 4px;
}
.address-page .slot7-tag {
  padding: 1px 5px;
  font-size: 0.54rem;
}
.address-page .slot7-machine-shell {
  width: 188px;
  padding: 1px 7px 0;
  gap: 2px;
}
.address-page .slot7-machine-head {
  min-width: 66px;
  min-height: 16px;
  padding: 0 8px;
  font-size: 0.56rem;
}
.address-page .slot7-machine-body {
  padding: 5px 17px 5px 5px;
}
.address-page .slot7-reels {
  gap: 5px;
}
.address-page .slot7-reel-window {
  height: 30px;
}
.address-page .slot7-reel-track {
  gap: 3px;
  padding: 3px 0;
}
.address-page .slot7-mini-icon {
  width: 16px;
  height: 16px;
}
.address-page .slot7-mini-icon-shield {
  font-size: 0.62rem;
}
.address-page .slot7-mini-icon-chip {
  font-size: 0.58rem;
}
.address-page .slot7-mini-icon-diamond {
  width: 13px;
  height: 13px;
}
.address-page .slot7-machine-lever {
  right: 5px;
  top: 3px;
  width: 12px;
  height: 34px;
}
.address-page .slot7-machine-lever::before {
  left: 4px;
  height: 22px;
}
.address-page .slot7-machine-knob {
  width: 10px;
  height: 10px;
}
.address-page .slot7-machine-base {
  font-size: 0.78rem;
}
@media (max-width: 1180px) {
  .address-page .slot7-banner-grid {
    grid-template-columns: 1fr;
    padding: 8px 10px 10px;
  }
  .address-page .slot7-machine-shell {
    width: 188px;
  }
}

/* third banner v17: top-aligned copy + glass money bag + smaller slot */
.address-page .slot7-banner-grid {
  grid-template-columns: minmax(0, 1fr) 58px 168px;
  gap: 6px;
  align-items: start;
  padding: 3px 8px 2px;
}
.address-page .slot7-copy-strip {
  align-self: start;
  height: auto;
  border: 0;
  border-radius: 12px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.72), rgba(245, 251, 255, 0.68) 44%, rgba(239, 248, 255, 0.64) 100%);
  box-shadow: none;
}
.address-page .slot7-copy-card {
  align-content: start;
  padding: 2px 9px 1px;
}
.address-page .slot7-brand-lockup {
  align-items: start;
}
.address-page .slot7-brand-copy {
  align-content: start;
}
.address-page .slot7-brand-wordmark {
  font-size: 1.22rem;
}
.address-page .slot7-brand-slogan {
  font-size: 0.64rem;
  letter-spacing: 0.12em;
}
.address-page .slot7-copy-title,
.address-page .slot7-trust-title {
  font-size: 0.7rem;
}
.address-page .slot7-copy-sub,
.address-page .slot7-trust-sub {
  font-size: 0.58rem;
  line-height: 1;
}
.address-page .slot7-trust-tags {
  margin-top: 0;
}
.address-page .slot7-tag {
  font-size: 0.5rem;
}
.address-page .slot7-money-bag-block {
  align-self: center;
  justify-self: center;
  width: 58px;
  display: grid;
  justify-items: center;
}
.address-page .slot7-money-bag {
  position: relative;
  width: 44px;
  height: 52px;
  animation: slot7BagFloat 4.2s ease-in-out infinite;
}
.address-page .slot7-money-bag-core {
  position: absolute;
  left: 4px;
  right: 4px;
  bottom: 1px;
  top: 14px;
  border-radius: 18px 18px 14px 14px;
  background: linear-gradient(180deg, rgba(255,255,255,0.54), rgba(214,235,255,0.28));
  border: 1px solid rgba(255,255,255,0.44);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.66), inset 0 -8px 14px rgba(134,186,255,0.14), 0 10px 18px rgba(113,171,224,0.16);
  backdrop-filter: blur(10px);
}
.address-page .slot7-money-bag-core::before {
  content: '';
  position: absolute;
  left: 8px;
  right: 8px;
  top: 8px;
  height: 14px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(255,255,255,0.42), rgba(255,255,255,0));
}
.address-page .slot7-money-bag-neck {
  position: absolute;
  left: 14px;
  top: 8px;
  width: 16px;
  height: 12px;
  border-radius: 7px 7px 4px 4px;
  background: linear-gradient(180deg, rgba(255,255,255,0.58), rgba(191,223,255,0.34));
  border: 1px solid rgba(255,255,255,0.42);
}
.address-page .slot7-money-bag-knot {
  position: absolute;
  left: 10px;
  top: 15px;
  width: 24px;
  height: 5px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(129,195,246,0.94), rgba(72,147,219,0.94));
  box-shadow: 0 2px 6px rgba(76, 145, 214, 0.18);
}
.address-page .slot7-money-bag-symbol {
  position: absolute;
  left: 50%;
  top: 31px;
  transform: translate(-50%, -50%);
  color: rgba(91, 173, 240, 0.94);
  font-size: 1rem;
  font-weight: 1000;
  line-height: 1;
  text-shadow: 0 1px 0 rgba(255,255,255,0.7);
}
.address-page .slot7-money-bag-coin {
  position: absolute;
  border-radius: 999px;
  background: linear-gradient(145deg, rgba(255,255,255,0.72), rgba(183,218,255,0.48));
  border: 1px solid rgba(255,255,255,0.44);
  box-shadow: 0 4px 8px rgba(127, 171, 224, 0.12);
}
.address-page .slot7-money-bag-coin-a {
  width: 12px;
  height: 12px;
  right: 0;
  bottom: 9px;
}
.address-page .slot7-money-bag-coin-b {
  width: 8px;
  height: 8px;
  left: 2px;
  bottom: 13px;
}
.address-page .slot7-machine-shell {
  width: 168px;
  padding: 1px 6px 0;
}
.address-page .slot7-machine-head {
  min-width: 58px;
  min-height: 15px;
  font-size: 0.52rem;
}
.address-page .slot7-machine-body {
  padding: 4px 15px 4px 4px;
  border-radius: 10px;
}
.address-page .slot7-reels {
  gap: 4px;
}
.address-page .slot7-reel-window {
  height: 27px;
  border-radius: 8px;
}
.address-page .slot7-reel-track {
  gap: 3px;
  padding: 2px 0;
}
.address-page .slot7-machine-lever {
  top: 2px;
  right: 4px;
  width: 11px;
  height: 30px;
}
.address-page .slot7-machine-lever::before {
  left: 4px;
  height: 20px;
}
.address-page .slot7-machine-knob {
  width: 9px;
  height: 9px;
}
.address-page .slot7-machine-base {
  font-size: 0.72rem;
}
@keyframes slot7BagFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-3px); }
}
@media (max-width: 1180px) {
  .address-page .slot7-banner-grid {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 8px 10px 10px;
  }
  .address-page .slot7-money-bag-block {
    display: none;
  }
  .address-page .slot7-machine-shell {
    width: 168px;
  }
}
@media (max-width: 760px) {
  .address-page .slot7-copy-strip {
    grid-template-columns: 1fr;
  }
}
@media (prefers-reduced-motion: reduce) {
  .address-page .slot7-money-bag {
    animation: none;
  }
}

/* third banner v18: larger copy + matching 7t mini logos + refined bag */
.address-page .slot7-banner-grid {
  grid-template-columns: minmax(0, 1fr) 50px 148px;
  gap: 4px;
}
.address-page .slot7-copy-strip {
  grid-template-columns: minmax(0, 1.22fr) minmax(0, 1fr) minmax(0, 1.08fr);
}
.address-page .slot7-copy-card {
  padding: 1px 8px 0;
}
.address-page .slot7-brand-wordmark {
  font-size: 1.34rem;
}
.address-page .slot7-brand-slogan {
  font-size: 0.68rem;
  letter-spacing: 0.13em;
}
.address-page .slot7-license-head {
  gap: 4px;
  margin-bottom: 1px;
}
.address-page .slot7-copy-title,
.address-page .slot7-trust-title {
  font-size: 0.76rem;
  gap: 4px;
}
.address-page .slot7-copy-sub,
.address-page .slot7-trust-sub {
  font-size: 0.61rem;
}
.address-page .slot7-trust-tags {
  gap: 3px;
}
.address-page .slot7-tag {
  font-size: 0.52rem;
}
.address-page .slot7-mini-logo {
  position: relative;
  display: inline-block;
  width: 22px;
  height: 24px;
  flex: 0 0 auto;
}
.address-page .slot7-mini-logo-shield {
  position: absolute;
  inset: 0;
  border-radius: 5px;
  background: linear-gradient(180deg, #7ec8ff 0%, #52b2ef 58%, #79a0ff 100%);
  clip-path: polygon(16% 0, 84% 0, 100% 34%, 50% 100%, 0 34%);
  box-shadow: 0 3px 8px rgba(97, 165, 228, 0.22);
}
.address-page .slot7-mini-logo-seven {
  position: absolute;
  left: 6px;
  top: 2px;
  color: #ffffff;
  font-size: 0.9rem;
  font-weight: 1000;
  line-height: 1;
}
.address-page .slot7-mini-logo-ring {
  position: absolute;
  right: 1px;
  bottom: 4px;
  width: 9px;
  height: 9px;
  border-radius: 999px;
  border: 1.6px solid rgba(255, 255, 255, 0.98);
  background: rgba(124, 198, 255, 0.14);
}
.address-page .slot7-mini-logo-t {
  position: absolute;
  right: 3px;
  bottom: 5px;
  color: #ffffff;
  font-size: 0.38rem;
  font-weight: 1000;
  line-height: 1;
}
.address-page .slot7-license-badge-gcb {
  min-width: 30px;
  height: 15px;
  padding: 0 5px;
  font-size: 0.6rem;
}
.address-page .slot7-trust-mark {
  display: none;
}
.address-page .slot7-money-bag-block {
  width: 50px;
}
.address-page .slot7-money-bag {
  width: 38px;
  height: 50px;
}
.address-page .slot7-money-bag-core {
  left: 3px;
  right: 3px;
  top: 16px;
  bottom: 1px;
  border-radius: 16px 16px 12px 12px;
  background: linear-gradient(180deg, rgba(229, 248, 255, 0.92) 0%, rgba(165, 216, 255, 0.34) 54%, rgba(115, 188, 255, 0.18) 100%);
  border: 1px solid rgba(255,255,255,0.62);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.74), inset 0 -10px 14px rgba(88,154,229,0.14), 0 8px 16px rgba(103,161,222,0.14);
}
.address-page .slot7-money-bag-core::before {
  left: 6px;
  right: 6px;
  top: 6px;
  height: 15px;
  background: linear-gradient(180deg, rgba(255,255,255,0.66), rgba(255,255,255,0));
}
.address-page .slot7-money-bag-core::after {
  content: '';
  position: absolute;
  left: 50%;
  top: 52%;
  width: 18px;
  height: 18px;
  transform: translate(-50%, -50%);
  border-radius: 999px;
  background: radial-gradient(circle at 32% 32%, rgba(255,255,255,0.64), rgba(179,220,255,0.22) 56%, rgba(120,182,240,0.08) 100%);
  border: 1px solid rgba(255,255,255,0.46);
}
.address-page .slot7-money-bag-neck {
  left: 11px;
  top: 9px;
  width: 16px;
  height: 10px;
  border-radius: 9px 9px 4px 4px;
  background: linear-gradient(180deg, rgba(237, 251, 255, 0.92), rgba(179, 226, 255, 0.42));
}
.address-page .slot7-money-bag-knot {
  left: 8px;
  top: 15px;
  width: 22px;
  height: 4px;
  background: linear-gradient(90deg, #77c9ff, #3f9de3);
}
.address-page .slot7-money-bag-symbol {
  top: 32px;
  font-size: 0.92rem;
  color: rgba(80, 161, 230, 0.96);
}
.address-page .slot7-money-bag-coin-a {
  width: 10px;
  height: 10px;
  right: -1px;
  bottom: 9px;
}
.address-page .slot7-money-bag-coin-b {
  width: 7px;
  height: 7px;
  left: 0;
  bottom: 13px;
}
.address-page .slot7-machine-shell {
  width: 148px;
  padding: 1px 5px 0;
}
.address-page .slot7-machine-head {
  min-width: 54px;
  min-height: 14px;
  font-size: 0.48rem;
}
.address-page .slot7-machine-body {
  padding: 3px 13px 3px 3px;
}
.address-page .slot7-reels {
  gap: 3px;
}
.address-page .slot7-reel-window {
  height: 25px;
}
.address-page .slot7-mini-icon {
  width: 15px;
  height: 15px;
}
.address-page .slot7-mini-icon-shield {
  font-size: 0.56rem;
}
.address-page .slot7-mini-icon-chip {
  font-size: 0.52rem;
}
.address-page .slot7-mini-icon-diamond {
  width: 12px;
  height: 12px;
}
.address-page .slot7-machine-lever {
  width: 10px;
  height: 28px;
}
.address-page .slot7-machine-lever::before {
  height: 18px;
}
.address-page .slot7-machine-knob {
  width: 8px;
  height: 8px;
}
.address-page .slot7-machine-base {
  font-size: 0.68rem;
}
@media (max-width: 1180px) {
  .address-page .slot7-banner-grid {
    grid-template-columns: 1fr;
  }
  .address-page .slot7-money-bag-block {
    display: none;
  }
  .address-page .slot7-machine-shell {
    width: 148px;
  }
}

/* third banner v19: reference-style icons, glass bag, and smaller slot */
.address-page .slot7-banner-grid {
  grid-template-columns: minmax(0, 1fr) 46px 138px;
  gap: 4px;
}
.address-page .slot7-copy-strip {
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr) minmax(0, 1.1fr);
}
.address-page .slot7-copy-title,
.address-page .slot7-trust-title {
  font-size: 0.78rem;
}
.address-page .slot7-copy-sub,
.address-page .slot7-trust-sub {
  font-size: 0.62rem;
}
.address-page .slot7-mini-logo {
  width: 24px;
  height: 26px;
}
.address-page .slot7-mini-logo-shield {
  border-radius: 0;
  background: linear-gradient(180deg, #77c6ff 0%, #57b4ef 56%, #7fa8ff 100%);
  clip-path: polygon(0 0, 100% 0, 100% 72%, 50% 100%, 0 72%);
  box-shadow: 0 3px 8px rgba(97, 165, 228, 0.22);
}
.address-page .slot7-mini-logo-seven {
  left: 6px;
  top: 2px;
  font-size: 1rem;
}
.address-page .slot7-mini-logo-ring {
  right: -1px;
  bottom: 1px;
  width: 10px;
  height: 10px;
  border-width: 1.5px;
  background: rgba(255, 255, 255, 0.12);
}
.address-page .slot7-mini-logo-t {
  right: 2px;
  bottom: 2px;
  font-size: 0.42rem;
}
.address-page .slot7-money-bag-block {
  width: 46px;
}
.address-page .slot7-money-bag {
  width: 34px;
  height: 48px;
}
.address-page .slot7-money-bag-core {
  left: 2px;
  right: 2px;
  top: 15px;
  bottom: 0;
  border-radius: 12px 12px 11px 11px;
  background: linear-gradient(180deg, rgba(242,252,255,0.98) 0%, rgba(174,225,255,0.42) 54%, rgba(76,177,255,0.24) 100%);
  border: 1px solid rgba(255,255,255,0.78);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.92), inset 0 -9px 12px rgba(86,164,243,0.18), 0 8px 14px rgba(111,173,230,0.14);
}
.address-page .slot7-money-bag-core::before {
  left: 4px;
  right: 4px;
  top: 5px;
  height: 16px;
  background: linear-gradient(180deg, rgba(255,255,255,0.78), rgba(255,255,255,0));
}
.address-page .slot7-money-bag-core::after {
  width: 16px;
  height: 16px;
  top: 55%;
  background: radial-gradient(circle at 32% 32%, rgba(255,255,255,0.66), rgba(178,220,255,0.28) 56%, rgba(120,182,240,0.12) 100%);
}
.address-page .slot7-money-bag-neck {
  left: 9px;
  top: 8px;
  width: 16px;
  height: 9px;
  border: 1px solid rgba(255,255,255,0.56);
}
.address-page .slot7-money-bag-knot {
  left: 6px;
  top: 14px;
  width: 22px;
  height: 5px;
  border-radius: 999px;
  background: linear-gradient(180deg, #5daeff 0%, #2f7fe6 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.3), 0 2px 5px rgba(51, 119, 214, 0.18);
}
.address-page .slot7-money-bag-symbol {
  top: 31px;
  font-size: 1rem;
  color: rgba(85, 166, 236, 0.9);
  text-shadow: 0 1px 0 rgba(255,255,255,0.8);
}
.address-page .slot7-money-bag-coin-a,
.address-page .slot7-money-bag-coin-b {
  display: none;
}
.address-page .slot7-machine-shell {
  width: 138px;
  padding: 1px 4px 0;
}
.address-page .slot7-machine-head {
  min-width: 50px;
  min-height: 13px;
  font-size: 0.45rem;
}
.address-page .slot7-machine-body {
  padding: 3px 12px 3px 3px;
}
.address-page .slot7-reel-window {
  height: 23px;
}
.address-page .slot7-mini-icon {
  width: 14px;
  height: 14px;
}
.address-page .slot7-mini-icon-shield {
  font-size: 0.52rem;
}
.address-page .slot7-mini-icon-chip {
  font-size: 0.48rem;
}
.address-page .slot7-mini-icon-diamond {
  width: 11px;
  height: 11px;
}
.address-page .slot7-machine-lever {
  width: 9px;
  height: 26px;
}
.address-page .slot7-machine-lever::before {
  height: 17px;
}
.address-page .slot7-machine-knob {
  width: 7px;
  height: 7px;
}
.address-page .slot7-machine-base {
  font-size: 0.64rem;
  letter-spacing: 0.04em;
}
.address-page .slot7-machine-base span {
  animation: none;
}
@media (max-width: 1180px) {
  .address-page .slot7-banner-grid {
    grid-template-columns: 1fr;
  }
  .address-page .slot7-money-bag-block {
    display: none;
  }
  .address-page .slot7-machine-shell {
    width: 138px;
  }
}

/* third banner v20: no copy panel fill, rounded-bottom icons, tighter slot */
.address-page .slot7-copy-strip {
  background: transparent;
  border: 0;
  box-shadow: none;
}
.address-page .slot7-copy-card {
  background: transparent;
}
.address-page .slot7-logo-shield,
.address-page .slot7-mini-logo-shield {
  clip-path: none;
  border-radius: 0 0 12px 12px;
  overflow: hidden;
}
.address-page .slot7-logo-shield::after,
.address-page .slot7-mini-logo-shield::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: -28%;
  height: 58%;
  background: linear-gradient(180deg, rgba(122, 201, 255, 0.96) 0%, rgba(122, 168, 255, 0.96) 100%);
  border-radius: 0 0 999px 999px;
}
.address-page .slot7-logo-shield::before,
.address-page .slot7-mini-logo-shield::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(119, 198, 255, 0.98) 0%, rgba(87, 180, 239, 0.96) 60%, rgba(127, 168, 255, 0.98) 100%);
}
.address-page .slot7-logo-shield,
.address-page .slot7-mini-logo-shield {
  background: none;
}
.address-page .slot7-logo-seven,
.address-page .slot7-logo-ring,
.address-page .slot7-logo-t,
.address-page .slot7-mini-logo-seven,
.address-page .slot7-mini-logo-ring,
.address-page .slot7-mini-logo-t {
  z-index: 1;
}
.address-page .slot7-logo-ring {
  bottom: 0;
  top: auto;
}
.address-page .slot7-logo-t {
  bottom: 2px;
  top: auto;
}
.address-page .slot7-mini-logo-ring {
  bottom: 0;
}
.address-page .slot7-mini-logo-t {
  bottom: 1px;
}
.address-page .slot7-machine-block {
  align-self: start;
  margin-top: -2px;
}
.address-page .slot7-machine-shell {
  width: 130px;
  padding: 1px 4px 1px;
}
.address-page .slot7-machine-head {
  min-width: 46px;
  min-height: 12px;
  font-size: 0.43rem;
}
.address-page .slot7-machine-body {
  padding: 2px 11px 2px 2px;
}
.address-page .slot7-reels {
  gap: 2px;
}
.address-page .slot7-reel-window {
  height: 22px;
}
.address-page .slot7-mini-icon {
  width: 13px;
  height: 13px;
}
.address-page .slot7-mini-icon-shield {
  font-size: 0.48rem;
}
.address-page .slot7-mini-icon-chip {
  font-size: 0.44rem;
}
.address-page .slot7-mini-icon-diamond {
  width: 10px;
  height: 10px;
}
.address-page .slot7-machine-lever {
  width: 8px;
  height: 24px;
  top: 1px;
}
.address-page .slot7-machine-lever::before {
  left: 3px;
  height: 16px;
}
.address-page .slot7-machine-knob {
  width: 7px;
  height: 7px;
}
.address-page .slot7-machine-base {
  margin-top: 1px;
  min-height: 10px;
  padding: 0 1px;
  overflow: visible;
  white-space: nowrap;
  font-size: 0.56rem;
  letter-spacing: 0.01em;
  line-height: 1;
  transform: scale(0.98);
  transform-origin: center top;
}
@media (max-width: 1180px) {
  .address-page .slot7-machine-shell {
    width: 130px;
  }
}

/* third banner v21: aligned front icons, shifted bag, clearly changing jackpot */
.address-page .slot7-copy-card-license,
.address-page .slot7-copy-card-trust {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr);
  column-gap: 8px;
  align-content: start;
}
.address-page .slot7-copy-card-body {
  min-width: 0;
  display: grid;
  align-content: start;
  gap: 0;
}
.address-page .slot7-copy-card-icon {
  align-self: start;
  justify-self: start;
  margin-top: 1px;
}
.address-page .slot7-license-head {
  min-height: 15px;
  display: flex;
  align-items: center;
  margin-bottom: 0;
}
.address-page .slot7-trust-title {
  min-height: 15px;
  display: flex;
  align-items: center;
}
.address-page .slot7-logo-ring {
  right: 1px;
  left: auto;
  bottom: 1px;
  width: 12px;
  height: 12px;
  top: auto;
}
.address-page .slot7-logo-t {
  right: 4px;
  left: auto;
  bottom: 3px;
  top: auto;
  font-size: 0.5rem;
}
.address-page .slot7-mini-logo-ring {
  right: -1px;
  bottom: 0;
  width: 10px;
  height: 10px;
}
.address-page .slot7-mini-logo-t {
  right: 2px;
  bottom: 2px;
  font-size: 0.42rem;
}
.address-page .slot7-money-bag-block {
  width: 42px;
  margin-left: -8px;
}
.address-page .slot7-money-bag {
  width: 32px;
}
.address-page .slot7-machine-block {
  margin-top: -4px;
}
.address-page .slot7-machine-shell {
  width: 126px;
}
.address-page .slot7-machine-base {
  margin-top: 2px;
  min-height: 11px;
  padding: 0;
  font-size: 0.58rem;
  transform: none;
}
@media (max-width: 1180px) {
  .address-page .slot7-machine-shell {
    width: 126px;
  }
}

/* third banner v22: clearer first logo, larger copy, flipping icons, pouch bag */
.address-page .slot7-brand-lockup {
  grid-template-columns: 68px minmax(0, 1fr);
  gap: 10px;
}
.address-page .slot7-logo-mark {
  width: 68px;
  height: 48px;
  perspective: 500px;
  animation: slot7CoinFlip 3.6s ease-in-out infinite;
  transform-style: preserve-3d;
}
.address-page .slot7-logo-shield {
  width: 46px;
  height: 46px;
  border-radius: 8px 8px 16px 16px;
}
.address-page .slot7-logo-seven {
  left: 10px;
  top: 3px;
  font-size: 1.62rem;
}
.address-page .slot7-logo-ring {
  right: 0;
  bottom: 1px;
  width: 13px;
  height: 13px;
}
.address-page .slot7-logo-t {
  right: 3px;
  bottom: 4px;
  font-size: 0.52rem;
}
.address-page .slot7-copy-card-license,
.address-page .slot7-copy-card-trust {
  grid-template-columns: 28px minmax(0, 1fr);
  column-gap: 8px;
}
.address-page .slot7-copy-card-icon {
  width: 28px;
  height: 30px;
  margin-top: 0;
  perspective: 500px;
  animation: slot7CoinFlip 3.6s ease-in-out infinite;
  transform-style: preserve-3d;
}
.address-page .slot7-copy-card-trust .slot7-copy-card-icon {
  animation-delay: 0.28s;
}
.address-page .slot7-copy-card-license .slot7-copy-card-icon {
  animation-delay: 0.14s;
}
.address-page .slot7-mini-logo-shield {
  border-radius: 6px 6px 12px 12px;
}
.address-page .slot7-mini-logo-seven {
  left: 7px;
  top: 2px;
  font-size: 1.06rem;
}
.address-page .slot7-mini-logo-ring {
  right: -1px;
  bottom: 0;
  width: 11px;
  height: 11px;
}
.address-page .slot7-mini-logo-t {
  right: 2px;
  bottom: 2px;
  font-size: 0.44rem;
}
.address-page .slot7-brand-wordmark {
  font-size: 1.42rem;
}
.address-page .slot7-brand-slogan {
  font-size: 0.74rem;
  letter-spacing: 0.12em;
}
.address-page .slot7-copy-title,
.address-page .slot7-trust-title {
  font-size: 0.84rem;
  line-height: 1.02;
}
.address-page .slot7-copy-sub,
.address-page .slot7-trust-sub {
  font-size: 0.66rem;
  line-height: 1.05;
}
.address-page .slot7-tag {
  font-size: 0.54rem;
}
.address-page .slot7-money-bag-block {
  width: 48px;
  margin-left: -10px;
}
.address-page .slot7-money-bag {
  width: 36px;
  height: 52px;
  animation: slot7BagFloat 4.2s ease-in-out infinite;
}
.address-page .slot7-money-bag-neck {
  left: 13px;
  top: 5px;
  width: 10px;
  height: 10px;
  border-radius: 999px 999px 3px 3px;
  background: linear-gradient(180deg, rgba(236, 248, 255, 0.96), rgba(182, 221, 255, 0.56));
}
.address-page .slot7-money-bag-knot {
  left: 8px;
  top: 13px;
  width: 20px;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(180deg, #6cb8ff 0%, #2f7ee4 100%);
}
.address-page .slot7-money-bag-core {
  left: 2px;
  right: 2px;
  top: 15px;
  bottom: 0;
  border-radius: 9px 9px 16px 16px;
  background: linear-gradient(180deg, rgba(245,253,255,0.98) 0%, rgba(183,228,255,0.42) 52%, rgba(88,184,255,0.24) 100%);
}
.address-page .slot7-money-bag-core::before {
  left: 6px;
  right: 6px;
  top: 6px;
  height: 17px;
}
.address-page .slot7-money-bag-core::after {
  width: 14px;
  height: 18px;
  top: 58%;
}
.address-page .slot7-money-bag-symbol {
  top: 33px;
  font-size: 0.96rem;
}
.address-page .slot7-machine-base {
  font-size: 0.6rem;
}
@keyframes slot7CoinFlip {
  0%, 100% { transform: rotateY(0deg); }
  50% { transform: rotateY(180deg); }
}
@media (prefers-reduced-motion: reduce) {
  .address-page .slot7-logo-mark,
  .address-page .slot7-copy-card-icon,
  .address-page .slot7-money-bag {
    animation: none;
  }
}

/* third banner v23: closer T mark, larger copy, diamond icon */
.address-page .slot7-brand-lockup {
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 10px;
}
.address-page .slot7-logo-mark {
  width: 72px;
  height: 50px;
}
.address-page .slot7-logo-seven {
  left: 10px;
  top: 2px;
  font-size: 1.7rem;
}
.address-page .slot7-logo-ring {
  right: 5px;
  bottom: 2px;
  width: 11px;
  height: 11px;
}
.address-page .slot7-logo-t {
  right: 7px;
  bottom: 4px;
  font-size: 0.46rem;
}
.address-page .slot7-mini-logo-ring {
  right: 1px;
  bottom: 1px;
}
.address-page .slot7-mini-logo-t {
  right: 4px;
  bottom: 3px;
}
.address-page .slot7-brand-wordmark {
  font-size: 1.54rem;
}
.address-page .slot7-brand-slogan {
  font-size: 0.78rem;
}
.address-page .slot7-copy-title,
.address-page .slot7-trust-title {
  font-size: 0.9rem;
}
.address-page .slot7-copy-sub,
.address-page .slot7-trust-sub {
  font-size: 0.7rem;
}
.address-page .slot7-tag {
  font-size: 0.58rem;
}
.address-page .slot7-diamond-block {
  width: 50px;
  margin-left: -8px;
  align-self: center;
  justify-self: center;
  display: grid;
  justify-items: center;
}
.address-page .slot7-diamond-icon {
  position: relative;
  width: 34px;
  height: 42px;
  animation: slot7BagFloat 4.2s ease-in-out infinite;
}
.address-page .slot7-diamond-facet {
  position: absolute;
  display: block;
  background: linear-gradient(180deg, rgba(244,252,255,0.98) 0%, rgba(153,221,255,0.58) 48%, rgba(88,181,255,0.26) 100%);
  border: 1px solid rgba(255,255,255,0.7);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.82);
}
.address-page .slot7-diamond-facet-top {
  left: 7px;
  top: 0;
  width: 20px;
  height: 11px;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
}
.address-page .slot7-diamond-facet-left {
  left: 1px;
  top: 10px;
  width: 16px;
  height: 26px;
  clip-path: polygon(100% 0, 100% 100%, 0 58%);
}
.address-page .slot7-diamond-facet-right {
  right: 1px;
  top: 10px;
  width: 16px;
  height: 26px;
  clip-path: polygon(0 0, 100% 58%, 0 100%);
}
.address-page .slot7-diamond-facet-bottom {
  left: 9px;
  bottom: 0;
  width: 16px;
  height: 17px;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
}
.address-page .slot7-diamond-core {
  position: absolute;
  left: 50%;
  top: 47%;
  width: 12px;
  height: 14px;
  transform: translate(-50%, -50%);
  border-radius: 6px;
  background: radial-gradient(circle at 35% 30%, rgba(255,255,255,0.82), rgba(178,223,255,0.28) 58%, rgba(94,183,255,0.16) 100%);
  border: 1px solid rgba(255,255,255,0.58);
}
@media (prefers-reduced-motion: reduce) {
  .address-page .slot7-diamond-icon {
    animation: none;
  }
}

/* third banner v24: tighter T mark, larger copy, classic diamond, downward slot spin */
.address-page .slot7-brand-wordmark {
  font-size: 1.62rem;
}
.address-page .slot7-brand-slogan {
  font-size: 0.82rem;
}
.address-page .slot7-copy-title,
.address-page .slot7-trust-title {
  font-size: 0.96rem;
}
.address-page .slot7-copy-sub,
.address-page .slot7-trust-sub {
  font-size: 0.74rem;
}
.address-page .slot7-tag {
  font-size: 0.6rem;
}
.address-page .slot7-logo-ring {
  right: 10px;
  bottom: 2px;
  width: 12px;
  height: 12px;
}
.address-page .slot7-logo-t {
  right: 12px;
  bottom: 4px;
  font-size: 0.48rem;
}
.address-page .slot7-mini-logo-ring {
  right: 3px;
  bottom: 1px;
}
.address-page .slot7-mini-logo-t {
  right: 6px;
  bottom: 3px;
}
.address-page .slot7-diamond-block {
  width: 46px;
  margin-left: -10px;
}
.address-page .slot7-diamond-icon {
  width: 36px;
  height: 34px;
}
.address-page .slot7-diamond-facet {
  background: linear-gradient(180deg, rgba(247,253,255,0.98) 0%, rgba(170,228,255,0.62) 46%, rgba(86,186,255,0.28) 100%);
}
.address-page .slot7-diamond-facet-top {
  left: 10px;
  top: 0;
  width: 16px;
  height: 8px;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
}
.address-page .slot7-diamond-facet-left {
  left: 1px;
  top: 7px;
  width: 16px;
  height: 13px;
  clip-path: polygon(100% 0, 100% 100%, 0 30%);
}
.address-page .slot7-diamond-facet-right {
  right: 1px;
  top: 7px;
  width: 16px;
  height: 13px;
  clip-path: polygon(0 0, 100% 30%, 0 100%);
}
.address-page .slot7-diamond-facet-bottom {
  left: 6px;
  bottom: 0;
  width: 24px;
  height: 20px;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
}
.address-page .slot7-diamond-core {
  width: 10px;
  height: 10px;
  top: 40%;
  border-radius: 3px;
}
.address-page .slot7-reel-track-a,
.address-page .slot7-reel-track-b,
.address-page .slot7-reel-track-c {
  animation-direction: reverse;
}
@media (prefers-reduced-motion: reduce) {
  .address-page .slot7-reel-track-a,
  .address-page .slot7-reel-track-b,
  .address-page .slot7-reel-track-c {
    animation-direction: normal;
  }
}

/* third banner v26: tighter 7T lockup + more faceted diamond */
.address-page .slot7-logo-ring {
  right: 7px;
  bottom: 1px;
  width: 12px;
  height: 12px;
}
.address-page .slot7-logo-t {
  right: 9px;
  bottom: 3px;
  font-size: 0.48rem;
}
.address-page .slot7-mini-logo-ring {
  right: 2px;
  bottom: 0;
}
.address-page .slot7-mini-logo-t {
  right: 5px;
  bottom: 2px;
}
.address-page .slot7-diamond-block {
  width: 50px;
  margin-left: -12px;
}
.address-page .slot7-diamond-icon {
  width: 40px;
  height: 30px;
  animation: slot7BagFloat 4.2s ease-in-out infinite;
  filter: drop-shadow(0 8px 12px rgba(89, 168, 236, 0.12));
}
.address-page .slot7-diamond-icon::before {
  content: '';
  position: absolute;
  left: 6px;
  right: 6px;
  top: 12px;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,0.92) 18%, rgba(190,231,255,0.95) 50%, rgba(255,255,255,0.92) 82%, rgba(255,255,255,0));
  box-shadow: 0 0 8px rgba(255,255,255,0.35);
}
.address-page .slot7-diamond-icon::after {
  content: '';
  position: absolute;
  left: 50%;
  top: 4px;
  width: 10px;
  height: 20px;
  transform: translateX(-50%);
  background: linear-gradient(180deg, rgba(255,255,255,0.64), rgba(181,224,255,0.08));
  clip-path: polygon(50% 0, 78% 20%, 64% 100%, 36% 100%, 22% 20%);
  opacity: 0.85;
}
.address-page .slot7-diamond-facet {
  border: 1px solid rgba(255,255,255,0.78);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.9);
}
.address-page .slot7-diamond-facet-top {
  left: 10px;
  top: 0;
  width: 20px;
  height: 7px;
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(189,231,255,0.72));
  clip-path: polygon(12% 0, 88% 0, 100% 100%, 0 100%);
}
.address-page .slot7-diamond-facet-left {
  left: 0;
  top: 6px;
  width: 16px;
  height: 10px;
  background: linear-gradient(135deg, rgba(244,252,255,0.98), rgba(152,220,255,0.34));
  clip-path: polygon(100% 0, 100% 100%, 0 36%);
}
.address-page .slot7-diamond-facet-right {
  right: 0;
  top: 6px;
  width: 16px;
  height: 10px;
  background: linear-gradient(225deg, rgba(244,252,255,0.98), rgba(152,220,255,0.34));
  clip-path: polygon(0 0, 100% 36%, 0 100%);
}
.address-page .slot7-diamond-facet-bottom {
  left: 8px;
  bottom: 0;
  width: 24px;
  height: 18px;
  background: linear-gradient(180deg, rgba(205,236,255,0.74), rgba(79,179,255,0.22));
  clip-path: polygon(0 0, 100% 0, 50% 100%);
}
.address-page .slot7-diamond-core {
  width: 22px;
  height: 12px;
  top: 9px;
  transform: translateX(-50%);
  border-radius: 2px 2px 6px 6px;
  background: linear-gradient(180deg, rgba(255,255,255,0.9), rgba(180,228,255,0.36));
  border: 1px solid rgba(255,255,255,0.74);
  box-shadow: 0 1px 6px rgba(255,255,255,0.24);
}
@media (prefers-reduced-motion: reduce) {
  .address-page .slot7-diamond-icon {
    animation: none;
  }
}

/* third banner v27: centered copy, tighter 7T spacing, clearer diamond */
.address-page .slot7-banner-grid {
  align-items: center;
}
.address-page .slot7-copy-strip {
  align-self: center;
  transform: translateY(5px);
}
.address-page .slot7-copy-card,
.address-page .slot7-copy-card-body,
.address-page .slot7-brand-lockup,
.address-page .slot7-brand-copy {
  align-content: center;
}
.address-page .slot7-logo-ring {
  left: 25px;
  right: auto;
  bottom: 1px;
  width: 13px;
  height: 13px;
}
.address-page .slot7-logo-t {
  left: 29px;
  right: auto;
  bottom: 4px;
  font-size: 0.47rem;
}
.address-page .slot7-mini-logo-ring {
  left: 13px;
  right: auto;
  bottom: 0;
  width: 10px;
  height: 10px;
}
.address-page .slot7-mini-logo-t {
  left: 16px;
  right: auto;
  bottom: 2px;
  font-size: 0.42rem;
}
.address-page .slot7-diamond-block {
  width: 56px;
  margin-left: -8px;
}
.address-page .slot7-diamond-icon {
  width: 44px;
  height: 34px;
  filter: drop-shadow(0 10px 16px rgba(70, 152, 229, 0.16));
}
.address-page .slot7-diamond-icon::before {
  left: 5px;
  right: 5px;
  top: 13px;
  height: 4px;
  background: linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,0.98) 16%, rgba(197,235,255,0.98) 50%, rgba(255,255,255,0.98) 84%, rgba(255,255,255,0));
  box-shadow: 0 0 12px rgba(255,255,255,0.42);
}
.address-page .slot7-diamond-icon::after {
  top: 3px;
  width: 12px;
  height: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,0.82), rgba(184,228,255,0.10));
  clip-path: polygon(50% 0, 82% 18%, 65% 100%, 35% 100%, 18% 18%);
}
.address-page .slot7-diamond-facet {
  border: 1px solid rgba(255,255,255,0.82);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.94);
}
.address-page .slot7-diamond-facet-top {
  left: 11px;
  top: 0;
  width: 22px;
  height: 8px;
  background: linear-gradient(180deg, rgba(255,255,255,1), rgba(198,235,255,0.78));
  clip-path: polygon(8% 0, 92% 0, 100% 100%, 0 100%);
}
.address-page .slot7-diamond-facet-left {
  left: 0;
  top: 7px;
  width: 18px;
  height: 11px;
  background: linear-gradient(135deg, rgba(255,255,255,0.96), rgba(160,222,255,0.42));
  clip-path: polygon(100% 0, 100% 100%, 0 30%);
}
.address-page .slot7-diamond-facet-right {
  right: 0;
  top: 7px;
  width: 18px;
  height: 11px;
  background: linear-gradient(225deg, rgba(255,255,255,0.96), rgba(160,222,255,0.42));
  clip-path: polygon(0 0, 100% 30%, 0 100%);
}
.address-page .slot7-diamond-facet-bottom {
  left: 7px;
  bottom: 0;
  width: 30px;
  height: 21px;
  background: linear-gradient(180deg, rgba(214,240,255,0.84), rgba(84,182,255,0.24));
  clip-path: polygon(0 0, 100% 0, 50% 100%);
}
.address-page .slot7-diamond-core {
  width: 26px;
  height: 13px;
  top: 10px;
  transform: translateX(-50%);
  border-radius: 2px 2px 7px 7px;
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(188,232,255,0.44));
  border: 1px solid rgba(255,255,255,0.82);
  box-shadow: 0 1px 8px rgba(255,255,255,0.28);
}
@media (max-width: 1180px) {
  .address-page .slot7-copy-strip {
    transform: none;
  }
}

/* third banner v28: first flip matches others + trophy icon */
.address-page .slot7-logo-mark,
.address-page .slot7-copy-card-icon {
  perspective: 500px;
  transform-style: preserve-3d;
  transform-origin: center center;
  animation-name: slot7CoinFlip;
  animation-duration: 3.6s;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
}
.address-page .slot7-logo-mark > span,
.address-page .slot7-copy-card-icon > span {
  backface-visibility: hidden;
}
.address-page .slot7-trophy-block {
  width: 54px;
  margin-left: -8px;
  align-self: center;
  justify-self: center;
  display: grid;
  justify-items: center;
}
.address-page .slot7-trophy-icon {
  position: relative;
  width: 34px;
  height: 42px;
  animation: slot7BagFloat 4.2s ease-in-out infinite;
  filter: drop-shadow(0 9px 12px rgba(89, 168, 236, 0.16));
}
.address-page .slot7-trophy-cup {
  position: absolute;
  left: 7px;
  top: 6px;
  width: 20px;
  height: 16px;
  background: linear-gradient(180deg, rgba(255, 248, 226, 0.98), rgba(238, 199, 108, 0.96) 45%, rgba(199, 129, 34, 0.94) 100%);
  clip-path: polygon(0 0, 100% 0, 82% 72%, 56% 100%, 44% 100%, 18% 72%);
  border: 1px solid rgba(255, 236, 186, 0.72);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.58), 0 2px 6px rgba(129, 88, 18, 0.16);
}
.address-page .slot7-trophy-rim {
  position: absolute;
  left: 6px;
  top: 4px;
  width: 22px;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(255, 249, 233, 1), rgba(232, 187, 92, 0.96));
}
.address-page .slot7-trophy-handle {
  position: absolute;
  top: 8px;
  width: 8px;
  height: 11px;
  border: 2px solid rgba(228, 175, 67, 0.96);
  border-top-color: rgba(255, 239, 193, 0.94);
  border-radius: 999px;
  opacity: 0.95;
}
.address-page .slot7-trophy-handle-left {
  left: 2px;
  border-right: 0;
}
.address-page .slot7-trophy-handle-right {
  right: 2px;
  border-left: 0;
}
.address-page .slot7-trophy-stem {
  position: absolute;
  left: 14px;
  top: 22px;
  width: 6px;
  height: 9px;
  border-radius: 3px;
  background: linear-gradient(180deg, rgba(255, 246, 216, 0.98), rgba(216, 153, 48, 0.96));
}
.address-page .slot7-trophy-base {
  position: absolute;
  left: 9px;
  bottom: 2px;
  width: 16px;
  height: 7px;
  border-radius: 5px 5px 7px 7px;
  background: linear-gradient(180deg, rgba(205, 136, 35, 0.98), rgba(120, 75, 14, 0.98));
  box-shadow: inset 0 1px 0 rgba(255, 224, 156, 0.36);
}
.address-page .slot7-trophy-shine {
  position: absolute;
  left: 12px;
  top: 8px;
  width: 6px;
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(255,255,255,0.78), rgba(255,255,255,0));
  transform: rotate(16deg);
}
@media (prefers-reduced-motion: reduce) {
  .address-page .slot7-trophy-icon {
    animation: none;
  }
}

/* third banner v29: no-disappear flip + podium icon */
@keyframes slot7CoinFlip {
  0%, 100% {
    transform: rotateY(0deg) scaleX(1);
  }
  18% {
    transform: rotateY(50deg) scaleX(0.82);
  }
  34% {
    transform: rotateY(88deg) scaleX(0.62);
  }
  50% {
    transform: rotateY(180deg) scaleX(0.92);
  }
  66% {
    transform: rotateY(268deg) scaleX(0.62);
  }
  82% {
    transform: rotateY(320deg) scaleX(0.82);
  }
}
.address-page .slot7-logo-mark,
.address-page .slot7-copy-card-icon {
  backface-visibility: visible;
}
.address-page .slot7-logo-mark > span,
.address-page .slot7-copy-card-icon > span {
  backface-visibility: visible;
}
.address-page .slot7-podium-block {
  width: 56px;
  margin-left: -8px;
  align-self: center;
  justify-self: center;
  display: grid;
  justify-items: center;
}
.address-page .slot7-podium-icon {
  position: relative;
  width: 40px;
  height: 34px;
  animation: slot7BagFloat 4.2s ease-in-out infinite;
  filter: drop-shadow(0 9px 12px rgba(89, 168, 236, 0.14));
}
.address-page .slot7-podium-step {
  position: absolute;
  bottom: 0;
  display: grid;
  place-items: center;
  border-radius: 7px 7px 3px 3px;
  background: linear-gradient(180deg, rgba(250, 252, 255, 0.98), rgba(173, 221, 255, 0.56) 46%, rgba(93, 180, 244, 0.28) 100%);
  border: 1px solid rgba(255,255,255,0.72);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.9), 0 6px 10px rgba(81, 147, 210, 0.14);
}
.address-page .slot7-podium-step i {
  font-style: normal;
  color: #5ba8e6;
  font-size: 0.72rem;
  font-weight: 1000;
  line-height: 1;
  text-shadow: 0 1px 0 rgba(255,255,255,0.75);
}
.address-page .slot7-podium-step-left {
  left: 0;
  width: 12px;
  height: 16px;
}
.address-page .slot7-podium-step-center {
  left: 50%;
  width: 14px;
  height: 24px;
  transform: translateX(-50%);
  background: linear-gradient(180deg, rgba(255, 249, 230, 0.98), rgba(236, 198, 106, 0.86) 48%, rgba(193, 128, 36, 0.78) 100%);
}
.address-page .slot7-podium-step-center i {
  color: #ffffff;
  font-size: 0.76rem;
}
.address-page .slot7-podium-step-right {
  right: 0;
  width: 12px;
  height: 12px;
}
@media (prefers-reduced-motion: reduce) {
  .address-page .slot7-podium-icon {
    animation: none;
  }
}

/* final v30: player selection visibility + banner alignment + centered podium */
.address-page ::selection {
  color: #08131a;
  background: rgba(118, 209, 255, 0.58);
  text-shadow: none;
}
.address-page .header-music-player,
.address-page .header-music-player .music-meta,
.address-page .header-music-player .music-title,
.address-page .header-music-player .music-status {
  user-select: text;
  -webkit-user-select: text;
  -webkit-text-fill-color: currentColor;
}
.address-page .header-music-player.is-playing .music-title,
.address-page .header-music-player.is-playing .music-status {
  color: #17313a;
  text-shadow: none;
}
.address-page .header-music-player.is-playing .music-title::selection,
.address-page .header-music-player.is-playing .music-status::selection {
  color: #08131a;
  background: rgba(126, 217, 255, 0.7);
}

.address-page .ad-banner-panel-premium .premium-ad-copy-lane {
  transform: translateY(-5px);
}
.address-page .ad-banner-panel-premium .premium-ad-copy-lane-2,
.address-page .ad-banner-panel-premium .premium-ad-copy-lane-3 {
  transform: translateY(-7px);
}

.address-page .slot7-banner-grid {
  grid-template-columns: minmax(0, 1fr) 74px 138px;
  gap: 8px;
  align-items: center;
}
.address-page .slot7-copy-strip {
  align-self: center;
}
.address-page .slot7-podium-block {
  width: 74px;
  min-width: 74px;
  margin-left: 0;
  place-self: center;
}
.address-page .slot7-podium-icon {
  width: 56px;
  height: 46px;
}
.address-page .slot7-podium-step {
  border-radius: 9px 9px 4px 4px;
}
.address-page .slot7-podium-step i {
  font-size: 0.84rem;
}
.address-page .slot7-podium-step-left {
  width: 16px;
  height: 22px;
}
.address-page .slot7-podium-step-center {
  width: 20px;
  height: 34px;
}
.address-page .slot7-podium-step-center i {
  font-size: 0.9rem;
}
.address-page .slot7-podium-step-right {
  width: 16px;
  height: 18px;
}
.address-page .slot7-machine-block {
  justify-self: end;
}

/* final v31: tighten address page section gaps */
.address-page .address-shell {
  padding-top: 8px;
  padding-bottom: 20px;
  gap: 7px;
}
.address-page .address-primary-grid {
  gap: 7px;
}
.address-page .address-side-rail {
  gap: 7px;
}
@media (max-width: 920px) {
  .address-page .address-shell {
    padding-top: 8px;
    padding-bottom: 18px;
    gap: 7px;
  }
  .address-page .address-primary-grid,
  .address-page .address-side-rail {
    gap: 7px;
  }
}

/* final v32: lift ad copy and sync centered 7T icon flip */
.address-page .ad-banner-panel-premium .premium-ad-copy-lane {
  transform: translateY(-8px);
}
.address-page .ad-banner-panel-premium .premium-ad-copy-lane-2,
.address-page .ad-banner-panel-premium .premium-ad-copy-lane-3 {
  transform: translateY(-10px);
}

.address-page .slot7-copy-strip {
  align-self: center;
  transform: translateY(-4px);
}
.address-page .slot7-brand-lockup {
  grid-template-columns: 54px minmax(0, 1fr);
  gap: 8px;
}
.address-page .slot7-logo-mark {
  width: 46px;
  height: 46px;
  justify-self: center;
  margin: 0 auto;
  transform-origin: 50% 50%;
}
.address-page .slot7-logo-shield {
  width: 46px;
  height: 46px;
}
.address-page .slot7-logo-seven {
  left: 10px;
  top: 2px;
  font-size: 1.68rem;
}
.address-page .slot7-logo-ring {
  right: 0;
  bottom: 1px;
  width: 11px;
  height: 11px;
}
.address-page .slot7-logo-t {
  right: 2px;
  bottom: 3px;
  font-size: 0.46rem;
}

@keyframes slot7CoinFlipV32 {
  0% {
    transform: rotateY(0deg) scaleX(1);
  }
  9% {
    transform: rotateY(320deg) scaleX(0.82);
  }
  18% {
    transform: rotateY(720deg) scaleX(0.62);
  }
  27% {
    transform: rotateY(1120deg) scaleX(0.82);
  }
  36%, 50% {
    transform: rotateY(1440deg) scaleX(1);
  }
  59% {
    transform: rotateY(1760deg) scaleX(0.82);
  }
  68% {
    transform: rotateY(2160deg) scaleX(0.62);
  }
  77% {
    transform: rotateY(2560deg) scaleX(0.82);
  }
  86%, 100% {
    transform: rotateY(2880deg) scaleX(1);
  }
}
.address-page .slot7-logo-mark,
.address-page .slot7-copy-card-icon {
  perspective: 560px;
  transform-origin: 50% 50%;
  transform-style: preserve-3d;
  animation-name: slot7CoinFlipV32;
  animation-duration: 5.6s;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
  animation-delay: 0s;
  will-change: transform;
}
.address-page .slot7-logo-mark > span,
.address-page .slot7-copy-card-icon > span {
  backface-visibility: visible;
}
.address-page .slot7-copy-card-license .slot7-copy-card-icon,
.address-page .slot7-copy-card-trust .slot7-copy-card-icon {
  animation-delay: 0s;
}

@media (max-width: 1180px) {
  .address-page .slot7-copy-strip {
    transform: none;
  }
}

/* final v33: larger closer T marks and faster 7T fast-flip */
.address-page .slot7-logo-ring {
  right: 2px;
}
.address-page .slot7-logo-t {
  right: 3px;
  bottom: 2px;
  font-size: 0.56rem;
}
.address-page .slot7-mini-logo-ring {
  left: 12px;
  right: auto;
}
.address-page .slot7-mini-logo-t {
  left: 14px;
  right: auto;
  bottom: 1px;
  font-size: 0.48rem;
}

@keyframes slot7CoinFlipV33 {
  0% {
    transform: rotateY(0deg) scaleX(1);
  }
  7% {
    transform: rotateY(420deg) scaleX(0.78);
  }
  14% {
    transform: rotateY(960deg) scaleX(0.56);
  }
  21% {
    transform: rotateY(1440deg) scaleX(0.78);
  }
  28%, 46% {
    transform: rotateY(1800deg) scaleX(1);
  }
  53% {
    transform: rotateY(2220deg) scaleX(0.78);
  }
  60% {
    transform: rotateY(2760deg) scaleX(0.56);
  }
  67% {
    transform: rotateY(3240deg) scaleX(0.78);
  }
  74%, 100% {
    transform: rotateY(3600deg) scaleX(1);
  }
}
.address-page .slot7-logo-mark,
.address-page .slot7-copy-card-icon {
  animation-name: slot7CoinFlipV33;
  animation-duration: 4.8s;
}

/* final v34: rebuild 7T icons to match supplied logo shape */
.address-page .slot7-logo-mark {
  width: 48px;
  height: 50px;
  margin: 0 auto;
}
.address-page .slot7-logo-shield {
  left: 0;
  top: 0;
  width: 48px;
  height: 50px;
  border-radius: 4px 4px 15px 15px;
  background: linear-gradient(180deg, #74c3f7 0%, #59afea 58%, #84a7ef 100%);
  clip-path: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.28), 0 6px 14px rgba(92, 156, 216, 0.18);
}
.address-page .slot7-logo-seven {
  left: 7px;
  top: 3px;
  color: #ffffff;
  font-size: 2.38rem;
  font-weight: 1000;
  line-height: 1;
  letter-spacing: -0.1em;
  transform: scaleX(1.02);
  text-shadow: 0 1px 0 rgba(255,255,255,0.18);
}
.address-page .slot7-logo-ring {
  left: auto;
  right: 1px;
  bottom: 4px;
  top: auto;
  width: 19px;
  height: 19px;
  border-radius: 999px;
  border: 2.4px solid rgba(255,255,255,0.98);
  background: linear-gradient(180deg, rgba(102, 186, 243, 0.16), rgba(91, 138, 227, 0.22));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.22);
}
.address-page .slot7-logo-t {
  left: auto;
  right: 5px;
  bottom: 6px;
  top: auto;
  width: 11px;
  height: 12px;
  color: transparent;
  font-size: 0;
}
.address-page .slot7-logo-t::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 1px;
  width: 10px;
  height: 2.4px;
  border-radius: 999px;
  background: #ffffff;
  transform: translateX(-50%);
}
.address-page .slot7-logo-t::after {
  content: '';
  position: absolute;
  left: 50%;
  top: 3px;
  width: 3px;
  height: 8px;
  border-radius: 999px;
  background: #ffffff;
  transform: translateX(-50%);
  box-shadow: 0 -0.6px 0 0 #ffffff;
}
.address-page .slot7-logo-ring::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 10px;
  width: 12px;
  height: 3px;
  border-radius: 999px;
  border: 1.6px solid rgba(255,255,255,0.96);
  transform: translateX(-50%);
  background: transparent;
}

.address-page .slot7-mini-logo {
  width: 24px;
  height: 26px;
}
.address-page .slot7-mini-logo-shield {
  inset: 0;
  border-radius: 3px 3px 8px 8px;
  background: linear-gradient(180deg, #74c3f7 0%, #59afea 58%, #84a7ef 100%);
  clip-path: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.22), 0 2px 6px rgba(92, 156, 216, 0.18);
}
.address-page .slot7-mini-logo-seven {
  left: 3px;
  top: 2px;
  font-size: 1.22rem;
  letter-spacing: -0.1em;
  transform: scaleX(1.02);
}
.address-page .slot7-mini-logo-ring {
  left: auto;
  right: 0;
  bottom: 2px;
  width: 10px;
  height: 10px;
  border: 1.6px solid rgba(255,255,255,0.98);
  background: linear-gradient(180deg, rgba(102, 186, 243, 0.16), rgba(91, 138, 227, 0.22));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.16);
}
.address-page .slot7-mini-logo-ring::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 5px;
  width: 6px;
  height: 1.6px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.96);
  transform: translateX(-50%);
  background: transparent;
}
.address-page .slot7-mini-logo-t {
  left: auto;
  right: 2px;
  bottom: 3px;
  width: 5px;
  height: 6px;
  color: transparent;
  font-size: 0;
}
.address-page .slot7-mini-logo-t::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 0;
  width: 5px;
  height: 1.4px;
  border-radius: 999px;
  background: #ffffff;
  transform: translateX(-50%);
}
.address-page .slot7-mini-logo-t::after {
  content: '';
  position: absolute;
  left: 50%;
  top: 1px;
  width: 1.7px;
  height: 4.6px;
  border-radius: 999px;
  background: #ffffff;
  transform: translateX(-50%);
}

/* final v35: replace third banner with world cup animated banner */
.address-page .slot7-banner-panel {
  position: relative;
  overflow: hidden;
  border-color: rgba(129, 214, 255, 0.92);
  background:
    radial-gradient(circle at 10% 24%, rgba(110, 216, 255, 0.28), transparent 24%),
    radial-gradient(circle at 88% 22%, rgba(90, 167, 255, 0.26), transparent 20%),
    linear-gradient(135deg, #062348 0%, #0c4a98 44%, #0d75c7 100%);
  box-shadow: 0 20px 40px rgba(15, 73, 132, 0.26);
}
.address-page .slot7-banner-panel:hover {
  border-color: rgba(160, 229, 255, 0.98);
  box-shadow: 0 24px 48px rgba(15, 73, 132, 0.34);
}
.address-page .slot7-worldcup-backdrop,
.address-page .slot7-worldcup-shine {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.address-page .slot7-worldcup-backdrop {
  border-radius: inherit;
}
.address-page .slot7-worldcup-backdrop-left {
  inset: auto auto -34px -30px;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 50%, rgba(70, 214, 255, 0.26), rgba(70, 214, 255, 0.05) 64%, transparent 68%);
}
.address-page .slot7-worldcup-backdrop-right {
  inset: -42px -28px auto auto;
  width: 206px;
  height: 206px;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 50%, rgba(126, 184, 255, 0.24), rgba(126, 184, 255, 0.04) 64%, transparent 68%);
}
.address-page .slot7-worldcup-banner {
  position: relative;
  z-index: 1;
  height: 100%;
  display: grid;
  grid-template-columns: minmax(178px, 224px) minmax(0, 1fr) minmax(150px, 214px);
  gap: 16px;
  align-items: center;
  padding: 0 22px;
  color: #ffffff;
}
.address-page .slot7-worldcup-logo-block {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
  padding: 16px 18px;
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(255,255,255,0.14), rgba(255,255,255,0.04));
  border: 1px solid rgba(255,255,255,0.14);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.14);
  backdrop-filter: blur(10px);
}
.address-page .slot7-worldcup-logo-emblem {
  position: relative;
  flex: 0 0 64px;
  width: 64px;
  height: 68px;
  border-radius: 7px 7px 20px 20px;
  background: linear-gradient(180deg, #7ed7ff 0%, #4cb7f2 58%, #7e99f4 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.34), 0 10px 20px rgba(4, 34, 74, 0.26);
  animation: slot7WorldcupBadge 3.8s ease-in-out infinite;
}
.address-page .slot7-worldcup-logo-seven {
  position: absolute;
  left: 9px;
  top: 3px;
  color: #ffffff;
  font-size: 3.05rem;
  font-weight: 1000;
  line-height: 1;
  letter-spacing: -0.12em;
}
.address-page .slot7-worldcup-logo-ring {
  position: absolute;
  right: 3px;
  bottom: 6px;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 2.5px solid rgba(255,255,255,0.98);
  background: linear-gradient(180deg, rgba(123, 214, 255, 0.22), rgba(114, 120, 238, 0.26));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.16);
}
.address-page .slot7-worldcup-logo-ring i {
  position: absolute;
  left: 50%;
  top: 11px;
  width: 13px;
  height: 3px;
  border-radius: 999px;
  border: 1.5px solid rgba(255,255,255,0.98);
  transform: translateX(-50%);
}
.address-page .slot7-worldcup-logo-t {
  position: absolute;
  right: 9px;
  bottom: 10px;
  width: 8px;
  height: 11px;
}
.address-page .slot7-worldcup-logo-t::before,
.address-page .slot7-worldcup-logo-t::after {
  content: '';
  position: absolute;
  left: 50%;
  background: #ffffff;
  border-radius: 999px;
  transform: translateX(-50%);
}
.address-page .slot7-worldcup-logo-t::before {
  top: 0;
  width: 8px;
  height: 2.4px;
}
.address-page .slot7-worldcup-logo-t::after {
  top: 2px;
  width: 2.6px;
  height: 9px;
}
.address-page .slot7-worldcup-logo-copy {
  display: grid;
  gap: 4px;
  min-width: 0;
}
.address-page .slot7-worldcup-logo-copy strong {
  font-size: 1.38rem;
  font-weight: 1000;
  letter-spacing: 0.03em;
  line-height: 1;
}
.address-page .slot7-worldcup-logo-copy span {
  color: rgba(226, 244, 255, 0.82);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.18em;
}
.address-page .slot7-worldcup-copy {
  display: grid;
  align-content: center;
  gap: 10px;
  min-width: 0;
}
.address-page .slot7-worldcup-year {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.address-page .slot7-worldcup-year span {
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  color: #ffffff;
  font-size: 0.96rem;
  font-weight: 900;
  background: linear-gradient(180deg, rgba(94, 216, 255, 0.9), rgba(24, 122, 220, 0.96));
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.44), 0 8px 16px rgba(3, 44, 88, 0.22);
  animation: slot7WorldcupPulse 2.8s ease-in-out infinite;
}
.address-page .slot7-worldcup-year span:nth-child(2) {
  animation-delay: 0.2s;
}
.address-page .slot7-worldcup-year span:nth-child(3) {
  animation-delay: 0.4s;
}
.address-page .slot7-worldcup-year span:nth-child(4) {
  animation-delay: 0.6s;
}
.address-page .slot7-worldcup-title {
  font-size: clamp(1.06rem, 1.6vw, 1.42rem);
  font-weight: 1000;
  line-height: 1.18;
  letter-spacing: 0.02em;
  text-shadow: 0 2px 12px rgba(0, 18, 48, 0.22);
}
.address-page .slot7-worldcup-sub {
  color: rgba(226, 244, 255, 0.9);
  font-size: 0.82rem;
  line-height: 1.45;
  letter-spacing: 0.02em;
}
.address-page .slot7-worldcup-visual {
  position: relative;
  height: 100%;
  min-height: 126px;
}
.address-page .slot7-worldcup-stadium-glow {
  position: absolute;
  right: 8px;
  bottom: 8px;
  width: 180px;
  height: 78px;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 50%, rgba(151, 224, 255, 0.34), rgba(151, 224, 255, 0.08) 54%, transparent 66%);
  filter: blur(0.3px);
}
.address-page .slot7-worldcup-trophy {
  position: absolute;
  right: 72px;
  top: 16px;
  width: 74px;
  height: 94px;
  filter: drop-shadow(0 14px 20px rgba(7, 40, 83, 0.24));
  animation: slot7WorldcupFloat 3.8s ease-in-out infinite;
}
.address-page .slot7-worldcup-trophy-cup,
.address-page .slot7-worldcup-trophy-stem,
.address-page .slot7-worldcup-trophy-base,
.address-page .slot7-worldcup-trophy-handle,
.address-page .slot7-worldcup-trophy-shine {
  position: absolute;
}
.address-page .slot7-worldcup-trophy-cup {
  left: 18px;
  top: 10px;
  width: 38px;
  height: 28px;
  background: linear-gradient(180deg, rgba(255, 247, 216, 0.98), rgba(245, 199, 88, 0.98) 48%, rgba(203, 128, 20, 0.98));
  clip-path: polygon(0 0, 100% 0, 86% 74%, 58% 100%, 42% 100%, 14% 74%);
  border-radius: 0 0 12px 12px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.64);
}
.address-page .slot7-worldcup-trophy-handle {
  top: 14px;
  width: 14px;
  height: 20px;
  border: 3px solid rgba(238, 183, 58, 0.98);
  border-top-color: rgba(255, 236, 170, 0.96);
  border-radius: 50%;
}
.address-page .slot7-worldcup-trophy-handle-left {
  left: 8px;
  border-right: 0;
}
.address-page .slot7-worldcup-trophy-handle-right {
  right: 8px;
  border-left: 0;
}
.address-page .slot7-worldcup-trophy-stem {
  left: 31px;
  top: 38px;
  width: 12px;
  height: 23px;
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(255, 246, 210, 0.98), rgba(222, 159, 39, 0.98));
}
.address-page .slot7-worldcup-trophy-base {
  left: 22px;
  bottom: 10px;
  width: 30px;
  height: 16px;
  border-radius: 7px 7px 12px 12px;
  background: linear-gradient(180deg, rgba(194, 126, 26, 0.98), rgba(103, 65, 12, 0.98));
  box-shadow: inset 0 1px 0 rgba(255, 223, 147, 0.36);
}
.address-page .slot7-worldcup-trophy-shine {
  left: 28px;
  top: 16px;
  width: 9px;
  height: 18px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(255,255,255,0.82), rgba(255,255,255,0));
  transform: rotate(16deg);
}
.address-page .slot7-worldcup-ball {
  position: absolute;
  right: 14px;
  bottom: 18px;
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background: radial-gradient(circle at 36% 28%, rgba(255,255,255,0.96), rgba(220, 242, 255, 0.92) 42%, rgba(113, 177, 239, 0.82) 100%);
  box-shadow: inset -8px -10px 18px rgba(41, 114, 185, 0.18), 0 14px 18px rgba(7, 40, 83, 0.2);
  animation: slot7WorldcupSpin 4.2s linear infinite;
}
.address-page .slot7-worldcup-ball-panel {
  position: absolute;
  background: linear-gradient(180deg, rgba(28, 84, 142, 0.92), rgba(8, 54, 108, 0.98));
  clip-path: polygon(50% 0, 100% 36%, 82% 100%, 18% 100%, 0 36%);
}
.address-page .slot7-worldcup-ball-panel-a {
  left: 20px;
  top: 7px;
  width: 18px;
  height: 15px;
}
.address-page .slot7-worldcup-ball-panel-b {
  left: 7px;
  top: 20px;
  width: 13px;
  height: 12px;
}
.address-page .slot7-worldcup-ball-panel-c {
  right: 7px;
  top: 20px;
  width: 13px;
  height: 12px;
}
.address-page .slot7-worldcup-ball-panel-d {
  left: 16px;
  bottom: 9px;
  width: 12px;
  height: 10px;
}
.address-page .slot7-worldcup-ball-panel-e {
  right: 16px;
  bottom: 9px;
  width: 12px;
  height: 10px;
}
.address-page .slot7-worldcup-shine {
  background: linear-gradient(110deg, transparent 28%, rgba(255,255,255,0.04) 44%, rgba(255,255,255,0.24) 50%, rgba(255,255,255,0.04) 56%, transparent 72%);
  transform: translateX(-135%) skewX(-20deg);
  animation: slot7WorldcupShine 4.8s linear infinite;
}
@keyframes slot7WorldcupShine {
  to {
    transform: translateX(135%) skewX(-20deg);
  }
}
@keyframes slot7WorldcupPulse {
  0%,
  100% {
    transform: translateY(0) scale(1);
  }
  50% {
    transform: translateY(-2px) scale(1.08);
  }
}
@keyframes slot7WorldcupFloat {
  0%,
  100% {
    transform: translateY(0) rotate(-3deg);
  }
  50% {
    transform: translateY(-5px) rotate(3deg);
  }
}
@keyframes slot7WorldcupSpin {
  to {
    transform: rotate(360deg);
  }
}
@keyframes slot7WorldcupBadge {
  0%,
  100% {
    transform: translateY(0) scale(1);
  }
  50% {
    transform: translateY(-2px) scale(1.03);
  }
}
@media (max-width: 1080px) {
  .address-page .slot7-worldcup-banner {
    grid-template-columns: minmax(166px, 200px) minmax(0, 1fr) minmax(136px, 180px);
    gap: 12px;
    padding: 0 18px;
  }
  .address-page .slot7-worldcup-logo-block {
    padding: 14px 15px;
  }
  .address-page .slot7-worldcup-title {
    font-size: 1rem;
  }
  .address-page .slot7-worldcup-sub {
    font-size: 0.76rem;
  }
}
@media (max-width: 920px) {
  .address-page .slot7-banner-panel {
    height: auto;
    min-height: 0;
  }
  .address-page .slot7-worldcup-banner {
    grid-template-columns: 1fr;
    justify-items: center;
    gap: 14px;
    padding: 18px;
    text-align: center;
  }
  .address-page .slot7-worldcup-copy {
    justify-items: center;
  }
  .address-page .slot7-worldcup-year {
    justify-content: center;
  }
  .address-page .slot7-worldcup-visual {
    width: 200px;
    min-height: 110px;
  }
  .address-page .slot7-worldcup-trophy {
    right: 70px;
    top: 8px;
  }
  .address-page .slot7-worldcup-ball {
    right: 20px;
    bottom: 8px;
  }
}
@media (prefers-reduced-motion: reduce) {
  .address-page .slot7-worldcup-logo-emblem,
  .address-page .slot7-worldcup-year span,
  .address-page .slot7-worldcup-trophy,
  .address-page .slot7-worldcup-ball,
  .address-page .slot7-worldcup-shine {
    animation: none;
  }
}

/* final v36: make second and third banners match first banner size */
.address-page .ad-banner-panel-premium,
.address-page .slot7-banner-panel {
  min-height: var(--promo-banner-height);
  height: var(--promo-banner-height);
  max-height: var(--promo-banner-height);
  border-radius: 24px;
}
.address-page .ad-banner-panel-premium .premium-ad-inner-triple,
.address-page .slot7-worldcup-banner {
  min-height: 100%;
  height: 100%;
  align-items: center;
}
.address-page .ad-banner-panel-premium .premium-ad-inner-triple {
  padding-top: 12px;
  padding-bottom: 12px;
}
.address-page .slot7-worldcup-banner {
  padding-top: 14px;
  padding-bottom: 14px;
}
@media (max-width: 920px) {
  .address-page .ad-banner-panel-premium,
  .address-page .slot7-banner-panel {
    min-height: var(--promo-banner-height);
    height: auto;
    max-height: none;
  }
}

/* final v37: larger premium copy + closer 7T gif recreation */
.address-page .ad-banner-panel-premium .premium-ad-copy-kicker {
  font-size: 1.02rem;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-title {
  font-size: 1.08rem;
  line-height: 1.06;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-sub {
  font-size: 0.78rem;
  line-height: 1.18;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-lane {
  gap: 5px;
}

.address-page .slot7-banner-panel {
  border-color: rgba(87, 202, 245, 0.96);
  background: linear-gradient(180deg, #fdfefe 0%, #f8fdff 100%);
  box-shadow: 0 18px 38px rgba(76, 177, 219, 0.18);
}
.address-page .slot7-banner-panel:hover {
  border-color: rgba(53, 191, 243, 0.98);
  box-shadow: 0 20px 42px rgba(76, 177, 219, 0.22);
}
.address-page .slot7-worldcup-backdrop-left,
.address-page .slot7-worldcup-backdrop-right {
  display: none;
}
.address-page .slot7-worldcup-banner {
  grid-template-columns: 214px 170px minmax(0, 1fr) 126px;
  gap: 12px;
  padding: 10px 18px;
  color: #17b7ef;
}
.address-page .slot7-worldcup-logo-block {
  position: relative;
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}
.address-page .slot7-worldcup-logo-emblem {
  width: 58px;
  height: 58px;
  flex-basis: 58px;
  border-radius: 6px 6px 18px 18px;
  background: linear-gradient(180deg, #72d6fb 0%, #43c0f4 55%, #79a8f5 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.62), 0 6px 12px rgba(73, 178, 227, 0.22);
  animation: slot7GifBadgeBounce 3.6s ease-in-out infinite;
}
.address-page .slot7-worldcup-logo-seven {
  left: 7px;
  top: 2px;
  font-size: 2.82rem;
  letter-spacing: -0.13em;
}
.address-page .slot7-worldcup-logo-ring {
  right: 2px;
  bottom: 5px;
  width: 22px;
  height: 22px;
  border-width: 2.4px;
}
.address-page .slot7-worldcup-logo-ring i {
  top: 10px;
  width: 12px;
  height: 3px;
  border-width: 1.3px;
}
.address-page .slot7-worldcup-logo-t {
  right: 7px;
  bottom: 9px;
}
.address-page .slot7-worldcup-logo-copy {
  gap: 5px;
}
.address-page .slot7-worldcup-logo-copy strong {
  color: #24beef;
  font-size: 1.38rem;
  letter-spacing: 0.01em;
  text-shadow: none;
}
.address-page .slot7-worldcup-logo-copy span {
  color: #111111;
  font-size: 0.58rem;
  font-weight: 900;
  letter-spacing: 0.28em;
  white-space: nowrap;
}
.address-page .slot7-worldcup-copy {
  display: contents;
}
.address-page .slot7-worldcup-year {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
}
.address-page .slot7-worldcup-year span {
  width: 52px;
  height: 52px;
  border: 3px solid #57cbf7;
  background: radial-gradient(circle at 34% 28%, rgba(255,255,255,0.96), rgba(227,249,255,0.92) 40%, rgba(124,217,248,0.95) 100%);
  color: #1bb8ef;
  font-size: 2rem;
  font-weight: 1000;
  line-height: 1;
  text-shadow: 0 1px 0 rgba(255,255,255,0.72);
  box-shadow: inset 0 2px 0 rgba(255,255,255,0.9), 0 4px 10px rgba(79, 192, 233, 0.24);
  animation: slot7GifBallPulse 2.6s ease-in-out infinite;
}
.address-page .slot7-worldcup-title {
  display: flex;
  align-items: center;
  min-width: 0;
  height: 50px;
  padding: 0 18px;
  border-radius: 999px;
  background: linear-gradient(180deg, #59d0fa 0%, #14b7ef 100%);
  color: #ffffff;
  font-size: 1.02rem;
  font-weight: 1000;
  line-height: 1;
  letter-spacing: 0.02em;
  white-space: nowrap;
  text-shadow: none;
  box-shadow: inset 0 2px 0 rgba(255,255,255,0.36), 0 8px 18px rgba(74, 188, 229, 0.24);
  animation: slot7GifTitleGlow 3.4s ease-in-out infinite;
}
.address-page .slot7-worldcup-sub {
  display: none;
}
.address-page .slot7-worldcup-visual {
  position: relative;
  min-height: 58px;
  height: 58px;
}
.address-page .slot7-worldcup-stadium-glow {
  display: none;
}
.address-page .slot7-worldcup-trophy {
  right: 48px;
  top: 0;
  width: 26px;
  height: 52px;
  filter: drop-shadow(0 4px 8px rgba(81, 157, 31, 0.14));
  animation: slot7GifTrophyBob 2.8s ease-in-out infinite;
}
.address-page .slot7-worldcup-trophy-cup {
  left: 6px;
  top: 4px;
  width: 14px;
  height: 16px;
  border-radius: 0 0 6px 6px;
  background: linear-gradient(180deg, #d9b364 0%, #a66d13 100%);
  clip-path: polygon(0 0, 100% 0, 84% 68%, 60% 100%, 40% 100%, 16% 68%);
  box-shadow: inset 0 1px 0 rgba(255,239,197,0.52);
}
.address-page .slot7-worldcup-trophy-handle {
  top: 7px;
  width: 6px;
  height: 10px;
  border-width: 1.8px;
  border-color: rgba(183, 128, 25, 0.96);
  border-top-color: rgba(232, 194, 113, 0.96);
}
.address-page .slot7-worldcup-trophy-handle-left {
  left: 2px;
}
.address-page .slot7-worldcup-trophy-handle-right {
  right: 2px;
}
.address-page .slot7-worldcup-trophy-stem {
  left: 10px;
  top: 20px;
  width: 6px;
  height: 14px;
  border-radius: 4px;
  background: linear-gradient(180deg, #d4b06d 0%, #9b6a19 100%);
}
.address-page .slot7-worldcup-trophy-base {
  left: 6px;
  bottom: 3px;
  width: 14px;
  height: 8px;
  border-radius: 3px 3px 5px 5px;
  background: linear-gradient(180deg, #29b8ef 0%, #0f9fd8 100%);
}
.address-page .slot7-worldcup-trophy-shine {
  left: 10px;
  top: 6px;
  width: 4px;
  height: 8px;
}
.address-page .slot7-worldcup-visual-mark {
  position: absolute;
  right: 46px;
  bottom: -1px;
  color: #169de0;
  font-size: 0.52rem;
  font-weight: 900;
  letter-spacing: 0.08em;
}
.address-page .slot7-worldcup-ball {
  right: 0;
  bottom: 1px;
  width: 48px;
  height: 48px;
  background: radial-gradient(circle at 35% 30%, rgba(255,255,255,0.98), rgba(248,248,248,0.94) 42%, rgba(220,220,220,0.96) 100%);
  box-shadow: inset -6px -7px 12px rgba(0,0,0,0.08), 0 4px 10px rgba(0,0,0,0.14);
  animation: slot7GifBallSpin 3.8s linear infinite;
}
.address-page .slot7-worldcup-ball-panel {
  background: linear-gradient(180deg, #101010 0%, #2c2c2c 100%);
}
.address-page .slot7-worldcup-shine {
  background: linear-gradient(108deg, transparent 22%, rgba(255,255,255,0.08) 44%, rgba(255,255,255,0.5) 50%, rgba(255,255,255,0.08) 56%, transparent 78%);
  animation: slot7GifSweep 4.2s linear infinite;
}
@keyframes slot7GifSweep {
  0% {
    transform: translateX(-130%) skewX(-22deg);
  }
  100% {
    transform: translateX(130%) skewX(-22deg);
  }
}
@keyframes slot7GifBallPulse {
  0%, 100% {
    transform: translateY(0) scale(1);
  }
  50% {
    transform: translateY(-1px) scale(1.06);
  }
}
@keyframes slot7GifTitleGlow {
  0%, 100% {
    filter: brightness(1);
  }
  50% {
    filter: brightness(1.08);
  }
}
@keyframes slot7GifTrophyBob {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-2px);
  }
}
@keyframes slot7GifBallSpin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@keyframes slot7GifBadgeBounce {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-1px);
  }
}
@media (max-width: 1180px) {
  .address-page .slot7-worldcup-banner {
    grid-template-columns: 198px 154px minmax(0, 1fr) 118px;
    gap: 10px;
    padding: 10px 14px;
  }
  .address-page .slot7-worldcup-year span {
    width: 46px;
    height: 46px;
    font-size: 1.76rem;
  }
  .address-page .slot7-worldcup-title {
    font-size: 0.92rem;
    padding: 0 15px;
  }
  .address-page .slot7-worldcup-logo-copy strong {
    font-size: 1.22rem;
  }
}
@media (max-width: 920px) {
  .address-page .slot7-worldcup-banner {
    grid-template-columns: 1fr;
    justify-items: center;
    gap: 10px;
    text-align: center;
  }
  .address-page .slot7-worldcup-copy {
    display: grid;
    gap: 8px;
    justify-items: center;
  }
  .address-page .slot7-worldcup-title {
    white-space: normal;
    height: auto;
    min-height: 46px;
    justify-content: center;
    text-align: center;
  }
  .address-page .slot7-worldcup-visual {
    width: 96px;
  }
}

/* final v38: enlarge marked copy, cleaner ball, bigger trophy */
.address-page .ad-banner-panel-premium .premium-ad-copy-kicker {
  font-size: 1.1rem;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-title {
  font-size: 1.2rem;
  line-height: 1.04;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-sub {
  font-size: 0.82rem;
  line-height: 1.2;
}
.address-page .ad-banner-panel-premium .premium-ad-copy-lane {
  gap: 6px;
}

.address-page .slot7-worldcup-logo-copy strong {
  font-size: 1.48rem;
}
.address-page .slot7-worldcup-logo-copy span {
  font-size: 0.62rem;
}
.address-page .slot7-worldcup-title {
  height: 52px;
  padding: 0 20px;
  font-size: 1.12rem;
}
.address-page .slot7-worldcup-trophy {
  right: 54px;
  top: -4px;
  width: 34px;
  height: 62px;
  filter: drop-shadow(0 6px 10px rgba(122, 95, 21, 0.18));
}
.address-page .slot7-worldcup-trophy-cup {
  left: 7px;
  top: 4px;
  width: 20px;
  height: 20px;
  border-radius: 0 0 7px 7px;
  clip-path: polygon(0 0, 100% 0, 86% 70%, 62% 100%, 38% 100%, 14% 70%);
}
.address-page .slot7-worldcup-trophy-handle {
  top: 8px;
  width: 8px;
  height: 12px;
  border-width: 2px;
}
.address-page .slot7-worldcup-trophy-handle-left {
  left: 1px;
}
.address-page .slot7-worldcup-trophy-handle-right {
  right: 1px;
}
.address-page .slot7-worldcup-trophy-stem {
  left: 13px;
  top: 24px;
  width: 8px;
  height: 17px;
}
.address-page .slot7-worldcup-trophy-base {
  left: 8px;
  bottom: 4px;
  width: 18px;
  height: 10px;
}
.address-page .slot7-worldcup-trophy-shine {
  left: 13px;
  top: 7px;
  width: 5px;
  height: 10px;
}
.address-page .slot7-worldcup-visual-mark {
  right: 50px;
  bottom: -2px;
}
.address-page .slot7-worldcup-ball {
  right: 0;
  bottom: 0;
  width: 52px;
  height: 52px;
  border: 1px solid rgba(0, 0, 0, 0.06);
  background:
    radial-gradient(circle at 32% 28%, rgba(255,255,255,0.98), rgba(246,246,246,0.96) 40%, rgba(213,213,213,0.98) 100%);
  box-shadow:
    inset -6px -7px 12px rgba(0,0,0,0.08),
    inset 4px 4px 8px rgba(255,255,255,0.58),
    0 5px 10px rgba(0,0,0,0.14);
}
.address-page .slot7-worldcup-ball-panel {
  background: linear-gradient(180deg, #131313 0%, #2a2a2a 100%);
  clip-path: polygon(50% 0, 96% 34%, 80% 100%, 20% 100%, 4% 34%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
}
.address-page .slot7-worldcup-ball-panel-a {
  left: 18px;
  top: 6px;
  width: 16px;
  height: 14px;
}
.address-page .slot7-worldcup-ball-panel-b {
  left: 7px;
  top: 18px;
  width: 12px;
  height: 11px;
  transform: rotate(-8deg);
}
.address-page .slot7-worldcup-ball-panel-c {
  right: 7px;
  top: 18px;
  width: 12px;
  height: 11px;
  transform: rotate(8deg);
}
.address-page .slot7-worldcup-ball-panel-d {
  left: 14px;
  bottom: 8px;
  width: 11px;
  height: 10px;
  transform: rotate(-6deg);
}
.address-page .slot7-worldcup-ball-panel-e {
  right: 14px;
  bottom: 8px;
  width: 11px;
  height: 10px;
  transform: rotate(6deg);
}
@media (max-width: 1180px) {
  .address-page .ad-banner-panel-premium .premium-ad-copy-kicker {
    font-size: 1.04rem;
  }
  .address-page .ad-banner-panel-premium .premium-ad-copy-title {
    font-size: 1.12rem;
  }
  .address-page .slot7-worldcup-title {
    font-size: 1rem;
  }
}

/* final v39: bigger 9G kicker, bouncier 2026, left trophy, cleaner football */
.address-page .ad-banner-panel-premium .premium-ad-copy-lane-1 .premium-ad-copy-kicker {
  font-size: 1.58rem;
  line-height: 0.92;
  letter-spacing: -0.01em;
}

.address-page .slot7-worldcup-banner {
  grid-template-columns: 214px 182px minmax(0, 1fr) 112px;
  gap: 10px;
}
.address-page .slot7-worldcup-year {
  gap: 7px;
}
.address-page .slot7-worldcup-year span {
  animation-name: slot7GifYearBounce;
  animation-duration: 1.9s;
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
}
.address-page .slot7-worldcup-year span:nth-child(2) {
  animation-delay: 0.14s;
}
.address-page .slot7-worldcup-year span:nth-child(3) {
  animation-delay: 0.28s;
}
.address-page .slot7-worldcup-year span:nth-child(4) {
  animation-delay: 0.42s;
}
.address-page .slot7-worldcup-title {
  width: 100%;
  margin-right: 10px;
  justify-content: center;
  padding: 0 14px;
  font-size: 1.18rem;
  letter-spacing: 0;
}
.address-page .slot7-worldcup-trophy {
  right: 70px;
  top: -3px;
  width: 36px;
  height: 66px;
}
.address-page .slot7-worldcup-trophy-cup {
  left: 8px;
  width: 20px;
  height: 21px;
}
.address-page .slot7-worldcup-trophy-handle {
  top: 8px;
  width: 8px;
  height: 13px;
}
.address-page .slot7-worldcup-trophy-handle-left {
  left: 2px;
}
.address-page .slot7-worldcup-trophy-handle-right {
  right: 2px;
}
.address-page .slot7-worldcup-trophy-stem {
  left: 14px;
  top: 25px;
  width: 8px;
  height: 18px;
}
.address-page .slot7-worldcup-trophy-base {
  left: 9px;
  width: 18px;
  height: 10px;
}
.address-page .slot7-worldcup-trophy-shine {
  left: 14px;
}
.address-page .slot7-worldcup-visual-mark {
  right: 65px;
  bottom: -2px;
}
.address-page .slot7-worldcup-ball {
  right: 0;
  bottom: 0;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: 1px solid rgba(0, 0, 0, 0.08);
  background:
    radial-gradient(circle at 32% 28%, rgba(255,255,255,1), rgba(249,249,249,0.97) 38%, rgba(215,215,215,0.98) 100%);
  box-shadow:
    inset -6px -8px 14px rgba(0,0,0,0.08),
    inset 5px 5px 10px rgba(255,255,255,0.62),
    0 5px 11px rgba(0,0,0,0.14);
}
.address-page .slot7-worldcup-ball::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 50%;
  width: 15px;
  height: 13px;
  transform: translate(-50%, -50%);
  background: linear-gradient(180deg, #111111 0%, #2d2d2d 100%);
  clip-path: polygon(50% 0, 100% 36%, 82% 100%, 18% 100%, 0 36%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.08);
}
.address-page .slot7-worldcup-ball::after {
  content: '';
  position: absolute;
  inset: 7px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 6px, rgba(26,26,26,0.96) 0 5px, transparent 5.5px),
    radial-gradient(circle at calc(100% - 9px) 18px, rgba(26,26,26,0.96) 0 4.5px, transparent 5px),
    radial-gradient(circle at calc(100% - 14px) calc(100% - 11px), rgba(26,26,26,0.96) 0 4.5px, transparent 5px),
    radial-gradient(circle at 14px calc(100% - 11px), rgba(26,26,26,0.96) 0 4.5px, transparent 5px),
    radial-gradient(circle at 9px 18px, rgba(26,26,26,0.96) 0 4.5px, transparent 5px);
  opacity: 0.98;
}
.address-page .slot7-worldcup-ball-panel {
  display: none;
}
@keyframes slot7GifYearBounce {
  0%,
  100% {
    transform: translateY(0) scale(1);
  }
  35% {
    transform: translateY(-7px) scale(1.08);
  }
  60% {
    transform: translateY(-2px) scale(1.03);
  }
}
@media (max-width: 1180px) {
  .address-page .ad-banner-panel-premium .premium-ad-copy-lane-1 .premium-ad-copy-kicker {
    font-size: 1.42rem;
  }
  .address-page .slot7-worldcup-title {
    font-size: 1.06rem;
    margin-right: 8px;
  }
  .address-page .slot7-worldcup-trophy {
    right: 64px;
  }
}

/* final v40: bigger 7T logo, larger title bar, flowing text shine, rolling football */
.address-page .slot7-worldcup-logo-copy strong {
  font-size: 1.72rem;
  line-height: 0.92;
  letter-spacing: -0.02em;
}
.address-page .slot7-worldcup-logo-copy span {
  font-size: 0.64rem;
}
.address-page .slot7-worldcup-banner {
  grid-template-columns: 226px 182px minmax(0, 1fr) 106px;
  gap: 9px;
}
.address-page .slot7-worldcup-title {
  display: grid;
  place-items: center;
  width: 100%;
  height: 60px;
  margin-right: 0;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid rgba(89, 201, 244, 0.92);
  box-shadow: inset 0 2px 0 rgba(255,255,255,0.34), 0 8px 18px rgba(74, 188, 229, 0.24);
  background:
    linear-gradient(180deg, #6ed5fb 0%, #1fbdf2 100%) padding-box,
    linear-gradient(108deg, rgba(255,255,255,0.82) 0%, #ffffff 18%, #dff6ff 32%, #ffffff 46%, rgba(255,255,255,0.82) 58%, #dff6ff 72%, #ffffff 86%, rgba(255,255,255,0.82) 100%) text;
  background-size: 100% 100%, 220% 100%;
  background-position: 0 0, 160% 0;
  -webkit-background-clip: padding-box, text;
  background-clip: padding-box, text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  text-align: center;
  font-size: 1.28rem;
  font-weight: 1000;
  letter-spacing: -0.01em;
  white-space: nowrap;
  animation: slot7GifTitleStream 3.2s linear infinite;
}
.address-page .slot7-worldcup-visual {
  width: 106px;
  min-width: 106px;
  min-height: 64px;
  height: 64px;
}
.address-page .slot7-worldcup-trophy {
  left: 6px;
  right: auto;
  top: -2px;
  width: 38px;
  height: 68px;
}
.address-page .slot7-worldcup-visual-mark {
  left: 10px;
  right: auto;
  bottom: -2px;
}
.address-page .slot7-worldcup-ball {
  left: 30px;
  right: auto;
  bottom: 2px;
  width: 56px;
  height: 56px;
  animation: slot7GifBallTravel 3.6s ease-in-out infinite;
}
.address-page .slot7-worldcup-ball::before {
  width: 16px;
  height: 14px;
}
.address-page .slot7-worldcup-ball::after {
  inset: 8px;
  background:
    radial-gradient(circle at 50% 6px, rgba(26,26,26,0.98) 0 5px, transparent 5.4px),
    radial-gradient(circle at calc(100% - 8px) 18px, rgba(26,26,26,0.98) 0 4.3px, transparent 4.8px),
    radial-gradient(circle at calc(100% - 13px) calc(100% - 10px), rgba(26,26,26,0.98) 0 4.3px, transparent 4.8px),
    radial-gradient(circle at 13px calc(100% - 10px), rgba(26,26,26,0.98) 0 4.3px, transparent 4.8px),
    radial-gradient(circle at 8px 18px, rgba(26,26,26,0.98) 0 4.3px, transparent 4.8px);
}
@keyframes slot7GifTitleStream {
  0% {
    background-position: 0 0, 160% 0;
    filter: brightness(1);
  }
  50% {
    background-position: 0 0, 40% 0;
    filter: brightness(1.06);
  }
  100% {
    background-position: 0 0, -80% 0;
    filter: brightness(1);
  }
}
@keyframes slot7GifBallTravel {
  0% {
    transform: translateX(0) translateY(0) rotate(0deg) scale(1);
  }
  34% {
    transform: translateX(18px) translateY(0) rotate(190deg) scale(1);
  }
  42% {
    transform: translateX(24px) translateY(-4px) rotate(230deg) scale(1.02, 0.98);
  }
  50% {
    transform: translateX(28px) translateY(0) rotate(270deg) scale(0.98, 1.02);
  }
  58% {
    transform: translateX(24px) translateY(-3px) rotate(310deg) scale(1.02, 0.98);
  }
  74% {
    transform: translateX(10px) translateY(0) rotate(420deg) scale(1);
  }
  92% {
    transform: translateX(2px) translateY(-2px) rotate(520deg) scale(1.01);
  }
  100% {
    transform: translateX(0) translateY(0) rotate(560deg) scale(1);
  }
}
@media (max-width: 1180px) {
  .address-page .slot7-worldcup-logo-copy strong {
    font-size: 1.54rem;
  }
  .address-page .slot7-worldcup-title {
    font-size: 1.1rem;
  }
}

/* final v41: fix empty grid column, enlarge title frame, streamline text shine, cleaner football and full right-edge bounce */
.address-page .slot7-worldcup-banner {
  grid-template-columns: 220px minmax(0, 1fr) 132px;
  gap: 10px;
  padding: 0 18px 0 20px;
}
.address-page .slot7-worldcup-copy {
  gap: 8px;
}
.address-page .slot7-worldcup-title {
  width: 100%;
  height: 68px;
  min-height: 68px;
  padding: 0 4px;
  border-radius: 26px;
  border: 1px solid rgba(111, 215, 255, 0.96);
  box-shadow: inset 0 2px 0 rgba(255,255,255,0.34), 0 10px 22px rgba(65, 183, 232, 0.24);
  background:
    linear-gradient(180deg, #7be0ff 0%, #20c0f7 50%, #1095e3 100%) padding-box,
    linear-gradient(102deg, rgba(255,255,255,0.18) 0%, rgba(255,255,255,0.18) 16%, #ffffff 24%, #d7f6ff 31%, #ffffff 38%, rgba(255,255,255,0.2) 46%, rgba(255,255,255,0.2) 57%, #ffffff 66%, #d7f6ff 73%, #ffffff 80%, rgba(255,255,255,0.18) 88%, rgba(255,255,255,0.18) 100%) text;
  background-size: 100% 100%, 260% 100%;
  background-position: 0 0, 175% 0;
  -webkit-background-clip: padding-box, text;
  background-clip: padding-box, text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  font-size: clamp(1.4rem, 1.95vw, 1.56rem);
  font-weight: 1000;
  line-height: 1;
  letter-spacing: -0.055em;
  white-space: nowrap;
  animation: slot7GifTitleRibbon 2.35s linear infinite;
}
.address-page .slot7-worldcup-visual {
  justify-self: end;
  width: 132px;
  min-width: 132px;
  height: 76px;
  min-height: 76px;
  overflow: visible;
}
.address-page .slot7-worldcup-trophy {
  left: 0;
  top: -4px;
  width: 40px;
  height: 70px;
}
.address-page .slot7-worldcup-visual-mark {
  left: 6px;
  bottom: -1px;
}
.address-page .slot7-worldcup-ball {
  left: 12px;
  right: auto;
  bottom: 3px;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cdefs%3E%3CradialGradient id='g' cx='28%25' cy='24%25' r='72%25'%3E%3Cstop offset='0%25' stop-color='%23ffffff'/%3E%3Cstop offset='58%25' stop-color='%23fafafa'/%3E%3Cstop offset='100%25' stop-color='%23d8d8d8'/%3E%3C/radialGradient%3E%3C/defs%3E%3Ccircle cx='32' cy='32' r='30' fill='url(%23g)' stroke='%23ffffff' stroke-width='2.2'/%3E%3Cpath d='M32 14l8 6-3 10H27l-3-10 8-6z' fill='%23181818'/%3E%3Cpath d='M24 20l-8 5-2 9 8 4 5-8-3-10z' fill='%23181818'/%3E%3Cpath d='M40 20l8 5 2 9-8 4-5-8 3-10z' fill='%23181818'/%3E%3Cpath d='M22 38l-6 6 6 8 10-2v-8l-10-4z' fill='%23181818'/%3E%3Cpath d='M42 38l6 6-6 8-10-2v-8l10-4z' fill='%23181818'/%3E%3Cpath d='M27 30h10l5 8-10 4-10-4 5-8z' fill='%23181818'/%3E%3Cpath d='M24 20l8-6 8 6' fill='none' stroke='%239f9f9f' stroke-width='1.1' stroke-linecap='round'/%3E%3Cpath d='M22 38l10 4 10-4' fill='none' stroke='%239f9f9f' stroke-width='1.1' stroke-linecap='round'/%3E%3Ccircle cx='22' cy='20' r='7' fill='%23ffffff' opacity='.18'/%3E%3C/svg%3E")
      center / contain no-repeat;
  box-shadow: 0 10px 18px rgba(4, 26, 52, 0.28);
  animation: slot7GifBallWallRun 4.1s cubic-bezier(0.42, 0, 0.22, 1) infinite;
}
.address-page .slot7-worldcup-ball::before,
.address-page .slot7-worldcup-ball::after,
.address-page .slot7-worldcup-ball-panel {
  display: none;
}
@keyframes slot7GifTitleRibbon {
  0% {
    background-position: 0 0, 175% 0;
    filter: brightness(1);
  }
  48% {
    background-position: 0 0, 42% 0;
    filter: brightness(1.08);
  }
  100% {
    background-position: 0 0, -96% 0;
    filter: brightness(1);
  }
}
@keyframes slot7GifBallWallRun {
  0% {
    transform: translateX(0) translateY(0) rotate(0deg) scale(1);
  }
  15% {
    transform: translateX(22px) translateY(0) rotate(170deg) scale(1);
  }
  26% {
    transform: translateX(52px) translateY(0) rotate(360deg) scale(1);
  }
  31% {
    transform: translateX(63px) translateY(-5px) rotate(430deg) scale(1.05, 0.95);
  }
  37% {
    transform: translateX(51px) translateY(0) rotate(520deg) scale(0.98, 1.02);
  }
  53% {
    transform: translateX(4px) translateY(0) rotate(760deg) scale(1);
  }
  58% {
    transform: translateX(-2px) translateY(-4px) rotate(835deg) scale(1.03, 0.97);
  }
  64% {
    transform: translateX(8px) translateY(0) rotate(910deg) scale(0.99, 1.01);
  }
  78% {
    transform: translateX(44px) translateY(0) rotate(1120deg) scale(1);
  }
  88% {
    transform: translateX(62px) translateY(0) rotate(1290deg) scale(1);
  }
  92% {
    transform: translateX(69px) translateY(-4px) rotate(1360deg) scale(1.05, 0.95);
  }
  100% {
    transform: translateX(0) translateY(0) rotate(1620deg) scale(1);
  }
}
@media (max-width: 1180px) {
  .address-page .slot7-worldcup-banner {
    grid-template-columns: 208px minmax(0, 1fr) 118px;
  }
  .address-page .slot7-worldcup-title {
    height: 62px;
    min-height: 62px;
    font-size: 1.18rem;
  }
  .address-page .slot7-worldcup-visual {
    width: 118px;
    min-width: 118px;
  }
  .address-page .slot7-worldcup-ball {
    width: 48px;
    height: 48px;
  }
}

/* final v42: stabilize third banner layout and restore visible title text */
.address-page .slot7-worldcup-backdrop-left {
  width: 124px;
  height: 124px;
  inset: auto auto -46px -38px;
  opacity: 0.3;
}
.address-page .slot7-worldcup-backdrop-right {
  width: 146px;
  height: 146px;
  inset: -56px -44px auto auto;
  opacity: 0.34;
}
.address-page .slot7-worldcup-banner {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  padding: 0 18px 0 18px !important;
}
.address-page .slot7-worldcup-logo-block {
  flex: 0 0 216px;
  min-width: 216px;
  padding: 12px 14px;
}
.address-page .slot7-worldcup-copy {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 8px;
}
.address-page .slot7-worldcup-year {
  gap: 7px;
}
.address-page .slot7-worldcup-year span {
  width: 31px;
  height: 31px;
  font-size: 1.04rem;
}
.address-page .slot7-worldcup-title {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-width: 0;
  height: 52px;
  min-height: 52px;
  margin: 0;
  padding: 0 18px;
  border-radius: 18px;
  border: 1px solid rgba(111, 215, 255, 0.96);
  background: linear-gradient(112deg, #4ab4f0 0%, #79d8ff 14%, #4ab4f0 26%, #2b9fe5 38%, #8de5ff 50%, #2f9fe3 62%, #46b4ef 76%, #9ae9ff 88%, #51baf4 100%);
  background-size: 240% 100%;
  background-position: 180% 0;
  box-shadow: inset 0 2px 0 rgba(255,255,255,0.34), 0 8px 18px rgba(35, 144, 210, 0.24);
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
  -webkit-background-clip: border-box !important;
  background-clip: border-box !important;
  text-align: center;
  text-shadow: 0 2px 10px rgba(0, 40, 92, 0.34), 0 0 12px rgba(255,255,255,0.18);
  font-size: 1.15rem;
  font-weight: 1000;
  line-height: 1;
  letter-spacing: -0.01em;
  white-space: nowrap;
  overflow: hidden;
  animation: slot7TitleBoxFlow 2.6s linear infinite;
}
.address-page .slot7-worldcup-visual {
  position: relative;
  flex: 0 0 118px;
  width: 118px;
  min-width: 118px;
  height: 76px;
  min-height: 76px;
  justify-self: auto;
  overflow: hidden;
}
.address-page .slot7-worldcup-stadium-glow {
  right: 2px;
  bottom: 6px;
  width: 86px;
  height: 28px;
  opacity: 0.5;
}
.address-page .slot7-worldcup-trophy {
  left: 0;
  right: auto;
  top: 1px;
  width: 38px;
  height: 68px;
}
.address-page .slot7-worldcup-visual-mark {
  left: 4px;
  right: auto;
  bottom: -1px;
  font-size: 0.54rem;
}
.address-page .slot7-worldcup-ball {
  left: 16px;
  right: auto;
  bottom: 2px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cdefs%3E%3CradialGradient id='g' cx='30%25' cy='26%25' r='72%25'%3E%3Cstop offset='0%25' stop-color='%23ffffff'/%3E%3Cstop offset='64%25' stop-color='%23f4f4f4'/%3E%3Cstop offset='100%25' stop-color='%23dddddd'/%3E%3C/radialGradient%3E%3C/defs%3E%3Ccircle cx='32' cy='32' r='30' fill='url(%23g)' stroke='%23ffffff' stroke-width='2'/%3E%3Cpath d='M32 14l8 6-3 9H27l-3-9 8-6z' fill='%23171717'/%3E%3Cpath d='M24 20l-8 5-2 9 8 4 5-9-3-9z' fill='%23171717'/%3E%3Cpath d='M40 20l8 5 2 9-8 4-5-9 3-9z' fill='%23171717'/%3E%3Cpath d='M22 38l-6 6 6 8 10-2v-8l-10-4z' fill='%23171717'/%3E%3Cpath d='M42 38l6 6-6 8-10-2v-8l10-4z' fill='%23171717'/%3E%3Cpath d='M27 29h10l5 9-10 4-10-4 5-9z' fill='%23171717'/%3E%3Ccircle cx='22' cy='20' r='7' fill='%23ffffff' opacity='.16'/%3E%3C/svg%3E") center / contain no-repeat;
  box-shadow: 0 8px 16px rgba(4, 26, 52, 0.24);
  animation: slot7BallRollStable 4s ease-in-out infinite;
}
.address-page .slot7-worldcup-ball::before,
.address-page .slot7-worldcup-ball::after,
.address-page .slot7-worldcup-ball-panel {
  display: none;
}
@keyframes slot7TitleBoxFlow {
  0% {
    background-position: 180% 0;
    box-shadow: inset 0 2px 0 rgba(255,255,255,0.34), 0 8px 18px rgba(35, 144, 210, 0.24);
  }
  50% {
    background-position: 52% 0;
    box-shadow: inset 0 2px 0 rgba(255,255,255,0.38), 0 10px 22px rgba(35, 144, 210, 0.3);
  }
  100% {
    background-position: -82% 0;
    box-shadow: inset 0 2px 0 rgba(255,255,255,0.34), 0 8px 18px rgba(35, 144, 210, 0.24);
  }
}
@keyframes slot7BallRollStable {
  0% {
    transform: translateX(0) translateY(0) rotate(0deg);
  }
  18% {
    transform: translateX(20px) translateY(0) rotate(180deg);
  }
  30% {
    transform: translateX(42px) translateY(0) rotate(320deg);
  }
  36% {
    transform: translateX(48px) translateY(-4px) rotate(380deg);
  }
  44% {
    transform: translateX(40px) translateY(0) rotate(460deg);
  }
  62% {
    transform: translateX(4px) translateY(0) rotate(700deg);
  }
  78% {
    transform: translateX(34px) translateY(0) rotate(940deg);
  }
  86% {
    transform: translateX(48px) translateY(-3px) rotate(1030deg);
  }
  100% {
    transform: translateX(0) translateY(0) rotate(1240deg);
  }
}
@media (max-width: 1180px) {
  .address-page .slot7-worldcup-logo-block {
    flex-basis: 204px;
    min-width: 204px;
  }
  .address-page .slot7-worldcup-title {
    font-size: 1.02rem;
    height: 48px;
    min-height: 48px;
    padding: 0 14px;
  }
  .address-page .slot7-worldcup-visual {
    flex-basis: 110px;
    width: 110px;
    min-width: 110px;
  }
}

/* final v43: align third banner to marked layout, enlarge 7T and year row, smooth football glide */
.address-page .slot7-worldcup-banner {
  gap: 12px !important;
  padding: 0 18px 0 16px !important;
}
.address-page .slot7-worldcup-logo-block {
  flex: 0 0 228px;
  min-width: 228px;
  padding: 12px 14px 11px;
}
.address-page .slot7-worldcup-logo-copy strong {
  font-size: 1.98rem;
  line-height: 0.9;
  letter-spacing: -0.03em;
}
.address-page .slot7-worldcup-logo-copy span {
  font-size: 0.74rem;
  letter-spacing: 0.16em;
}
.address-page .slot7-worldcup-copy {
  justify-content: center;
  align-items: flex-start;
  gap: 9px;
  padding-top: 7px;
}
.address-page .slot7-worldcup-year {
  gap: 8px;
  transform: translateY(5px);
}
.address-page .slot7-worldcup-year span {
  width: 38px;
  height: 38px;
  font-size: 1.26rem;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.46), 0 8px 16px rgba(22, 132, 207, 0.26);
}
.address-page .slot7-worldcup-title {
  width: auto;
  max-width: 100%;
  height: 52px;
  min-height: 52px;
  padding: 0 26px;
  border-radius: 17px;
  font-size: 1.2rem;
  letter-spacing: -0.025em;
  align-self: flex-start;
}
.address-page .slot7-worldcup-visual {
  flex: 0 0 110px;
  width: 110px;
  min-width: 110px;
  height: 78px;
  min-height: 78px;
  overflow: visible;
}
.address-page .slot7-worldcup-trophy {
  left: 6px;
  top: 0;
  width: 34px;
  height: 64px;
}
.address-page .slot7-worldcup-visual-mark {
  left: 12px;
  bottom: 0;
  font-size: 0.52rem;
}
.address-page .slot7-worldcup-ball {
  left: 58px;
  bottom: 8px;
  width: 30px;
  height: 30px;
  box-shadow: 0 7px 14px rgba(4, 26, 52, 0.2);
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cdefs%3E%3CradialGradient id='g' cx='30%25' cy='24%25' r='72%25'%3E%3Cstop offset='0%25' stop-color='%23ffffff'/%3E%3Cstop offset='62%25' stop-color='%23f7f7f7'/%3E%3Cstop offset='100%25' stop-color='%23dddddd'/%3E%3C/radialGradient%3E%3C/defs%3E%3Ccircle cx='32' cy='32' r='30' fill='url(%23g)' stroke='%23ffffff' stroke-width='1.8'/%3E%3Cpath d='M32 14l7 5.5-2.8 8.8H27.8L25 19.5 32 14z' fill='%23191919'/%3E%3Cpath d='M24.8 20l-7.8 5-1.8 8.4 7.8 4.2 4.8-8.3-3-9.3z' fill='%23191919'/%3E%3Cpath d='M39.2 20l7.8 5 1.8 8.4-7.8 4.2-4.8-8.3 3-9.3z' fill='%23191919'/%3E%3Cpath d='M23.2 38.2 17.6 44l5.6 7.2 8.8-1.8v-7.2l-8.8-4z' fill='%23191919'/%3E%3Cpath d='M40.8 38.2 46.4 44l-5.6 7.2-8.8-1.8v-7.2l8.8-4z' fill='%23191919'/%3E%3Cpath d='M27.8 28.3h8.4l4.8 8.8-9 4-9-4 4.8-8.8z' fill='%23191919'/%3E%3Ccircle cx='22' cy='21' r='6.5' fill='%23ffffff' opacity='.16'/%3E%3C/svg%3E") center / contain no-repeat;
  animation: slot7BallGlide 2.9s cubic-bezier(0.42, 0, 0.24, 1) infinite alternate;
}
@keyframes slot7BallGlide {
  0% {
    transform: translateX(0) rotate(0deg);
  }
  100% {
    transform: translateX(22px) rotate(540deg);
  }
}
@media (max-width: 1180px) {
  .address-page .slot7-worldcup-logo-block {
    flex-basis: 212px;
    min-width: 212px;
  }
  .address-page .slot7-worldcup-logo-copy strong {
    font-size: 1.74rem;
  }
  .address-page .slot7-worldcup-year span {
    width: 34px;
    height: 34px;
    font-size: 1.12rem;
  }
  .address-page .slot7-worldcup-title {
    font-size: 1.06rem;
    padding: 0 18px;
  }
}

/* final v44: tighter third-banner alignment, larger logo/year, cleaner football and smoother roll */
.address-page .slot7-worldcup-banner {
  gap: 10px !important;
  padding: 0 16px 0 14px !important;
}
.address-page .slot7-worldcup-logo-block {
  flex: 0 0 236px;
  min-width: 236px;
  padding: 12px 14px;
}
.address-page .slot7-worldcup-logo-copy {
  gap: 5px;
}
.address-page .slot7-worldcup-logo-copy strong {
  font-size: 2.14rem;
  line-height: 0.88;
  letter-spacing: -0.04em;
}
.address-page .slot7-worldcup-logo-copy span {
  font-size: 0.76rem;
  letter-spacing: 0.14em;
}
.address-page .slot7-worldcup-copy {
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding-top: 2px;
}
.address-page .slot7-worldcup-year {
  justify-content: center;
  width: 100%;
  gap: 9px;
  transform: translateY(6px);
}
.address-page .slot7-worldcup-year span {
  width: 41px;
  height: 41px;
  font-size: 1.34rem;
}
.address-page .slot7-worldcup-title {
  width: max-content;
  max-width: 100%;
  min-width: 0;
  height: 53px;
  min-height: 53px;
  padding: 0 22px;
  border-radius: 16px;
  font-size: 1.18rem;
  line-height: 1;
  letter-spacing: -0.02em;
  align-self: center;
}
.address-page .slot7-worldcup-visual {
  flex: 0 0 112px;
  width: 112px;
  min-width: 112px;
  height: 78px;
  min-height: 78px;
}
.address-page .slot7-worldcup-trophy {
  left: 8px;
  top: 2px;
  width: 32px;
  height: 61px;
}
.address-page .slot7-worldcup-visual-mark {
  left: 12px;
  bottom: 1px;
}
.address-page .slot7-worldcup-ball {
  left: 60px;
  bottom: 10px;
  width: 31px;
  height: 31px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Cdefs%3E%3CradialGradient id='bg' cx='30%25' cy='24%25' r='72%25'%3E%3Cstop offset='0%25' stop-color='%23ffffff'/%3E%3Cstop offset='68%25' stop-color='%23f6f6f6'/%3E%3Cstop offset='100%25' stop-color='%23d9d9d9'/%3E%3C/radialGradient%3E%3C/defs%3E%3Ccircle cx='32' cy='32' r='30' fill='url(%23bg)' stroke='%23ffffff' stroke-width='1.8'/%3E%3Cpath d='M32 14 39 19.5 36.3 28H27.7L25 19.5 32 14Z' fill='%23171717'/%3E%3Cpath d='M25 19.5 17.5 24.8 16 33.1 23.5 37.1 27.7 28Z' fill='%23171717'/%3E%3Cpath d='M39 19.5 46.5 24.8 48 33.1 40.5 37.1 36.3 28Z' fill='%23171717'/%3E%3Cpath d='M23.5 37.1 18.3 43.2 23.4 49.6 32 47.5V41.2Z' fill='%23171717'/%3E%3Cpath d='M40.5 37.1 45.7 43.2 40.6 49.6 32 47.5V41.2Z' fill='%23171717'/%3E%3Cpath d='M27.7 28h8.6l4.2 9.1L32 41.2l-8.5-4.1Z' fill='%23171717'/%3E%3Cpath d='M32 14 39 19.5 46.5 24.8 48 33.1 45.7 43.2 40.6 49.6 32 47.5 23.4 49.6 18.3 43.2 16 33.1 17.5 24.8 25 19.5Z' fill='none' stroke='%23b7b7b7' stroke-width='1.05' stroke-linejoin='round'/%3E%3Ccircle cx='22' cy='21' r='6.5' fill='%23ffffff' opacity='.16'/%3E%3C/svg%3E") center / contain no-repeat;
  animation: slot7BallRollSilky 3.1s linear infinite;
}
@keyframes slot7BallRollSilky {
  0% {
    transform: translateX(0) rotate(0deg);
  }
  50% {
    transform: translateX(20px) rotate(360deg);
  }
  100% {
    transform: translateX(0) rotate(720deg);
  }
}
@media (max-width: 1180px) {
  .address-page .slot7-worldcup-logo-block {
    flex-basis: 220px;
    min-width: 220px;
  }
  .address-page .slot7-worldcup-logo-copy strong {
    font-size: 1.86rem;
  }
  .address-page .slot7-worldcup-year span {
    width: 36px;
    height: 36px;
    font-size: 1.18rem;
  }
  .address-page .slot7-worldcup-title {
    font-size: 1.08rem;
    padding: 0 18px;
  }
}

/* final v45: push 2026 down to title line, move trophy left, enlarge football with clearer pentagons */
.address-page .slot7-worldcup-copy {
  align-items: flex-start;
  justify-content: center;
  gap: 6px;
  padding-top: 0;
}
.address-page .slot7-worldcup-year {
  justify-content: flex-start;
  transform: translateY(17px);
}
.address-page .slot7-worldcup-title {
  align-self: flex-start;
}
.address-page .slot7-worldcup-visual {
  flex: 0 0 126px;
  width: 126px;
  min-width: 126px;
  height: 82px;
  min-height: 82px;
}
.address-page .slot7-worldcup-trophy {
  left: -24px;
  top: 2px;
  width: 33px;
  height: 62px;
}
.address-page .slot7-worldcup-visual-mark {
  left: -19px;
  bottom: 2px;
}
.address-page .slot7-worldcup-ball {
  left: 52px;
  bottom: 5px;
  width: 42px;
  height: 42px;
  box-shadow: 0 10px 18px rgba(4, 26, 52, 0.24);
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 84 84'%3E%3Cdefs%3E%3CradialGradient id='bg' cx='30%25' cy='24%25' r='72%25'%3E%3Cstop offset='0%25' stop-color='%23ffffff'/%3E%3Cstop offset='70%25' stop-color='%23f3f3f3'/%3E%3Cstop offset='100%25' stop-color='%23d6d6d6'/%3E%3C/radialGradient%3E%3C/defs%3E%3Ccircle cx='42' cy='42' r='39' fill='url(%23bg)' stroke='%23ffffff' stroke-width='2.2'/%3E%3Cpath d='M42 16 51.5 23 47.8 35H36.2L32.5 23 42 16Z' fill='%23101010'/%3E%3Cpath d='M32.5 23 22.2 30.4 20.2 41.3 30.6 46.7 36.2 35Z' fill='%23101010'/%3E%3Cpath d='M51.5 23 61.8 30.4 63.8 41.3 53.4 46.7 47.8 35Z' fill='%23101010'/%3E%3Cpath d='M30.6 46.7 23.6 54.6 30.4 63 42 60.1V51.9Z' fill='%23101010'/%3E%3Cpath d='M53.4 46.7 60.4 54.6 53.6 63 42 60.1V51.9Z' fill='%23101010'/%3E%3Cpath d='M36.2 35h11.6l5.6 11.7L42 51.9l-11.4-5.2Z' fill='%23101010'/%3E%3Cpath d='M42 16 51.5 23 61.8 30.4 63.8 41.3 60.4 54.6 53.6 63 42 60.1 30.4 63 23.6 54.6 20.2 41.3 22.2 30.4 32.5 23Z' fill='none' stroke='%23a3a3a3' stroke-width='1.4' stroke-linejoin='round'/%3E%3Cpath d='M36.2 35 30.6 46.7 42 51.9 53.4 46.7 47.8 35Z' fill='none' stroke='%23bcbcbc' stroke-width='1'/%3E%3Ccircle cx='27.5' cy='27' r='8.8' fill='%23ffffff' opacity='.15'/%3E%3C/svg%3E") center / contain no-repeat;
  animation: slot7BallRollPremium 3.25s linear infinite;
}
@keyframes slot7BallRollPremium {
  0% {
    transform: translateX(0) rotate(0deg);
  }
  50% {
    transform: translateX(24px) rotate(360deg);
  }
  100% {
    transform: translateX(0) rotate(720deg);
  }
}
@media (max-width: 1180px) {
  .address-page .slot7-worldcup-year {
    transform: translateY(13px);
  }
  .address-page .slot7-worldcup-visual {
    flex-basis: 118px;
    width: 118px;
    min-width: 118px;
  }
  .address-page .slot7-worldcup-ball {
    width: 38px;
    height: 38px;
    left: 49px;
  }
}

/* final v46: lower 2026 further, align copy on one visual band, shift trophy left, rebuild bigger premium football */
.address-page .slot7-worldcup-copy {
  align-content: center;
  gap: 4px;
  padding-top: 5px;
}
.address-page .slot7-worldcup-year {
  transform: translateY(25px);
}
.address-page .slot7-worldcup-title {
  align-self: flex-start;
  transform: translateY(3px);
}
.address-page .slot7-worldcup-trophy {
  left: -56px;
  top: 1px;
}
.address-page .slot7-worldcup-visual-mark {
  left: -50px;
  bottom: 3px;
}
.address-page .slot7-worldcup-ball {
  left: 48px;
  bottom: 1px;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  box-shadow: 0 14px 24px rgba(4, 26, 52, 0.28);
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 96 96'%3E%3Cdefs%3E%3CradialGradient id='ball' cx='30%25' cy='26%25' r='76%25'%3E%3Cstop offset='0%25' stop-color='%23ffffff'/%3E%3Cstop offset='50%25' stop-color='%23fbfbfb'/%3E%3Cstop offset='78%25' stop-color='%23e4e4e4'/%3E%3Cstop offset='100%25' stop-color='%23cfcfcf'/%3E%3C/radialGradient%3E%3CradialGradient id='shine' cx='24%25' cy='20%25' r='34%25'%3E%3Cstop offset='0%25' stop-color='%23ffffff' stop-opacity='.92'/%3E%3Cstop offset='100%25' stop-color='%23ffffff' stop-opacity='0'/%3E%3C/radialGradient%3E%3ClinearGradient id='edge' x1='0%25' y1='0%25' x2='100%25' y2='100%25'%3E%3Cstop offset='0%25' stop-color='%23ffffff'/%3E%3Cstop offset='100%25' stop-color='%23b7b7b7'/%3E%3C/linearGradient%3E%3C/defs%3E%3Ccircle cx='48' cy='48' r='45' fill='url(%23ball)' stroke='url(%23edge)' stroke-width='2.4'/%3E%3Cpath d='M48 19.5 59.3 27.6 54.9 41.5H41.1L36.7 27.6 48 19.5Z' fill='%23070707'/%3E%3Cpath d='M36.7 27.6 24.3 36.4 22 48.8 34.8 55.3 41.1 41.5Z' fill='%23090909'/%3E%3Cpath d='M59.3 27.6 71.7 36.4 74 48.8 61.2 55.3 54.9 41.5Z' fill='%23090909'/%3E%3Cpath d='M34.8 55.3 26.5 64.2 34.5 74 48 70.7V61.5Z' fill='%23080808'/%3E%3Cpath d='M61.2 55.3 69.5 64.2 61.5 74 48 70.7V61.5Z' fill='%23080808'/%3E%3Cpath d='M41.1 41.5h13.8l6.3 13.8L48 61.5l-13.2-6.2Z' fill='%230b0b0b'/%3E%3Cpath d='M48 19.5 59.3 27.6 71.7 36.4 74 48.8 69.5 64.2 61.5 74 48 70.7 34.5 74 26.5 64.2 22 48.8 24.3 36.4 36.7 27.6Z' fill='none' stroke='%23a9a9a9' stroke-width='1.8' stroke-linejoin='round'/%3E%3Cpath d='M41.1 41.5 34.8 55.3 48 61.5 61.2 55.3 54.9 41.5Z' fill='none' stroke='%23c9c9c9' stroke-width='1.2'/%3E%3Cpath d='M34.8 55.3 26.5 64.2M61.2 55.3 69.5 64.2M36.7 27.6 24.3 36.4M59.3 27.6 71.7 36.4' stroke='%23d7d7d7' stroke-width='1.15' stroke-linecap='round'/%3E%3Ccircle cx='34' cy='30' r='18' fill='url(%23shine)'/%3E%3Cellipse cx='61' cy='73' rx='16' ry='6' fill='%23000000' opacity='.08'/%3E%3C/svg%3E") center / contain no-repeat;
  animation: slot7BallRollUltra 3.5s linear infinite;
}
@keyframes slot7BallRollUltra {
  0% {
    transform: translateX(0) rotate(0deg);
  }
  50% {
    transform: translateX(28px) rotate(360deg);
  }
  100% {
    transform: translateX(0) rotate(720deg);
  }
}
@media (max-width: 1180px) {
  .address-page .slot7-worldcup-copy {
    padding-top: 4px;
  }
  .address-page .slot7-worldcup-year {
    transform: translateY(20px);
  }
  .address-page .slot7-worldcup-trophy {
    left: -46px;
  }
  .address-page .slot7-worldcup-visual-mark {
    left: -40px;
  }
  .address-page .slot7-worldcup-ball {
    left: 46px;
    width: 44px;
    height: 44px;
  }
}

/* final v47: replace third banner with embedded GIF while keeping ad-slot height and avoiding local file paths */
.address-page .slot7-banner-panel-gif {
  padding: 0;
  border-color: rgba(93, 163, 233, 0.78);
  background: linear-gradient(135deg, #081220 0%, #0e1f34 100%);
  box-shadow: 0 18px 36px rgba(29, 68, 116, 0.20);
}
.address-page .slot7-banner-panel-gif:hover {
  border-color: rgba(118, 191, 255, 0.92);
  box-shadow: 0 22px 40px rgba(29, 68, 116, 0.28);
}
.address-page .slot7-banner-gif-wrap {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.address-page .slot7-banner-gif {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: fill;
}

/* final v48: use embedded GIFs for 9G and 7T banners, keep first-banner height, preserve native GIF animation */
.address-page .ad-banner-panel-premium-gif,
.address-page .slot7-banner-panel-gif {
  min-height: var(--promo-banner-height);
  height: var(--promo-banner-height);
  max-height: var(--promo-banner-height);
  padding: 0;
  border-radius: 24px;
  overflow: hidden;
}
.address-page .ad-banner-panel-premium-gif {
  background: #07111d;
  border-color: rgba(214, 168, 70, 0.42);
  box-shadow: 0 20px 42px rgba(39, 27, 8, 0.22);
}
.address-page .slot7-banner-panel-gif {
  background: #081220;
  border-color: rgba(93, 163, 233, 0.78);
  box-shadow: 0 18px 36px rgba(29, 68, 116, 0.20);
}
.address-page .ad-banner-panel-premium-gif:hover {
  border-color: rgba(233, 190, 101, 0.64);
  box-shadow: 0 24px 46px rgba(39, 27, 8, 0.28);
}
.address-page .slot7-banner-panel-gif:hover {
  border-color: rgba(118, 191, 255, 0.92);
  box-shadow: 0 22px 40px rgba(29, 68, 116, 0.28);
}
.address-page .ad-banner-gif-wrap,
.address-page .slot7-banner-gif-wrap {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.address-page .ad-banner-gif,
.address-page .slot7-banner-gif {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: fill;
}
@media (max-width: 920px) {
  .address-page .ad-banner-panel-premium-gif,
  .address-page .slot7-banner-panel-gif {
    min-height: var(--promo-banner-height);
    height: auto;
    max-height: none;
  }
}

/* final v49: unify GIF banner edge colors by removing outer frame and trimming inconsistent source-edge pixels */
.address-page .ad-banner-panel-premium-gif,
.address-page .slot7-banner-panel-gif {
  padding: 0;
  border: none !important;
  background: transparent !important;
  box-shadow: 0 18px 34px rgba(22, 32, 48, 0.16);
  isolation: isolate;
}
.address-page .premium-banner-gif-wrap,
.address-page .slot7-banner-gif-wrap {
  width: 100%;
  height: 100%;
  border-radius: inherit;
}
.address-page .premium-banner-gif-wrap {
  background: #100d09;
}
.address-page .slot7-banner-gif-wrap {
  background: #f6fbff;
}
.address-page .ad-banner-gif,
.address-page .slot7-banner-gif {
  width: calc(100% + 6px);
  height: calc(100% + 6px);
  margin: -3px;
  max-width: none;
  border-radius: inherit;
  object-fit: fill;
  transform: translateZ(0);
}
.address-page .ad-banner-panel-premium-gif:hover,
.address-page .slot7-banner-panel-gif:hover {
  border: none !important;
  box-shadow: 0 22px 40px rgba(22, 32, 48, 0.22);
}

/* final v50: scale GIFs slightly inward so the original four-side and rounded-corner border colors stay fully visible */
.address-page .premium-banner-gif-wrap,
.address-page .slot7-banner-gif-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 3px;
  box-sizing: border-box;
  overflow: hidden;
}
.address-page .ad-banner-gif,
.address-page .slot7-banner-gif {
  width: 100%;
  height: 100%;
  margin: 0;
  max-width: 100%;
  object-fit: fill;
  transform: none;
}

/* final v51: keep each banner theme distinct while making the second and third frames feel harmonious with the first */
.address-page .ad-banner-panel-premium-gif,
.address-page .slot7-banner-panel-gif {
  padding: 0;
  border-width: 1px !important;
  border-style: solid !important;
  border-radius: 24px;
  overflow: hidden;
  isolation: isolate;
}
.address-page .ad-banner-panel-premium-gif {
  background: linear-gradient(135deg, rgba(18, 15, 11, 0.98) 0%, rgba(35, 29, 20, 0.98) 52%, rgba(17, 14, 11, 0.98) 100%) !important;
  border-color: rgba(171, 141, 76, 0.88) !important;
  box-shadow: 0 20px 44px rgba(43, 31, 14, 0.22);
}
.address-page .ad-banner-panel-premium-gif:hover {
  border-color: rgba(212, 181, 113, 0.96) !important;
  box-shadow: 0 24px 52px rgba(43, 31, 14, 0.28);
}
.address-page .slot7-banner-panel-gif {
  background: linear-gradient(135deg, rgba(248, 253, 255, 0.99) 0%, rgba(237, 247, 255, 0.99) 48%, rgba(229, 243, 255, 0.99) 100%) !important;
  border-color: rgba(136, 205, 255, 0.96) !important;
  box-shadow: 0 20px 44px rgba(67, 143, 214, 0.18);
}
.address-page .slot7-banner-panel-gif:hover {
  border-color: rgba(94, 181, 247, 0.98) !important;
  box-shadow: 0 24px 52px rgba(67, 143, 214, 0.24);
}
.address-page .premium-banner-gif-wrap,
.address-page .slot7-banner-gif-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  padding: 5px;
  box-sizing: border-box;
  border-radius: 21px;
  overflow: hidden;
}
.address-page .premium-banner-gif-wrap {
  background: linear-gradient(180deg, rgba(42, 34, 24, 0.90), rgba(20, 16, 11, 0.92));
}
.address-page .slot7-banner-gif-wrap {
  background: linear-gradient(180deg, rgba(243, 251, 255, 0.98), rgba(234, 246, 255, 0.98));
}
.address-page .ad-banner-gif,
.address-page .slot7-banner-gif {
  width: 100%;
  height: 100%;
  margin: 0;
  max-width: 100%;
  border-radius: 18px;
  object-fit: fill;
  transform: none;
}

/* final v52: enlarge the 9G and 7T inner frames so they sit closer to the outer card frame */
.address-page .premium-banner-gif-wrap,
.address-page .slot7-banner-gif-wrap {
  padding: 1px;
  border-radius: 23px;
}
.address-page .ad-banner-gif,
.address-page .slot7-banner-gif {
  width: calc(100% + 2px);
  height: calc(100% + 2px);
  margin: -1px;
  max-width: none;
  border-radius: 22px;
}

/* final v53: use a true thin theme outline like the first banner, keep corner color continuous, and reduce edge thickness */
.address-page .ad-banner-panel-premium-gif,
.address-page .slot7-banner-panel-gif {
  position: relative;
  border: 1px solid transparent !important;
  border-radius: 24px;
  padding: 0;
  overflow: hidden;
}
.address-page .ad-banner-panel-premium-gif::after,
.address-page .slot7-banner-panel-gif::after {
  content: "";
  position: absolute;
  inset: 0;
  border: 1px solid transparent;
  border-radius: inherit;
  pointer-events: none;
  z-index: 3;
}
.address-page .ad-banner-panel-premium-gif {
  background: linear-gradient(135deg, rgba(16, 13, 10, 0.98) 0%, rgba(32, 27, 19, 0.98) 55%, rgba(14, 12, 10, 0.98) 100%) !important;
  box-shadow: 0 20px 44px rgba(43, 31, 14, 0.20);
}
.address-page .ad-banner-panel-premium-gif::after {
  border-color: rgba(171, 141, 76, 0.82);
}
.address-page .ad-banner-panel-premium-gif:hover::after {
  border-color: rgba(206, 177, 112, 0.92);
}
.address-page .slot7-banner-panel-gif {
  background: linear-gradient(135deg, rgba(247, 252, 255, 0.99) 0%, rgba(239, 248, 255, 0.99) 52%, rgba(231, 244, 255, 0.99) 100%) !important;
  box-shadow: 0 20px 44px rgba(67, 143, 214, 0.16);
}
.address-page .slot7-banner-panel-gif::after {
  border-color: rgba(136, 205, 255, 0.90);
}
.address-page .slot7-banner-panel-gif:hover::after {
  border-color: rgba(97, 184, 248, 0.96);
}
.address-page .premium-banner-gif-wrap,
.address-page .slot7-banner-gif-wrap {
  width: 100%;
  height: 100%;
  padding: 1px;
  box-sizing: border-box;
  border-radius: 23px;
  background: transparent;
}
.address-page .ad-banner-gif,
.address-page .slot7-banner-gif {
  width: calc(100% + 2px);
  height: calc(100% + 2px);
  margin: -1px;
  max-width: none;
  border-radius: 22px;
  object-fit: fill;
}

/* final v54: remove 9G black-edge overflow and 7T white-edge overflow while keeping the thin themed outline */
.address-page .premium-banner-gif-wrap,
.address-page .slot7-banner-gif-wrap {
  padding: 0;
  border-radius: 23px;
  overflow: hidden;
}
.address-page .ad-banner-gif,
.address-page .slot7-banner-gif {
  width: 100%;
  height: 100%;
  margin: 0;
  max-width: 100%;
  border-radius: 23px;
  object-fit: fill;
}

/* final v55: slightly enlarge each GIF inside its clipped frame so the inner content sits closer to the outer border without overflow */
.address-page .premium-banner-gif-wrap,
.address-page .slot7-banner-gif-wrap {
  overflow: hidden;
}
.address-page .ad-banner-panel-premium-gif .ad-banner-gif {
  transform: scale(1.015);
  transform-origin: center center;
}
.address-page .slot7-banner-panel-gif .slot7-banner-gif {
  transform: scale(1.026);
  transform-origin: center center;
}

/* final v56: pull back GIF enlargement so edge elements stay fully visible */
.address-page .ad-banner-panel-premium-gif .ad-banner-gif {
  transform: scale(1.006);
}
.address-page .slot7-banner-panel-gif .slot7-banner-gif {
  transform: none;
}

/* final v57: stop clipping edge artwork in the GIF banners, especially 7T left icons and right football */
.address-page .ad-banner-panel-premium-gif .ad-banner-gif {
  transform: scale(1.001);
  transform-origin: center center;
}
.address-page .slot7-banner-panel-gif .slot7-banner-gif {
  transform: scale(1);
  transform-origin: center center;
}

/* final v58: switch 9G and 7T banners to video-first media layers with GIF fallback */
.address-page .premium-banner-gif-wrap,
.address-page .slot7-banner-gif-wrap {
  position: relative;
}
.address-page .ad-banner-media {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 23px;
  object-fit: fill;
}
.address-page .ad-banner-video,
.address-page .slot7-banner-video {
  opacity: 0;
  z-index: 2;
  background: transparent;
  transition: opacity 220ms ease;
}
.address-page .ad-banner-video.is-ready,
.address-page .slot7-banner-video.is-ready {
  opacity: 1;
}
.address-page .ad-banner-video.is-ready + .ad-banner-gif,
.address-page .slot7-banner-video.is-ready + .slot7-banner-gif {
  opacity: 0;
}
.address-page .ad-banner-gif,
.address-page .slot7-banner-gif {
  z-index: 1;
}
.address-page .ad-banner-panel-premium-gif .ad-banner-video,
.address-page .ad-banner-panel-premium-gif .ad-banner-gif {
  transform: scale(1.001);
  transform-origin: center center;
}
.address-page .slot7-banner-panel-gif .slot7-banner-video,
.address-page .slot7-banner-panel-gif .slot7-banner-gif {
  transform: scale(1);
  transform-origin: center center;
}

/* final v59: make banner videos visible via external JS readiness hooks and stop fill-stretch distortion */
.address-page .premium-banner-gif-wrap,
.address-page .slot7-banner-gif-wrap {
  overflow: hidden;
  background: transparent;
}
.address-page .ad-banner-media {
  object-fit: contain;
  background: transparent;
}
.address-page .ad-banner-video,
.address-page .slot7-banner-video {
  opacity: 0;
  z-index: 2;
  pointer-events: none;
}
.address-page .ad-banner-video.is-ready,
.address-page .slot7-banner-video.is-ready {
  opacity: 1;
}
.address-page .ad-banner-video.is-ready + .ad-banner-gif,
.address-page .slot7-banner-video.is-ready + .slot7-banner-gif {
  opacity: 0;
}

/* final v60: keep the premium and 7T banner frames in their harmonious hover state all the time */
.address-page .ad-banner-panel-premium-gif {
  box-shadow: 0 24px 46px rgba(39, 27, 8, 0.28) !important;
}
.address-page .ad-banner-panel-premium-gif::after {
  border-color: rgba(206, 177, 112, 0.92) !important;
}
.address-page .ad-banner-panel-premium-gif:hover {
  box-shadow: 0 24px 46px rgba(39, 27, 8, 0.28) !important;
}
.address-page .ad-banner-panel-premium-gif:hover::after {
  border-color: rgba(206, 177, 112, 0.92) !important;
}
.address-page .slot7-banner-panel-gif {
  box-shadow: 0 22px 40px rgba(29, 68, 116, 0.28) !important;
}
.address-page .slot7-banner-panel-gif::after {
  border-color: rgba(97, 184, 248, 0.96) !important;
}
.address-page .slot7-banner-panel-gif:hover {
  box-shadow: 0 22px 40px rgba(29, 68, 116, 0.28) !important;
}
.address-page .slot7-banner-panel-gif:hover::after {
  border-color: rgba(97, 184, 248, 0.96) !important;
}

/* final v61: match the real hover frame by removing the outer physical border in the default state too */
.address-page .ad-banner-panel-premium-gif,
.address-page .slot7-banner-panel-gif {
  border: none !important;
}
.address-page .ad-banner-panel-premium-gif:hover,
.address-page .slot7-banner-panel-gif:hover {
  border: none !important;
}

/* final v62: force the 9G and 7T MP4 layers to be the default visible media instead of the GIF fallback */
.address-page .ad-banner-panel-premium-gif .ad-banner-video,
.address-page .slot7-banner-panel-gif .slot7-banner-video {
  opacity: 1 !important;
  object-fit: fill !important;
}
.address-page .ad-banner-panel-premium-gif .ad-banner-gif,
.address-page .slot7-banner-panel-gif .slot7-banner-gif {
  opacity: 0 !important;
  pointer-events: none;
}

/* final v63: give the 9G and 7T video banners the same deepened selected hover feel as the first banner */
.address-page .ad-banner-panel-premium-gif,
.address-page .slot7-banner-panel-gif {
  transform: translateZ(0);
  transition: box-shadow 0.22s ease, transform 0.22s ease, filter 0.22s ease;
}
.address-page .ad-banner-panel-premium-gif::before,
.address-page .slot7-banner-panel-gif::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  opacity: 0;
  z-index: 2;
  transition: opacity 0.22s ease;
}
.address-page .ad-banner-panel-premium-gif::before {
  background: linear-gradient(180deg, rgba(8, 6, 4, 0.04) 0%, rgba(10, 8, 6, 0.12) 100%);
}
.address-page .slot7-banner-panel-gif::before {
  background: linear-gradient(180deg, rgba(5, 27, 44, 0.05) 0%, rgba(7, 54, 90, 0.14) 100%);
}
.address-page .ad-banner-panel-premium-gif .ad-banner-video,
.address-page .ad-banner-panel-premium-gif .ad-banner-gif,
.address-page .slot7-banner-panel-gif .slot7-banner-video,
.address-page .slot7-banner-panel-gif .slot7-banner-gif {
  z-index: 1 !important;
}
.address-page .ad-banner-panel-premium-gif:hover,
.address-page .slot7-banner-panel-gif:hover {
  transform: translateY(-1px);
}
.address-page .ad-banner-panel-premium-gif:hover::before,
.address-page .slot7-banner-panel-gif:hover::before {
  opacity: 1;
}
.address-page .ad-banner-panel-premium-gif:hover .ad-banner-video,
.address-page .ad-banner-panel-premium-gif:hover .ad-banner-gif,
.address-page .slot7-banner-panel-gif:hover .slot7-banner-video,
.address-page .slot7-banner-panel-gif:hover .slot7-banner-gif {
  filter: brightness(0.94) saturate(1.03);
}

/* final v63: butterfly cursor companion with twinkling stars across the site */
.cursor-butterfly-layer {
  position: fixed;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 9999;
}
.cursor-butterfly {
  position: absolute;
  width: 42px;
  height: 34px;
  transform: translate3d(-999px, -999px, 0);
  transform-origin: 50% 58%;
  filter: drop-shadow(0 5px 12px rgba(82, 47, 131, 0.18));
  will-change: transform;
}
.cursor-butterfly-wing {
  position: absolute;
  top: 4px;
  width: 19px;
  height: 24px;
  border-radius: 78% 22% 74% 28%;
  background:
    radial-gradient(circle at 34% 30%, rgba(255, 255, 255, 0.92), transparent 22%),
    radial-gradient(circle at 66% 62%, rgba(255, 221, 150, 0.86), transparent 20%),
    linear-gradient(155deg, rgba(117, 235, 255, 0.95) 0%, rgba(131, 159, 255, 0.92) 48%, rgba(193, 120, 255, 0.96) 100%);
  border: 1px solid rgba(255, 255, 255, 0.52);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.66), 0 3px 8px rgba(104, 94, 196, 0.18);
}
.cursor-butterfly-wing-left {
  left: 1px;
  transform-origin: 100% 58%;
  animation: butterflyWingLeft 240ms ease-in-out infinite alternate;
}
.cursor-butterfly-wing-right {
  right: 1px;
  transform-origin: 0% 58%;
  transform: scaleX(-1);
  animation: butterflyWingRight 240ms ease-in-out infinite alternate;
}
.cursor-butterfly-body {
  position: absolute;
  left: 50%;
  top: 6px;
  width: 8px;
  height: 24px;
  margin-left: -4px;
  border-radius: 999px;
  background: linear-gradient(180deg, #5d3b18 0%, #3f2410 48%, #251106 100%);
  box-shadow: inset 0 1px 0 rgba(255, 245, 214, 0.45);
}
.cursor-butterfly-body::before,
.cursor-butterfly-body::after {
  content: "";
  position: absolute;
  top: -6px;
  width: 1px;
  height: 8px;
  background: linear-gradient(180deg, rgba(85, 50, 18, 0.9), rgba(85, 50, 18, 0));
}
.cursor-butterfly-body::before {
  left: 1px;
  transform: rotate(-28deg);
}
.cursor-butterfly-body::after {
  right: 1px;
  transform: rotate(28deg);
}
.cursor-butterfly-glow {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 34px;
  height: 16px;
  margin-left: -17px;
  margin-top: -1px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(255, 249, 187, 0.52) 0%, rgba(255, 249, 187, 0.08) 62%, transparent 100%);
  filter: blur(1px);
}
.cursor-butterfly-star {
  position: absolute;
  width: 14px;
  height: 14px;
  transform: translate3d(-999px, -999px, 0);
  will-change: transform, opacity;
}
.cursor-butterfly-star::before,
.cursor-butterfly-star::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 2px;
  height: 12px;
  margin-left: -1px;
  margin-top: -6px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0), rgba(255, 250, 199, 0.98), rgba(255, 255, 255, 0));
  box-shadow: 0 0 10px rgba(255, 240, 170, 0.48);
}
.cursor-butterfly-star::after {
  transform: rotate(90deg);
}
.cursor-butterfly-star:nth-child(2n)::before,
.cursor-butterfly-star:nth-child(2n)::after {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0), rgba(188, 242, 255, 0.98), rgba(255, 255, 255, 0));
  box-shadow: 0 0 10px rgba(145, 225, 255, 0.44);
}
.cursor-butterfly-star {
  animation: butterflyStarTwinkle 1.35s ease-in-out infinite;
}
.cursor-butterfly-star-1 { animation-delay: 0s; }
.cursor-butterfly-star-2 { animation-delay: 0.18s; }
.cursor-butterfly-star-3 { animation-delay: 0.36s; }
.cursor-butterfly-star-4 { animation-delay: 0.54s; }
.cursor-butterfly-star-5 { animation-delay: 0.72s; }
.cursor-butterfly-star-6 { animation-delay: 0.9s; }

@keyframes butterflyWingLeft {
  from { transform: rotate(-20deg) scale(1.02); }
  to { transform: rotate(18deg) scale(0.92); }
}
@keyframes butterflyWingRight {
  from { transform: scaleX(-1) rotate(-20deg) scale(1.02); }
  to { transform: scaleX(-1) rotate(18deg) scale(0.92); }
}
@keyframes butterflyStarTwinkle {
  0%, 100% { opacity: 0.34; }
  50% { opacity: 1; }
}

@media (pointer: coarse) {
  .cursor-butterfly-layer {
    display: none !important;
  }
}

/* final v64: make the cursor butterfly smaller, symmetrical, and calmer around the cursor tip */
.cursor-butterfly {
  width: 30px;
  height: 26px;
  transform-origin: 50% 62%;
  filter: drop-shadow(0 4px 9px rgba(82, 47, 131, 0.14));
}
.cursor-butterfly-wing {
  top: 3px;
  width: 13px;
  height: 18px;
  border: 1px solid rgba(255, 255, 255, 0.48);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.62), 0 2px 6px rgba(104, 94, 196, 0.14);
}
.cursor-butterfly-wing-left {
  left: 1px;
  border-radius: 82% 18% 72% 28% / 82% 28% 72% 18%;
  transform-origin: 100% 58%;
  animation: butterflyWingLeft 260ms ease-in-out infinite alternate;
}
.cursor-butterfly-wing-right {
  right: 1px;
  border-radius: 18% 82% 28% 72% / 28% 82% 18% 72%;
  transform-origin: 0% 58%;
  transform: none;
  animation: butterflyWingRight 260ms ease-in-out infinite alternate;
}
.cursor-butterfly-body {
  top: 5px;
  width: 5px;
  height: 17px;
  margin-left: -2.5px;
  box-shadow: inset 0 1px 0 rgba(255, 245, 214, 0.4), 0 0 3px rgba(43, 24, 10, 0.1);
}
.cursor-butterfly-body::before,
.cursor-butterfly-body::after {
  top: -5px;
  height: 7px;
}
.cursor-butterfly-glow {
  width: 24px;
  height: 10px;
  margin-left: -12px;
  margin-top: 2px;
  background: radial-gradient(circle, rgba(255, 249, 187, 0.42) 0%, rgba(255, 249, 187, 0.06) 60%, transparent 100%);
}
.cursor-butterfly-star {
  width: 10px;
  height: 10px;
}
.cursor-butterfly-star::before,
.cursor-butterfly-star::after {
  width: 1.5px;
  height: 9px;
  margin-left: -0.75px;
  margin-top: -4.5px;
}
@keyframes butterflyWingLeft {
  from { transform: rotate(-26deg) scale(1.02); }
  to { transform: rotate(12deg) scale(0.9); }
}
@keyframes butterflyWingRight {
  from { transform: rotate(26deg) scale(1.02); }
  to { transform: rotate(-12deg) scale(0.9); }
}

/* final v65: keep 9G and 7T hover feedback on the border only, without darkening the media */
.address-page .ad-banner-panel-premium-gif,
.address-page .slot7-banner-panel-gif {
  transition: box-shadow 0.22s ease, border-color 0.22s ease, transform 0.22s ease;
}
.address-page .ad-banner-panel-premium-gif::before,
.address-page .slot7-banner-panel-gif::before {
  opacity: 0 !important;
}
.address-page .ad-banner-panel-premium-gif:hover,
.address-page .slot7-banner-panel-gif:hover {
  transform: none;
}
.address-page .ad-banner-panel-premium-gif:hover .ad-banner-video,
.address-page .ad-banner-panel-premium-gif:hover .ad-banner-gif,
.address-page .slot7-banner-panel-gif:hover .slot7-banner-video,
.address-page .slot7-banner-panel-gif:hover .slot7-banner-gif {
  filter: none !important;
}
.address-page .ad-banner-panel-premium-gif:hover::after {
  border-color: rgba(230, 201, 126, 1) !important;
  box-shadow: inset 0 0 0 1px rgba(255, 225, 152, 0.22);
}
.address-page .slot7-banner-panel-gif:hover::after {
  border-color: rgba(124, 209, 255, 1) !important;
  box-shadow: inset 0 0 0 1px rgba(190, 237, 255, 0.2);
}
/* final v66: reshape the cursor butterfly into a side-profile flyer and extend the brighter matching star tail */
.cursor-butterfly {
  width: 36px;
  height: 24px;
  transform-origin: 76% 60%;
  filter: drop-shadow(0 4px 10px rgba(55, 118, 186, 0.22));
}
.cursor-butterfly-wing {
  top: auto;
  border: 1px solid rgba(255, 255, 255, 0.5);
  background:
    radial-gradient(circle at 28% 28%, rgba(255, 255, 255, 0.98), transparent 24%),
    radial-gradient(circle at 52% 74%, rgba(243, 223, 255, 0.56), transparent 28%),
    linear-gradient(140deg, rgba(112, 247, 255, 0.98) 0%, rgba(88, 198, 255, 0.96) 46%, rgba(178, 120, 255, 0.95) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    inset 0 -2px 5px rgba(87, 69, 170, 0.18),
    0 3px 10px rgba(59, 117, 194, 0.18);
}
.cursor-butterfly-wing-left {
  left: 1px;
  top: 1px;
  width: 18px;
  height: 16px;
  border-radius: 80% 20% 88% 12% / 84% 30% 70% 16%;
  transform-origin: 86% 68%;
  animation: butterflyWingLeft 220ms ease-in-out infinite alternate;
}
.cursor-butterfly-wing-right {
  left: 5px;
  top: 11px;
  right: auto;
  width: 13px;
  height: 11px;
  border-radius: 82% 18% 84% 16% / 72% 42% 58% 28%;
  transform-origin: 88% 30%;
  animation: butterflyWingRight 220ms ease-in-out infinite alternate;
}
.cursor-butterfly-body {
  left: 17px;
  top: 8px;
  width: 15px;
  height: 5px;
  margin-left: 0;
  border-radius: 999px 70% 70% 999px;
  background: linear-gradient(90deg, rgba(66, 38, 14, 0.96) 0%, rgba(93, 56, 24, 0.98) 32%, rgba(38, 17, 8, 0.96) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 239, 210, 0.42),
    0 0 4px rgba(33, 14, 6, 0.12);
  transform: rotate(8deg);
}
.cursor-butterfly-body::before,
.cursor-butterfly-body::after {
  content: "";
  position: absolute;
  background: none;
}
.cursor-butterfly-body::before {
  right: -2px;
  top: -1px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, rgba(255, 236, 188, 0.82), rgba(84, 48, 18, 0.96) 72%);
  box-shadow: 0 0 4px rgba(46, 21, 8, 0.14);
}
.cursor-butterfly-body::after {
  left: -7px;
  top: 2px;
  width: 9px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(58, 25, 9, 0), rgba(58, 25, 9, 0.9) 46%, rgba(58, 25, 9, 0.1) 100%);
}
.cursor-butterfly-glow {
  left: 15px;
  top: 9px;
  width: 26px;
  height: 12px;
  margin-left: 0;
  margin-top: 0;
  background: radial-gradient(circle, rgba(125, 236, 255, 0.34) 0%, rgba(160, 127, 255, 0.18) 42%, rgba(255, 255, 255, 0) 78%);
  filter: blur(1.4px);
}
.cursor-butterfly-star {
  width: 14px;
  height: 14px;
}
.cursor-butterfly-star::before,
.cursor-butterfly-star::after {
  width: 2px;
  height: 14px;
  margin-left: -1px;
  margin-top: -7px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0), rgba(116, 247, 255, 0.96), rgba(178, 120, 255, 0.94), rgba(255, 255, 255, 0));
  box-shadow: 0 0 12px rgba(116, 233, 255, 0.55);
}
.cursor-butterfly-star::after {
  transform: rotate(90deg);
}
.cursor-butterfly-star:nth-child(2n)::before,
.cursor-butterfly-star:nth-child(2n)::after {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0), rgba(255, 214, 248, 0.94), rgba(104, 214, 255, 0.96), rgba(255, 255, 255, 0));
  box-shadow: 0 0 12px rgba(152, 214, 255, 0.48);
}
@keyframes butterflyWingLeft {
  from { transform: rotate(-36deg) scale(1.03); }
  to { transform: rotate(14deg) scale(0.92); }
}
@keyframes butterflyWingRight {
  from { transform: rotate(-18deg) scale(1.01); }
  to { transform: rotate(18deg) scale(0.88); }
}
/* final v67: clean side butterfly, park it on the cursor right side, and keep the star tail flowing to the right */
.cursor-butterfly {
  width: 34px;
  height: 22px;
  transform-origin: 28% 54%;
  filter: drop-shadow(0 3px 8px rgba(77, 151, 226, 0.2));
}
.cursor-butterfly-wing {
  border: 1px solid rgba(255, 255, 255, 0.56);
  background:
    radial-gradient(circle at 30% 26%, rgba(255, 255, 255, 0.96), transparent 24%),
    linear-gradient(145deg, rgba(118, 246, 255, 0.98) 0%, rgba(89, 198, 255, 0.96) 44%, rgba(171, 126, 255, 0.94) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.78),
    inset 0 -2px 4px rgba(64, 111, 179, 0.16),
    0 2px 8px rgba(76, 143, 226, 0.18);
}
.cursor-butterfly-wing-left {
  left: 2px;
  top: 1px;
  width: 16px;
  height: 13px;
  border-radius: 82% 18% 86% 14% / 90% 28% 72% 10%;
  transform-origin: 92% 72%;
  animation: butterflyWingLeft 180ms ease-in-out infinite alternate;
}
.cursor-butterfly-wing-right {
  left: 5px;
  top: 11px;
  right: auto;
  width: 11px;
  height: 8px;
  border-radius: 78% 22% 82% 18% / 72% 34% 66% 28%;
  transform-origin: 94% 18%;
  animation: butterflyWingRight 180ms ease-in-out infinite alternate;
}
.cursor-butterfly-body {
  left: 16px;
  top: 8px;
  width: 13px;
  height: 4px;
  margin-left: 0;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(59, 31, 12, 0.96) 0%, rgba(96, 57, 25, 0.98) 45%, rgba(43, 18, 7, 0.98) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 238, 214, 0.42), 0 0 3px rgba(26, 12, 4, 0.12);
  transform: rotate(4deg);
}
.cursor-butterfly-body::before,
.cursor-butterfly-body::after {
  content: "";
  position: absolute;
}
.cursor-butterfly-body::before {
  right: -3px;
  top: -1px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, rgba(255, 235, 198, 0.88), rgba(83, 46, 18, 0.98) 74%);
  box-shadow: 0 0 3px rgba(43, 19, 7, 0.12);
}
.cursor-butterfly-body::after {
  right: 2px;
  top: -5px;
  width: 6px;
  height: 6px;
  border-top: 1px solid rgba(92, 52, 18, 0.88);
  border-right: 1px solid rgba(92, 52, 18, 0.88);
  border-radius: 0 100% 0 0;
  transform: rotate(-8deg);
}
.cursor-butterfly-glow {
  left: 10px;
  top: 5px;
  width: 24px;
  height: 12px;
  margin-left: 0;
  margin-top: 0;
  background: radial-gradient(circle, rgba(110, 238, 255, 0.34) 0%, rgba(161, 132, 255, 0.18) 46%, rgba(255, 255, 255, 0) 78%);
  filter: blur(1.2px);
}
.cursor-butterfly-star {
  width: 11px;
  height: 11px;
}
.cursor-butterfly-star::before,
.cursor-butterfly-star::after {
  width: 2px;
  height: 11px;
  margin-left: -1px;
  margin-top: -5.5px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0), rgba(113, 246, 255, 0.98), rgba(176, 128, 255, 0.94), rgba(255, 255, 255, 0));
  box-shadow: 0 0 10px rgba(108, 230, 255, 0.6);
}
.cursor-butterfly-star::after {
  transform: rotate(90deg);
}
.cursor-butterfly-star:nth-child(2n)::before,
.cursor-butterfly-star:nth-child(2n)::after {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0), rgba(255, 223, 246, 0.98), rgba(101, 217, 255, 0.95), rgba(255, 255, 255, 0));
  box-shadow: 0 0 10px rgba(157, 215, 255, 0.58);
}
@keyframes butterflyWingLeft {
  from { transform: rotate(-34deg) scale(1.02); }
  to { transform: rotate(8deg) scale(0.93); }
}
@keyframes butterflyWingRight {
  from { transform: rotate(-20deg) scale(1.01); }
  to { transform: rotate(10deg) scale(0.9); }
}

/* final v68: make the side butterfly read clearly as a butterfly silhouette */
.cursor-butterfly {
  width: 32px;
  height: 20px;
  transform-origin: 34% 54%;
  filter: drop-shadow(0 2px 6px rgba(82, 150, 228, 0.18));
}
.cursor-butterfly-wing {
  border: 1px solid rgba(255, 255, 255, 0.52);
  background:
    radial-gradient(circle at 28% 24%, rgba(255, 255, 255, 0.94), transparent 22%),
    radial-gradient(circle at 48% 70%, rgba(215, 190, 255, 0.34), transparent 28%),
    linear-gradient(150deg, rgba(128, 245, 255, 0.98) 0%, rgba(100, 196, 255, 0.95) 48%, rgba(163, 127, 255, 0.92) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.76),
    inset 0 -1px 3px rgba(72, 114, 181, 0.14),
    0 2px 6px rgba(80, 145, 225, 0.16);
}
.cursor-butterfly-wing-left {
  left: 2px;
  top: 1px;
  width: 14px;
  height: 12px;
  border-radius: 88% 12% 78% 22% / 92% 32% 68% 8%;
  transform-origin: 96% 78%;
  animation: butterflyWingLeft 170ms ease-in-out infinite alternate;
}
.cursor-butterfly-wing-right {
  left: 5px;
  top: 10px;
  right: auto;
  width: 9px;
  height: 7px;
  border-radius: 84% 16% 72% 28% / 78% 34% 66% 22%;
  transform-origin: 98% 16%;
  animation: butterflyWingRight 170ms ease-in-out infinite alternate;
}
.cursor-butterfly-body {
  left: 15px;
  top: 8px;
  width: 11px;
  height: 3px;
  margin-left: 0;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(88, 57, 29, 0.94) 0%, rgba(117, 80, 44, 0.98) 40%, rgba(63, 36, 18, 0.98) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 242, 222, 0.28), 0 0 2px rgba(42, 20, 8, 0.08);
  transform: rotate(3deg);
}
.cursor-butterfly-body::before,
.cursor-butterfly-body::after {
  content: "";
  position: absolute;
}
.cursor-butterfly-body::before {
  right: -2px;
  top: -1px;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, rgba(255, 238, 208, 0.88), rgba(97, 63, 31, 0.96) 74%);
  box-shadow: 0 0 2px rgba(47, 22, 8, 0.1);
}
.cursor-butterfly-body::after {
  right: 1px;
  top: -4px;
  width: 5px;
  height: 5px;
  border-top: 1px solid rgba(92, 57, 26, 0.84);
  border-right: 1px solid rgba(92, 57, 26, 0.84);
  border-radius: 0 100% 0 0;
  transform: rotate(-2deg);
}
.cursor-butterfly-glow {
  left: 8px;
  top: 4px;
  width: 20px;
  height: 10px;
  margin-left: 0;
  margin-top: 0;
  background: radial-gradient(circle, rgba(110, 238, 255, 0.22) 0%, rgba(156, 132, 255, 0.12) 50%, rgba(255, 255, 255, 0) 78%);
  filter: blur(1px);
}
@keyframes butterflyWingLeft {
  from { transform: rotate(-28deg) scale(1.01); }
  to { transform: rotate(6deg) scale(0.94); }
}
@keyframes butterflyWingRight {
  from { transform: rotate(-18deg) scale(1.01); }
  to { transform: rotate(8deg) scale(0.92); }
}
/* final v69: replace butterfly with particle trail overlay */
.cursor-particles-layer {
  position: fixed;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 9999;
}
.cursor-particles-canvas {
  display: block;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
@media (pointer: coarse) {
  .cursor-particles-layer {
    display: none !important;
  }
}
/* final v87: keep the 9G side edges and shave the top-bottom two more ticks */
.address-page .premium-banner-gif-wrap {
  border-radius: 24px;
}
.address-page .ad-banner-panel-premium-gif .ad-banner-video,
.address-page .ad-banner-panel-premium-gif .ad-banner-gif {
  transform: scaleX(1.0025) scaleY(1.0253);
  transform-origin: center center;
  border-radius: 24px;
}

.address-page .transfer-panel {
  position: relative;
  transition: opacity 0.18s ease, filter 0.18s ease;
}
.address-page .transfer-panel.is-loading {
  pointer-events: none;
}
.address-page .transfer-panel.is-loading > * {
  opacity: 0.56;
  filter: saturate(0.92);
}
.address-page .transfer-panel.is-loading::after {
  content: "\52A0\8F7D\4E2D...";
  position: absolute;
  top: 18px;
  right: 18px;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(10, 18, 34, 0.82);
  color: rgba(236, 244, 255, 0.96);
  font-size: 12px;
  letter-spacing: 0.08em;
  box-shadow: 0 10px 24px rgba(3, 8, 18, 0.24);
}


/* final v88: stabilize mobile home layout, mobile address header, and video ad visibility */
@media (max-width: 920px) {
  .home-page .nav-row {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 10px 14px;
  }
  .home-page .nav-links {
    width: auto;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 10px 14px;
  }
  .home-page .home-hero {
    min-height: calc(100svh - 64px);
    padding: 24px 0 40px;
  }
  .home-page .home-center-wrap {
    gap: 16px;
  }
  .home-page .home-copy {
    gap: 10px;
  }
  .home-page .home-feature-row {
    gap: 12px;
  }
  .home-page .home-feature-card {
    padding: 16px 16px 14px;
  }

  .address-page {
    --address-main-column-height: auto;
    --address-ad-height: 72px;
    --promo-banner-height: 144px;
  }

  .address-page .ad-banner-panel-premium-gif,
  .address-page .slot7-banner-panel-gif {
    min-height: var(--promo-banner-height);
    height: var(--promo-banner-height);
    max-height: var(--promo-banner-height);
  }
}

@media (max-width: 768px) {
  .address-page .address-site-header {
    background: rgba(39, 41, 45, 0.92);
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(14px);
  }
  .address-site-header .container.address-nav-row {
    width: min(100%, calc(100% - 16px)) !important;
    max-width: min(100%, calc(100% - 16px)) !important;
    margin: 0 auto !important;
    padding: calc(10px + env(safe-area-inset-top, 0px)) 0 12px !important;
  }
  .address-nav-row {
    display: grid;
    grid-template-columns: 1fr;
    align-items: stretch;
    justify-content: stretch;
    width: 100%;
    gap: 10px;
  }
  .address-nav-row > * {
    width: 100%;
    min-width: 0;
    max-width: 100%;
    margin-left: 0 !important;
  }
  .address-nav-row .nav-links,
  .address-nav-row .nav-links-light {
    width: 100%;
    justify-content: flex-start;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 10px 14px;
  }
  .address-nav-row .header-music-player,
  .address-nav-row .header-search {
    width: 100%;
    min-width: 0;
    max-width: 100%;
  }
  .address-page .address-hero-panel {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .address-page .address-title {
    white-space: normal;
    word-break: break-all;
  }
  .address-page .qr-card {
    width: 100%;
  }
}

.address-page .premium-banner-gif-wrap,
.address-page .slot7-banner-gif-wrap {
  min-height: inherit;
}

.address-page .ad-banner-panel-premium-gif .ad-banner-video,
.address-page .slot7-banner-panel-gif .slot7-banner-video {
  display: block;
  visibility: visible;
  opacity: 1 !important;
  object-fit: fill;
}
/* final v89: hard-fix phone header width, equalize ad heights, and freeze slot7 copy text */
@media (max-width: 768px) {
  .address-page .site-header.address-site-header,
  .swap-page .site-header.address-site-header {
    position: sticky;
    top: 0;
    z-index: 12;
    width: 100%;
    max-width: 100%;
    background: rgba(244, 255, 249, 0.94) !important;
    border-bottom: 1px solid rgba(195, 225, 216, 0.82) !important;
    backdrop-filter: blur(12px);
  }
  .address-page .container.address-nav-row,
  .swap-page .container.address-nav-row {
    width: calc(100vw - 16px) !important;
    max-width: calc(100vw - 16px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding: calc(10px + env(safe-area-inset-top, 0px)) 0 12px !important;
    box-sizing: border-box !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
  }
  .address-page .address-nav-row,
  .swap-page .address-nav-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    align-items: stretch !important;
    justify-content: stretch !important;
    width: 100% !important;
  }
  .address-page .address-nav-row > *,
  .swap-page .address-nav-row > * {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }
  .address-page .brand-rich,
  .swap-page .brand-rich,
  .address-page .nav-links-light,
  .swap-page .nav-links-light,
  .address-page .header-music-player,
  .swap-page .header-music-player,
  .address-page .header-search,
  .swap-page .header-search {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }
  .address-page .nav-links-light,
  .swap-page .nav-links-light {
    display: flex !important;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 10px 12px;
  }
  .address-page .header-search,
  .swap-page .header-search {
    grid-template-columns: minmax(0, 1fr) 92px !important;
  }

  .address-page .promo-banner-panel,
  .address-page .ad-banner-panel-premium-gif,
  .address-page .slot7-banner-panel-gif {
    min-height: 144px !important;
    height: 144px !important;
    max-height: 144px !important;
  }
}

.address-page .slot7-banner-panel-gif {
  position: relative;
}
.address-page .slot7-static-overlay {
  position: absolute;
  inset: 0;
  z-index: 4;
  display: flex;
  align-items: center;
  padding: 0 18px;
  pointer-events: none;
}
.address-page .slot7-static-overlay::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 78%;
  background: linear-gradient(90deg, rgba(247, 252, 255, 0.98) 0%, rgba(239, 248, 255, 0.98) 66%, rgba(239, 248, 255, 0.9) 82%, rgba(239, 248, 255, 0) 100%);
}
.address-page .slot7-static-copy {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: baseline;
  gap: 10px;
  flex-wrap: wrap;
  max-width: 78%;
}
.address-page .slot7-static-brand {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
}
.address-page .slot7-static-mark {
  color: #55aef5;
  font-size: clamp(1.28rem, 2.4vw, 2rem);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.03em;
}
.address-page .slot7-static-year {
  color: #67befa;
  font-size: clamp(1.62rem, 3.1vw, 2.55rem);
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.08em;
}
.address-page .slot7-static-title {
  color: #63b6f8;
  font-size: clamp(0.9rem, 1.72vw, 1.42rem);
  font-weight: 900;
  line-height: 1.08;
  white-space: nowrap;
}
@media (max-width: 768px) {
  .address-page .slot7-static-overlay {
    padding: 0 12px;
  }
  .address-page .slot7-static-overlay::before {
    width: 82%;
  }
  .address-page .slot7-static-copy {
    max-width: 82%;
    gap: 6px 8px;
  }
  .address-page .slot7-static-mark {
    font-size: 1.08rem;
  }
  .address-page .slot7-static-year {
    font-size: 1.48rem;
    letter-spacing: 0.05em;
  }
  .address-page .slot7-static-title {
    font-size: 0.84rem;
    white-space: normal;
  }
}
/* final v90: unstick mobile header, keep it in normal flow, restore slot7 original video, and scale the U8 banner like desktop */
@media (max-width: 768px) {
  .address-page .site-header.address-site-header,
  .swap-page .site-header.address-site-header {
    position: static !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    z-index: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    background: rgba(244, 255, 249, 0.94) !important;
    border-bottom: 1px solid rgba(195, 225, 216, 0.82) !important;
    backdrop-filter: blur(12px);
  }
  .address-page .container.address-nav-row,
  .swap-page .container.address-nav-row {
    width: min(100%, calc(100% - 16px)) !important;
    max-width: min(100%, calc(100% - 16px)) !important;
    margin: 0 auto !important;
    padding: calc(10px + env(safe-area-inset-top, 0px)) 0 12px !important;
    box-sizing: border-box !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
  }
  .address-page .address-nav-row,
  .swap-page .address-nav-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    align-items: stretch !important;
    justify-content: stretch !important;
    width: 100% !important;
    padding: 0 !important;
    gap: 10px !important;
  }
  .address-page .address-nav-row > *,
  .swap-page .address-nav-row > * {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin-left: 0 !important;
  }

  .address-page .promo-banner-panel,
  .address-page .ad-banner-panel-premium-gif,
  .address-page .slot7-banner-panel-gif {
    min-height: 144px !important;
    height: 144px !important;
    max-height: 144px !important;
  }

  .address-page .promo-banner-panel {
    position: relative;
    overflow: hidden;
  }
  .address-page .promo-banner-grid {
    position: absolute !important;
    left: 12px;
    top: 50%;
    width: 860px !important;
    max-width: none !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    padding: 10px 16px 10px 18px !important;
    transform: translateY(-50%) scale(0.42);
    transform-origin: left center;
  }
  .address-page .promo-banner-brand-block {
    flex: 0 1 332px !important;
    max-width: 332px !important;
    padding-left: 10px !important;
    transform: translateY(-4px);
  }
  .address-page .promo-banner-copy-block {
    flex: 0 1 438px !important;
    max-width: 438px !important;
    min-height: 90px !important;
    margin-left: -10px !important;
    justify-content: center !important;
    gap: 12px !important;
    text-align: center !important;
  }
  .address-page .promo-banner-icons {
    flex: 0 0 auto !important;
    margin-left: 2px !important;
  }
  .address-page .promo-banner-tags {
    flex: 0 0 124px !important;
    width: 124px !important;
    margin-left: auto !important;
    gap: 6px !important;
  }
}

@media (max-width: 420px) {
  .address-page .promo-banner-grid {
    transform: translateY(-50%) scale(0.39);
  }
}
/* final v91: make the mobile address header a true full-width block and enlarge the U8 banner composition on phones */
@media (max-width: 768px) {
  .address-page .site-header.address-site-header,
  .swap-page .site-header.address-site-header {
    position: static !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    z-index: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    background: transparent !important;
    border-bottom: 0 !important;
    backdrop-filter: none !important;
    box-shadow: none !important;
    overflow: visible !important;
  }
  .address-page .container.nav-row.address-nav-row,
  .swap-page .container.nav-row.address-nav-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    width: auto !important;
    max-width: none !important;
    margin: 0 8px 10px !important;
    padding: calc(10px + env(safe-area-inset-top, 0px)) 12px 12px !important;
    background: linear-gradient(135deg, rgba(244, 255, 249, 0.96) 0%, rgba(235, 247, 243, 0.96) 56%, rgba(235, 244, 255, 0.96) 100%) !important;
    border: 1px solid rgba(195, 225, 216, 0.82) !important;
    border-radius: 0 0 18px 18px !important;
    box-shadow: 0 12px 28px rgba(96, 144, 158, 0.12) !important;
    box-sizing: border-box !important;
  }
  .address-page .address-nav-row,
  .swap-page .address-nav-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 10px !important;
    min-height: 0 !important;
    padding: 0 !important;
    align-items: stretch !important;
    justify-items: stretch !important;
    justify-content: stretch !important;
    width: 100% !important;
  }
  .address-page .address-nav-row > *,
  .swap-page .address-nav-row > * {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    flex: none !important;
  }
  .address-page .nav-links,
  .address-page .nav-links-light,
  .swap-page .nav-links,
  .swap-page .nav-links-light {
    display: flex !important;
    width: 100% !important;
    flex-wrap: wrap !important;
    justify-content: flex-start !important;
    gap: 10px 12px !important;
  }
  .address-page .header-music-player,
  .swap-page .header-music-player,
  .address-page .header-search,
  .swap-page .header-search {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    flex: none !important;
  }
  .address-page .header-search,
  .swap-page .header-search {
    grid-template-columns: minmax(0, 1fr) 92px !important;
  }

  .address-page .promo-banner-grid {
    left: 8px !important;
    width: 760px !important;
    gap: 10px !important;
    transform: translateY(-50%) scale(0.5) !important;
    transform-origin: left center !important;
  }
}

@media (max-width: 420px) {
  .address-page .promo-banner-grid {
    transform: translateY(-50%) scale(0.46) !important;
  }
}
/* final v92: hard-fix mobile address header width and enlarge the U8 promo composition on phones */
@media (max-width: 768px) {
  body.address-page,
  body.swap-page {
    overflow-x: hidden;
  }

  .address-page .site-header.address-site-header,
  .swap-page .site-header.address-site-header {
    display: block !important;
    position: static !important;
    inset: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow-x: clip !important;
  }

  .address-page .address-site-header .container.address-nav-row,
  .swap-page .address-site-header .container.address-nav-row,
  .address-page .container.nav-row.address-nav-row,
  .swap-page .container.nav-row.address-nav-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    width: calc(100vw - 10px) !important;
    max-width: calc(100vw - 10px) !important;
    min-width: 0 !important;
    margin: 0 auto 10px !important;
    padding: calc(10px + env(safe-area-inset-top, 0px)) 10px 12px !important;
    box-sizing: border-box !important;
  }

  .address-page .address-nav-row,
  .swap-page .address-nav-row {
    gap: 9px !important;
  }

  .address-page .brand-rich,
  .swap-page .brand-rich,
  .address-page .nav-links,
  .address-page .nav-links-light,
  .swap-page .nav-links,
  .swap-page .nav-links-light,
  .address-page .header-music-player,
  .swap-page .header-music-player,
  .address-page .header-search,
  .swap-page .header-search {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    justify-self: stretch !important;
  }

  .address-page .promo-banner-grid {
    left: 6px !important;
    top: 50% !important;
    width: 704px !important;
    gap: 8px !important;
    transform: translateY(-50%) scale(0.535) !important;
    transform-origin: left center !important;
  }

  .address-page .promo-banner-brand-block {
    padding-left: 8px !important;
  }

  .address-page .promo-banner-copy-block {
    margin-left: -4px !important;
  }

  .address-page .promo-banner-icons {
    margin-left: 0 !important;
  }

  .address-page .promo-banner-tags {
    margin-left: 2px !important;
  }
}

@media (max-width: 420px) {
  .address-page .address-site-header .container.address-nav-row,
  .swap-page .address-site-header .container.address-nav-row,
  .address-page .container.nav-row.address-nav-row,
  .swap-page .container.nav-row.address-nav-row {
    width: calc(100vw - 8px) !important;
    max-width: calc(100vw - 8px) !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
  }

  .address-page .promo-banner-grid {
    left: 4px !important;
    width: 680px !important;
    transform: translateY(-50%) scale(0.5) !important;
  }
}

/* final v93: use exported WebM for the first promo banner */
.promo-banner-panel-video {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.98) 0%, rgba(241, 247, 255, 0.98) 36%, rgba(234, 243, 255, 0.98) 100%);
}
.promo-banner-panel-video .promo-banner-video {
  position: absolute;
  left: -2px;
  right: -2px;
  top: -2px;
  bottom: -1px;
  display: block;
  width: calc(100% + 4px);
  height: calc(100% + 3px);
  margin: 0;
  border-radius: 0;
  object-fit: fill;
  background: transparent;
  transform: none;
  transform-origin: center center;
}

@media (max-width: 768px) {
  .address-page main.container.address-shell,
  .swap-page main.container.address-shell,
  .address-page .address-shell,
  .swap-page .address-shell {
    width: min(100%, calc(100% - 16px)) !important;
    max-width: min(1120px, calc(100% - 16px)) !important;
    min-width: 0 !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    box-sizing: border-box !important;
  }

  .address-page .site-header.address-site-header > .container.address-nav-row,
  .swap-page .site-header.address-site-header > .container.address-nav-row,
  .address-page .container.nav-row.address-nav-row,
  .swap-page .container.nav-row.address-nav-row {
    width: calc(100vw - 12px) !important;
    max-width: calc(100vw - 12px) !important;
  }
}

@media (max-width: 420px) {
  .address-page main.container.address-shell,
  .swap-page main.container.address-shell,
  .address-page .address-shell,
  .swap-page .address-shell {
    width: min(100%, calc(100% - 12px)) !important;
    max-width: min(1120px, calc(100% - 12px)) !important;
  }

  .address-page .site-header.address-site-header > .container.address-nav-row,
  .swap-page .site-header.address-site-header > .container.address-nav-row,
  .address-page .container.nav-row.address-nav-row,
  .swap-page .container.nav-row.address-nav-row {
    width: calc(100vw - 8px) !important;
    max-width: calc(100vw - 8px) !important;
  }
}

/* final v96: keep only the mobile header full-width, restore normal page content scaling */
@media (max-width: 768px) {
  .address-page main.container.address-shell,
  .swap-page main.container.address-shell {
    width: min(100%, calc(100% - 16px)) !important;
    max-width: min(1120px, calc(100% - 16px)) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    box-sizing: border-box !important;
  }

  .address-page .address-primary-grid,
  .swap-page .address-primary-grid,
  .address-page .address-hero-panel,
  .swap-page .address-hero-panel {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .address-page .site-header.address-site-header > .container.address-nav-row,
  .swap-page .site-header.address-site-header > .container.address-nav-row,
  .address-page .container.nav-row.address-nav-row,
  .swap-page .container.nav-row.address-nav-row {
    width: calc(100vw - 12px) !important;
    max-width: calc(100vw - 12px) !important;
  }
}

@media (max-width: 420px) {
  .address-page main.container.address-shell,
  .swap-page main.container.address-shell {
    width: min(100%, calc(100% - 12px)) !important;
    max-width: min(1120px, calc(100% - 12px)) !important;
  }

  .address-page .site-header.address-site-header > .container.address-nav-row,
  .swap-page .site-header.address-site-header > .container.address-nav-row,
  .address-page .container.nav-row.address-nav-row,
  .swap-page .container.nav-row.address-nav-row {
    width: calc(100vw - 8px) !important;
    max-width: calc(100vw - 8px) !important;
  }
}
/* final v97: hard-fix mobile address body layout and ease the first banner edge trim */
@media (max-width: 768px) {
  .address-page main.container.address-shell {
    width: min(100%, calc(100% - 16px)) !important;
    max-width: calc(100% - 16px) !important;
    min-width: 0 !important;
    margin: 0 auto !important;
    padding: 0 !important;
    gap: 14px !important;
    overflow-x: clip !important;
    box-sizing: border-box !important;
  }
  .address-page .address-hero-panel,
  .address-page .address-primary-grid,
  .address-page .address-secondary-grid,
  .address-page .address-side-rail {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    grid-template-columns: 1fr !important;
  }
  .address-page .address-hero-panel {
    gap: 12px !important;
    padding: 14px !important;
  }
  .address-page .address-hero-main,
  .address-page .address-hero-heading,
  .address-page .address-meta-strip,
  .address-page .address-action-row,
  .address-page .overview-main-row,
  .address-page .overview-table,
  .address-page .overview-table-row,
  .address-page .asset-row,
  .address-page .asset-token-main,
  .address-page .approval-main,
  .address-page .stack-row,
  .address-page .stack-row-block,
  .address-page .permission-row,
  .address-page .transfer-token-cell {
    min-width: 0 !important;
    max-width: 100% !important;
  }
  .address-page .address-title {
    white-space: normal !important;
    word-break: break-all !important;
    overflow-wrap: anywhere !important;
    line-height: 1.08 !important;
  }
  .address-page .meta-chip,
  .address-page .overview-chip,
  .address-page .ghost-action,
  .address-page .permission-key {
    min-width: 0 !important;
    max-width: 100% !important;
  }
  .address-page .overview-panel,
  .address-page .asset-panel,
  .address-page .address-side-rail,
  .address-page .address-side-rail .compact-panel {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
  }
  .address-page .asset-panel .asset-scroll-list,
  .address-page .address-side-rail .compact-list,
  .address-page .address-side-rail .stack-list {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
    padding-right: 0 !important;
    scrollbar-gutter: auto !important;
  }
  .address-page .overview-table-row,
  .address-page .asset-row,
  .address-page .approval-row,
  .address-page .stack-row {
    flex-wrap: wrap !important;
  }
  .address-page .align-right,
  .address-page .overview-table-value {
    text-align: left !important;
  }
  .address-page .overview-table-value-icons {
    justify-content: flex-start !important;
  }
  .address-page .transfer-table-wrap,
  .address-page .table-wrap {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
  }
  .address-page .transfer-table-wrap table,
  .address-page .table-wrap table {
    min-width: 640px;
  }
}
@media (max-width: 420px) {
  .address-page main.container.address-shell {
    width: min(100%, calc(100% - 12px)) !important;
    max-width: calc(100% - 12px) !important;
  }
  .address-page .address-hero-panel {
    padding: 12px !important;
  }
}

/* final v98: stack mobile address hero content cleanly */
@media (max-width: 768px) {
  .address-page .address-hero-panel {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
  }

  .address-page .address-hero-heading {
    align-items: flex-start !important;
    flex-wrap: nowrap !important;
  }

  .address-page .address-hero-heading > div {
    min-width: 0 !important;
    flex: 1 1 auto !important;
  }

  .address-page .address-meta-strip,
  .address-page .address-action-row {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  .address-page .meta-chip,
  .address-page .ghost-action,
  .address-page .ghost-action-telegram,
  .address-page .qr-card {
    width: 100% !important;
  }

  .address-page .ghost-action {
    justify-content: flex-start !important;
    padding: 0 14px !important;
  }

  .address-page .qr-card {
    justify-items: center !important;
    padding: 16px 14px !important;
  }

  .address-page .qr-image {
    width: min(196px, 100%) !important;
    height: auto !important;
    aspect-ratio: 1 / 1;
  }
}

@media (max-width: 420px) {
  .address-page .address-hero-heading {
    gap: 12px !important;
  }

  .address-page .wallet-hero-icon {
    width: 42px !important;
    height: 42px !important;
  }

  .address-page .ghost-action {
    min-height: 42px !important;
    font-size: 0.92rem !important;
  }
}

/* final v99: make mobile address heading truly single-column */
@media (max-width: 768px) {
  .address-page .address-shell,
  .address-page .panel,
  .address-page .address-hero-main {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow-x: clip !important;
  }

  .address-page .address-hero-heading {
    display: grid !important;
    grid-template-columns: 1fr !important;
    align-items: start !important;
    justify-items: start !important;
    gap: 10px !important;
  }

  .address-page .address-hero-heading > div {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .address-page .address-title {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    font-size: clamp(1.18rem, 6.5vw, 1.86rem) !important;
    line-height: 1.12 !important;
    letter-spacing: -0.035em !important;
    white-space: normal !important;
    word-break: break-all !important;
    overflow-wrap: anywhere !important;
  }

  .address-page .overview-amount,
  .address-page .overview-sub,
  .address-page .token-id-line,
  .address-page .permission-key {
    overflow-wrap: anywhere !important;
    word-break: break-all !important;
  }
}

@media (max-width: 420px) {
  .address-page .address-hero-heading {
    gap: 8px !important;
  }

  .address-page .wallet-hero-icon {
    width: 38px !important;
    height: 38px !important;
  }

  .address-page .address-title {
    font-size: clamp(1.08rem, 6vw, 1.54rem) !important;
  }
}





/* final v109: keep 7t fully visible and use a clear left-to-right spotlight sweep like the premium banner reference */
.address-page .slot7-banner-panel-image .slot7-banner-image-wrap {
  position: relative;
  overflow: hidden;
  border-radius: inherit;
  isolation: isolate;
}

.address-page .slot7-banner-panel-image .slot7-banner-image {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: fill;
  border-radius: inherit;
  transform: none;
  animation: none;
  filter: none;
  will-change: auto;
}

.address-page .slot7-banner-panel-image .slot7-banner-image-wrap::after {
  content: "";
  position: absolute;
  top: -16%;
  bottom: -16%;
  left: -24%;
  width: 34%;
  z-index: 3;
  pointer-events: none;
  opacity: 0;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(245, 252, 255, 0.12) 16%, rgba(255, 255, 255, 0.46) 40%, rgba(255, 255, 255, 0.72) 50%, rgba(224, 248, 255, 0.42) 60%, rgba(255, 255, 255, 0.12) 80%, rgba(255, 255, 255, 0) 100%);
  filter: blur(3px);
  mix-blend-mode: screen;
  transform: translate3d(-160%, 0, 0) skewX(-12deg);
  animation: slot7ImageSweep 5.2s cubic-bezier(0.18, 0.72, 0.22, 1) infinite;
}

@keyframes slot7ImageSweep {
  0%, 18% {
    opacity: 0;
    transform: translate3d(-160%, 0, 0) skewX(-12deg);
  }
  24% {
    opacity: 0.96;
  }
  54% {
    opacity: 0.92;
    transform: translate3d(235%, 0, 0) skewX(-12deg);
  }
  62%, 100% {
    opacity: 0;
    transform: translate3d(250%, 0, 0) skewX(-12deg);
  }
}  28% {
    opacity: 0.78;
  }
  58% {
    opacity: 0.82;
    transform: translate3d(18%, 0, 0);
  }
  72% {
    opacity: 0.3;
  }
  100% {
    opacity: 0;
    transform: translate3d(150%, 0, 0);
  }
}  26%, 54% { opacity: 1; }
  70%, 100% { transform: translateX(140%); opacity: 0; }
}







