:root {
  --pbv-bg: #fff8ec;
  --pbv-surface: #ffffff;
  --pbv-ink: #1a1a1a;
  --pbv-charcoal: #3a3a3a;
  --pbv-mint: #2dd4bf;
  --pbv-pink: #f472b6;
  --pbv-blue: #60a5fa;
  --pbv-banana: #fde047;
  --pbv-border: 3px solid #1a1a1a;
  --pbv-shadow: 8px 8px 0 #f472b6;
  --pbv-max: 1180px;
  --pbv-radius: 0px;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: "DM Sans", Arial, sans-serif;
  color: var(--pbv-ink);
  background-color: var(--pbv-bg);
  background-image:
    radial-gradient(circle at 20% 30%, #f472b6 4px, transparent 4px),
    radial-gradient(circle at 80% 70%, #60a5fa 3px, transparent 3px),
    linear-gradient(135deg, transparent 0 49%, rgba(45, 212, 191, 0.18) 49% 51%, transparent 51%),
    linear-gradient(45deg, transparent 0 49%, rgba(253, 224, 71, 0.18) 49% 51%, transparent 51%);
  background-size: 200px 200px, 200px 200px, 180px 180px, 180px 180px;
  overflow-x: hidden;
}

img {
  max-width: 100%;
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input,
textarea {
  font: inherit;
}

.pbv-progress {
  position: fixed;
  inset: 0 0 auto;
  height: 6px;
  background: rgba(26, 26, 26, 0.08);
  z-index: 120;
}

.pbv-progress-bar {
  display: block;
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, var(--pbv-mint), var(--pbv-pink), var(--pbv-blue));
}

.pbv-page {
  width: min(var(--pbv-max), calc(100% - 32px));
  margin: 0 auto;
}

.pbv-header {
  position: sticky;
  top: 0;
  z-index: 90;
  background: rgba(255, 248, 236, 0.95);
  backdrop-filter: blur(8px);
  border-bottom: var(--pbv-border);
}

.pbv-header-inner {
  display: flex;
  align-items: center;
  gap: 1rem;
  justify-content: space-between;
  padding: 0.8rem 0;
}

.pbv-logo {
  display: inline-flex;
  align-items: center;
  gap: 0.85rem;
  min-width: 0;
}

.pbv-logo-icon {
  width: 3rem;
  height: 3rem;
  flex-shrink: 0;
}

.pbv-logo-text {
  font-family: "Archivo Black", Arial, sans-serif;
  text-transform: uppercase;
  font-size: 0.9rem;
  letter-spacing: 0.08em;
  line-height: 1.1;
}

.pbv-logo-text span {
  display: block;
  font-family: "DM Sans", Arial, sans-serif;
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  text-transform: none;
}

.pbv-nav-toggle {
  width: 3rem;
  height: 3rem;
  border: var(--pbv-border);
  background: var(--pbv-surface);
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.28rem;
  cursor: pointer;
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}

.pbv-nav-toggle:hover {
  transform: translate(-2px, -2px);
  box-shadow: 4px 4px 0 var(--pbv-pink);
  background: var(--pbv-banana);
}

.pbv-nav-toggle span {
  width: 1.2rem;
  height: 3px;
  background: var(--pbv-ink);
}

.pbv-nav {
  display: flex;
  align-items: center;
  gap: 1rem;
  font-family: "Archivo Black", Arial, sans-serif;
  text-transform: uppercase;
  font-size: 0.84rem;
  letter-spacing: 0.08em;
}

.pbv-nav a {
  padding: 0.25rem 0.4rem;
  position: relative;
  transition: transform 0.15s ease, background 0.15s ease;
}

.pbv-nav a:hover,
.pbv-nav a:focus-visible {
  background: var(--pbv-banana);
  transform: rotate(-2deg);
}

.pbv-banner {
  padding: 1rem 0 0.7rem;
}

.pbv-banner-inner {
  border: var(--pbv-border);
  background: var(--pbv-surface);
  padding: 1rem 1.2rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  justify-content: space-between;
  flex-wrap: wrap;
  box-shadow: 8px 8px 0 var(--pbv-blue);
}

.pbv-banner-copy {
  display: flex;
  align-items: baseline;
  gap: 1rem;
  flex-wrap: wrap;
  min-width: 0;
}

.pbv-banner-copy h1 {
  margin: 0;
  font-family: "Archivo Black", Arial, sans-serif;
  font-size: clamp(1.18rem, 2.8vw, 2.3rem);
  line-height: 0.98;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.pbv-banner-copy p {
  margin: 0;
  max-width: 32rem;
  color: var(--pbv-charcoal);
}

.pbv-highlight {
  background: var(--pbv-pink);
  padding: 0 0.35rem;
  transform: rotate(-2deg);
  display: inline-block;
}

.pbv-banner-marks {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: center;
}

.pbv-reg-badge,
.pbv-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  border: 2px solid var(--pbv-ink);
  padding: 0.4rem 0.7rem;
  font-family: "Archivo Black", Arial, sans-serif;
  text-transform: uppercase;
  font-size: 0.72rem;
  letter-spacing: 0.07em;
  background: var(--pbv-surface);
}

.pbv-reg-badge:nth-child(2n) {
  background: var(--pbv-mint);
}

.pbv-reg-badge:nth-child(3n) {
  background: var(--pbv-banana);
}

.pbv-main {
  padding: 0.8rem 0 3rem;
}

.pbv-section {
  margin-bottom: 1.5rem;
  border: var(--pbv-border);
  background: rgba(255, 255, 255, 0.92);
  padding: 1.4rem;
  position: relative;
  box-shadow: 8px 8px 0 rgba(26, 26, 26, 0.14);
}

.pbv-section::before {
  content: "";
  position: absolute;
  inset: 12px auto auto 12px;
  width: 48px;
  height: 14px;
  background:
    radial-gradient(circle, var(--pbv-ink) 2px, transparent 2px) 0 0 / 12px 12px,
    linear-gradient(90deg, var(--pbv-mint), var(--pbv-pink));
}

.pbv-section h2 {
  margin: 0 0 1rem;
  font-family: "Archivo Black", Arial, sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: clamp(1.16rem, 2.6vw, 2.2rem);
}

.pbv-section p {
  color: var(--pbv-charcoal);
  line-height: 1.65;
}

.pbv-section-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: end;
  flex-wrap: wrap;
  margin-bottom: 1.15rem;
}

.pbv-kicker {
  margin: 0;
  font-family: "Archivo Black", Arial, sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  font-size: 0.78rem;
  color: var(--pbv-charcoal);
}

.pbv-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1rem;
}

.pbv-card {
  border: var(--pbv-border);
  background: var(--pbv-surface);
  padding: 1.2rem;
  position: relative;
  overflow: hidden;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.pbv-card::before {
  content: "";
  position: absolute;
  right: -2px;
  top: -2px;
  width: 70px;
  height: 70px;
  border-left: var(--pbv-border);
  border-bottom: var(--pbv-border);
  background: var(--pbv-mint);
}

.pbv-card:nth-child(4n + 2)::before {
  background: var(--pbv-pink);
  clip-path: circle(52% at 50% 50%);
}

.pbv-card:nth-child(4n + 3)::before {
  background: var(--pbv-blue);
  clip-path: inset(0);
}

.pbv-card:nth-child(4n + 4)::before {
  background: var(--pbv-banana);
  clip-path: polygon(0 0, 100% 18%, 80% 100%, 0 82%);
}

.pbv-card:hover,
.pbv-card[data-hover="active"] {
  transform: translate(-4px, -4px);
  box-shadow: var(--pbv-shadow);
}

.pbv-card-top {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.85rem;
  text-align: center;
  position: relative;
  z-index: 1;
}

.pbv-card-rank {
  font-family: "Archivo Black", Arial, sans-serif;
  font-size: 3rem;
  color: var(--pbv-blue);
  line-height: 1;
}

.pbv-card:nth-child(3n) .pbv-card-rank {
  color: var(--pbv-pink);
}

.pbv-card:nth-child(4n) .pbv-card-rank {
  color: #10b981;
}

.pbv-logo-wrap {
  padding: 6px;
  width: 140px;
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  overflow: hidden;
  background: #ffffff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.14);
  flex-shrink: 0;
}

.pbv-logo-wrap img {
  object-fit: contain;
  width: 100%;
  height: 100%;
  display: block;
  border-radius: 12px;
}

.pbv-brand-meta {
  min-width: 0;
  width: 100%;
}

.pbv-brand-meta h3 {
  margin: 0;
  font-family: "Archivo Black", Arial, sans-serif;
  font-size: 1.2rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.pbv-score {
  min-width: 0;
}

.pbv-score strong {
  display: block;
  font-family: "Archivo Black", Arial, sans-serif;
  font-size: 1.3rem;
}

.pbv-score span {
  color: var(--pbv-charcoal);
  font-size: 0.92rem;
}

.pbv-bonus {
  margin: 1rem 0 0.75rem;
  border: var(--pbv-border);
  background: var(--pbv-banana);
  padding: 0.9rem;
  font-family: "Archivo Black", Arial, sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 0.96rem;
}

.pbv-divider {
  height: 12px;
  background:
    radial-gradient(circle at 6px 6px, var(--pbv-ink) 2px, transparent 2px) 0 0 / 16px 12px,
    linear-gradient(90deg, transparent 0 8%, var(--pbv-pink) 8% 16%, transparent 16% 24%, var(--pbv-mint) 24% 32%, transparent 32% 40%, var(--pbv-blue) 40% 48%, transparent 48% 56%, var(--pbv-banana) 56% 64%, transparent 64%);
  margin: 0.8rem 0;
}

.pbv-feature-list,
.pbv-glossary-list,
.pbv-detail-list,
.pbv-rg-checklist {
  list-style: none;
  margin: 0;
  padding: 0;
}

.pbv-feature-list li {
  padding: 0.45rem 0;
  border-bottom: 1px dashed rgba(26, 26, 26, 0.22);
  font-size: 0.96rem;
}

.pbv-feature-list li:last-child {
  border-bottom: 0;
}

.pbv-card-foot {
  margin-top: 1rem;
  display: grid;
  gap: 0.7rem;
}

.pbv-disclaimer {
  font-size: 0.78rem;
  color: var(--pbv-charcoal);
  min-height: 3rem;
}

.pbv-button,
.pbv-link-button,
.pbv-form button,
.pbv-age-actions button,
.pbv-cookie-banner button,
.pbv-back-top {
  border: var(--pbv-border);
  background: var(--pbv-ink);
  color: #ffffff;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-family: "Archivo Black", Arial, sans-serif;
  padding: 0.9rem 1.1rem;
  cursor: pointer;
  transition: transform 0.1s ease, background 0.1s ease, box-shadow 0.1s ease, color 0.1s ease;
}

.pbv-button:hover,
.pbv-link-button:hover,
.pbv-form button:hover,
.pbv-age-actions button:hover,
.pbv-cookie-banner button:hover,
.pbv-back-top:hover {
  transform: translate(-2px, -2px);
  background: var(--pbv-mint);
  color: var(--pbv-ink);
  box-shadow: 4px 4px 0 var(--pbv-pink);
}

.pbv-button {
  display: inline-flex;
  justify-content: center;
  width: 100%;
}

.pbv-card-note {
  display: flex;
  justify-content: space-between;
  gap: 0.6rem;
  flex-wrap: wrap;
  font-size: 0.82rem;
  color: var(--pbv-charcoal);
}

.pbv-card-note a {
  text-decoration: underline;
}

.pbv-spotlight-grid,
.pbv-games-grid,
.pbv-glossary-grid,
.pbv-rg-grid,
.pbv-numbers-grid,
.pbv-page-grid,
.pbv-review-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1rem;
}

.pbv-spotlight-card,
.pbv-game-card,
.pbv-glossary-card,
.pbv-rg-item,
.pbv-number-card,
.pbv-page-panel,
.pbv-review-panel {
  border: var(--pbv-border);
  background: var(--pbv-surface);
  padding: 1rem;
  min-width: 0;
}

.pbv-spotlight-card h3,
.pbv-game-card h3,
.pbv-glossary-card h3,
.pbv-number-card h3,
.pbv-page-panel h3,
.pbv-review-panel h3 {
  margin-top: 0;
  font-family: "Archivo Black", Arial, sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.pbv-mini-tag {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  border: 2px solid var(--pbv-ink);
  background: var(--pbv-banana);
  padding: 0.35rem 0.6rem;
  font-family: "Archivo Black", Arial, sans-serif;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.pbv-table-wrap {
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: 1rem 0;
}

.pbv-methodology-table,
table {
  width: 100%;
  border-collapse: collapse;
  background: var(--pbv-surface);
}

.pbv-methodology-table th,
.pbv-methodology-table td,
table th,
table td {
  border: 2px solid var(--pbv-ink);
  padding: 0.7rem 0.8rem;
  text-align: left;
}

.pbv-methodology-table thead th,
table thead th {
  background: var(--pbv-banana);
  font-family: "Archivo Black", Arial, sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.pbv-counter {
  font-family: "Archivo Black", Arial, sans-serif;
  font-size: clamp(1.8rem, 4vw, 3rem);
  line-height: 1;
  margin-bottom: 0.4rem;
}

.pbv-rg-item {
  background: #fff7d1;
}

.pbv-rg-checklist {
  display: grid;
  gap: 0.8rem;
  padding-inline: 0;
}

.pbv-rg-checklist li {
  border: var(--pbv-border);
  background: var(--pbv-surface);
  padding: 0.9rem;
  min-width: 0;
}

.pbv-rg-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  margin-top: 1rem;
}

.pbv-rg-links a {
  text-decoration: underline;
  font-weight: 700;
}

.pbv-page-hero {
  padding: 5rem 0 2rem;
}

.pbv-page-hero-box {
  border: var(--pbv-border);
  background: var(--pbv-surface);
  padding: 1.3rem;
  box-shadow: 8px 8px 0 var(--pbv-blue);
}

.pbv-page-hero h1 {
  margin: 0 0 0.8rem;
  font-family: "Archivo Black", Arial, sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  font-size: clamp(1.22rem, 4vw, 3.4rem);
}

.pbv-page-hero p {
  margin: 0;
  max-width: 48rem;
}

.pbv-form {
  display: grid;
  gap: 0.8rem;
}

.pbv-form label {
  font-weight: 700;
}

.pbv-form input,
.pbv-form textarea {
  width: 100%;
  border: var(--pbv-border);
  background: #fffdf8;
  padding: 0.85rem;
}

.pbv-footer {
  padding: 0 0 2rem;
}

.pbv-footer-box {
  border: var(--pbv-border);
  background: var(--pbv-surface);
  padding: 1.1rem 1.2rem;
  box-shadow: 8px 8px 0 var(--pbv-pink);
}

.pbv-footer-row {
  display: flex;
  gap: 0.8rem;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  border-bottom: 2px solid rgba(26, 26, 26, 0.18);
  padding-bottom: 0.7rem;
}

.pbv-footer-nav,
.pbv-footer-meta {
  display: flex;
  gap: 0.8rem;
  flex-wrap: wrap;
  align-items: center;
}

.pbv-footer-meta {
  padding-top: 0.85rem;
  font-size: 0.88rem;
  color: var(--pbv-charcoal);
}

.pbv-footer-title {
  font-family: "Archivo Black", Arial, sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.pbv-age-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  padding: 1rem;
  background: rgba(26, 26, 26, 0.35);
  overflow-y: auto;
  transition: opacity 0.2s ease;
}

.pbv-age-overlay[data-pbv-age-state="confirmed"] {
  opacity: 0;
  pointer-events: none;
}

.pbv-age-box {
  width: min(760px, 100%);
  margin: auto;
  border: var(--pbv-border);
  background: var(--pbv-surface);
  padding: 1rem 1.2rem;
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: center;
  flex-wrap: wrap;
  box-shadow: 8px 8px 0 var(--pbv-banana);
}

.pbv-age-box h2 {
  margin: 0;
  font-family: "Archivo Black", Arial, sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: clamp(1.1rem, 3vw, 1.8rem);
}

.pbv-age-box p {
  margin: 0;
  color: var(--pbv-charcoal);
}

.pbv-age-actions {
  display: flex;
  gap: 0.7rem;
  flex-wrap: wrap;
}

.pbv-cookie-banner {
  position: fixed;
  left: 16px;
  right: 16px;
  bottom: 16px;
  z-index: 100;
  border: var(--pbv-border);
  background: var(--pbv-surface);
  padding: 12px 16px;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
  box-shadow: 8px 8px 0 var(--pbv-blue);
  transition: transform 0.2s ease, opacity 0.2s ease;
}

.pbv-cookie-banner[data-pbv-cookie-state="hidden"] {
  opacity: 0;
  pointer-events: none;
  transform: translateY(16px);
}

.pbv-cookie-actions {
  display: flex;
  gap: 0.7rem;
  flex-wrap: wrap;
}

.pbv-back-top {
  position: fixed;
  right: 1rem;
  bottom: 5rem;
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  z-index: 80;
}

.pbv-inline-list {
  display: flex;
  gap: 0.8rem;
  flex-wrap: wrap;
}

.pbv-review-brand {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  align-items: center;
}

.pbv-review-brand .pbv-logo-wrap {
  width: min(180px, 100%);
  height: 96px;
}

.pbv-chipline {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
  margin: 1rem 0;
}

.pbv-chip {
  border: 2px solid var(--pbv-ink);
  background: #fffdf8;
  padding: 0.45rem 0.7rem;
  font-size: 0.86rem;
}

.pbv-note-box {
  border-left: 8px solid var(--pbv-pink);
  padding-left: 1rem;
}

@media (max-width: 900px) {
  .pbv-nav-toggle {
    display: inline-flex;
  }

  .pbv-header-inner {
    position: relative;
  }

  .pbv-nav {
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    left: auto;
    width: min(320px, calc(100vw - 24px));
    flex-direction: column;
    align-items: flex-start;
    padding: 14px;
    border: var(--pbv-border);
    background: var(--pbv-surface);
    box-shadow: 8px 8px 0 var(--pbv-pink);
    opacity: 0;
    pointer-events: none;
    transform: translateY(-8px);
    transition: opacity 0.15s ease, transform 0.15s ease;
  }

  .pbv-nav.pbv-nav-open {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }
}

@media (max-width: 680px) {
  .pbv-banner-copy {
    align-items: flex-start;
    flex-direction: column;
  }

  .pbv-age-box {
    align-items: flex-start;
  }
}

@media (max-width: 550px) {
  body { overflow-x: hidden; }
  .pbv-page { width: min(var(--pbv-max, 1180px), calc(100% - 12px)); }
  .pbv-header-inner { padding: 0.65rem 0.75rem; gap: 0.5rem; position: relative; }
  .pbv-logo { min-width: 0; align-items: center; }
  .pbv-logo-text { font-size: clamp(0.58rem, 2.9vw, 0.78rem); letter-spacing: 0.05em; line-height: 1.2; word-break: break-word; overflow-wrap: anywhere; }
  .pbv-logo-icon { width: 2.25rem; height: 2.25rem; flex-shrink: 0; }
  .pbv-nav { left: 8px; right: 8px; padding: 12px; }
  .pbv-nav a { font-size: 0.72rem; letter-spacing: 0.1em; padding-block: 0.2rem; }
  .pbv-hero, .pbv-page-hero { padding: 4.75rem 0.6rem 2.5rem; }
  .pbv-hero h1, .pbv-page-hero h1 { font-size: clamp(1.05rem, 5.8vw, 2rem); letter-spacing: 0.055em; word-break: break-word; overflow-wrap: anywhere; }
  .pbv-kicker { font-size: 0.65rem; letter-spacing: 0.12em; max-width: 100%; }
  .pbv-cta-row { gap: 0.65rem; margin-top: 1.35rem; }
  .pbv-button, .pbv-link-button, .pbv-form button, .pbv-age-actions button, .pbv-cookie-banner button, .pbv-back-top { padding: 0.72rem 1rem; font-size: 0.88rem; }
  .pbv-section { padding: 0.95rem 0.75rem; border-radius: 18px; margin-bottom: 1.25rem; }
  .pbv-section h2 { font-size: clamp(1.02rem, 4.8vw, 1.55rem); letter-spacing: 0.06em; word-break: break-word; overflow-wrap: anywhere; }
  .pbv-methodology-table, table { font-size: 0.78rem; table-layout: auto; width: max-content; min-width: 100%; }
  .pbv-methodology-table thead th, table thead th { white-space: nowrap; }
  .pbv-methodology-table th, .pbv-methodology-table td, table th, table td { padding: 0.5rem 0.4rem; word-break: normal; overflow-wrap: break-word; hyphens: none; }
  .pbv-table-wrap { max-width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .pbv-card { padding: 0.95rem 0.75rem; border-radius: 18px; }
  .pbv-card:hover, .pbv-card[data-hover="active"] { transform: none; }
  .pbv-card-top { flex-wrap: wrap; align-items: flex-start; gap: 0.55rem; }
  .pbv-score { text-align: left; flex: 1 1 auto; min-width: 0; }
  .pbv-badge { font-size: 0.65rem; padding: 0.32rem 0.55rem; max-width: 100%; white-space: normal; text-align: left; }
  .pbv-logo-wrap { width: min(140px, 100%); max-width: 100%; height: auto; min-height: 4.25rem; }
  .pbv-brand-meta { min-width: 0; width: 100%; }
  .pbv-bonus { padding: 0.65rem 0.7rem; font-size: 0.88rem; }
  .pbv-cookie-banner { padding: 10px 10px; gap: 10px; font-size: 0.84rem; }
  .pbv-footer-box { padding: 1.15rem 0.75rem; border-radius: 20px; }
  .pbv-footer-title { letter-spacing: 0.08em; font-size: clamp(0.95rem, 4vw, 1.2rem); word-break: break-word; }
  .pbv-back-top { right: 0.45rem; bottom: 5.25rem; width: 2.65rem; height: 2.65rem; font-size: 1.05rem; }
  .pbv-age-overlay { position: fixed; inset: 0; z-index: 9999; display: grid; place-items: center; }
  .pbv-age-box { padding: 1.1rem 0.75rem; }
  .pbv-age-box h2 { font-size: clamp(1rem, 4.5vw, 1.35rem); letter-spacing: 0.06em; word-break: break-word; }
  .pbv-rg-item { min-width: 0; word-break: break-word; overflow-wrap: anywhere; }
  .pbv-rg-checklist { gap: 0.55rem; padding-inline: 0; }
  .pbv-rg-checklist li, .pbv-rg-checklist p { word-break: break-word; overflow-wrap: anywhere; hyphens: auto; min-width: 0; }
  .pbv-reg-badge { white-space: normal; text-align: center; padding: 0.28rem 0.5rem; font-size: 0.72rem; max-width: 100%; flex-shrink: 1; }
}
@media (max-width: 380px) {
  .pbv-page { width: min(var(--pbv-max, 1180px), calc(100% - 8px)); }
  .pbv-logo-text { font-size: 0.52rem; letter-spacing: 0.02em; }
  .pbv-hero h1, .pbv-page-hero h1 { font-size: clamp(1rem, 5.2vw, 1.75rem); }
  .pbv-header-inner { padding: 0.55rem 0.55rem; }
  .pbv-section, .pbv-card, .pbv-footer-box { padding-inline: 0.65rem; }
  .pbv-methodology-table th, .pbv-methodology-table td, table th, table td { padding: 0.42rem 0.32rem; font-size: 0.72rem; }
}
@media (max-width: 900px) {
  .pbv-header-inner { position: relative; }
}
