:root {
  --bg-1: #07070a;
  --bg-2: #17111f;
  --card: rgba(255, 255, 255, 0.08);
  --card-strong: rgba(255, 255, 255, 0.13);
  --card-border: rgba(255, 255, 255, 0.18);
  --text: #fff8ef;
  --muted: rgba(255, 248, 239, 0.78);
  --shadow: rgba(0, 0, 0, 0.45);
  --pink: #ff30a8;
  --blue: #00d7ff;
  --gold: #ffd000;
}

* { box-sizing: border-box; }
html, body { min-height: 100%; }
body {
  margin: 0;
  font-family: Arial, Helvetica, sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at 15% 20%, rgba(255, 48, 168, 0.38), transparent 28%),
    radial-gradient(circle at 85% 16%, rgba(0, 215, 255, 0.32), transparent 30%),
    radial-gradient(circle at 50% 95%, rgba(255, 208, 0, 0.22), transparent 32%),
    linear-gradient(145deg, var(--bg-1), var(--bg-2));
  background-attachment: fixed;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 38px 38px;
  mask-image: radial-gradient(circle at center, black, transparent 78%);
}
a { color: inherit; }
.page-shell { width: min(1120px, calc(100% - 32px)); margin: 0 auto; padding: 48px 0; }
.hero { display: grid; gap: 24px; align-items: center; text-align: center; }
.logo { width: min(820px, 94vw); margin: 0 auto; display: block; filter: drop-shadow(0 22px 30px var(--shadow)); }
.tagline { margin: -4px 0 6px; font-size: clamp(1.1rem, 3vw, 1.65rem); font-weight: 800; letter-spacing: 0.02em; text-shadow: 0 4px 18px rgba(0,0,0,0.6); }
.video-card, .copy-card, .section-card, .stats-card {
  width: min(960px, 100%);
  margin: 0 auto;
  padding: clamp(16px, 2.5vw, 28px);
  border: 1px solid var(--card-border);
  border-radius: 28px;
  background: var(--card);
  box-shadow: 0 24px 70px rgba(0,0,0,0.36);
  backdrop-filter: blur(14px);
}
.video-header h1 { margin: 0 0 10px; font-size: clamp(2rem, 6vw, 4rem); line-height: 1; }
.video-header p { color: var(--muted); font-size: clamp(1rem, 2vw, 1.2rem); margin: 0 auto 20px; }
.video-pick-row { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; margin: 18px auto 22px; }
.now-playing { text-align: left; width: min(900px,100%); margin: 0 auto 12px; }
.now-playing h2 { margin: 0 0 4px; font-size: clamp(1.4rem, 4vw, 2.35rem); }
.now-playing p { margin: 0; color: var(--muted); font-weight: 800; }
.video-frame { overflow: hidden; border-radius: 20px; background: #000; aspect-ratio: 16 / 9; }
.large-player { width: min(900px, 100%); margin: 0 auto; }
video { width: 100%; height: 100%; display: block; object-fit: contain; background: #000; }
.copy-card h1, .section-copy h2, .stats-card h2 { margin: 0 0 10px; font-size: clamp(2rem, 6vw, 4rem); line-height: 1; }
.section-copy h2, .stats-card h2 { font-size: clamp(1.8rem, 5vw, 3.3rem); }
.copy-card p, .section-copy p { width: min(720px, 100%); margin: 0 auto; color: var(--muted); font-size: clamp(1rem, 2vw, 1.2rem); line-height: 1.55; }
.eyebrow { display: inline-block; margin-bottom: 10px; color: #fff; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; font-size: .78rem; opacity: .88; }
.section-card { display: grid; grid-template-columns: 1.05fr .95fr; gap: 24px; align-items: center; text-align: left; }
.section-card .section-copy p { margin-left: 0; }
.centered-copy, .centered-copy p { text-align: center; margin-left: auto; margin-right: auto; }
.donate-card, .guestbook-card, .coming-soon-card { grid-template-columns: 1fr; text-align: center; }
.subscribe-card { grid-template-columns: .9fr 1.1fr; }
.stats-card { display: flex; justify-content: space-between; align-items: center; gap: 22px; text-align: left; }
.counter-wrap { min-width: 180px; padding: 18px; border-radius: 22px; background: linear-gradient(135deg, rgba(255,48,168,.22), rgba(0,215,255,.18)); border: 1px solid rgba(255,255,255,.18); text-align: center; }
.counter-number { display: block; font-size: clamp(2.2rem, 8vw, 4.2rem); font-weight: 900; line-height: 1; }
.counter-label { color: var(--muted); font-weight: 700; }
.button-row { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 20px; }
.centered-row { justify-content: center; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 46px; padding: 12px 18px; border-radius: 999px; border: 1px solid rgba(255,255,255,.28); background: rgba(255,255,255,.10); text-decoration: none; font-weight: 900; box-shadow: 0 10px 24px rgba(0,0,0,.25); cursor: pointer; }
.button.primary { color: #170618; background: linear-gradient(135deg, var(--gold), #fff1a5 45%, #ff8cdf); border-color: rgba(255,255,255,.5); }
.button.disabled { opacity: .58; cursor: not-allowed; }
.qr-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; justify-items: center; }
.qr-frame { width: min(220px, 100%); margin: 0 auto; padding: 14px; border-radius: 28px; background: linear-gradient(145deg, rgba(255,255,255,.10), rgba(255,255,255,.025)); border: 1px solid rgba(255,255,255,.18); box-shadow: inset 0 1px 0 rgba(255,255,255,.10), 0 18px 45px rgba(0,0,0,.24); }
.soft-qr img { width: 100%; aspect-ratio: 1 / 1; object-fit: contain; display: block; filter: drop-shadow(0 8px 16px rgba(0,0,0,.38)); mix-blend-mode: screen; }
.qr-frame figcaption { margin-top: 8px; color: var(--muted); font-weight: 900; text-align: center; }
.form-card { display: grid; gap: 14px; padding: 18px; border-radius: 24px; background: rgba(0,0,0,.22); border: 1px solid rgba(255,255,255,.15); }
.form-card label { display: grid; gap: 7px; color: var(--muted); font-weight: 800; text-align: left; }
input, textarea, select { width: 100%; border: 1px solid rgba(255,255,255,.22); border-radius: 16px; background: rgba(255,255,255,.11); color: var(--text); padding: 13px 14px; font: inherit; outline: none; }
select option { color: #111; }
textarea { resize: vertical; }
.approved-comments { text-align: left; padding: 18px; border-radius: 22px; background: rgba(0,0,0,.17); border: 1px solid rgba(255,255,255,.12); }
.approved-comments h3 { margin-top: 0; }
.comment-list { display: grid; gap: 12px; }
.comment { padding: 14px; border-radius: 18px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12); }
.comment p { margin: 0 0 7px; color: var(--text); line-height: 1.45; }
.comment strong { color: var(--muted); }
.fine-print { color: var(--muted); font-size: .92rem; line-height: 1.45; }
.expand-card {
  width: min(960px,100%);
  margin: 0 auto;
  border: 1px solid var(--card-border);
  border-radius: 28px;
  background: var(--card);
  box-shadow: 0 24px 70px rgba(0,0,0,0.36);
  backdrop-filter: blur(14px);
  overflow: hidden;
  text-align: left;
}
.expand-card summary {
  list-style: none;
  cursor: pointer;
  padding: clamp(16px, 2.5vw, 24px);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
}
.expand-card summary::-webkit-details-marker { display: none; }
.summary-text { display: grid; gap: 6px; }
.summary-text .eyebrow { margin-bottom: 0; }
.summary-text strong { font-size: clamp(1.4rem, 4vw, 2.3rem); line-height: 1; }
.summary-action { padding: 10px 14px; border-radius: 999px; border: 1px solid rgba(255,255,255,.22); background: rgba(255,255,255,.10); font-weight: 900; }
.expand-card[open] .summary-action::before { content: "Close"; }
.expand-card[open] .summary-action { font-size: 0; }
.expand-card[open] .summary-action::before { font-size: 1rem; }
.expand-card .section-card { width: 100%; border: 0; border-top: 1px solid rgba(255,255,255,.14); border-radius: 0; box-shadow: none; background: rgba(0,0,0,.08); }
.site-footer { width: min(960px,calc(100% - 32px)); margin: 0 auto; padding: 12px 0 34px; color: var(--muted); text-align: center; }
@media (max-width: 820px) { .section-card, .subscribe-card { grid-template-columns: 1fr; text-align: center; } .now-playing { text-align: center; } .section-card .section-copy p { margin-left: auto; } .button-row { justify-content: center; } .qr-grid { grid-template-columns: 1fr; } .stats-card { display: grid; text-align: center; } }
@media (max-width: 640px) { .page-shell { padding: 28px 0; } .video-card, .copy-card, .section-card, .stats-card { border-radius: 22px; } .video-frame { border-radius: 16px; } }

/* Small visitor + adventure stats */
.compact-stats { gap: 18px; }
.mini-stat-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(120px, 1fr));
  gap: 12px;
  width: min(560px, 100%);
}
.counter-wrap.mini-counter { min-width: 0; padding: 12px 14px; border-radius: 18px; }
.mini-counter .counter-number { font-size: clamp(1.45rem, 5vw, 2.4rem); }
.mini-counter .counter-label { font-size: .86rem; }
@media (max-width: 640px) { .mini-stat-grid { grid-template-columns: 1fr; } }

/* Counts + simple anti-spam fields */
.counts-card { grid-template-columns: 1fr; text-align: center; }
.public-counts { margin: 4px auto 10px; }
.hp-field {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
}
.captcha-label .captcha-question { color: var(--text); font-weight: 900; }

.check-line {
  display: flex !important;
  align-items: center;
  gap: 10px;
  font-size: .95rem;
  color: var(--muted);
}
.check-line input { width: auto; }
.success-page {
  width: min(760px, calc(100% - 32px));
  margin: 48px auto;
  padding: clamp(18px, 4vw, 34px);
  border: 1px solid var(--card-border);
  border-radius: 28px;
  background: var(--card);
  box-shadow: 0 24px 70px rgba(0,0,0,0.36);
  backdrop-filter: blur(14px);
  text-align: center;
}
.success-page h1 { margin-top: 0; font-size: clamp(2rem, 6vw, 3.6rem); }
.proof-box {
  margin: 20px auto;
  padding: 14px;
  border-radius: 18px;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.16);
  text-align: left;
  max-width: 560px;
}
.proof-box code { color: #ffd000; font-weight: 800; }

.video-status {
  margin: 12px auto 0;
  color: rgba(255, 248, 239, 0.88);
  font-size: 0.95rem;
  line-height: 1.45;
}

.made-with { font-weight: 800; letter-spacing: 0.02em; }


/* Final DGD fixes: force counts 2x2 and Apple footer styling */
.counts-grid.public-counts {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(180px, 1fr)) !important;
  gap: 16px !important;
  max-width: 620px !important;
  margin: 8px auto 12px !important;
}
.apple-logo {
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", Arial, sans-serif;
  font-weight: 700;
}
@media (max-width: 560px) {
  .counts-grid.public-counts { grid-template-columns: 1fr !important; }
}

/* DGD polish pass: center card tops, clean evolution/support sections */
.section-card .section-copy,
.section-card .section-copy h2,
.section-card .section-copy p,
.copy-card,
.video-header,
.now-playing,
.counts-card,
.guestbook-card > .section-copy,
.donate-card > .section-copy,
.join-world-card > .section-copy,
.evolution-card > .section-copy {
  text-align: center !important;
}

.section-card .section-copy p,
.copy-card p,
.video-header p,
.now-playing,
.counts-card .section-copy p,
.guestbook-card .section-copy p,
.donate-card .section-copy p,
.join-world-card .section-copy p,
.evolution-card .section-copy p {
  margin-left: auto !important;
  margin-right: auto !important;
}

.section-card .button-row,
.button-row.centered-row {
  justify-content: center !important;
}

.form-card,
.approved-comments {
  text-align: left !important;
}

.evolution-card,
.join-world-card,
.direct-support-card,
.donate-card,
.guestbook-card,
.counts-card,
.coming-soon-card {
  grid-template-columns: 1fr !important;
}

.evolution-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(220px, 1fr));
  gap: 16px;
  width: min(760px, 100%);
  margin: 24px auto 0;
}

.evolution-mini-card {
  padding: 18px;
  border-radius: 22px;
  background: rgba(0,0,0,.18);
  border: 1px solid rgba(255,255,255,.14);
  text-align: center;
}

.evolution-mini-card h3 {
  margin: 0 0 8px;
  font-size: clamp(1.15rem, 3vw, 1.45rem);
}

.evolution-mini-card p {
  margin: 0 auto !important;
  color: var(--muted);
  line-height: 1.5;
}

.zelle-box {
  width: min(620px, 100%);
  margin: 24px auto 20px;
  padding: 22px;
  border-radius: 24px;
  background: rgba(0,0,0,.22);
  border: 1px solid rgba(255,255,255,.16);
  text-align: center;
}

.zelle-box span {
  display: block;
  margin-bottom: 8px;
  color: var(--gold);
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: .9rem;
}

.zelle-box strong {
  display: block;
  font-size: clamp(1.4rem, 5vw, 2.6rem);
  line-height: 1.1;
  overflow-wrap: anywhere;
}

.mini-stat-grid.public-counts,
.counts-grid.public-counts {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(180px, 1fr)) !important;
  gap: 16px !important;
  width: min(620px, 100%) !important;
  max-width: 620px !important;
  margin: 12px auto !important;
  justify-items: stretch !important;
}

.mini-stat-grid.public-counts .counter-wrap,
.counts-grid.public-counts .counter-wrap {
  width: 100% !important;
}

@media (max-width: 640px) {
  .evolution-grid,
  .mini-stat-grid.public-counts,
  .counts-grid.public-counts {
    grid-template-columns: 1fr !important;
  }
}

/* Unified Do Good Dolls Hub */
.hub-card {
  width: min(960px, 100%);
  margin: 0 auto;
  padding: clamp(16px, 2.4vw, 26px);
  border: 1px solid var(--card-border);
  border-radius: 28px;
  background: var(--card);
  box-shadow: 0 24px 70px rgba(0,0,0,0.36);
  backdrop-filter: blur(14px);
  text-align: center;
}

.hub-header {
  width: min(760px, 100%);
  margin: 0 auto 18px;
}

.hub-header h2 {
  margin: 8px 0 10px;
  font-size: clamp(1.8rem, 5vw, 3.2rem);
  line-height: 1.05;
}

.hub-header p {
  margin: 0 auto;
  color: var(--muted);
  line-height: 1.55;
  font-size: clamp(1rem, 2vw, 1.12rem);
}

.hub-shell {
  min-height: 96px;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.14);
  overflow: hidden;
  transition: min-height .25s ease;
}

.hub-tabs {
  display: flex;
  align-items: stretch;
  gap: 10px;
  padding: 14px;
  overflow-x: auto;
  scrollbar-width: thin;
}

.hub-tab {
  flex: 1 0 auto;
  min-width: 108px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 999px;
  padding: 12px 16px;
  background: rgba(255,255,255,.08);
  color: var(--text);
  font-weight: 900;
  cursor: pointer;
  transition: transform .15s ease, background .15s ease;
}

.hub-tab:hover,
.hub-tab.active {
  transform: translateY(-1px);
  background: rgba(255,216,77,.95);
  color: #17110a;
}

.hub-content {
  display: none;
  position: relative;
}

.hub-placeholder,
.hub-panel {
  padding: clamp(18px, 3vw, 30px);
}

.hub-placeholder h3,
.hub-panel h3 {
  margin: 8px auto 10px;
  font-size: clamp(1.7rem, 4.5vw, 2.8rem);
  line-height: 1.08;
}

.hub-placeholder p,
.hub-panel > p {
  width: min(720px, 100%);
  margin: 0 auto 16px;
  color: var(--muted);
  font-size: clamp(1rem, 2vw, 1.14rem);
  line-height: 1.58;
}

.hub-panel {
  display: none;
  text-align: center;
  max-height: 580px;
  overflow-y: auto;
  overscroll-behavior: contain;
}

.hub-panel.active { display: block; }

.hub-close {
  float: right;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
  padding: 9px 14px;
  background: rgba(255,255,255,.08);
  color: var(--text);
  font-weight: 900;
  cursor: pointer;
}

.hub-card.is-open .hub-shell {
  display: grid;
  grid-template-columns: minmax(150px, 20%) 1fr;
  min-height: 640px;
}

.hub-card.is-open .hub-tabs {
  flex-direction: column;
  align-items: stretch;
  overflow-x: visible;
  overflow-y: auto;
  border-right: 1px solid rgba(255,255,255,.14);
  max-height: 640px;
}

.hub-card.is-open .hub-tab {
  flex: 0 0 auto;
  width: 100%;
  min-width: 0;
}

.hub-card.is-open .hub-content {
  display: block;
  min-width: 0;
}

.hub-card.is-open .hub-placeholder {
  display: none;
}

.hub-card:not(.is-open) .hub-content {
  display: none;
}

.hub-qr {
  width: min(220px, 72vw);
  margin: 22px auto 0;
}

.hub-qr img {
  width: 100%;
  height: auto;
  display: block;
}

.continue-watch-row {
  margin: 16px auto 0;
  text-align: center;
}

.hub-panel .form-card {
  margin-top: 18px;
}

.hub-panel .approved-comments {
  margin-top: 24px;
}

.hub-panel .approved-comments h4 {
  margin: 0 0 12px;
  font-size: clamp(1.3rem, 3vw, 1.8rem);
}

.hub-panel .evolution-grid h4 {
  margin: 0 0 8px;
  font-size: clamp(1.12rem, 3vw, 1.35rem);
}

@media (max-width: 760px) {
  .hub-card.is-open .hub-shell {
    display: block;
    min-height: 0;
  }
  .hub-card.is-open .hub-tabs {
    flex-direction: row;
    overflow-x: auto;
    overflow-y: hidden;
    border-right: 0;
    border-bottom: 1px solid rgba(255,255,255,.14);
    max-height: none;
  }
  .hub-card.is-open .hub-tab {
    width: auto;
    min-width: 112px;
  }
  .hub-panel {
    max-height: 620px;
  }
}

/* Easter-egg video flow: short plays first, continue appears only after it ends. */
.hidden-video-chooser {
  display: none !important;
}

.continue-watch-row {
  min-height: 76px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 16px;
}

.easter-egg-button {
  box-shadow: 0 0 0 0 rgba(255, 216, 77, 0.55);
  animation: dgdPulse 1.8s ease-in-out infinite;
}

.easter-egg-button[hidden] {
  display: none !important;
}

@keyframes dgdPulse {
  0% { transform: translateY(0); box-shadow: 0 0 0 0 rgba(255, 216, 77, 0.50); }
  70% { transform: translateY(-1px); box-shadow: 0 0 0 16px rgba(255, 216, 77, 0); }
  100% { transform: translateY(0); box-shadow: 0 0 0 0 rgba(255, 216, 77, 0); }
}

/* Hub size + scroll clarity patch */
.hub-card.is-open .hub-shell {
  min-height: 780px;
}

.hub-card.is-open .hub-tabs {
  max-height: 780px;
}

.hub-card.is-open .hub-content {
  position: relative;
  min-height: 780px;
  max-height: 780px;
  overflow: hidden;
}

.hub-panel {
  max-height: 780px;
  padding-bottom: 82px;
  scrollbar-width: thin;
}

.hub-panel.active::after {
  content: "Scroll for more ↓";
  position: sticky;
  bottom: 0;
  z-index: 5;
  display: inline-block;
  margin-top: 22px;
  padding: 9px 16px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
  background: rgba(10, 8, 14, .84);
  color: rgba(255,248,239,.88);
  font-size: .88rem;
  font-weight: 900;
  backdrop-filter: blur(10px);
  box-shadow: 0 12px 28px rgba(0,0,0,.28);
}

.hub-panel .form-card {
  margin-bottom: 24px;
}

@media (max-width: 760px) {
  .hub-card.is-open .hub-content {
    min-height: 700px;
    max-height: 700px;
  }
  .hub-panel {
    max-height: 700px;
  }
}

/* Targeted Hub behavior: auto-size every panel except Comments. */
.hub-card.is-open .hub-shell {
  min-height: 0 !important;
  align-items: stretch;
}

.hub-card.is-open .hub-tabs {
  max-height: none !important;
}

.hub-card.is-open .hub-content {
  min-height: 0 !important;
  max-height: none !important;
  overflow: visible !important;
}

.hub-panel {
  max-height: none !important;
  overflow-y: visible !important;
  padding-bottom: clamp(18px, 3vw, 30px) !important;
}

.hub-panel.active::after {
  content: none !important;
  display: none !important;
}

#hub-comments.hub-panel {
  max-height: 720px !important;
  overflow-y: auto !important;
  padding-bottom: 82px !important;
  scrollbar-width: thin;
}

#hub-comments.hub-panel.active::after {
  content: "Scroll for more comments ↓" !important;
  position: sticky;
  bottom: 0;
  z-index: 5;
  display: inline-block !important;
  margin-top: 22px;
  padding: 9px 16px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
  background: rgba(10, 8, 14, .84);
  color: rgba(255,248,239,.88);
  font-size: .88rem;
  font-weight: 900;
  backdrop-filter: blur(10px);
  box-shadow: 0 12px 28px rgba(0,0,0,.28);
}

@media (max-width: 760px) {
  #hub-comments.hub-panel {
    max-height: 700px !important;
  }
}

/* DGD final comments hub sizing — driven by data-active-hub="comments" */
.hub-card.is-open[data-active-hub="comments"] .hub-shell {
  min-height: 840px !important;
}

.hub-card.is-open[data-active-hub="comments"] .hub-tabs {
  max-height: 840px !important;
}

.hub-card.is-open[data-active-hub="comments"] .hub-content {
  min-height: 840px !important;
  max-height: 840px !important;
  overflow: hidden !important;
}

.hub-card.is-open[data-active-hub="comments"] #hub-comments.hub-panel {
  height: 840px !important;
  max-height: 840px !important;
  overflow-y: auto !important;
  padding-bottom: 34px !important;
  scrollbar-width: thin;
}

.hub-card.is-open[data-active-hub="comments"] #hub-comments .comment-scroll-note {
  display: block !important;
  width: fit-content !important;
  margin: 16px auto 14px !important;
  padding: 9px 16px !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  border-radius: 999px !important;
  background: rgba(10, 8, 14, .84) !important;
  color: rgba(255,248,239,.88) !important;
  font-size: .88rem !important;
  font-weight: 900 !important;
  text-align: center !important;
  backdrop-filter: blur(10px);
  box-shadow: 0 12px 28px rgba(0,0,0,.28);
}

.hub-card.is-open[data-active-hub="comments"] #hub-comments .approved-comments {
  margin-top: 0 !important;
}

.hub-card.is-open[data-active-hub="comments"] #hub-comments .approved-comments,
.hub-card.is-open[data-active-hub="comments"] #hub-comments .comment-list {
  max-height: none !important;
  overflow: visible !important;
}

@media (max-width: 760px) {
  .hub-card.is-open[data-active-hub="comments"] .hub-content,
  .hub-card.is-open[data-active-hub="comments"] #hub-comments.hub-panel {
    min-height: 800px !important;
    max-height: 800px !important;
    height: 800px !important;
  }
}

/* DGD patch: put the comments scroll cue back in normal flow, not floating */
#hub-comments.hub-panel {
  max-height: 720px !important;
  overflow-y: auto !important;
  padding-bottom: 34px !important;
}

#hub-comments.hub-panel.active::after,
#hub-comments.hub-panel::after,
.hub-panel.active::after {
  content: none !important;
  display: none !important;
}

#hub-comments .comments-real-scroll-cue {
  display: block !important;
  position: static !important;
  width: fit-content;
  margin: 18px auto 18px !important;
  padding: 9px 16px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
  background: rgba(10, 8, 14, .62);
  color: rgba(255,248,239,.88);
  font-size: .88rem;
  font-weight: 900;
  text-align: center;
  backdrop-filter: blur(10px);
  box-shadow: 0 12px 28px rgba(0,0,0,.20);
}

#hub-comments .approved-comments {
  margin-top: 0 !important;
}
