/* Estland 2 — Portal V5
   Immersive dark interface, built for desktop and mobile. */

:root {
  --v5-bg: #04070d;
  --v5-bg-2: #07111f;
  --v5-panel: rgba(11, 21, 36, 0.78);
  --v5-panel-strong: rgba(13, 26, 46, 0.92);
  --v5-panel-soft: rgba(255, 255, 255, 0.035);
  --v5-line: rgba(168, 196, 230, 0.13);
  --v5-line-strong: rgba(233, 189, 99, 0.34);
  --v5-text: #f4f7fb;
  --v5-text-soft: #aebbd0;
  --v5-muted: #72819a;
  --v5-gold: #e7b85f;
  --v5-gold-2: #ffd786;
  --v5-gold-deep: #8f6120;
  --v5-cyan: #62d4ff;
  --v5-green: #7be3b0;
  --v5-red: #ff7d8a;
  --v5-radius-xl: 38px;
  --v5-radius-lg: 28px;
  --v5-radius-md: 20px;
  --v5-radius-sm: 14px;
  --v5-shadow: 0 28px 80px rgba(0, 0, 0, 0.38);
  --v5-shadow-soft: 0 18px 44px rgba(0, 0, 0, 0.22);
  --v5-shell: 1380px;
  --v5-header-top: 34px;
}

html {
  scroll-behavior: smooth;
  background: var(--v5-bg);
}

body.portal-v5 {
  min-height: 100vh;
  margin: 0;
  overflow-x: hidden;
  color: var(--v5-text);
  background:
    radial-gradient(circle at 8% -8%, rgba(42, 93, 170, 0.23), transparent 34%),
    radial-gradient(circle at 92% 5%, rgba(231, 184, 95, 0.12), transparent 28%),
    radial-gradient(circle at 55% 100%, rgba(23, 79, 126, 0.13), transparent 35%),
    linear-gradient(180deg, #04070d 0%, #06101c 38%, #04080f 100%);
  font-family: Inter, ui-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body.portal-v5::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -5;
  pointer-events: none;
  opacity: 0.22;
  background-image:
    linear-gradient(rgba(255,255,255,.026) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.026) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: radial-gradient(circle at 50% 25%, black, transparent 78%);
}

body.portal-v5::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 9998;
  pointer-events: none;
  opacity: 0.055;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.86' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.6'/%3E%3C/svg%3E");
  mix-blend-mode: soft-light;
}

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

.portal-v5 a { color: inherit; text-decoration: none; }
.portal-v5 button,
.portal-v5 input,
.portal-v5 textarea,
.portal-v5 select { font: inherit; }
.portal-v5 button { color: inherit; }
.portal-v5 img { max-width: 100%; }

.portal-v5 .shell {
  width: min(calc(100% - 42px), var(--v5-shell));
  margin-inline: auto;
}

.portal-v5 .ambient-stage {
  position: fixed;
  inset: 0;
  z-index: -4;
  overflow: hidden;
  pointer-events: none;
}

.portal-v5 .ambient-aura {
  position: absolute;
  border-radius: 50%;
  filter: blur(95px);
  opacity: 0.22;
  animation: v5-drift 18s ease-in-out infinite alternate;
}

.portal-v5 .ambient-aura-gold {
  width: 420px;
  height: 420px;
  right: -150px;
  top: 260px;
  background: rgba(224, 172, 74, 0.38);
}

.portal-v5 .ambient-aura-cyan {
  width: 520px;
  height: 520px;
  left: -260px;
  top: 35%;
  background: rgba(66, 175, 255, 0.25);
  animation-delay: -6s;
}

.portal-v5 .ambient-aura-blue {
  width: 360px;
  height: 360px;
  left: 46%;
  top: -170px;
  background: rgba(46, 91, 191, 0.22);
  animation-delay: -11s;
}

.portal-v5 .ambient-grid,
.portal-v5 .ambient-noise { display: none; }

@keyframes v5-drift {
  to { transform: translate3d(42px, -28px, 0) scale(1.08); }
}

/* Cursor spotlight */
.v5-cursor-light {
  position: fixed;
  z-index: -1;
  width: 420px;
  height: 420px;
  left: 0;
  top: 0;
  border-radius: 50%;
  pointer-events: none;
  opacity: 0;
  background: radial-gradient(circle, rgba(104, 183, 255, .105), transparent 66%);
  transform: translate3d(calc(var(--cursor-x, -999px) - 50%), calc(var(--cursor-y, -999px) - 50%), 0);
  transition: opacity .35s ease;
}

body.has-pointer .v5-cursor-light { opacity: 1; }

/* Language strip */
.portal-v5 .site-language-bar {
  position: relative;
  z-index: 70;
  height: var(--v5-header-top);
  border-bottom: 1px solid rgba(255, 255, 255, 0.055);
  background: rgba(2, 6, 12, 0.84);
  backdrop-filter: blur(18px);
}

.portal-v5 .site-language-inner {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}

.portal-v5 .site-language-inner > span {
  color: rgba(206, 218, 235, .52);
  font-size: .66rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.portal-v5 .site-language-options {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 3px;
  border: 1px solid rgba(255,255,255,.065);
  border-radius: 999px;
  background: rgba(255,255,255,.025);
}

.portal-v5 .site-language-options button {
  min-width: 34px;
  min-height: 22px;
  padding: 0 9px;
  border: 0;
  border-radius: 999px;
  color: rgba(200, 211, 228, .58);
  background: transparent;
  font-size: .67rem;
  font-weight: 850;
  letter-spacing: .04em;
  cursor: pointer;
  transition: color .18s ease, background .18s ease, transform .18s ease;
}

.portal-v5 .site-language-options button:hover {
  color: var(--v5-text);
  background: rgba(255,255,255,.06);
}

.portal-v5 .site-language-options button.is-active {
  color: #211607;
  background: linear-gradient(180deg, #ffe09a, #e5ae4a);
  box-shadow: 0 6px 18px rgba(226, 169, 66, .22);
}

/* Floating navigation */
.portal-v5 .site-header.portal-header {
  position: sticky;
  top: 0;
  z-index: 65;
  padding: 14px 0 0;
  background: linear-gradient(180deg, rgba(4, 7, 13, .84), rgba(4,7,13,0));
  transition: padding .22s ease;
}

.portal-v5 .site-header.portal-header.is-scrolled { padding-top: 8px; }

.portal-v5 .portal-header-inner {
  min-height: 74px;
  padding: 10px 12px 10px 14px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 28px;
  border: 1px solid rgba(159, 188, 225, 0.15);
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(14, 27, 45, .86), rgba(7, 16, 29, .82));
  box-shadow: 0 18px 42px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.06);
  backdrop-filter: blur(24px) saturate(140%);
  transition: min-height .22s ease, border-radius .22s ease, background .22s ease;
}

.portal-v5 .site-header.is-scrolled .portal-header-inner {
  min-height: 66px;
  border-radius: 20px;
  background: rgba(7, 15, 27, .91);
}

.portal-v5 .portal-brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.portal-v5 .portal-brand-mark {
  position: relative;
  width: 45px;
  height: 45px;
  flex: 0 0 auto;
  display: grid;
  place-items: center;
  border-radius: 15px;
  border: 1px solid rgba(231, 184, 95, .26);
  background:
    radial-gradient(circle at 30% 20%, rgba(255,255,255,.16), transparent 34%),
    linear-gradient(145deg, rgba(231,184,95,.18), rgba(25,45,74,.58));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 12px 28px rgba(0,0,0,.25);
  overflow: hidden;
}

.portal-v5 .portal-brand-mark::after {
  content: "";
  position: absolute;
  inset: -40%;
  background: linear-gradient(110deg, transparent 38%, rgba(255,255,255,.26), transparent 62%);
  transform: translateX(-80%) rotate(12deg);
  animation: v5-logo-shine 7s ease-in-out infinite;
}

@keyframes v5-logo-shine {
  0%, 72% { transform: translateX(-90%) rotate(12deg); }
  88%, 100% { transform: translateX(90%) rotate(12deg); }
}

.portal-v5 .portal-brand-mark img {
  position: relative;
  z-index: 1;
  width: 27px;
  height: 27px;
  object-fit: contain;
}

.portal-v5 .portal-brand > span:last-child {
  display: grid;
  line-height: 1.05;
}

.portal-v5 .portal-brand strong {
  font-size: .98rem;
  font-weight: 850;
  letter-spacing: -.02em;
}

.portal-v5 .portal-brand em {
  margin-top: 5px;
  color: var(--v5-muted);
  font-size: .66rem;
  font-style: normal;
  font-weight: 700;
}

.portal-v5 .portal-primary-nav {
  justify-self: center;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px;
  border: 1px solid rgba(255,255,255,.055);
  border-radius: 999px;
  background: rgba(255,255,255,.025);
}

.portal-v5 .portal-primary-nav a {
  position: relative;
  min-height: 38px;
  padding: 0 17px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  color: #91a0b8;
  font-size: .78rem;
  font-weight: 800;
  transition: color .2s ease, background .2s ease, transform .2s ease;
}

.portal-v5 .portal-primary-nav a:hover {
  color: var(--v5-text);
  background: rgba(255,255,255,.05);
  transform: translateY(-1px);
}

.portal-v5 .portal-primary-nav a.is-active {
  color: #241706;
  background: linear-gradient(180deg, #ffdd93, #dca13c);
  box-shadow: 0 10px 24px rgba(222,163,59,.22), inset 0 1px 0 rgba(255,255,255,.45);
}

.portal-v5 .portal-header-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
}

.portal-v5 .portal-more-button,
.portal-v5 .portal-mobile-menu-button,
.portal-v5 .portal-play-button {
  min-height: 44px;
  border-radius: 15px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  cursor: pointer;
  transition: transform .2s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease;
}

.portal-v5 .portal-more-button,
.portal-v5 .portal-mobile-menu-button {
  border: 1px solid rgba(255,255,255,.08);
  color: #aebad0;
  background: rgba(255,255,255,.035);
}

.portal-v5 .portal-more-button { padding: 0 15px; font-size: .77rem; font-weight: 800; }
.portal-v5 .portal-more-button svg { width: 15px; height: 15px; fill: none; stroke: currentColor; stroke-width: 2; }
.portal-v5 .portal-more-button:hover,
.portal-v5 .portal-mobile-menu-button:hover { color: var(--v5-text); background: rgba(255,255,255,.07); transform: translateY(-1px); }

.portal-v5 .portal-play-button {
  position: relative;
  overflow: hidden;
  padding: 0 20px;
  color: #1f1405;
  background: linear-gradient(135deg, #ffe19a 0%, #e7b359 52%, #c8862c 100%);
  box-shadow: 0 12px 28px rgba(213,145,40,.25), inset 0 1px 0 rgba(255,255,255,.5);
  font-size: .8rem;
  font-weight: 900;
}

.portal-v5 .portal-play-button::after {
  content: "";
  position: absolute;
  inset: -120% -30%;
  background: linear-gradient(105deg, transparent 42%, rgba(255,255,255,.55), transparent 58%);
  transform: translateX(-65%) rotate(12deg);
  transition: transform .55s ease;
}

.portal-v5 .portal-play-button:hover { transform: translateY(-2px); box-shadow: 0 16px 34px rgba(213,145,40,.34); }
.portal-v5 .portal-play-button:hover::after { transform: translateX(65%) rotate(12deg); }
.portal-v5 .portal-play-button svg { width: 17px; height: 17px; fill: currentColor; }

.portal-v5 .portal-mobile-menu-button { display: none; width: 44px; padding: 0; }
.portal-v5 .portal-mobile-menu-button svg { width: 20px; height: 20px; fill: none; stroke: currentColor; stroke-width: 2; }

.portal-v5 .portal-more-menu {
  position: absolute;
  top: calc(100% + 8px);
  right: max(21px, calc((100vw - var(--v5-shell)) / 2 + 4px));
  width: min(520px, calc(100vw - 42px));
  padding: 14px;
  border: 1px solid rgba(164,193,228,.15);
  border-radius: 24px;
  background: rgba(8, 17, 30, .95);
  box-shadow: 0 30px 80px rgba(0,0,0,.48), inset 0 1px 0 rgba(255,255,255,.055);
  backdrop-filter: blur(26px);
  transform-origin: top right;
  animation: v5-pop .18s ease-out;
}

@keyframes v5-pop { from { opacity: 0; transform: translateY(-8px) scale(.98); } }

.portal-v5 .portal-more-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.portal-v5 .portal-more-grid a {
  min-height: 74px;
  padding: 14px;
  display: flex;
  align-items: center;
  gap: 12px;
  border: 1px solid rgba(255,255,255,.055);
  border-radius: 18px;
  background: rgba(255,255,255,.025);
  color: #b7c3d6;
  transition: transform .2s ease, border-color .2s ease, background .2s ease, color .2s ease;
}

.portal-v5 .portal-more-grid a:hover {
  transform: translateY(-2px);
  border-color: rgba(231,184,95,.25);
  background: rgba(231,184,95,.075);
  color: var(--v5-text);
}

.portal-v5 .portal-more-grid a.is-active { border-color: rgba(231,184,95,.35); background: rgba(231,184,95,.1); }
.portal-v5 .portal-menu-icon { width: 38px; height: 38px; border-radius: 13px; display: grid; place-items: center; background: rgba(255,255,255,.05); }
.portal-v5 .portal-menu-icon svg { width: 19px; height: 19px; fill: none; stroke: currentColor; stroke-width: 1.8; }
.portal-v5 .portal-more-grid strong { font-size: .82rem; }
.portal-v5 .portal-more-community { margin-top: 10px; padding: 12px 4px 0; display: flex; flex-wrap: wrap; gap: 14px; border-top: 1px solid rgba(255,255,255,.06); }
.portal-v5 .portal-more-community a { color: var(--v5-muted); font-size: .72rem; font-weight: 750; }
.portal-v5 .portal-more-community a:hover { color: var(--v5-gold-2); }

/* Base cards / buttons */
.portal-v5 .surface-card {
  position: relative;
  border: 1px solid var(--v5-line);
  border-radius: var(--v5-radius-lg);
  background:
    linear-gradient(145deg, rgba(18, 34, 56, .84), rgba(7, 16, 29, .82));
  box-shadow: var(--v5-shadow-soft), inset 0 1px 0 rgba(255,255,255,.045);
  backdrop-filter: blur(18px) saturate(125%);
}

.portal-v5 .surface-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background: radial-gradient(500px circle at var(--card-x, 50%) var(--card-y, 0%), rgba(255,255,255,.065), transparent 42%);
  opacity: 0;
  transition: opacity .25s ease;
}

.portal-v5 .surface-card:hover::before { opacity: 1; }

.portal-v5 .button {
  min-height: 46px;
  padding: 0 18px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 15px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  color: #d7dfeb;
  background: rgba(255,255,255,.04);
  font-size: .8rem;
  font-weight: 850;
  cursor: pointer;
  transition: transform .2s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease;
}

.portal-v5 .button:hover { transform: translateY(-2px); border-color: rgba(255,255,255,.16); background: rgba(255,255,255,.075); }
.portal-v5 .button-primary {
  color: #211606;
  border-color: rgba(255,217,139,.45);
  background: linear-gradient(135deg, #ffe19a, #e2a947);
  box-shadow: 0 14px 32px rgba(209,142,37,.2), inset 0 1px 0 rgba(255,255,255,.55);
}
.portal-v5 .button-primary:hover { background: linear-gradient(135deg, #ffe8ad, #edb754); box-shadow: 0 18px 38px rgba(209,142,37,.29); }
.portal-v5 .button-glass,
.portal-v5 .button-subtle { background: rgba(255,255,255,.035); }
.portal-v5 .button-xl { min-height: 52px; padding-inline: 22px; border-radius: 17px; }

.portal-v5 .kicker,
.portal-v5 .eyebrow-live,
.portal-v5 .micro-pill,
.portal-v5 .content-tag,
.portal-v5 .status-pill,
.portal-v5 .roadmap-status-tag,
.portal-v5 .shop-badge,
.portal-v5 .shop-kind-tag,
.portal-v5 .shop-sync-pill,
.portal-v5 .shop-sales-pill,
.portal-v5 .promo-code-expiry-pill {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  width: fit-content;
  min-height: 27px;
  padding: 0 10px;
  border: 1px solid rgba(231,184,95,.2);
  border-radius: 999px;
  color: var(--v5-gold-2);
  background: rgba(231,184,95,.08);
  font-size: .66rem;
  line-height: 1;
  font-weight: 850;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.portal-v5 .content-tag-neutral { color: #a8b8cd; border-color: rgba(168,184,205,.16); background: rgba(168,184,205,.06); }
.portal-v5 .tag-announcement,
.portal-v5 .tag-update { color: #8cddff; border-color: rgba(98,212,255,.22); background: rgba(98,212,255,.08); }
.portal-v5 .tag-bugfix { color: #8ce8ba; border-color: rgba(123,227,176,.22); background: rgba(123,227,176,.08); }
.portal-v5 .tag-issue { color: #ff9ea8; border-color: rgba(255,125,138,.22); background: rgba(255,125,138,.08); }

/* Home — immersive hero */
.portal-v5 .hero-premium-grid {
  padding-top: 42px;
  display: grid;
  grid-template-columns: minmax(0, 1.72fr) minmax(330px, .68fr);
  gap: 18px;
  align-items: stretch;
}

.portal-v5 .hero-command-card {
  min-height: 650px;
  padding: clamp(30px, 4.2vw, 64px);
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(260px, .85fr);
  align-items: center;
  gap: 38px;
  border-radius: 42px;
  background:
    radial-gradient(circle at 84% 18%, rgba(84, 169, 255, .18), transparent 34%),
    radial-gradient(circle at 18% 100%, rgba(231,184,95,.12), transparent 38%),
    linear-gradient(145deg, rgba(20, 40, 68, .94), rgba(6, 15, 28, .94));
  box-shadow: 0 38px 100px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.08);
}

.portal-v5 .hero-command-card::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 52px 52px;
  mask-image: linear-gradient(90deg, black, transparent 82%);
  opacity: .55;
}

.portal-v5 .hero-copy-wrap { position: relative; z-index: 2; min-width: 0; }
.portal-v5 .hero-overline-row { display: flex; flex-wrap: wrap; align-items: center; gap: 9px; }
.portal-v5 .eyebrow-live { color: var(--v5-green); border-color: rgba(123,227,176,.24); background: rgba(123,227,176,.08); }
.portal-v5 .eyebrow-live::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: currentColor; box-shadow: 0 0 0 5px rgba(123,227,176,.08), 0 0 18px rgba(123,227,176,.55); animation: v5-pulse 2s ease-out infinite; }
@keyframes v5-pulse { 50% { box-shadow: 0 0 0 9px rgba(123,227,176,0), 0 0 22px rgba(123,227,176,.5); } }
.portal-v5 .micro-pill { color: #a7b8cd; border-color: rgba(167,184,205,.15); background: rgba(255,255,255,.03); }

.portal-v5 .hero-command-card h1 {
  max-width: 10.5ch;
  margin: 24px 0 20px;
  font-size: clamp(3rem, 5.3vw, 5.35rem);
  line-height: .94;
  letter-spacing: -.065em;
  font-weight: 880;
  text-wrap: balance;
}

.portal-v5 .hero-command-card h1 em {
  color: var(--v5-gold-2);
  font-style: normal;
}

.portal-v5 .hero-description {
  max-width: 53ch;
  margin: 0;
  color: var(--v5-text-soft);
  font-size: clamp(.98rem, 1.3vw, 1.1rem);
  line-height: 1.75;
}

.portal-v5 .hero-actions { margin-top: 30px; display: flex; flex-wrap: wrap; gap: 11px; }
.portal-v5 .hero-actions .button-primary b { font-size: .72rem; }
.portal-v5 .hero-trust-grid { margin-top: 34px; display: flex; flex-wrap: wrap; gap: 8px; }
.portal-v5 .hero-trust-grid article {
  min-height: 36px;
  padding: 0 13px;
  display: flex;
  align-items: center;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 999px;
  background: rgba(255,255,255,.035);
  color: #9eacc1;
}
.portal-v5 .hero-trust-grid strong { font-size: .72rem; font-weight: 750; }

.portal-v5 .hero-visual-stage {
  position: relative;
  z-index: 2;
  min-height: 430px;
  display: grid;
  place-items: center;
  perspective: 1000px;
}

.portal-v5 .visual-orbit,
.portal-v5 .visual-orbit::before,
.portal-v5 .visual-orbit::after {
  position: absolute;
  border-radius: 50%;
  border: 1px solid rgba(124,184,236,.16);
}

.portal-v5 .visual-orbit {
  width: min(360px, 100%);
  aspect-ratio: 1;
  box-shadow: inset 0 0 70px rgba(58,141,222,.08), 0 0 80px rgba(58,141,222,.08);
  animation: v5-spin 22s linear infinite;
}
.portal-v5 .visual-orbit::before { content: ""; inset: 35px; border-color: rgba(231,184,95,.19); animation: v5-spin-reverse 13s linear infinite; }
.portal-v5 .visual-orbit::after { content: ""; inset: 82px; border-style: dashed; border-color: rgba(98,212,255,.22); }
@keyframes v5-spin { to { transform: rotate(360deg); } }
@keyframes v5-spin-reverse { to { transform: rotate(-720deg); } }

.portal-v5 .visual-core {
  position: relative;
  width: 200px;
  aspect-ratio: 1;
  border-radius: 58px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255,255,255,.14);
  background:
    radial-gradient(circle at 30% 20%, rgba(255,255,255,.18), transparent 34%),
    linear-gradient(145deg, rgba(33,67,106,.92), rgba(8,18,34,.95));
  box-shadow: 0 34px 75px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.1);
  transform: rotate(-7deg) translateZ(40px);
  animation: v5-float 6s ease-in-out infinite;
}
@keyframes v5-float { 50% { transform: rotate(-3deg) translateY(-14px) translateZ(40px); } }
.portal-v5 .visual-core::after { content: ""; position: absolute; inset: 13px; border-radius: 47px; border: 1px solid rgba(231,184,95,.2); }
.portal-v5 .visual-core img { width: 64%; height: 64%; object-fit: contain; filter: drop-shadow(0 18px 24px rgba(0,0,0,.32)); }

.portal-v5 .floating-chip {
  position: absolute;
  min-width: 128px;
  padding: 12px 14px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 17px;
  background: rgba(8,17,30,.72);
  box-shadow: 0 20px 46px rgba(0,0,0,.32), inset 0 1px 0 rgba(255,255,255,.06);
  backdrop-filter: blur(18px);
  animation: v5-chip-float 5.5s ease-in-out infinite;
}
.portal-v5 .floating-chip span { display: block; color: var(--v5-muted); font-size: .61rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.portal-v5 .floating-chip strong { display: block; margin-top: 5px; font-size: .85rem; }
.portal-v5 .floating-chip b { color: var(--v5-gold-2); font-size: .7rem; }
.portal-v5 .floating-chip-one { top: 54px; right: -4px; transform: rotate(3deg); }
.portal-v5 .floating-chip-two { left: -2px; bottom: 64px; animation-delay: -2.7s; transform: rotate(-3deg); }
@keyframes v5-chip-float { 50% { translate: 0 -10px; } }

.portal-v5 .hero-intelligence-stack { display: grid; grid-template-rows: 1fr auto; gap: 18px; }
.portal-v5 .intelligence-card,
.portal-v5 .social-command-card { padding: 24px; overflow: hidden; }
.portal-v5 .intelligence-card { min-height: 430px; }
.portal-v5 .premium-card-head,
.portal-v5 .card-head,
.portal-v5 .portal-panel-head,
.portal-v5 .feed-heading,
.portal-v5 .panel-heading-row,
.portal-v5 .codes-panel-head,
.portal-v5 .studio-card-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; }
.portal-v5 .premium-card-head h2,
.portal-v5 .card-head h2,
.portal-v5 .portal-panel-head h3,
.portal-v5 .feed-heading h2,
.portal-v5 .codes-panel-head h2 {
  margin: 9px 0 0;
  font-size: clamp(1.25rem, 2.1vw, 1.75rem);
  line-height: 1.08;
  letter-spacing: -.035em;
}
.portal-v5 .status-pill { color: var(--v5-text-soft); border-color: rgba(255,255,255,.09); background: rgba(255,255,255,.035); }

.portal-v5 .premium-stat-grid {
  margin-top: 22px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 8px;
}
.portal-v5 .roblox-stat {
  min-height: 120px;
  padding: 16px;
  border: 1px solid rgba(255,255,255,.075);
  border-radius: 18px;
  background: rgba(255,255,255,.028);
}
.portal-v5 .roblox-stat span,
.portal-v5 .roblox-stat strong,
.portal-v5 .roblox-stat small { display: block; }
.portal-v5 .roblox-stat span { color: var(--v5-muted); font-size: .64rem; font-weight: 850; letter-spacing: .11em; text-transform: uppercase; }
.portal-v5 .roblox-stat strong { margin-top: 16px; font-size: 1.8rem; line-height: 1; letter-spacing: -.05em; }
.portal-v5 .roblox-stat-live strong { color: var(--v5-green); }
.portal-v5 .roblox-stat small { margin-top: 10px; color: #66758b; font-size: .63rem; line-height: 1.4; }
.portal-v5 .signal-links { margin-top: 14px; display: flex; flex-wrap: wrap; gap: 12px; }
.portal-v5 .signal-links a { color: var(--v5-muted); font-size: .67rem; font-weight: 750; }
.portal-v5 .signal-links a:hover { color: var(--v5-gold-2); }

.portal-v5 .social-command-card { min-height: 200px; }
.portal-v5 .compact-link-grid { margin-top: 18px; display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 8px; }
.portal-v5 .compact-link-card {
  min-width: 0;
  padding: 15px;
  border: 1px solid rgba(255,255,255,.075);
  border-radius: 17px;
  background: rgba(255,255,255,.028);
  transition: transform .2s ease, border-color .2s ease, background .2s ease;
}
.portal-v5 .compact-link-card:hover { transform: translateY(-3px); border-color: rgba(98,212,255,.2); background: rgba(98,212,255,.055); }
.portal-v5 .compact-link-card span,
.portal-v5 .compact-link-card strong,
.portal-v5 .compact-link-card em { display: block; min-width: 0; overflow: hidden; text-overflow: ellipsis; }
.portal-v5 .compact-link-card span { color: var(--v5-gold-2); font-size: .63rem; font-weight: 850; letter-spacing: .09em; text-transform: uppercase; }
.portal-v5 .compact-link-card strong { margin-top: 7px; white-space: nowrap; font-size: .76rem; }
.portal-v5 .compact-link-card em { margin-top: 6px; color: var(--v5-muted); font-size: .65rem; font-style: normal; }

/* Home feed */
.portal-v5 .signal-board-section { padding-top: 74px; padding-bottom: 36px; }
.portal-v5 .section-intro { margin-bottom: 20px; display: flex; align-items: flex-end; justify-content: space-between; gap: 18px; }
.portal-v5 .section-intro h2 { margin: 10px 0 0; font-size: clamp(2rem, 3vw, 3rem); line-height: 1; letter-spacing: -.055em; }
.portal-v5 .signal-board-grid { display: grid; grid-template-columns: 1.35fr .82fr .82fr; gap: 18px; align-items: start; }
.portal-v5 .portal-panel { min-height: 390px; padding: 24px; overflow: hidden; }
.portal-v5 .portal-panel:first-child { min-height: 490px; }
.portal-v5 .portal-panel::after { content: ""; position: absolute; width: 240px; height: 240px; right: -120px; top: -120px; border-radius: 50%; background: radial-gradient(circle, rgba(98,212,255,.12), transparent 68%); pointer-events: none; }
.portal-v5 .portal-panel:nth-child(2)::after { background: radial-gradient(circle, rgba(123,227,176,.11), transparent 68%); }
.portal-v5 .portal-panel:nth-child(3)::after { background: radial-gradient(circle, rgba(231,184,95,.13), transparent 68%); }
.portal-v5 .text-link { color: var(--v5-gold-2); font-size: .7rem; font-weight: 850; }
.portal-v5 .text-link:hover { color: #ffe9b4; }
.portal-v5 .signal-stack { margin-top: 18px; display: grid; gap: 9px; }
.portal-v5 .signal-card,
.portal-v5 .home-post,
.portal-v5 .roadmap-signal,
.portal-v5 .code-signal {
  position: relative;
  min-width: 0;
  padding: 16px;
  border: 1px solid rgba(255,255,255,.065);
  border-radius: 18px;
  background: rgba(255,255,255,.027);
  transition: transform .2s ease, border-color .2s ease, background .2s ease;
}
.portal-v5 .signal-card:hover,
.portal-v5 .home-post:hover,
.portal-v5 .roadmap-signal:hover,
.portal-v5 .code-signal:hover { transform: translateY(-2px); border-color: rgba(231,184,95,.22); background: rgba(231,184,95,.045); }
.portal-v5 .signal-card strong,
.portal-v5 .home-post strong,
.portal-v5 .roadmap-signal strong,
.portal-v5 .code-signal strong { display: block; margin-top: 10px; font-size: .9rem; line-height: 1.35; }
.portal-v5 .signal-card p,
.portal-v5 .home-post p,
.portal-v5 .roadmap-signal p,
.portal-v5 .code-signal p { margin: 7px 0 0; color: var(--v5-muted); font-size: .74rem; line-height: 1.55; }

/* Shared page layout */
.portal-v5 .content-page { padding-top: 42px; padding-bottom: 74px; }
.portal-v5 .page-hero {
  position: relative;
  overflow: hidden;
  min-height: 255px;
  padding: clamp(28px, 4vw, 48px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 30px;
  border-radius: 36px;
  background:
    radial-gradient(circle at 88% 18%, rgba(82,171,255,.16), transparent 28%),
    radial-gradient(circle at 12% 115%, rgba(231,184,95,.1), transparent 36%),
    linear-gradient(145deg, rgba(19,38,64,.92), rgba(7,16,29,.92));
}
.portal-v5 .page-hero::after { content: ""; position: absolute; width: 310px; height: 310px; right: -72px; top: -100px; border: 1px solid rgba(255,255,255,.07); border-radius: 46%; transform: rotate(18deg); box-shadow: inset 0 0 60px rgba(98,212,255,.07); }
.portal-v5 .page-hero > * { position: relative; z-index: 1; }
.portal-v5 .page-hero h1,
.portal-v5 .rules-hero h1 {
  max-width: 15ch;
  margin: 12px 0 12px;
  font-size: clamp(2.25rem, 4vw, 4rem);
  line-height: .98;
  letter-spacing: -.058em;
  font-weight: 880;
  text-wrap: balance;
}
.portal-v5 .page-hero p,
.portal-v5 .rules-hero-copy > p { max-width: 64ch; margin: 0; color: var(--v5-text-soft); line-height: 1.7; font-size: .94rem; }
.portal-v5 .page-hero-split { display: grid; grid-template-columns: minmax(0,1fr) minmax(320px,.62fr); }
.portal-v5 .hero-side-panel { min-width: 0; }

.portal-v5 .search-field,
.portal-v5 .field {
  display: grid;
  gap: 8px;
}
.portal-v5 .search-field span,
.portal-v5 .field span,
.portal-v5 label > span { color: #8d9bb0; font-size: .69rem; font-weight: 780; }
.portal-v5 input,
.portal-v5 textarea,
.portal-v5 select {
  width: 100%;
  min-height: 48px;
  padding: 0 15px;
  border: 1px solid rgba(168,196,230,.13);
  border-radius: 15px;
  outline: none;
  color: var(--v5-text);
  background: rgba(3,9,17,.48);
  transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.portal-v5 textarea { min-height: 150px; padding-top: 14px; resize: vertical; }
.portal-v5 input:focus,
.portal-v5 textarea:focus,
.portal-v5 select:focus { border-color: rgba(231,184,95,.44); box-shadow: 0 0 0 4px rgba(231,184,95,.08); background: rgba(4,12,22,.72); }
.portal-v5 input::placeholder,
.portal-v5 textarea::placeholder { color: #526075; }

.portal-v5 .filter-pills,
.portal-v5 .type-filters,
.portal-v5 .roadmap-filters,
.portal-v5 .shop-filters { display: flex; flex-wrap: wrap; gap: 7px; }
.portal-v5 .filter-pill,
.portal-v5 .filter-button,
.portal-v5 [data-filter],
.portal-v5 [data-roadmap-filter] {
  min-height: 36px;
  padding: 0 13px;
  border: 1px solid rgba(255,255,255,.075);
  border-radius: 999px;
  color: #94a3b8;
  background: rgba(255,255,255,.03);
  font-size: .7rem;
  font-weight: 800;
  cursor: pointer;
  transition: color .2s ease, background .2s ease, border-color .2s ease, transform .2s ease;
}
.portal-v5 [data-filter]:hover,
.portal-v5 [data-roadmap-filter]:hover { color: var(--v5-text); transform: translateY(-1px); }
.portal-v5 [data-filter].is-active,
.portal-v5 [data-roadmap-filter].is-active { color: #211606; border-color: rgba(255,219,148,.4); background: linear-gradient(180deg,#ffdf98,#dfa43e); }

.portal-v5 .content-grid-with-rail,
.portal-v5 .reports-layout,
.portal-v5 .leaderboard-hub-layout {
  margin-top: 18px;
  display: grid;
  grid-template-columns: minmax(260px,.34fr) minmax(0,1fr);
  gap: 18px;
  align-items: start;
}
.portal-v5 .content-rail,
.portal-v5 .shop-sidebar { display: grid; gap: 14px; position: sticky; top: 104px; }
.portal-v5 .stat-rail-card,
.portal-v5 .rail-cta-card,
.portal-v5 .leaderboard-selector-card,
.portal-v5 .leaderboard-stats-card,
.portal-v5 .report-form-card,
.portal-v5 .known-issues-card,
.portal-v5 .roadmap-metrics-card,
.portal-v5 .codes-panel { padding: 23px; }
.portal-v5 .stat-rail-card h2,
.portal-v5 .rail-cta-card h2,
.portal-v5 .leaderboard-selector-card h2,
.portal-v5 .leaderboard-stats-card h2,
.portal-v5 .report-form-card h2,
.portal-v5 .known-issues-card h2,
.portal-v5 .roadmap-metrics-card h2,
.portal-v5 .codes-panel h2 { margin: 9px 0 0; font-size: 1.35rem; letter-spacing: -.035em; }
.portal-v5 .rail-metrics,
.portal-v5 .hero-mini-metrics,
.portal-v5 .roadmap-metrics,
.portal-v5 .leaderboard-stat-grid { margin-top: 18px; display: grid; gap: 8px; }
.portal-v5 .rail-metrics article,
.portal-v5 .hero-mini-metrics article,
.portal-v5 .roadmap-metrics article,
.portal-v5 .leaderboard-stat-grid article {
  padding: 14px;
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 16px;
  background: rgba(255,255,255,.026);
}
.portal-v5 .rail-metrics span,
.portal-v5 .hero-mini-metrics span,
.portal-v5 .roadmap-metrics span,
.portal-v5 .leaderboard-stat-grid span { display: block; color: var(--v5-muted); font-size: .65rem; font-weight: 800; text-transform: uppercase; letter-spacing: .1em; }
.portal-v5 .rail-metrics strong,
.portal-v5 .hero-mini-metrics strong,
.portal-v5 .roadmap-metrics strong,
.portal-v5 .leaderboard-stat-grid strong { display: block; margin-top: 7px; font-size: 1.35rem; letter-spacing: -.045em; }
.portal-v5 .rail-cta-card p,
.portal-v5 .helper-copy { color: var(--v5-muted); font-size: .76rem; line-height: 1.6; }

.portal-v5 .content-feed { min-width: 0; }
.portal-v5 .feed-heading { margin-bottom: 14px; }
.portal-v5 .feed-heading-main h2 { margin: 8px 0 0; }
.portal-v5 .update-feed,
.portal-v5 .shop-grid,
.portal-v5 .roadmap-grid,
.portal-v5 .promo-code-grid,
.portal-v5 .known-issues-list { display: grid; gap: 12px; }

/* Dynamic content cards */
.portal-v5 .update-card,
.portal-v5 .pinned-card,
.portal-v5 .shop-item-card,
.portal-v5 .featured-shop-card,
.portal-v5 .roadmap-card,
.portal-v5 .promo-code-card,
.portal-v5 .known-issue-card,
.portal-v5 .leaderboard-board-card,
.portal-v5 .leaderboard-row {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--v5-line);
  border-radius: 22px;
  background: linear-gradient(145deg, rgba(16,30,50,.82), rgba(7,16,28,.78));
  box-shadow: 0 16px 36px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.035);
  transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease, background .22s ease;
}
.portal-v5 .update-card:hover,
.portal-v5 .pinned-card:hover,
.portal-v5 .shop-item-card:hover,
.portal-v5 .featured-shop-card:hover,
.portal-v5 .roadmap-card:hover,
.portal-v5 .promo-code-card:hover,
.portal-v5 .known-issue-card:hover { transform: translateY(-4px); border-color: rgba(231,184,95,.24); box-shadow: 0 24px 54px rgba(0,0,0,.28); }

.portal-v5 .update-card,
.portal-v5 .pinned-card { padding: 22px; }
.portal-v5 .update-card h3,
.portal-v5 .pinned-card h3 { margin: 13px 0 8px; font-size: 1.2rem; line-height: 1.2; letter-spacing: -.035em; }
.portal-v5 .update-card p,
.portal-v5 .pinned-card p { color: var(--v5-text-soft); font-size: .82rem; line-height: 1.66; }
.portal-v5 .update-card-top,
.portal-v5 .update-card-footer,
.portal-v5 .update-card-tags,
.portal-v5 .tag-row,
.portal-v5 .roadmap-card-top,
.portal-v5 .shop-item-meta-row,
.portal-v5 .shop-item-tags,
.portal-v5 .promo-code-card-top,
.portal-v5 .promo-code-token-row { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; }
.portal-v5 .update-card-top,
.portal-v5 .roadmap-card-top,
.portal-v5 .promo-code-card-top { justify-content: space-between; }
.portal-v5 .update-card-date { color: var(--v5-muted); font-size: .68rem; }
.portal-v5 .update-card-footer { margin-top: 18px; justify-content: space-between; }
.portal-v5 .read-more-button { min-height: 38px; padding: 0 13px; border: 1px solid rgba(255,255,255,.08); border-radius: 12px; background: rgba(255,255,255,.035); color: #c9d4e3; font-size: .71rem; font-weight: 800; cursor: pointer; }
.portal-v5 .read-more-button:hover { color: var(--v5-gold-2); border-color: rgba(231,184,95,.22); }

.portal-v5 .shop-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
.portal-v5 .shop-item-card,
.portal-v5 .featured-shop-card { min-width: 0; }
.portal-v5 .shop-item-image { position: relative; aspect-ratio: 16/9; overflow: hidden; background: linear-gradient(145deg,rgba(48,93,145,.18),rgba(231,184,95,.06)); }
.portal-v5 .shop-item-image img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s ease; }
.portal-v5 .shop-item-card:hover .shop-item-image img { transform: scale(1.045); }
.portal-v5 .shop-item-placeholder { width: 100%; height: 100%; display: grid; place-items: center; color: var(--v5-muted); font-size: .75rem; }
.portal-v5 .shop-item-body { padding: 18px; }
.portal-v5 .shop-item-body h3 { margin: 12px 0 7px; font-size: 1.08rem; letter-spacing: -.03em; }
.portal-v5 .shop-subtitle { margin: 0; color: var(--v5-muted); font-size: .77rem; line-height: 1.55; }
.portal-v5 .shop-price-stack { margin-top: 17px; display: flex; align-items: flex-end; justify-content: space-between; gap: 10px; }
.portal-v5 .shop-price { color: var(--v5-gold-2); font-size: 1.05rem; font-weight: 900; }
.portal-v5 .shop-buy-button { min-height: 40px; padding: 0 14px; border: 0; border-radius: 13px; color: #211606; background: linear-gradient(135deg,#ffe09a,#dfa440); font-size: .71rem; font-weight: 900; cursor: pointer; }

.portal-v5 .roadmap-grid { margin-top: 18px; grid-template-columns: repeat(3,minmax(0,1fr)); }
.portal-v5 .roadmap-card { padding: 20px; }
.portal-v5 .roadmap-card h3 { margin: 14px 0 8px; font-size: 1.08rem; letter-spacing: -.03em; }
.portal-v5 .roadmap-card p { color: var(--v5-muted); font-size: .77rem; line-height: 1.58; }
.portal-v5 .roadmap-chip-row { margin-top: 16px; display: flex; flex-wrap: wrap; gap: 6px; }
.portal-v5 .roadmap-chip { min-height: 26px; padding: 0 9px; display: inline-flex; align-items: center; border: 1px solid rgba(255,255,255,.07); border-radius: 999px; color: #92a1b6; background: rgba(255,255,255,.025); font-size: .62rem; font-weight: 760; }
.portal-v5 .roadmap-priority { color: var(--v5-gold-2); font-size: .68rem; font-weight: 800; }

.portal-v5 .codes-layout { margin-top: 18px; display: grid; grid-template-columns: 1.15fr .85fr; gap: 18px; align-items: start; }
.portal-v5 .promo-code-grid { margin-top: 18px; }
.portal-v5 .promo-code-card { padding: 20px; }
.portal-v5 .promo-code-token-row { margin-top: 16px; }
.portal-v5 .promo-code-token { flex: 1; min-width: 0; padding: 14px; border: 1px dashed rgba(231,184,95,.3); border-radius: 14px; color: var(--v5-gold-2); background: rgba(231,184,95,.055); font-family: ui-monospace,SFMono-Regular,Consolas,monospace; font-size: .92rem; font-weight: 900; letter-spacing: .08em; }
.portal-v5 .copy-code-button { min-height: 46px; padding: 0 14px; border: 1px solid rgba(255,255,255,.09); border-radius: 14px; background: rgba(255,255,255,.04); font-size: .71rem; font-weight: 850; cursor: pointer; }

.portal-v5 .leaderboard-hub-layout { grid-template-columns: 270px minmax(0,1fr) 280px; }
.portal-v5 .leaderboard-selector-buttons { margin-top: 16px; display: grid; gap: 7px; }
.portal-v5 .leaderboard-selector-button { min-height: 46px; padding: 0 14px; border: 1px solid rgba(255,255,255,.07); border-radius: 14px; color: #9aa8bc; background: rgba(255,255,255,.025); text-align: left; font-size: .73rem; font-weight: 800; cursor: pointer; }
.portal-v5 .leaderboard-selector-button.is-active { color: #211606; border-color: rgba(255,220,148,.38); background: linear-gradient(135deg,#ffe19a,#dfa440); }
.portal-v5 .leaderboard-board-card { padding: 24px; }
.portal-v5 .leaderboard-row { min-height: 66px; padding: 10px 14px; display: grid; grid-template-columns: 44px minmax(0,1fr) auto; align-items: center; gap: 12px; border-radius: 16px; }
.portal-v5 .leaderboard-rank-pill { width: 34px; height: 34px; border-radius: 11px; display: grid; place-items: center; color: var(--v5-gold-2); background: rgba(231,184,95,.08); font-size: .72rem; font-weight: 900; }
.portal-v5 .leaderboard-player-main strong { display: block; font-size: .82rem; }
.portal-v5 .leaderboard-player-main span { display: block; margin-top: 4px; color: var(--v5-muted); font-size: .65rem; }

.portal-v5 .reports-layout { grid-template-columns: minmax(0,1.1fr) minmax(310px,.72fr); }
.portal-v5 .report-form { margin-top: 18px; display: grid; gap: 14px; }
.portal-v5 .form-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 12px; }
.portal-v5 .known-issues-list { margin-top: 18px; }
.portal-v5 .known-issue-card { padding: 17px; }
.portal-v5 .known-issue-card h3 { margin: 10px 0 7px; font-size: .93rem; }
.portal-v5 .known-issue-card p { color: var(--v5-muted); font-size: .73rem; line-height: 1.55; }
.portal-v5 .notice { padding: 13px 15px; border: 1px solid rgba(98,212,255,.18); border-radius: 14px; color: #bcecff; background: rgba(98,212,255,.07); font-size: .75rem; }

/* Rules */
.portal-v5 .rules-hero {
  min-height: 390px;
  padding: clamp(30px,4vw,52px);
  display: grid;
  grid-template-columns: minmax(0,1.15fr) minmax(280px,.65fr);
  align-items: center;
  gap: 36px;
  overflow: hidden;
  border-radius: 36px;
  background:
    radial-gradient(circle at 80% 20%, rgba(87,171,255,.16), transparent 34%),
    linear-gradient(145deg,rgba(19,38,64,.93),rgba(7,16,29,.94));
}
.portal-v5 .rules-hero h1 { max-width: 12ch; }
.portal-v5 .rules-alert { margin-top: 24px; padding: 15px 16px; display: flex; gap: 12px; align-items: flex-start; border: 1px solid rgba(255,125,138,.2); border-radius: 17px; background: rgba(255,125,138,.065); }
.portal-v5 .rules-alert-icon { width: 31px; height: 31px; flex: 0 0 auto; border-radius: 10px; display: grid; place-items: center; color: #26090d; background: linear-gradient(180deg,#ffabb4,#ff7381); font-weight: 950; }
.portal-v5 .rules-alert strong { display: block; font-size: .79rem; }
.portal-v5 .rules-alert p { margin: 5px 0 0; color: #d2aeb4; font-size: .73rem; line-height: 1.5; }
.portal-v5 .rules-hero-panel { display: grid; gap: 18px; }
.portal-v5 .rules-emblem { width: 210px; aspect-ratio: 1; margin: 0 auto; border-radius: 58px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.12); background: linear-gradient(145deg,rgba(33,67,106,.84),rgba(8,18,34,.92)); box-shadow: 0 30px 60px rgba(0,0,0,.32); transform: rotate(5deg); }
.portal-v5 .rules-emblem img { width: 66%; transform: rotate(-5deg); }
.portal-v5 .rules-metrics { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 7px; }
.portal-v5 .rules-metrics article { padding: 12px 8px; border: 1px solid rgba(255,255,255,.07); border-radius: 14px; background: rgba(255,255,255,.026); text-align: center; }
.portal-v5 .rules-metrics strong { display: block; color: var(--v5-gold-2); font-size: 1.15rem; }
.portal-v5 .rules-metrics span { display: block; margin-top: 5px; color: var(--v5-muted); font-size: .58rem; line-height: 1.35; }
.portal-v5 .rules-layout { margin-top: 18px; display: grid; grid-template-columns: 270px minmax(0,1fr); gap: 18px; align-items: start; }
.portal-v5 .rules-toc-card { position: sticky; top: 104px; padding: 22px; }
.portal-v5 .rules-toc-card h2 { margin: 9px 0 7px; font-size: 1.35rem; }
.portal-v5 .rules-toc-card > p { margin: 0; color: var(--v5-muted); font-size: .73rem; line-height: 1.55; }
.portal-v5 .rules-toc-list { margin-top: 16px; display: grid; gap: 7px; }
.portal-v5 .rules-toc-link { min-height: 50px; padding: 8px 10px; display: grid; grid-template-columns: 32px minmax(0,1fr) auto; align-items: center; gap: 9px; border: 1px solid transparent; border-radius: 14px; color: #a6b3c6; background: rgba(255,255,255,.02); transition: transform .2s ease,border-color .2s ease,background .2s ease; }
.portal-v5 .rules-toc-link:hover { transform: translateX(3px); border-color: rgba(231,184,95,.2); background: rgba(231,184,95,.055); }
.portal-v5 .rules-toc-link span { width: 30px; height: 30px; border-radius: 10px; display: grid; place-items: center; color: var(--v5-gold-2); background: rgba(231,184,95,.08); font-size: .65rem; font-weight: 900; }
.portal-v5 .rules-toc-link strong { font-size: .72rem; line-height: 1.35; }
.portal-v5 .rules-list { display: grid; gap: 12px; }
.portal-v5 .rule-card { display: grid; grid-template-columns: 82px minmax(0,1fr); overflow: hidden; border-radius: 24px; }
.portal-v5 .rule-number-rail { padding: 24px 12px; display: flex; flex-direction: column; align-items: center; gap: 7px; border-right: 1px solid rgba(255,255,255,.07); background: linear-gradient(180deg,rgba(231,184,95,.08),rgba(255,255,255,.015)); }
.portal-v5 .rule-number-rail span { color: var(--v5-muted); font-size: .55rem; font-weight: 850; text-transform: uppercase; letter-spacing: .13em; }
.portal-v5 .rule-number-rail strong { color: var(--v5-gold-2); font-size: 1.7rem; letter-spacing: -.06em; }
.portal-v5 .rule-card-content { padding: clamp(22px,3vw,32px); }
.portal-v5 .rule-heading-row { display: flex; align-items: center; gap: 14px; }
.portal-v5 .rule-icon { width: 48px; height: 48px; flex: 0 0 auto; border-radius: 16px; display: grid; place-items: center; color: var(--v5-gold-2); border: 1px solid rgba(231,184,95,.2); background: rgba(231,184,95,.07); }
.portal-v5 .rule-icon svg { width: 24px; height: 24px; fill: none; stroke: currentColor; stroke-width: 1.8; }
.portal-v5 .rule-heading-row h2 { margin: 7px 0 0; font-size: clamp(1.25rem,2.2vw,1.85rem); line-height: 1.08; letter-spacing: -.04em; }
.portal-v5 .rule-intro { margin: 18px 0 0; color: var(--v5-text-soft); font-size: .85rem; line-height: 1.65; }
.portal-v5 .rule-points { list-style: none; margin: 18px 0 0; padding: 0; display: grid; gap: 8px; }
.portal-v5 .rule-points li { padding: 12px 13px; display: grid; grid-template-columns: 27px minmax(0,1fr); gap: 10px; align-items: start; border: 1px solid rgba(255,255,255,.065); border-radius: 14px; background: rgba(255,255,255,.023); }
.portal-v5 .rule-points li > span { width: 26px; height: 26px; border-radius: 9px; display: grid; place-items: center; color: #07150c; background: linear-gradient(180deg,#a4efc0,#68d795); font-size: .68rem; font-weight: 900; }
.portal-v5 .rule-points p { margin: 2px 0 0; color: var(--v5-text-soft); font-size: .79rem; line-height: 1.55; }
.portal-v5 .rule-callout,
.portal-v5 .rule-card blockquote { margin: 17px 0 0; border-radius: 15px; }
.portal-v5 .rule-callout { padding: 14px; display: flex; gap: 10px; align-items: center; border: 1px solid rgba(255,125,138,.2); background: rgba(255,125,138,.06); }
.portal-v5 .rule-callout span { width: 28px; height: 28px; flex: 0 0 auto; border-radius: 9px; display: grid; place-items: center; color: #24080b; background: var(--v5-red); font-weight: 900; }
.portal-v5 .rule-callout strong { font-size: .75rem; line-height: 1.5; }
.portal-v5 .rule-card blockquote { padding: 16px 18px; border-left: 3px solid var(--v5-gold); background: linear-gradient(90deg,rgba(231,184,95,.09),rgba(231,184,95,.02)); color: #fbe4b1; font-size: .9rem; font-weight: 820; line-height: 1.55; }
.portal-v5 .rules-report-cta { margin-top: 18px; padding: 26px; display: flex; align-items: center; justify-content: space-between; gap: 22px; }
.portal-v5 .rules-report-cta h2 { margin: 9px 0; font-size: 1.65rem; letter-spacing: -.04em; }
.portal-v5 .rules-report-cta p { margin: 0; color: var(--v5-muted); font-size: .8rem; line-height: 1.6; }

/* Modals */
.portal-v5 .modal-backdrop,
.portal-v5 .post-modal { backdrop-filter: blur(12px); }
.portal-v5 .post-modal,
.portal-v5 .bug-issue-modal { position: fixed; inset: 0; z-index: 200; display: grid; place-items: center; padding: 20px; background: rgba(1,4,8,.72); }
.portal-v5 .modal-shell,
.portal-v5 .modal-content { width: min(740px,100%); max-height: min(85vh,760px); overflow: auto; padding: 26px; border: 1px solid rgba(168,196,230,.17); border-radius: 28px; background: rgba(8,17,30,.97); box-shadow: 0 40px 120px rgba(0,0,0,.55); }
.portal-v5 .modal-close { width: 38px; height: 38px; border: 1px solid rgba(255,255,255,.08); border-radius: 13px; background: rgba(255,255,255,.04); cursor: pointer; }
.portal-v5 .modal-body-copy { color: var(--v5-text-soft); line-height: 1.7; }

/* Footer */
.portal-v5 .portal-footer { margin-top: 48px; padding: 0 0 32px; }
.portal-v5 .portal-footer-grid {
  padding: 28px;
  display: grid;
  grid-template-columns: 1.35fr .8fr .8fr;
  gap: 34px;
  border: 1px solid rgba(168,196,230,.11);
  border-radius: 30px;
  background: rgba(7,15,27,.64);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.035);
}
.portal-v5 .portal-footer-brand p { margin: 16px 0 0; color: var(--v5-muted); font-size: .69rem; }
.portal-v5 .portal-footer nav { display: grid; align-content: start; gap: 9px; }
.portal-v5 .portal-footer nav strong { margin-bottom: 4px; color: #c9d4e4; font-size: .72rem; }
.portal-v5 .portal-footer nav a { color: var(--v5-muted); font-size: .69rem; }
.portal-v5 .portal-footer nav a:hover { color: var(--v5-gold-2); }

/* Mobile navigation */
.portal-v5 .portal-mobile-dock {
  position: fixed;
  z-index: 90;
  left: 50%;
  bottom: 12px;
  transform: translateX(-50%);
  width: min(calc(100% - 20px), 540px);
  min-height: 68px;
  padding: 7px;
  display: none;
  grid-template-columns: repeat(5,minmax(0,1fr));
  gap: 4px;
  border: 1px solid rgba(168,196,230,.16);
  border-radius: 23px;
  background: rgba(7,15,27,.91);
  box-shadow: 0 24px 60px rgba(0,0,0,.48), inset 0 1px 0 rgba(255,255,255,.055);
  backdrop-filter: blur(24px);
}
.portal-v5 .portal-dock-item { min-width: 0; border-radius: 16px; display: grid; place-items: center; align-content: center; gap: 4px; color: #77869d; font-size: .57rem; font-weight: 780; }
.portal-v5 .portal-dock-item svg { width: 20px; height: 20px; fill: none; stroke: currentColor; stroke-width: 1.8; }
.portal-v5 .portal-dock-item.is-active { color: #241706; background: linear-gradient(180deg,#ffe09a,#dfa43f); box-shadow: 0 9px 22px rgba(211,145,40,.22); }
.portal-v5 .portal-dock-play { color: var(--v5-gold-2); background: rgba(231,184,95,.08); }

.portal-v5 .portal-drawer-backdrop { position: fixed; inset: 0; z-index: 110; border: 0; background: rgba(1,4,8,.72); opacity: 0; pointer-events: none; transition: opacity .22s ease; backdrop-filter: blur(8px); }
.portal-v5 .portal-drawer-backdrop.is-open { opacity: 1; pointer-events: auto; }
.portal-v5 .portal-mobile-drawer { position: fixed; z-index: 111; left: 10px; right: 10px; bottom: 10px; max-height: calc(100vh - 20px); overflow: auto; padding: 18px; border: 1px solid rgba(168,196,230,.16); border-radius: 28px; background: rgba(7,15,27,.97); box-shadow: 0 40px 100px rgba(0,0,0,.58); transform: translateY(calc(100% + 30px)); transition: transform .3s cubic-bezier(.22,.8,.22,1); }
.portal-v5 .portal-mobile-drawer.is-open { transform: translateY(0); }
.portal-v5 .portal-drawer-head { display: flex; align-items: center; justify-content: space-between; }
.portal-v5 .portal-drawer-brand { display: flex; align-items: center; gap: 10px; }
.portal-v5 .portal-drawer-brand img { width: 34px; height: 34px; padding: 7px; border: 1px solid rgba(231,184,95,.2); border-radius: 12px; background: rgba(231,184,95,.07); }
.portal-v5 .portal-drawer-close { width: 40px; height: 40px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.08); border-radius: 13px; background: rgba(255,255,255,.04); }
.portal-v5 .portal-drawer-close svg { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 2; }
.portal-v5 .portal-drawer-links { margin-top: 18px; display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 8px; }
.portal-v5 .portal-drawer-links a { min-height: 66px; padding: 12px; display: flex; align-items: center; gap: 10px; border: 1px solid rgba(255,255,255,.07); border-radius: 17px; background: rgba(255,255,255,.025); color: #a6b3c6; }
.portal-v5 .portal-drawer-links a.is-active { color: var(--v5-gold-2); border-color: rgba(231,184,95,.24); background: rgba(231,184,95,.07); }
.portal-v5 .portal-drawer-links svg { width: 20px; height: 20px; fill: none; stroke: currentColor; stroke-width: 1.8; }
.portal-v5 .portal-drawer-links strong { font-size: .75rem; }
.portal-v5 .portal-drawer-community { margin-top: 14px; padding-top: 14px; display: flex; flex-wrap: wrap; gap: 12px; border-top: 1px solid rgba(255,255,255,.06); }
.portal-v5 .portal-drawer-community span { width: 100%; color: var(--v5-muted); font-size: .63rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.portal-v5 .portal-drawer-community a { color: #9eacc1; font-size: .7rem; font-weight: 760; }
.portal-v5 .portal-drawer-play { margin-top: 16px; min-height: 50px; border-radius: 16px; display: flex; align-items: center; justify-content: center; gap: 8px; color: #211606; background: linear-gradient(135deg,#ffe19a,#dfa43f); font-size: .78rem; font-weight: 900; }
.portal-v5 .portal-drawer-play svg { width: 17px; height: 17px; fill: currentColor; }
.portal-v5.portal-drawer-open { overflow: hidden; }

/* Reveal */
.portal-v5 .v5-reveal { opacity: 0; transform: translateY(20px); transition: opacity .65s ease, transform .65s cubic-bezier(.22,.8,.22,1); }
.portal-v5 .v5-reveal.is-visible { opacity: 1; transform: none; }

.portal-v5 .hidden-block { display: none !important; }
.portal-v5 .empty-state,
.portal-v5 .loading-line,
.portal-v5 .leaderboard-empty-panel { padding: 24px; border: 1px dashed rgba(168,196,230,.14); border-radius: 17px; color: var(--v5-muted); background: rgba(255,255,255,.018); text-align: center; font-size: .77rem; }

@media (max-width: 1180px) {
  .portal-v5 .hero-premium-grid { grid-template-columns: minmax(0,1fr) 330px; }
  .portal-v5 .hero-command-card { grid-template-columns: 1fr .72fr; padding: 42px; }
  .portal-v5 .hero-command-card h1 { font-size: clamp(2.9rem,5vw,4.45rem); }
  .portal-v5 .visual-core { width: 170px; }
  .portal-v5 .visual-orbit { width: 300px; }
  .portal-v5 .signal-board-grid { grid-template-columns: 1.25fr .75fr; }
  .portal-v5 .signal-board-grid .portal-panel:nth-child(3) { grid-column: 1 / -1; min-height: 290px; }
  .portal-v5 .leaderboard-hub-layout { grid-template-columns: 240px minmax(0,1fr); }
  .portal-v5 .leaderboard-stats-card { grid-column: 1 / -1; }
  .portal-v5 .roadmap-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
}

@media (max-width: 980px) {
  .portal-v5 .portal-primary-nav,
  .portal-v5 .portal-more-button { display: none; }
  .portal-v5 .portal-header-inner { grid-template-columns: auto 1fr auto; }
  .portal-v5 .portal-mobile-menu-button { display: inline-grid; }
  .portal-v5 .hero-premium-grid { grid-template-columns: 1fr; }
  .portal-v5 .hero-command-card { min-height: 620px; }
  .portal-v5 .hero-intelligence-stack { grid-template-columns: 1fr 1fr; grid-template-rows: auto; }
  .portal-v5 .intelligence-card { min-height: 0; }
  .portal-v5 .content-grid-with-rail,
  .portal-v5 .reports-layout,
  .portal-v5 .leaderboard-hub-layout { grid-template-columns: 1fr; }
  .portal-v5 .content-rail,
  .portal-v5 .shop-sidebar { position: relative; top: auto; grid-template-columns: 1fr 1fr; }
  .portal-v5 .rules-layout { grid-template-columns: 1fr; }
  .portal-v5 .rules-toc-card { position: relative; top: auto; }
  .portal-v5 .rules-toc-list { grid-template-columns: repeat(3,minmax(0,1fr)); }
  .portal-v5 .portal-mobile-dock { display: grid; }
  .portal-v5 .portal-footer { padding-bottom: 100px; }
  .portal-v5 .portal-footer-grid { grid-template-columns: 1fr 1fr; }
  .portal-v5 .portal-footer-brand { grid-column: 1/-1; }
}

@media (max-width: 760px) {
  :root { --v5-header-top: 32px; }
  .portal-v5 .shell { width: min(calc(100% - 24px), var(--v5-shell)); }
  .portal-v5 .site-language-inner { justify-content: center; }
  .portal-v5 .site-language-inner > span { display: none; }
  .portal-v5 .site-header.portal-header { padding-top: 8px; }
  .portal-v5 .portal-header-inner { min-height: 62px; padding: 8px; border-radius: 19px; }
  .portal-v5 .portal-brand-mark { width: 40px; height: 40px; border-radius: 13px; }
  .portal-v5 .portal-brand-mark img { width: 24px; height: 24px; }
  .portal-v5 .portal-brand em { display: none; }
  .portal-v5 .portal-brand strong { font-size: .9rem; }
  .portal-v5 .portal-play-button { min-height: 40px; padding: 0 14px; border-radius: 13px; }
  .portal-v5 .portal-play-button span { display: none; }
  .portal-v5 .portal-mobile-menu-button { min-height: 40px; width: 40px; border-radius: 13px; }
  .portal-v5 .content-page { padding-top: 24px; padding-bottom: 46px; }
  .portal-v5 .hero-premium-grid { padding-top: 24px; gap: 14px; }
  .portal-v5 .hero-command-card { min-height: 0; padding: 28px 22px 24px; grid-template-columns: 1fr; gap: 24px; border-radius: 30px; }
  .portal-v5 .hero-command-card h1 { max-width: 12ch; margin: 20px 0 16px; font-size: clamp(2.45rem,12vw,3.55rem); line-height: .96; }
  .portal-v5 .hero-description { font-size: .9rem; line-height: 1.65; }
  .portal-v5 .hero-actions { margin-top: 24px; display: grid; grid-template-columns: 1fr; }
  .portal-v5 .hero-actions .button { width: 100%; }
  .portal-v5 .hero-trust-grid { margin-top: 22px; }
  .portal-v5 .hero-visual-stage { min-height: 260px; order: -1; }
  .portal-v5 .visual-orbit { width: 250px; }
  .portal-v5 .visual-core { width: 138px; border-radius: 40px; }
  .portal-v5 .visual-core::after { border-radius: 32px; }
  .portal-v5 .floating-chip { min-width: 108px; padding: 10px 11px; }
  .portal-v5 .floating-chip-one { top: 18px; right: 0; }
  .portal-v5 .floating-chip-two { left: 0; bottom: 28px; }
  .portal-v5 .hero-intelligence-stack { grid-template-columns: 1fr; gap: 14px; }
  .portal-v5 .intelligence-card,
  .portal-v5 .social-command-card { padding: 20px; border-radius: 24px; }
  .portal-v5 .premium-stat-grid { grid-template-columns: repeat(2,minmax(0,1fr)); }
  .portal-v5 .roblox-stat { min-height: 104px; padding: 14px; }
  .portal-v5 .roblox-stat strong { font-size: 1.5rem; }
  .portal-v5 .signal-board-section { padding-top: 48px; }
  .portal-v5 .signal-board-grid { grid-template-columns: 1fr; }
  .portal-v5 .signal-board-grid .portal-panel:nth-child(3) { grid-column: auto; }
  .portal-v5 .portal-panel,
  .portal-v5 .portal-panel:first-child { min-height: 0; padding: 20px; border-radius: 24px; }
  .portal-v5 .section-intro h2 { font-size: 2rem; }
  .portal-v5 .page-hero,
  .portal-v5 .rules-hero { min-height: 0; padding: 26px 20px; grid-template-columns: 1fr; border-radius: 28px; }
  .portal-v5 .page-hero h1,
  .portal-v5 .rules-hero h1 { font-size: clamp(2.15rem,10.5vw,3.15rem); }
  .portal-v5 .page-hero-split { grid-template-columns: 1fr; }
  .portal-v5 .content-rail,
  .portal-v5 .shop-sidebar { grid-template-columns: 1fr; }
  .portal-v5 .stat-rail-card,
  .portal-v5 .rail-cta-card,
  .portal-v5 .leaderboard-selector-card,
  .portal-v5 .leaderboard-stats-card,
  .portal-v5 .report-form-card,
  .portal-v5 .known-issues-card,
  .portal-v5 .roadmap-metrics-card,
  .portal-v5 .codes-panel { padding: 20px; border-radius: 24px; }
  .portal-v5 .shop-grid,
  .portal-v5 .roadmap-grid,
  .portal-v5 .codes-layout { grid-template-columns: 1fr; }
  .portal-v5 .form-grid { grid-template-columns: 1fr; }
  .portal-v5 .rules-hero-panel { display: none; }
  .portal-v5 .rules-toc-list { grid-template-columns: 1fr; }
  .portal-v5 .rule-card { grid-template-columns: 1fr; }
  .portal-v5 .rule-number-rail { padding: 12px 16px; flex-direction: row; justify-content: flex-start; border-right: 0; border-bottom: 1px solid rgba(255,255,255,.07); }
  .portal-v5 .rule-number-rail strong { font-size: 1.25rem; }
  .portal-v5 .rule-card-content { padding: 20px 17px; }
  .portal-v5 .rule-heading-row { align-items: flex-start; }
  .portal-v5 .rule-heading-row h2 { font-size: 1.4rem; }
  .portal-v5 .rules-report-cta { align-items: stretch; flex-direction: column; }
  .portal-v5 .portal-footer-grid { padding: 22px; grid-template-columns: 1fr; border-radius: 24px; }
  .portal-v5 .portal-footer-brand { grid-column: auto; }
}

@media (max-width: 430px) {
  .portal-v5 .shell { width: min(calc(100% - 18px), var(--v5-shell)); }
  .portal-v5 .portal-header-inner { gap: 8px; }
  .portal-v5 .premium-stat-grid { gap: 6px; }
  .portal-v5 .roblox-stat { min-height: 98px; }
  .portal-v5 .compact-link-grid { grid-template-columns: 1fr; }
  .portal-v5 .portal-drawer-links { grid-template-columns: 1fr; }
  .portal-v5 .portal-mobile-dock { bottom: 8px; width: calc(100% - 12px); min-height: 64px; border-radius: 20px; }
  .portal-v5 .portal-dock-item { border-radius: 14px; }
}

@media (hover: none) {
  .v5-cursor-light { display: none; }
  .portal-v5 .surface-card::before { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  .portal-v5 *,
  .portal-v5 *::before,
  .portal-v5 *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition-duration: .01ms !important; }
  .portal-v5 .v5-reveal { opacity: 1; transform: none; }
}

/* V5 refinement pass */
.portal-v5 .hero-command-card { min-height: 610px; }
.portal-v5 .hero-command-card h1 {
  max-width: 12.5ch;
  font-size: clamp(2.85rem, 4.5vw, 4.55rem);
}
.portal-v5 .section-intro {
  display: block;
}
.portal-v5 .section-intro h2 {
  margin-top: 10px;
}
.portal-v5 .content-feed .feed-heading {
  display: block;
  margin-bottom: 14px;
}
.portal-v5 .content-feed .feed-heading h2 {
  margin: 9px 0 0;
  font-size: clamp(1.55rem, 2.4vw, 2.15rem);
}
.portal-v5 .page-hero h1,
.portal-v5 .rules-hero h1 {
  font-size: clamp(2.15rem, 3.45vw, 3.45rem);
}
.portal-v5 .rules-hero:not(:has(.rules-hero-panel)) {
  grid-template-columns: 1fr;
}
.portal-v5 .rules-hero:not(:has(.rules-hero-panel)) > .rules-hero-copy {
  max-width: 820px;
}
.portal-v5 .rules-hero:not(:has(.rules-hero-panel))::after {
  content: "";
  position: absolute;
  width: 360px;
  height: 360px;
  right: 5%;
  top: 50%;
  border: 1px solid rgba(98,212,255,.12);
  border-radius: 46%;
  box-shadow: inset 0 0 80px rgba(98,212,255,.06), 0 0 90px rgba(98,212,255,.05);
  transform: translateY(-50%) rotate(18deg);
  pointer-events: none;
}

@media (max-width: 760px) {
  .portal-v5 .hero-command-card {
    position: relative;
    display: block;
    min-height: 0;
    padding: 28px 22px 26px;
  }
  .portal-v5 .hero-copy-wrap {
    position: relative;
    z-index: 2;
  }
  .portal-v5 .hero-command-card h1 {
    max-width: 10.5ch;
    font-size: clamp(2.25rem, 10.4vw, 3rem);
  }
  .portal-v5 .hero-visual-stage {
    position: absolute;
    z-index: 1;
    top: 18px;
    right: -34px;
    width: 235px;
    min-height: 235px;
    opacity: .45;
    pointer-events: none;
  }
  .portal-v5 .visual-orbit { width: 205px; }
  .portal-v5 .visual-core { width: 105px; border-radius: 32px; }
  .portal-v5 .visual-core::after { inset: 9px; border-radius: 24px; }
  .portal-v5 .floating-chip { display: none; }
  .portal-v5 .hero-overline-row { padding-right: 72px; }
  .portal-v5 .hero-description { max-width: 32ch; }
  .portal-v5 .rules-hero:not(:has(.rules-hero-panel))::after { width: 210px; height: 210px; right: -80px; opacity: .65; }
}
