:root {
  --bg: #f7f9ff;
  --bg-soft: #eef4ff;
  --bg-soft-2: #f5efff;
  --surface: rgba(255, 255, 255, 0.94);
  --surface-strong: #ffffff;
  --surface-muted: #f4f7ff;
  --line: #dbe4f4;
  --line-strong: #c3d0e8;
  --text: #0f2342;
  --text-soft: #5f7393;
  --text-faint: #7e8fa9;
  --blue: #2f5fe8;
  --blue-strong: #2349b7;
  --blue-soft: #eaf0ff;
  --violet-soft: #f1ecff;
  --mint-soft: #ecfaf4;
  --amber-soft: #fff5e8;
  --rose-soft: #fff0f4;
  --shadow-sm: 0 10px 26px rgba(28, 48, 86, 0.06);
  --shadow-md: 0 24px 60px rgba(28, 48, 86, 0.1);
  --shadow-lg: 0 34px 88px rgba(28, 48, 86, 0.12);
  --radius-xs: 12px;
  --radius-sm: 16px;
  --radius-md: 22px;
  --radius-lg: 30px;
  --container: min(1220px, calc(100% - 40px));
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at 8% 8%, rgba(207, 219, 255, 0.72), transparent 20%),
    radial-gradient(circle at 92% 12%, rgba(236, 227, 255, 0.7), transparent 24%),
    radial-gradient(circle at 72% 38%, rgba(222, 239, 255, 0.58), transparent 18%),
    linear-gradient(180deg, #fcfdff 0%, #f6f9ff 48%, #fbfcff 100%);
  min-height: 100vh;
  overflow-x: hidden;
}

body::before,
body::after {
  content: "";
  position: fixed;
  z-index: -1;
  pointer-events: none;
  border-radius: 999px;
  filter: blur(92px);
  opacity: 0.62;
}

body::before {
  width: 24rem;
  height: 24rem;
  top: -8rem;
  left: -6rem;
  background: rgba(201, 218, 255, 0.85);
}

body::after {
  width: 28rem;
  height: 28rem;
  right: -12rem;
  top: 18rem;
  background: rgba(235, 221, 255, 0.7);
}

body.nav-open {
  overflow: hidden;
}

a {
  color: inherit;
  text-decoration: none;
}

img {
  max-width: 100%;
}

p,
li,
span,
small,
label,
input,
textarea,
select,
button {
  color: var(--text-soft);
  line-height: 1.72;
  font: inherit;
}

h1,
h2,
h3,
h4,
p {
  margin-top: 0;
}

h1,
h2,
h3,
h4,
strong,
.brand-copy strong,
.brand-copy small,
.btn,
.nav-link,
.eyebrow,
.stat-value,
.status-pill,
.metric-label,
.section-index,
.filter-chip {
  color: var(--text);
}

.container {
  width: var(--container);
  margin: 0 auto;
}

.topbar {
  border-bottom: 1px solid rgba(195, 208, 232, 0.62);
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.82), rgba(234, 241, 255, 0.68));
}

.topbar-inner {
  min-height: 40px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
}

.topbar-inner span {
  color: #687b99;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 40;
  backdrop-filter: blur(16px);
  background: rgba(252, 253, 255, 0.84);
  border-bottom: 1px solid rgba(195, 208, 232, 0.54);
}

.nav-shell {
  min-height: 78px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

.brand {
  display: flex;
  align-items: center;
  gap: 14px;
}

.brand-mark {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border-radius: 15px;
  border: 1px solid var(--line-strong);
  background: linear-gradient(180deg, #f8faff 0%, #e8efff 100%);
  color: var(--blue);
  font-size: 1.1rem;
  font-weight: 800;
  box-shadow: 0 12px 24px rgba(47, 95, 232, 0.1);
}

.brand-copy {
  display: grid;
  gap: 1px;
}

.brand-copy strong {
  font-size: 0.8rem;
  letter-spacing: 0.16em;
  color: #60728f;
}

.brand-copy small {
  font-size: 0.98rem;
  font-weight: 700;
}

.nav-actions,
.nav-menu,
.nav-links,
.hero-actions,
.tag-row,
.inline-pills,
.footer-links,
.filter-bar,
.company-actions,
.info-list,
.route-actions,
.meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.nav-menu {
  gap: 6px;
}

.nav-link {
  padding: 10px 14px;
  border-radius: 12px;
  font-size: 0.92rem;
  color: #61748f;
  transition: background 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.nav-link:hover,
.nav-link.is-active {
  background: rgba(47, 95, 232, 0.08);
  color: var(--text);
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 18px;
  border: 1px solid transparent;
  border-radius: 14px;
  font-weight: 700;
  transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, border-color 0.18s ease;
}

.btn:hover {
  transform: translateY(-2px);
}

.btn-primary {
  background: var(--blue);
  color: #fff;
  box-shadow: 0 16px 30px rgba(47, 95, 232, 0.22);
}

.btn-primary:hover {
  background: var(--blue-strong);
}

.btn-secondary {
  background: #fff;
  border-color: var(--line-strong);
}

.btn-secondary:hover,
.btn-ghost:hover {
  border-color: #aebfe3;
  box-shadow: var(--shadow-sm);
}

.btn-ghost {
  background: rgba(255, 255, 255, 0.6);
  border-color: rgba(195, 208, 232, 0.9);
}

.btn-link {
  padding: 0;
  min-height: auto;
  border: none;
  background: transparent;
  color: var(--blue);
}

.nav-toggle {
  display: none;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  border: 1px solid var(--line-strong);
  background: #fff;
}

.page {
  padding: 30px 0 76px;
}

.section,
.hero {
  padding: 22px 0;
}

.hero-shell,
.page-shell,
.surface-card,
.showcase-card,
.summary-card,
.timeline-card,
.company-card,
.route-card,
.intake-card,
.contact-card,
.detail-card,
.quote-card,
.founder-card,
.hero-panel,
.band-card,
.metric-card {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.hero-shell,
.page-shell,
.hero-panel,
.intake-card,
.contact-card,
.founder-card,
.quote-card,
.band-card {
  padding: 32px;
}

.surface-card,
.showcase-card,
.summary-card,
.timeline-card,
.company-card,
.route-card,
.detail-card,
.metric-card {
  padding: 24px;
}

.hero-shell::before,
.page-shell::before,
.surface-card::before,
.showcase-card::before,
.summary-card::before,
.timeline-card::before,
.company-card::before,
.route-card::before,
.intake-card::before,
.contact-card::before,
.detail-card::before,
.quote-card::before,
.founder-card::before,
.hero-panel::before,
.band-card::before,
.metric-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 24px;
  right: 24px;
  height: 1px;
  background: linear-gradient(90deg, rgba(113, 140, 208, 0.24), transparent);
}

.hero-shell,
.page-shell,
.hero-panel,
.band-card,
.quote-card {
  background:
    radial-gradient(circle at top left, rgba(212, 222, 255, 0.72), transparent 26%),
    radial-gradient(circle at top right, rgba(235, 229, 255, 0.8), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(249, 251, 255, 0.98) 100%);
  box-shadow: var(--shadow-lg);
}

.hero-layout,
.two-column,
.aside-layout,
.detail-layout,
.contact-layout,
.footer-shell,
.grid-2,
.grid-3,
.grid-4,
.metrics-grid,
.route-grid,
.timeline-grid,
.division-grid,
.summary-grid,
.value-grid,
.filter-layout,
.company-grid {
  display: grid;
  gap: 18px;
}

.hero-layout,
.aside-layout,
.detail-layout,
.contact-layout {
  grid-template-columns: minmax(0, 1.18fr) minmax(0, 0.82fr);
  align-items: stretch;
}

.grid-2,
.summary-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.grid-3,
.metrics-grid,
.value-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.grid-4,
.route-grid,
.timeline-grid,
.company-grid,
.division-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.footer-shell {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
  font-size: 0.76rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: #60729b;
}

.eyebrow::before {
  content: "";
  width: 24px;
  height: 1px;
  background: #9aaed6;
}

.eyebrow.tight {
  margin-bottom: 8px;
}

h1 {
  font-size: clamp(2.6rem, 5vw, 5rem);
  line-height: 0.96;
  letter-spacing: -0.055em;
  margin-bottom: 16px;
  max-width: 16ch;
}

.page-shell h1 {
  max-width: 18ch;
}

h2 {
  font-size: clamp(1.92rem, 3vw, 3.08rem);
  line-height: 1.02;
  letter-spacing: -0.04em;
  margin-bottom: 12px;
}

h3 {
  font-size: 1.18rem;
  margin-bottom: 10px;
}

.lead {
  max-width: 80ch;
  font-size: 1.03rem;
}

.muted {
  color: var(--text-faint);
}

.tag,
.status-pill,
.metric-label,
.filter-chip,
.info-pill {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.9);
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #58719c;
}

.tag.blue,
.metric-label.blue,
.status-pill.active,
.filter-chip[data-filter='active'],
.info-pill.blue {
  background: var(--blue-soft);
}

.tag.violet,
.metric-label.violet,
.status-pill.upcoming,
.filter-chip[data-filter='upcoming'],
.info-pill.violet {
  background: var(--violet-soft);
}

.tag.mint,
.metric-label.mint,
.info-pill.mint {
  background: var(--mint-soft);
}

.tag.amber,
.metric-label.amber,
.status-pill.paused,
.filter-chip[data-filter='paused'],
.info-pill.amber {
  background: var(--amber-soft);
}

.tag.rose,
.info-pill.rose {
  background: var(--rose-soft);
}

.filter-chip {
  cursor: pointer;
  transition: border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
}

.filter-chip:hover,
.filter-chip[aria-pressed='true'] {
  transform: translateY(-1px);
  border-color: #adc0e8;
  box-shadow: var(--shadow-sm);
}

.filter-chip[aria-pressed='true'] {
  color: var(--text);
}

.kicker-copy {
  max-width: 56ch;
}

.hero-panel {
  display: grid;
  gap: 18px;
}

.hero-panel-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
}

.hero-panel-head p {
  margin-bottom: 0;
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.stat-card {
  padding: 18px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.84);
}

.stat-card.tint-blue { background: linear-gradient(180deg, #eef3ff 0%, #ffffff 100%); }
.stat-card.tint-violet { background: linear-gradient(180deg, #f4efff 0%, #ffffff 100%); }
.stat-card.tint-mint { background: linear-gradient(180deg, #effaf4 0%, #ffffff 100%); }
.stat-card.tint-amber { background: linear-gradient(180deg, #fff6eb 0%, #ffffff 100%); }

.stat-value {
  display: block;
  font-size: 1.4rem;
  font-weight: 800;
  margin-bottom: 2px;
  color: var(--text);
}

.stat-copy {
  font-size: 0.92rem;
}

.metric-card {
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.metric-card:hover,
.surface-card:hover,
.showcase-card:hover,
.summary-card:hover,
.timeline-card:hover,
.company-card:hover,
.route-card:hover,
.founder-card:hover,
.quote-card:hover,
.hero-panel:hover,
.band-card:hover,
.intake-card:hover,
.contact-card:hover,
.detail-card:hover,
.company-spotlight:hover,
.upcoming-card:hover,
.paused-shell:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: #b8c8e8;
}

.metric-index,
.section-index {
  width: 42px;
  height: 42px;
  display: inline-grid;
  place-items: center;
  border-radius: 12px;
  border: 1px solid var(--line-strong);
  background: #fff;
  color: var(--text);
  font-weight: 800;
  margin-bottom: 14px;
}

.note-list,
.bullet-list,
.summary-list,
.check-list {
  margin: 0;
  padding-left: 18px;
}

.summary-list {
  display: grid;
  gap: 8px;
}

.note-box {
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.84);
}

.note-box.blue { background: var(--blue-soft); }
.note-box.violet { background: var(--violet-soft); }
.note-box.mint { background: var(--mint-soft); }
.note-box.amber { background: var(--amber-soft); }
.note-box.rose { background: var(--rose-soft); }

.founder-mark {
  width: 72px;
  height: 72px;
  display: grid;
  place-items: center;
  border-radius: 22px;
  border: 1px solid var(--line-strong);
  background: linear-gradient(180deg, #f8faff 0%, #e8efff 100%);
  color: var(--blue);
  font-size: 1.48rem;
  font-weight: 800;
  margin-bottom: 18px;
}

.route-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.route-card p,
.company-card p,
.metric-card p,
.detail-card p,
.summary-card p,
.timeline-card p,
.surface-card p,
.band-card p,
.hero-panel p,
.intake-card p,
.contact-card p,
.founder-card p,
.quote-card p {
  margin-bottom: 0;
}

.timeline-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.97) 0%, rgba(248,250,255,0.97) 100%);
}

.company-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 100%;
}

.company-card.is-hidden {
  display: none;
}

.company-meta {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.company-copy {
  display: grid;
  gap: 8px;
}

.company-copy h3 {
  margin-bottom: 0;
}

.company-description {
  font-size: 0.94rem;
}

.company-card .company-actions {
  margin-top: auto;
}

.company-list {
  display: grid;
  gap: 8px;
  margin: 0;
  padding-left: 18px;
}

.summary-board {
  display: grid;
  gap: 16px;
}

.summary-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
  padding: 14px 0;
  border-bottom: 1px solid rgba(219, 228, 244, 0.8);
}

.summary-row:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.summary-row strong {
  display: block;
  margin-bottom: 4px;
}

.section-heading {
  display: grid;
  gap: 12px;
  margin-bottom: 22px;
}

.section-heading p {
  max-width: 72ch;
  margin-bottom: 0;
}

.division-rail {
  display: grid;
  gap: 12px;
}

.division-item {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.8);
}

.division-item h4 {
  margin-bottom: 4px;
}

.division-item p {
  margin-bottom: 0;
  font-size: 0.92rem;
}

.check-grid {
  display: grid;
  gap: 14px;
}

.contact-layout .contact-card,
.contact-layout .intake-card {
  min-height: 100%;
}

.field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.input,
.select,
.textarea {
  width: 100%;
  min-height: 54px;
  border-radius: 16px;
  border: 1px solid var(--line-strong);
  background: #f8fbff;
  padding: 0 18px;
  color: var(--text);
}

.textarea {
  min-height: 148px;
  padding: 16px 18px;
  resize: vertical;
}

.input:focus,
.select:focus,
.textarea:focus {
  outline: none;
  border-color: #95abdb;
  box-shadow: 0 0 0 4px rgba(47, 95, 232, 0.08);
}

.fake-form {
  display: grid;
  gap: 14px;
}

.divider {
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, rgba(195, 208, 232, 0.9), transparent);
}

.detail-hero-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
}

.detail-panel {
  display: grid;
  gap: 12px;
}

.detail-stack {
  display: grid;
  gap: 12px;
}

.note-box.white {
  background: rgba(255, 255, 255, 0.9);
}

.company-anchor-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 22px;
}

.showcase-stack {
  display: grid;
  gap: 20px;
}

.company-spotlight {
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(300px, 0.88fr);
  gap: 18px;
  padding: 28px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.9);
  box-shadow: var(--shadow-sm);
}

.company-spotlight.tone-blue {
  background: linear-gradient(180deg, rgba(238, 243, 255, 0.92) 0%, rgba(255, 255, 255, 0.96) 100%);
}

.company-spotlight.tone-violet {
  background: linear-gradient(180deg, rgba(244, 239, 255, 0.92) 0%, rgba(255, 255, 255, 0.96) 100%);
}

.company-spotlight.tone-mint {
  background: linear-gradient(180deg, rgba(239, 250, 244, 0.92) 0%, rgba(255, 255, 255, 0.96) 100%);
}

.company-spotlight-main,
.company-spotlight-side,
.paused-side {
  display: grid;
  gap: 16px;
}

.spotlight-header {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
}

.spotlight-header h3 {
  font-size: 1.52rem;
  margin: 10px 0 0;
}

.company-description-lg {
  font-size: 1rem;
  line-height: 1.8;
}

.spotlight-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.company-list-tight {
  gap: 10px;
}

.spotlight-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.spotlight-metrics.single-column {
  grid-template-columns: 1fr;
}

.spotlight-metric {
  display: grid;
  gap: 4px;
  padding: 16px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.88);
}

.spotlight-metric strong {
  font-size: 0.84rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #60729b;
}

.spotlight-metric span {
  color: var(--text);
  font-weight: 700;
}

.upcoming-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.upcoming-card {
  display: grid;
  gap: 14px;
  min-height: 100%;
  padding: 24px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: var(--shadow-sm);
}

.paused-shell {
  padding: 30px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  background:
    radial-gradient(circle at top left, rgba(255, 243, 224, 0.86), transparent 26%),
    radial-gradient(circle at top right, rgba(236, 240, 255, 0.88), transparent 28%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(252, 249, 244, 0.98) 100%);
  box-shadow: var(--shadow-md);
}

.paused-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(300px, 0.92fr);
  gap: 20px;
}

body.company-studio {
  --company-accent: #4d6bff;
  --company-accent-rgb: 77, 107, 255;
}

body.company-labs {
  --company-accent: #7a5cff;
  --company-accent-rgb: 122, 92, 255;
}

body.company-systems {
  --company-accent: #1f9d74;
  --company-accent-rgb: 31, 157, 116;
}

body.company-cloudops {
  --company-accent: #2f77e8;
  --company-accent-rgb: 47, 119, 232;
}

body.company-itcare {
  --company-accent: #d9892b;
  --company-accent-rgb: 217, 137, 43;
}

body.company-academy {
  --company-accent: #5e72e4;
  --company-accent-rgb: 94, 114, 228;
}

body.company-news {
  --company-accent: #7c5cff;
  --company-accent-rgb: 124, 92, 255;
}

body.company-cybershield {
  --company-accent: #3a65d8;
  --company-accent-rgb: 58, 101, 216;
}

body.company-page h1 {
  font-size: clamp(1.62rem, 2.05vw, 2.56rem);
  line-height: 1.02;
  letter-spacing: -0.044em;
  max-width: 15.4ch;
  text-wrap: balance;
}

body.company-page h2 {
  font-size: clamp(1.68rem, 2.35vw, 2.38rem);
  text-wrap: balance;
}

body.company-page h3 {
  font-size: 1.08rem;
}

body.company-page .lead {
  font-size: 0.92rem;
  line-height: 1.68;
  max-width: 66ch;
}

body.company-page .container {
  width: min(1060px, calc(100% - 40px));
}

body.company-page .brand-mark {
  color: var(--company-accent);
  box-shadow: 0 14px 26px rgba(var(--company-accent-rgb), 0.14);
}

body.company-page .btn-primary {
  background: linear-gradient(135deg, rgba(var(--company-accent-rgb), 0.96), rgba(var(--company-accent-rgb), 0.78));
  box-shadow: 0 18px 34px rgba(var(--company-accent-rgb), 0.24);
}

body.company-page .btn-primary:hover {
  filter: brightness(0.96);
}

body.company-page .btn-secondary {
  border-color: rgba(var(--company-accent-rgb), 0.18);
}

body.company-page .filter-chip:hover,
body.company-page .filter-chip[aria-pressed='true'] {
  border-color: rgba(var(--company-accent-rgb), 0.28);
  box-shadow: 0 10px 20px rgba(var(--company-accent-rgb), 0.08);
}

body.company-page .eyebrow::before {
  background: rgba(var(--company-accent-rgb), 0.55);
}

body.company-page .topbar-inner {
  font-size: 0.68rem;
}

body.company-page .nav-shell {
  min-height: 72px;
}

body.company-page .section-heading p,
body.company-page .company-description,
body.company-page .note-box p,
body.company-page .company-list li,
body.company-page .summary-list li {
  font-size: 0.93rem;
}

body.company-page .hero-shell {
  padding: 22px;
  background:
    radial-gradient(circle at top left, rgba(var(--company-accent-rgb), 0.11), transparent 24%),
    radial-gradient(circle at top right, rgba(235, 229, 255, 0.56), transparent 22%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(248, 250, 255, 0.98) 100%);
}

body.company-page .detail-hero-grid {
  grid-template-columns: minmax(0, 1.24fr) minmax(285px, 0.76fr);
  align-items: start;
  gap: 16px;
}

body.company-page .hero-panel {
  align-self: start;
  gap: 12px;
  padding: 18px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(var(--company-accent-rgb), 0.045) 100%);
  box-shadow: 0 14px 38px rgba(28, 48, 86, 0.06);
}

body.company-page .tag-row {
  gap: 10px;
}

body.company-page .company-local-nav {
  margin-top: 16px;
  gap: 8px;
}

body.company-page .company-page-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-top: 14px;
}

body.company-page .company-page-actions .btn {
  min-height: 42px;
}

body.company-page .company-local-nav .filter-chip {
  min-height: 34px;
  padding: 0 10px;
  font-size: 0.69rem;
}

body.company-page .company-status-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

body.company-page .company-split-card,
body.company-page .company-status-card,
body.company-page .company-pillar-card,
body.company-page .company-stage-card,
body.company-page .company-link-card,
body.company-page .company-side-card {
  backdrop-filter: blur(10px);
}

body.company-page .company-status-card,
body.company-page .company-pillar-card,
body.company-page .company-stage-card,
body.company-page .company-link-card,
body.company-page .company-side-card {
  padding: 18px;
  border-radius: 20px;
}

body.company-page .company-status-card .stat-value {
  font-size: 1.18rem;
}

body.company-page .company-status-card .stat-label,
body.company-page .company-stage-kicker,
body.company-page .company-link-kicker {
  font-size: 0.7rem;
}

body.company-page .company-pillar-grid,
body.company-page .company-stage-grid,
body.company-page .company-link-grid {
  gap: 16px;
}

body.company-page .company-split-card {
  align-items: start;
  padding: 22px;
  gap: 16px;
}

body.company-page .company-list-strong {
  gap: 8px;
}

body.company-page .section-heading {
  margin-bottom: 24px;
}

body.company-page .section {
  padding: 16px 0;
}

body.company-page .company-summary-card,
body.company-page .company-minimal-card,
body.company-page .company-note-panel,
body.company-page .company-disclosure summary,
body.company-page .disclosure-body {
  font-size: 0.9rem;
}

body.company-page .company-summary-card {
  padding: 14px;
}

body.company-page .company-summary-value {
  font-size: 0.9rem;
  color: var(--company-accent);
}

body.company-page .company-note-panel {
  padding: 14px 15px;
}

body.company-page .company-note-panel p,
body.company-page .disclosure-body p,
body.company-page .disclosure-body li {
  font-size: 0.9rem;
  line-height: 1.65;
}

body.company-page .company-minimal-card {
  padding: 15px;
}

body.company-page .company-story-card {
  padding: 18px;
  gap: 14px;
}

body.company-page .company-summary-strip,
body.company-page .company-minimal-grid,
body.company-page .company-disclosures {
  gap: 12px;
}

body.company-page .company-summary-strip {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.company-page .company-minimal-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.company-page .company-minimal-grid > :nth-child(3):last-child,
body.company-page .company-disclosures > :nth-child(3):last-child {
  grid-column: 1 / -1;
}

body.company-page .company-disclosures {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
}

body.company-page .company-disclosure {
  flex: 1 1 calc(50% - 6px);
  min-width: min(100%, 320px);
  align-self: flex-start;
}

body.company-page .company-disclosure:nth-child(3):last-child {
  flex-basis: 100%;
}

body.company-page .company-summary-card,
body.company-page .company-minimal-card,
body.company-page .company-note-panel,
body.company-page .company-disclosure {
  border-color: rgba(195, 208, 232, 0.86);
}

body.company-page .company-summary-card::before,
body.company-page .company-minimal-card::before,
body.company-page .company-note-panel::before,
body.company-page .company-disclosure::before {
  content: "";
  position: absolute;
  top: 0;
  left: 16px;
  right: 16px;
  height: 1px;
  background: linear-gradient(90deg, rgba(var(--company-accent-rgb), 0.34), transparent);
}

body.company-page .company-disclosure summary {
  display: grid;
  padding: 15px 16px;
}

body.company-page .company-disclosure .disclosure-body {
  padding: 0 16px 16px;
}

body.company-page .company-disclosure summary {
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: start;
}

body.company-page .company-disclosure-head {
  display: grid;
  gap: 5px;
}

body.company-page .company-disclosure-head strong {
  font-size: 1rem;
  line-height: 1.32;
}

body.company-page .company-disclosure summary::after {
  color: rgba(var(--company-accent-rgb), 0.88);
}

body.company-page .company-hero-band {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}

body.company-page .company-hero-card {
  position: relative;
  display: grid;
  gap: 8px;
  min-height: 100%;
  padding: 16px 16px 16px 18px;
  border-radius: 20px;
  border: 1px solid rgba(195, 208, 232, 0.86);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(var(--company-accent-rgb), 0.045) 100%);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

body.company-page .company-hero-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: linear-gradient(180deg, rgba(var(--company-accent-rgb), 0.84), rgba(var(--company-accent-rgb), 0.18));
}

body.company-page .company-hero-card::after {
  content: "";
  position: absolute;
  top: 0;
  left: 18px;
  right: 18px;
  height: 1px;
  background: linear-gradient(90deg, rgba(var(--company-accent-rgb), 0.3), transparent);
}

body.company-page .company-hero-label {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(var(--company-accent-rgb), 0.92);
}

body.company-page .company-hero-card strong {
  color: var(--text);
  font-size: 1.02rem;
  line-height: 1.28;
}

body.company-page .company-hero-card p {
  margin-bottom: 0;
  font-size: 0.9rem;
  line-height: 1.62;
}

body.company-page .company-highlight-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

body.company-page .company-highlight-card {
  position: relative;
  display: grid;
  gap: 10px;
  min-height: 100%;
  padding: 18px;
  border-radius: 22px;
  border: 1px solid rgba(195, 208, 232, 0.86);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(var(--company-accent-rgb), 0.045) 100%);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

body.company-page .company-highlight-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: linear-gradient(180deg, rgba(var(--company-accent-rgb), 0.85), rgba(var(--company-accent-rgb), 0.18));
}

body.company-page .company-highlight-card::after {
  content: "";
  position: absolute;
  top: 0;
  left: 18px;
  right: 18px;
  height: 1px;
  background: linear-gradient(90deg, rgba(var(--company-accent-rgb), 0.28), transparent);
}

body.company-page .company-highlight-card h3 {
  margin-bottom: 0;
}

body.company-page .company-highlight-card p {
  margin-bottom: 0;
  font-size: 0.92rem;
  line-height: 1.66;
}

body.company-page .company-highlight-card .company-mini-kicker {
  color: rgba(var(--company-accent-rgb), 0.92);
}

body.company-page .company-highlight-card:hover {
  transform: translateY(-4px);
  border-color: rgba(var(--company-accent-rgb), 0.22);
  box-shadow: 0 20px 42px rgba(var(--company-accent-rgb), 0.1);
}

body.company-page .company-story-card {
  background:
    radial-gradient(circle at top left, rgba(var(--company-accent-rgb), 0.12), transparent 22%),
    radial-gradient(circle at top right, rgba(235, 229, 255, 0.52), transparent 22%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(248, 250, 255, 0.99) 100%);
}

.company-summary-strip,
.company-minimal-grid,
.company-story-card {
  display: grid;
  gap: 14px;
}

.company-summary-strip {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-top: 18px;
}

.company-summary-card,
.company-minimal-card,
.company-story-card,
.company-note-panel {
  position: relative;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: var(--shadow-sm);
}

.company-summary-card,
.company-minimal-card,
.company-note-panel {
  padding: 18px;
  border-radius: 20px;
}

.company-story-card {
  grid-template-columns: minmax(0, 1.08fr) minmax(300px, 0.92fr);
  padding: 24px;
  border-radius: 28px;
  background:
    radial-gradient(circle at top left, rgba(212, 222, 255, 0.52), transparent 24%),
    radial-gradient(circle at top right, rgba(235, 229, 255, 0.56), transparent 22%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(248, 250, 255, 0.98) 100%);
}

.company-story-main,
.company-story-side,
.company-note-stack,
.company-disclosures {
  display: grid;
  gap: 14px;
}

.company-summary-card strong,
.company-minimal-card strong,
.company-note-panel strong,
.company-disclosure strong {
  color: var(--text);
}

.company-summary-label,
.company-mini-kicker,
.company-note-kicker,
.company-disclosure summary span {
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #60729b;
}

.company-summary-value {
  display: block;
  margin-top: 4px;
  font-size: 1.02rem;
  font-weight: 800;
  color: var(--text);
}

.company-minimal-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.company-minimal-card {
  display: grid;
  gap: 10px;
  min-height: 100%;
}

.company-minimal-card h3 {
  margin-bottom: 0;
}

.company-note-panel {
  display: grid;
  gap: 10px;
}

.company-note-panel.tone-blue,
.company-summary-card.tone-blue,
.company-minimal-card.tone-blue {
  background: linear-gradient(180deg, rgba(238, 243, 255, 0.96) 0%, rgba(255, 255, 255, 0.98) 100%);
}

.company-note-panel.tone-violet,
.company-summary-card.tone-violet,
.company-minimal-card.tone-violet {
  background: linear-gradient(180deg, rgba(244, 239, 255, 0.96) 0%, rgba(255, 255, 255, 0.98) 100%);
}

.company-note-panel.tone-mint,
.company-summary-card.tone-mint,
.company-minimal-card.tone-mint {
  background: linear-gradient(180deg, rgba(239, 250, 244, 0.96) 0%, rgba(255, 255, 255, 0.98) 100%);
}

.company-note-panel.tone-amber,
.company-summary-card.tone-amber,
.company-minimal-card.tone-amber {
  background: linear-gradient(180deg, rgba(255, 246, 235, 0.96) 0%, rgba(255, 255, 255, 0.98) 100%);
}

.company-disclosure {
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.company-disclosure[open] {
  box-shadow: var(--shadow-md);
  border-color: #b8c8e8;
}

.company-disclosure summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  list-style: none;
  padding: 17px 18px;
  color: var(--text);
  font-weight: 700;
}

.company-disclosure summary::-webkit-details-marker {
  display: none;
}

.company-disclosure summary::after {
  content: '+';
  font-size: 1.1rem;
  color: #60729b;
}

.company-disclosure[open] summary::after {
  content: '−';
}

.company-disclosure .disclosure-body {
  padding: 0 18px 18px;
}

.company-disclosure .disclosure-body p,
.company-disclosure .disclosure-body li {
  font-size: 0.95rem;
}

.company-disclosure .disclosure-body ul {
  margin: 10px 0 0;
  padding-left: 18px;
}

.company-local-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}

.company-status-grid,
.company-pillar-grid,
.company-stage-grid,
.company-rail-grid,
.company-link-grid {
  display: grid;
  gap: 16px;
}

.company-status-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 22px;
}

.company-pillar-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.company-stage-grid,
.company-link-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.company-rail-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.company-status-card,
.company-pillar-card,
.company-stage-card,
.company-link-card,
.company-side-card {
  position: relative;
  display: grid;
  gap: 12px;
  min-height: 100%;
  padding: 22px;
  border-radius: 24px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: var(--shadow-sm);
}

.company-status-card,
.company-pillar-card,
.company-stage-card,
.company-link-card,
.company-side-card {
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.company-status-card:hover,
.company-pillar-card:hover,
.company-stage-card:hover,
.company-link-card:hover,
.company-side-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: #b8c8e8;
}

.company-status-card strong,
.company-pillar-card strong,
.company-stage-card strong,
.company-link-card strong,
.company-side-card strong {
  color: var(--text);
}

.company-status-card .stat-value {
  font-size: 1.72rem;
}

.company-status-card .stat-label,
.company-stage-kicker,
.company-link-kicker {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #60729b;
}

.company-pillar-card.tone-blue,
.company-status-card.tone-blue,
.company-stage-card.tone-blue,
.company-link-card.tone-blue,
.company-side-card.tone-blue {
  background: linear-gradient(180deg, rgba(238, 243, 255, 0.96) 0%, rgba(255, 255, 255, 0.98) 100%);
}

.company-pillar-card.tone-violet,
.company-status-card.tone-violet,
.company-stage-card.tone-violet,
.company-link-card.tone-violet,
.company-side-card.tone-violet {
  background: linear-gradient(180deg, rgba(244, 239, 255, 0.96) 0%, rgba(255, 255, 255, 0.98) 100%);
}

.company-pillar-card.tone-mint,
.company-status-card.tone-mint,
.company-stage-card.tone-mint,
.company-link-card.tone-mint,
.company-side-card.tone-mint {
  background: linear-gradient(180deg, rgba(239, 250, 244, 0.96) 0%, rgba(255, 255, 255, 0.98) 100%);
}

.company-pillar-card.tone-amber,
.company-status-card.tone-amber,
.company-stage-card.tone-amber,
.company-link-card.tone-amber,
.company-side-card.tone-amber {
  background: linear-gradient(180deg, rgba(255, 246, 235, 0.96) 0%, rgba(255, 255, 255, 0.98) 100%);
}

.company-split-card {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(300px, 0.92fr);
  gap: 18px;
  padding: 28px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
  background:
    radial-gradient(circle at top left, rgba(212, 222, 255, 0.54), transparent 26%),
    radial-gradient(circle at top right, rgba(235, 229, 255, 0.58), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.97) 0%, rgba(248, 250, 255, 0.97) 100%);
  box-shadow: var(--shadow-md);
}

.company-split-main,
.company-split-side {
  display: grid;
  gap: 16px;
}

.company-list-strong {
  display: grid;
  gap: 10px;
  margin: 0;
  padding-left: 18px;
}

.company-list-strong li::marker {
  color: var(--blue);
}

.company-side-stack {
  display: grid;
  gap: 14px;
}

.company-link-card p,
.company-stage-card p,
.company-status-card p,
.company-pillar-card p,
.company-side-card p {
  margin-bottom: 0;
}

.company-link-card h3,
.company-stage-card h3,
.company-pillar-card h3 {
  margin-bottom: 0;
}

.footer {
  padding: 26px 0 44px;
}

.footer-shell {
  padding: 22px 0 0;
  border-top: 1px solid rgba(195, 208, 232, 0.9);
}

.footer-links a {
  color: #60728f;
}

.footer-links a:hover {
  color: var(--text);
}

[data-reveal] {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.72s ease, transform 0.72s ease;
}

[data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}

body.home-page .container {
  width: min(1140px, calc(100% - 40px));
}

body.home-page .hero-shell {
  padding: 34px;
  background:
    radial-gradient(circle at top left, rgba(209, 221, 255, 0.72), transparent 24%),
    radial-gradient(circle at top right, rgba(236, 228, 255, 0.68), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(248, 250, 255, 0.99) 100%);
}

.home-hero-grid,
.home-overview-grid,
.home-framework-grid,
.home-company-grid,
.home-upcoming-grid,
.home-founder-shell,
.home-hero-band,
.home-proof-grid {
  display: grid;
  gap: 16px;
}

.home-hero-grid {
  grid-template-columns: minmax(0, 1.12fr) minmax(320px, 0.88fr);
  align-items: start;
}

.home-anchor-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.home-anchor-bar .filter-chip {
  min-height: 36px;
  padding: 0 12px;
  font-size: 0.72rem;
}

.home-insight-panel,
.home-overview-card,
.home-framework-card,
.home-company-card,
.home-upcoming-card,
.home-founder-panel,
.home-cta-shell,
.home-proof-card,
.home-rule-card,
.home-side-card,
.home-paused-card,
.home-hero-card {
  position: relative;
  border: 1px solid rgba(195, 208, 232, 0.86);
  background: rgba(255, 255, 255, 0.95);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.home-insight-panel,
.home-overview-card,
.home-founder-panel,
.home-cta-shell,
.home-rule-card,
.home-paused-card {
  padding: 26px;
  border-radius: 28px;
}

.home-framework-card,
.home-company-card,
.home-upcoming-card,
.home-proof-card,
.home-side-card,
.home-hero-card {
  padding: 20px;
  border-radius: 22px;
}

.home-insight-panel::before,
.home-overview-card::before,
.home-framework-card::before,
.home-company-card::before,
.home-upcoming-card::before,
.home-founder-panel::before,
.home-cta-shell::before,
.home-proof-card::before,
.home-rule-card::before,
.home-side-card::before,
.home-paused-card::before,
.home-hero-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 18px;
  right: 18px;
  height: 1px;
  background: linear-gradient(90deg, rgba(98, 126, 192, 0.28), transparent);
}

.home-insight-panel {
  display: grid;
  gap: 16px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(241, 246, 255, 0.98) 100%);
}

.home-proof-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.home-proof-card {
  display: grid;
  gap: 8px;
  min-height: 100%;
}

.home-proof-card strong {
  display: block;
  font-size: 1.36rem;
  line-height: 1;
  color: var(--text);
}

.home-hero-band {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-top: 18px;
}

.home-hero-card {
  display: grid;
  gap: 8px;
  min-height: 100%;
  padding-left: 22px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(244, 247, 255, 0.98) 100%);
}

.home-hero-card::after,
.home-company-card::after,
.home-upcoming-card::after,
.home-proof-card::after,
.home-framework-card::after,
.home-paused-card::after {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: linear-gradient(180deg, rgba(47, 95, 232, 0.84), rgba(47, 95, 232, 0.12));
}

.home-hero-card.violet::after,
.home-framework-card.violet::after,
.home-company-card.violet::after,
.home-upcoming-card.violet::after,
.home-proof-card.violet::after,
.home-paused-card.violet::after {
  background: linear-gradient(180deg, rgba(123, 92, 255, 0.84), rgba(123, 92, 255, 0.12));
}

.home-hero-card.mint::after,
.home-framework-card.mint::after,
.home-company-card.mint::after,
.home-upcoming-card.mint::after,
.home-proof-card.mint::after,
.home-paused-card.mint::after {
  background: linear-gradient(180deg, rgba(31, 157, 116, 0.84), rgba(31, 157, 116, 0.12));
}

.home-hero-card.amber::after,
.home-framework-card.amber::after,
.home-company-card.amber::after,
.home-upcoming-card.amber::after,
.home-proof-card.amber::after,
.home-paused-card.amber::after {
  background: linear-gradient(180deg, rgba(217, 137, 43, 0.84), rgba(217, 137, 43, 0.12));
}

.home-hero-label,
.home-framework-step,
.home-company-kicker,
.home-upcoming-kicker,
.home-proof-label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #60729b;
}

.home-hero-card strong,
.home-framework-card h3,
.home-company-card h3,
.home-upcoming-card h3,
.home-proof-card h3,
.home-side-card h3,
.home-rule-card h3,
.home-paused-card h3 {
  margin-bottom: 0;
}

.home-overview-grid,
.home-founder-shell {
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
}

.home-aside-stack {
  display: grid;
  gap: 16px;
}

.home-framework-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.home-framework-card {
  display: grid;
  gap: 10px;
  min-height: 100%;
  padding-left: 22px;
}

.home-framework-step {
  color: var(--blue);
}

.home-company-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.home-company-card,
.home-upcoming-card {
  display: grid;
  gap: 12px;
  min-height: 100%;
  padding-left: 22px;
}

.home-company-card .company-actions,
.home-upcoming-card .company-actions,
.home-paused-card .company-actions {
  margin-top: auto;
}

.home-company-list,
.home-compact-list {
  display: grid;
  gap: 8px;
  margin: 0;
  padding-left: 18px;
}

.home-company-list li::marker,
.home-compact-list li::marker {
  color: var(--blue);
}

.home-upcoming-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.home-side-card,
.home-rule-card {
  display: grid;
  gap: 10px;
}

.home-rule-card {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(244, 248, 255, 0.99) 100%);
}

.home-paused-card {
  display: grid;
  gap: 14px;
  background:
    radial-gradient(circle at top left, rgba(255, 243, 224, 0.66), transparent 22%),
    radial-gradient(circle at top right, rgba(236, 240, 255, 0.6), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(252, 249, 244, 0.99) 100%);
}

.home-paused-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(300px, 0.92fr);
  gap: 18px;
}

.home-founder-panel {
  display: grid;
  gap: 14px;
}

.home-founder-grid {
  display: grid;
  gap: 14px;
}

.home-founder-mark {
  width: 74px;
  height: 74px;
  display: grid;
  place-items: center;
  border-radius: 24px;
  border: 1px solid var(--line-strong);
  background: linear-gradient(180deg, #f8faff 0%, #e8efff 100%);
  color: var(--blue);
  font-size: 1.58rem;
  font-weight: 800;
}

.home-cta-shell {
  background:
    radial-gradient(circle at top left, rgba(212, 222, 255, 0.6), transparent 22%),
    radial-gradient(circle at top right, rgba(235, 229, 255, 0.62), transparent 22%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(247, 250, 255, 0.99) 100%);
  box-shadow: var(--shadow-lg);
}

.home-cta-shell p,
.home-overview-card p,
.home-framework-card p,
.home-company-card p,
.home-upcoming-card p,
.home-side-card p,
.home-rule-card p,
.home-paused-card p,
.home-founder-panel p,
.home-proof-card p,
.home-hero-card p {
  margin-bottom: 0;
}

body.home-page .btn-primary {
  background: linear-gradient(135deg, #2f5fe8, #496df0);
}

body.home-page .btn-primary:hover {
  background: linear-gradient(135deg, #284fcb, #3f61dc);
}

@media (max-width: 1180px) {
  .home-hero-grid,
  .home-overview-grid,
  .home-framework-grid,
  .home-company-grid,
  .home-upcoming-grid,
  .home-founder-shell,
  .home-hero-band,
  .home-proof-grid,
  .home-paused-layout {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .home-hero-grid,
  .home-overview-grid,
  .home-founder-shell,
  .home-paused-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .home-framework-grid,
  .home-company-grid,
  .home-upcoming-grid,
  .home-hero-band,
  .home-proof-grid,
  .home-paused-layout {
    grid-template-columns: 1fr;
  }

  body.home-page .hero-shell,
  .home-insight-panel,
  .home-overview-card,
  .home-founder-panel,
  .home-cta-shell,
  .home-rule-card,
  .home-paused-card {
    padding: 22px;
  }
}

@media (max-width: 640px) {
  .home-anchor-bar {
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 1180px) {
  .hero-layout,
  .aside-layout,
  .detail-layout,
  .contact-layout,
  .grid-2,
  .grid-3,
  .grid-4,
  .metrics-grid,
  .route-grid,
  .timeline-grid,
  .division-grid,
  .summary-grid,
  .value-grid,
  .company-grid,
  .footer-shell,
  .detail-hero-grid,
  .stats-grid,
  .company-spotlight,
  .upcoming-grid,
  .paused-layout,
  .spotlight-metrics,
  .company-status-grid,
  .company-pillar-grid,
  .company-stage-grid,
  .company-rail-grid,
  .company-link-grid,
  .company-split-card,
  .company-summary-strip,
  .company-minimal-grid,
  .company-story-card {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1180px) {
  body.company-page .company-status-grid,
  body.company-page .company-pillar-grid,
  body.company-page .company-stage-grid,
  body.company-page .company-link-grid,
  body.company-page .company-rail-grid,
  body.company-page .company-summary-strip,
  body.company-page .company-minimal-grid,
  body.company-page .company-story-card,
  body.company-page .company-disclosures,
  body.company-page .company-highlight-grid,
  body.company-page .company-hero-band {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .nav-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .nav-menu {
    position: absolute;
    top: calc(100% + 10px);
    left: 20px;
    right: 20px;
    display: none;
    flex-direction: column;
    align-items: flex-start;
    padding: 18px;
    border-radius: 22px;
    border: 1px solid var(--line);
    background: rgba(255,255,255,0.97);
    box-shadow: var(--shadow-md);
  }

  .nav-menu.is-open {
    display: flex;
  }

  .hero-shell,
  .page-shell,
  .surface-card,
  .showcase-card,
  .summary-card,
  .timeline-card,
  .company-card,
  .route-card,
  .intake-card,
  .contact-card,
  .detail-card,
  .quote-card,
  .founder-card,
  .hero-panel,
  .band-card,
  .metric-card,
  .company-status-card,
  .company-pillar-card,
  .company-stage-card,
  .company-link-card,
  .company-side-card,
  .company-split-card {
    padding: 22px;
  }
}

@media (max-width: 760px) {
  body.company-page h1 {
    font-size: clamp(2.05rem, 8vw, 3rem);
    max-width: 100%;
  }

  body.company-page .company-status-grid,
  body.company-page .company-pillar-grid,
  body.company-page .company-stage-grid,
  body.company-page .company-link-grid,
  body.company-page .company-rail-grid,
  body.company-page .company-summary-strip,
  body.company-page .company-minimal-grid,
  body.company-page .company-story-card,
  body.company-page .company-disclosures,
  body.company-page .company-highlight-grid,
  body.company-page .company-hero-band {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  :root {
    --container: min(1220px, calc(100% - 24px));
  }

  .topbar-inner,
  .nav-actions,
  .hero-actions,
  .tag-row,
  .inline-pills,
  .footer-links,
  .filter-bar,
  .company-actions,
  .route-actions,
  .meta-row,
  .company-anchor-bar,
  .spotlight-badges,
  .company-local-nav {
    flex-direction: column;
    align-items: flex-start;
  }

  .btn {
    width: 100%;
  }

  .field-grid {
    grid-template-columns: 1fr;
  }

  h1 {
    max-width: 100%;
  }
}

/* Home v2 refinements */
body.home-page .container {
  width: min(1040px, calc(100% - 40px));
}

body.home-page h1 {
  font-size: clamp(2rem, 3vw, 3.35rem);
  line-height: 0.98;
  letter-spacing: -0.05em;
  max-width: 12ch;
  text-wrap: balance;
}

body.home-page h2 {
  font-size: clamp(1.72rem, 2.45vw, 2.45rem);
  line-height: 1.02;
  letter-spacing: -0.04em;
  text-wrap: balance;
}

body.home-page h3 {
  font-size: 1.1rem;
}

body.home-page .lead {
  font-size: 0.98rem;
  line-height: 1.7;
  max-width: 62ch;
}

body.home-page .page {
  padding-top: 24px;
}

body.home-page .hero-shell {
  padding: 28px;
  background:
    radial-gradient(circle at top left, rgba(209, 221, 255, 0.58), transparent 24%),
    radial-gradient(circle at top right, rgba(236, 228, 255, 0.56), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(248, 250, 255, 0.99) 100%);
}

.home-minimal-hero,
.home-keyline-grid,
.home-manifesto-grid,
.home-route-grid {
  display: grid;
  gap: 14px;
}

.home-minimal-hero {
  grid-template-columns: minmax(0, 1.12fr) minmax(300px, 0.88fr);
  align-items: start;
}

.home-note-shell,
.home-keyline-card,
.home-manifesto-card,
.home-route-card,
.home-cta-shell.home-cta-minimal {
  position: relative;
  border: 1px solid rgba(195, 208, 232, 0.86);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.home-note-shell,
.home-cta-shell.home-cta-minimal {
  padding: 24px;
  border-radius: 26px;
}

.home-keyline-card,
.home-manifesto-card,
.home-route-card {
  padding: 18px;
  border-radius: 22px;
}

.home-note-shell::before,
.home-keyline-card::before,
.home-manifesto-card::before,
.home-route-card::before,
.home-cta-shell.home-cta-minimal::before {
  content: "";
  position: absolute;
  top: 0;
  left: 18px;
  right: 18px;
  height: 1px;
  background: linear-gradient(90deg, rgba(98, 126, 192, 0.28), transparent);
}

.home-note-shell {
  display: grid;
  gap: 14px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(243, 247, 255, 0.98) 100%);
}

.home-mini-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.home-mini-links .filter-chip {
  min-height: 36px;
  padding: 0 12px;
  font-size: 0.72rem;
}

.home-keyline-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 18px;
}

.home-keyline-card,
.home-route-card {
  display: grid;
  gap: 10px;
  min-height: 100%;
  padding-left: 22px;
}

.home-keyline-card::after,
.home-route-card::after {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: linear-gradient(180deg, rgba(47, 95, 232, 0.84), rgba(47, 95, 232, 0.14));
}

.home-keyline-card.violet::after,
.home-route-card.violet::after {
  background: linear-gradient(180deg, rgba(123, 92, 255, 0.84), rgba(123, 92, 255, 0.14));
}

.home-keyline-card.mint::after,
.home-route-card.mint::after {
  background: linear-gradient(180deg, rgba(31, 157, 116, 0.84), rgba(31, 157, 116, 0.14));
}

.home-keyline-card.amber::after,
.home-route-card.amber::after {
  background: linear-gradient(180deg, rgba(217, 137, 43, 0.84), rgba(217, 137, 43, 0.14));
}

.home-manifesto-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.home-manifesto-card {
  display: grid;
  gap: 10px;
  min-height: 100%;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(246, 249, 255, 0.99) 100%);
}

.home-route-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.home-route-card .company-actions {
  margin-top: auto;
}

.home-keyline-card strong,
.home-manifesto-card h3,
.home-route-card h3 {
  margin-bottom: 0;
}

.home-keyline-card p,
.home-manifesto-card p,
.home-route-card p,
.home-note-shell p,
.home-cta-shell.home-cta-minimal p {
  margin-bottom: 0;
}

.home-cta-shell.home-cta-minimal {
  background:
    radial-gradient(circle at top left, rgba(212, 222, 255, 0.54), transparent 22%),
    radial-gradient(circle at top right, rgba(235, 229, 255, 0.56), transparent 22%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(247, 250, 255, 0.99) 100%);
}

@media (max-width: 1180px) {
  .home-minimal-hero,
  .home-keyline-grid,
  .home-manifesto-grid,
  .home-route-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .home-minimal-hero {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  body.home-page h1 {
    font-size: clamp(1.9rem, 7vw, 2.8rem);
    max-width: 100%;
  }

  body.home-page h2 {
    font-size: clamp(1.52rem, 5.2vw, 2.05rem);
  }

  .home-keyline-grid,
  .home-manifesto-grid,
  .home-route-grid {
    grid-template-columns: 1fr;
  }

  body.home-page .hero-shell,
  .home-note-shell,
  .home-manifesto-card,
  .home-route-card,
  .home-keyline-card,
  .home-cta-shell.home-cta-minimal {
    padding: 22px;
  }
}

@media (max-width: 640px) {
  .home-mini-links {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* Home editorial v3 */
body.home-editorial-page .container {
  width: min(980px, calc(100% - 40px));
}

body.home-editorial-page h1 {
  font-size: clamp(1.84rem, 2.35vw, 2.82rem);
  line-height: 1.01;
  letter-spacing: -0.045em;
  max-width: 14ch;
  text-wrap: balance;
}

body.home-editorial-page h2 {
  font-size: clamp(1.52rem, 1.95vw, 2.08rem);
  line-height: 1.06;
  letter-spacing: -0.036em;
  text-wrap: balance;
}

body.home-editorial-page h3 {
  font-size: 1.02rem;
}

body.home-editorial-page .lead,
body.home-editorial-page p,
body.home-editorial-page li {
  font-size: 0.95rem;
  line-height: 1.7;
}

body.home-editorial-page .page {
  padding-top: 20px;
}

body.home-editorial-page .nav-actions > .btn {
  display: none;
}

.home-editorial-hero,
.home-editorial-block,
.home-editorial-feature,
.home-editorial-closing {
  position: relative;
  border: 1px solid rgba(195, 208, 232, 0.84);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.97);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.home-editorial-hero,
.home-editorial-block,
.home-editorial-feature,
.home-editorial-closing {
  padding: 28px;
}

.home-editorial-hero::before,
.home-editorial-block::before,
.home-editorial-feature::before,
.home-editorial-closing::before {
  content: "";
  position: absolute;
  top: 0;
  left: 20px;
  right: 20px;
  height: 1px;
  background: linear-gradient(90deg, rgba(98, 126, 192, 0.28), transparent);
}

.home-editorial-hero {
  background:
    radial-gradient(circle at top left, rgba(209, 221, 255, 0.54), transparent 24%),
    radial-gradient(circle at top right, rgba(236, 228, 255, 0.52), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(248, 250, 255, 0.99) 100%);
}

.home-editorial-grid,
.home-thesis-layout,
.home-editorial-cards,
.home-standard-grid,
.home-no-grid {
  display: grid;
  gap: 14px;
}

.home-editorial-grid,
.home-thesis-layout {
  grid-template-columns: minmax(0, 1.1fr) minmax(290px, 0.9fr);
  align-items: start;
}

.home-editorial-secondary {
  margin-top: 12px;
}

.home-editorial-note,
.home-thesis-card,
.home-editorial-card,
.home-standard-card,
.home-no-card,
.home-editorial-closing {
  position: relative;
  border: 1px solid rgba(195, 208, 232, 0.84);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.home-editorial-note,
.home-editorial-closing {
  padding: 22px;
  border-radius: 24px;
}

.home-thesis-card,
.home-editorial-card,
.home-standard-card,
.home-no-card {
  padding: 18px;
  border-radius: 20px;
}

.home-editorial-note::before,
.home-thesis-card::before,
.home-editorial-card::before,
.home-standard-card::before,
.home-no-card::before,
.home-editorial-closing::before {
  content: "";
  position: absolute;
  top: 0;
  left: 18px;
  right: 18px;
  height: 1px;
  background: linear-gradient(90deg, rgba(98, 126, 192, 0.28), transparent);
}

.home-editorial-note {
  display: grid;
  gap: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,0.99) 0%, rgba(244,248,255,0.98) 100%);
}

.home-editorial-mini {
  display: grid;
  gap: 10px;
}

.home-editorial-mini article {
  display: grid;
  gap: 3px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(219, 228, 244, 0.76);
}

.home-editorial-mini article:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.home-editorial-mini span,
.home-thesis-card span,
.home-standard-card span {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #60729b;
}

.home-editorial-mini strong,
.home-thesis-card strong {
  color: var(--text);
}

.home-keyline-grid,
.home-standard-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.home-keyline-grid {
  display: none;
}

.home-thesis-copy {
  display: grid;
  gap: 14px;
}

.home-thesis-rail {
  display: grid;
  gap: 14px;
}

.home-thesis-card {
  display: grid;
  gap: 8px;
  padding-left: 22px;
}

.home-thesis-card::after,
.home-editorial-card::after,
.home-no-card::after {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: linear-gradient(180deg, rgba(47, 95, 232, 0.82), rgba(47, 95, 232, 0.12));
}

.home-thesis-card.violet::after,
.home-editorial-card.violet::after,
.home-no-card.violet::after {
  background: linear-gradient(180deg, rgba(123, 92, 255, 0.82), rgba(123, 92, 255, 0.12));
}

.home-thesis-card.mint::after,
.home-editorial-card.mint::after,
.home-no-card.mint::after {
  background: linear-gradient(180deg, rgba(31, 157, 116, 0.82), rgba(31, 157, 116, 0.12));
}

.home-thesis-card.amber::after,
.home-editorial-card.amber::after,
.home-no-card.amber::after {
  background: linear-gradient(180deg, rgba(217, 137, 43, 0.82), rgba(217, 137, 43, 0.12));
}

.home-editorial-cards,
.home-no-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.home-editorial-card,
.home-no-card {
  display: grid;
  gap: 10px;
  min-height: 100%;
  padding-left: 22px;
}

.home-standard-grid {
  margin-top: 8px;
}

.home-standard-card {
  display: grid;
  gap: 8px;
  min-height: 100%;
  background: linear-gradient(180deg, rgba(255,255,255,0.99) 0%, rgba(246,249,255,0.99) 100%);
}

.home-editorial-card h3,
.home-no-card h3,
.home-standard-card h3,
.home-editorial-note h3,
.home-editorial-closing h2 {
  margin-bottom: 0;
}

.home-editorial-card p,
.home-no-card p,
.home-standard-card p,
.home-editorial-note p,
.home-editorial-closing p,
.home-thesis-card p,
.home-thesis-copy p {
  margin-bottom: 0;
}

body.home-editorial-page .hero-actions,
body.home-editorial-page .home-mini-links {
  display: none;
}

@media (max-width: 1180px) {
  .home-editorial-grid,
  .home-thesis-layout,
  .home-editorial-cards,
  .home-standard-grid,
  .home-no-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .home-editorial-grid,
  .home-thesis-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  body.home-editorial-page h1 {
    font-size: clamp(1.72rem, 7vw, 2.45rem);
    max-width: 100%;
  }

  body.home-editorial-page h2 {
    font-size: clamp(1.38rem, 5vw, 1.85rem);
  }

  .home-editorial-cards,
  .home-standard-grid,
  .home-no-grid {
    grid-template-columns: 1fr;
  }

  .home-editorial-hero,
  .home-editorial-block,
  .home-editorial-feature,
  .home-editorial-closing,
  .home-editorial-note {
    padding: 22px;
  }
}

/* Home v4 */
body.home-v4 .container {
  width: min(1100px, calc(100% - 40px));
}

body.home-v4 h1 {
  font-size: clamp(1.76rem, 2.15vw, 2.58rem);
  line-height: 1.02;
  letter-spacing: -0.045em;
  max-width: 18.5ch;
  text-wrap: balance;
}

body.home-v4 h2 {
  font-size: clamp(1.46rem, 1.85vw, 1.98rem);
  line-height: 1.08;
  letter-spacing: -0.034em;
  text-wrap: balance;
}

body.home-v4 h3 {
  font-size: 1rem;
}

body.home-v4 .lead,
body.home-v4 p,
body.home-v4 li {
  font-size: 0.94rem;
  line-height: 1.7;
}

body.home-v4 .lead {
  max-width: 78ch;
}

body.home-v4 .page {
  padding-top: 18px;
}

body.home-v4 .tag-row {
  gap: 10px;
}

body.home-v4 .hero {
  padding-top: 8px;
}

body.home-v4 .section {
  padding: 16px 0;
}

.homev4-hero,
.homev4-panel {
  position: relative;
  border: 1px solid rgba(195, 208, 232, 0.84);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.homev4-hero,
.homev4-panel {
  padding: 30px;
}

.homev4-hero::before,
.homev4-panel::before {
  content: "";
  position: absolute;
  top: 0;
  left: 20px;
  right: 20px;
  height: 1px;
  background: linear-gradient(90deg, rgba(98, 126, 192, 0.28), transparent);
}

.homev4-hero {
  background:
    radial-gradient(circle at top left, rgba(209, 221, 255, 0.55), transparent 24%),
    radial-gradient(circle at top right, rgba(236, 228, 255, 0.5), transparent 24%),
    linear-gradient(180deg, rgba(255,255,255,0.99) 0%, rgba(248,250,255,0.99) 100%);
}

.homev4-sublead {
  margin-top: 12px;
}

.homev4-hero-grid,
.homev4-grid-2,
.homev4-grid-3,
.homev4-grid-4,
.homev4-routes,
.homev4-split {
  display: grid;
  gap: 14px;
}

.homev4-hero-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 22px;
}

.homev4-split {
  grid-template-columns: minmax(0, 1.08fr) minmax(285px, 0.92fr);
  align-items: start;
}

.homev4-grid-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.homev4-grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.homev4-grid-4,
.homev4-routes {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.homev4-hero-card,
.homev4-card,
.homev4-side-card,
.homev4-long-card,
.homev4-no-card,
.homev4-route-card {
  position: relative;
  border: 1px solid rgba(195, 208, 232, 0.84);
  background: rgba(255,255,255,0.96);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.homev4-hero-card,
.homev4-card,
.homev4-side-card,
.homev4-long-card,
.homev4-no-card,
.homev4-route-card {
  display: grid;
  gap: 10px;
  min-height: 100%;
  padding: 18px;
  border-radius: 22px;
}

.homev4-hero-card::before,
.homev4-card::before,
.homev4-side-card::before,
.homev4-long-card::before,
.homev4-no-card::before,
.homev4-route-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 18px;
  right: 18px;
  height: 1px;
  background: linear-gradient(90deg, rgba(98, 126, 192, 0.28), transparent);
}

.homev4-hero-card::after,
.homev4-card::after,
.homev4-long-card::after,
.homev4-no-card::after,
.homev4-route-card::after {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: linear-gradient(180deg, rgba(47,95,232,0.82), rgba(47,95,232,0.12));
}

.homev4-hero-card.violet::after,
.homev4-card.violet::after,
.homev4-long-card.violet::after,
.homev4-no-card.violet::after,
.homev4-route-card.violet::after {
  background: linear-gradient(180deg, rgba(123,92,255,0.82), rgba(123,92,255,0.12));
}

.homev4-hero-card.mint::after,
.homev4-card.mint::after,
.homev4-long-card.mint::after,
.homev4-no-card.mint::after,
.homev4-route-card.mint::after {
  background: linear-gradient(180deg, rgba(31,157,116,0.82), rgba(31,157,116,0.12));
}

.homev4-hero-card.amber::after,
.homev4-card.amber::after,
.homev4-long-card.amber::after,
.homev4-no-card.amber::after,
.homev4-route-card.amber::after {
  background: linear-gradient(180deg, rgba(217,137,43,0.82), rgba(217,137,43,0.12));
}

.homev4-mini-label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #60729b;
}

.homev4-hero-card strong,
.homev4-side-card strong,
.homev4-card h3,
.homev4-long-card h3,
.homev4-no-card h3,
.homev4-route-card h3 {
  margin-bottom: 0;
}

.homev4-hero-card p,
.homev4-card p,
.homev4-side-card p,
.homev4-long-card p,
.homev4-no-card p,
.homev4-route-card p {
  margin-bottom: 0;
}

.homev4-side-stack {
  display: grid;
  gap: 14px;
}

.homev4-route-card .company-actions {
  margin-top: auto;
}

.homev4-soft {
  background: linear-gradient(180deg, rgba(255,255,255,0.99) 0%, rgba(246,249,255,0.99) 100%);
}

@media (max-width: 1180px) {
  .homev4-hero-grid,
  .homev4-grid-2,
  .homev4-grid-3,
  .homev4-grid-4,
  .homev4-routes,
  .homev4-split {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .homev4-split {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  body.home-v4 h1 {
    font-size: clamp(1.68rem, 7vw, 2.32rem);
    max-width: 100%;
  }

  body.home-v4 h2 {
    font-size: clamp(1.34rem, 5vw, 1.8rem);
  }

  .homev4-hero-grid,
  .homev4-grid-2,
  .homev4-grid-3,
  .homev4-grid-4,
  .homev4-routes {
    grid-template-columns: 1fr;
  }

  .homev4-hero,
  .homev4-panel {
    padding: 22px;
  }
}

/* Home v5 */
body.home-v5 .container {
  width: min(1180px, calc(100% - 40px));
}

body.home-v5 h1 {
  font-size: clamp(2rem, 2.55vw, 3.12rem);
  line-height: 0.99;
  letter-spacing: -0.05em;
  max-width: 20ch;
  text-wrap: balance;
}

body.home-v5 h2 {
  font-size: clamp(1.52rem, 2.02vw, 2.18rem);
  line-height: 1.06;
  letter-spacing: -0.038em;
  text-wrap: balance;
}

body.home-v5 h3 {
  font-size: 1.04rem;
}

body.home-v5 .lead,
body.home-v5 p,
body.home-v5 li {
  font-size: 0.95rem;
  line-height: 1.7;
}

body.home-v5 .lead {
  max-width: 96ch;
  color: #4f617c;
}

body.home-v5 p,
body.home-v5 li {
  color: #5d6f8d;
}

body.home-v5 .page {
  padding-top: 18px;
}

body.home-v5 .section {
  padding: 16px 0;
}

.homev5-hero,
.homev5-panel {
  position: relative;
  border: 1px solid rgba(195, 208, 232, 0.84);
  border-radius: 30px;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.homev5-hero,
.homev5-panel {
  padding: 30px;
}

.homev5-hero::before,
.homev5-panel::before {
  content: "";
  position: absolute;
  top: 0;
  left: 20px;
  right: 20px;
  height: 1px;
  background: linear-gradient(90deg, rgba(98, 126, 192, 0.28), transparent);
}

.homev5-hero {
  background:
    radial-gradient(circle at top left, rgba(209, 221, 255, 0.56), transparent 24%),
    radial-gradient(circle at top right, rgba(236, 228, 255, 0.48), transparent 24%),
    linear-gradient(180deg, rgba(255,255,255,0.99) 0%, rgba(248,250,255,0.99) 100%);
}

.homev5-top,
.homev5-band,
.homev5-split,
.homev5-grid-2,
.homev5-grid-3,
.homev5-grid-4,
.homev5-routes {
  display: grid;
  gap: 14px;
}

.homev5-top,
.homev5-split {
  grid-template-columns: minmax(0, 1.22fr) minmax(310px, 0.78fr);
  align-items: start;
}

.homev5-copy {
  display: grid;
  gap: 12px;
}

.homev5-sublead {
  margin-top: 4px;
}

.homev5-aside,
.homev5-side-card,
.homev5-band-card,
.homev5-card,
.homev5-long-card,
.homev5-route-card {
  position: relative;
  border: 1px solid rgba(195, 208, 232, 0.84);
  background: rgba(255,255,255,0.96);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.homev5-aside {
  display: grid;
  gap: 14px;
  padding: 22px;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255,255,255,0.99) 0%, rgba(244,248,255,0.98) 100%);
}

.homev5-side-card,
.homev5-band-card,
.homev5-card,
.homev5-long-card,
.homev5-route-card {
  display: grid;
  gap: 10px;
  min-height: 100%;
  padding: 18px;
  border-radius: 22px;
}

.homev5-aside::before,
.homev5-side-card::before,
.homev5-band-card::before,
.homev5-card::before,
.homev5-long-card::before,
.homev5-route-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 18px;
  right: 18px;
  height: 1px;
  background: linear-gradient(90deg, rgba(98, 126, 192, 0.28), transparent);
}

.homev5-mini-stack {
  display: grid;
  gap: 10px;
}

.homev5-mini-stack article {
  display: grid;
  gap: 3px;
  padding: 11px 0;
  border-bottom: 1px solid rgba(219, 228, 244, 0.76);
}

.homev5-mini-stack article:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.homev5-mini-stack span,
.homev5-mini-label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #60729b;
}

.homev5-mini-stack strong,
.homev5-band-card strong,
.homev5-side-card strong {
  color: var(--text);
}

.homev5-band {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 20px;
}

.homev5-grid-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.homev5-grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.homev5-grid-4,
.homev5-routes {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.homev5-band-card,
.homev5-card,
.homev5-long-card,
.homev5-route-card {
  padding-left: 22px;
}

.homev5-band-card::after,
.homev5-card::after,
.homev5-long-card::after,
.homev5-route-card::after {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: linear-gradient(180deg, rgba(47,95,232,0.82), rgba(47,95,232,0.12));
}

.homev5-band-card.violet::after,
.homev5-card.violet::after,
.homev5-long-card.violet::after,
.homev5-route-card.violet::after {
  background: linear-gradient(180deg, rgba(123,92,255,0.82), rgba(123,92,255,0.12));
}

.homev5-band-card.mint::after,
.homev5-card.mint::after,
.homev5-long-card.mint::after,
.homev5-route-card.mint::after {
  background: linear-gradient(180deg, rgba(31,157,116,0.82), rgba(31,157,116,0.12));
}

.homev5-band-card.amber::after,
.homev5-card.amber::after,
.homev5-long-card.amber::after,
.homev5-route-card.amber::after {
  background: linear-gradient(180deg, rgba(217,137,43,0.82), rgba(217,137,43,0.12));
}

.homev5-side-grid {
  display: grid;
  gap: 14px;
}

.homev5-rich-copy {
  display: grid;
  gap: 14px;
}

.homev5-route-card .company-actions {
  margin-top: auto;
}

.homev5-soft {
  background: linear-gradient(180deg, rgba(255,255,255,0.99) 0%, rgba(246,249,255,0.99) 100%);
}

.homev5-band-card h3,
.homev5-card h3,
.homev5-long-card h3,
.homev5-route-card h3,
.homev5-aside h3,
.homev5-side-card h3 {
  margin-bottom: 0;
}

.homev5-band-card p,
.homev5-card p,
.homev5-long-card p,
.homev5-route-card p,
.homev5-aside p,
.homev5-side-card p {
  margin-bottom: 0;
}

@media (max-width: 1180px) {
  .homev5-top,
  .homev5-split,
  .homev5-band,
  .homev5-grid-2,
  .homev5-grid-3,
  .homev5-grid-4,
  .homev5-routes {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .homev5-top,
  .homev5-split {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  body.home-v5 h1 {
    font-size: clamp(1.72rem, 7vw, 2.45rem);
    max-width: 100%;
  }

  body.home-v5 h2 {
    font-size: clamp(1.34rem, 5vw, 1.82rem);
  }

  .homev5-band,
  .homev5-grid-2,
  .homev5-grid-3,
  .homev5-grid-4,
  .homev5-routes {
    grid-template-columns: 1fr;
  }

  .homev5-hero,
  .homev5-panel {
    padding: 22px;
  }
}

/* Home v5 layout fixes */
body.home-v5 .container {
  width: min(1200px, calc(100% - 40px));
}

body.home-v5 .homev5-top {
  grid-template-columns: 1fr;
  gap: 0;
  width: 100%;
}

body.home-v5 .homev5-copy,
body.home-v5 .homev5-rich-copy {
  width: 100%;
  max-width: none;
}

body.home-v5 .homev5-copy .lead {
  max-width: 60ch;
}

body.home-v5 .homev5-copy .homev5-sublead {
  max-width: 58ch;
}

body.home-v5 .homev5-copy > *,
body.home-v5 .homev5-rich-copy > * {
  max-width: none;
}

body.home-v5 h1 {
  max-width: 19ch;
}

body.home-v5 .lead {
  max-width: none;
}

body.home-v5 .homev5-hero,
body.home-v5 .homev5-panel {
  padding: 32px;
}

body.home-v5 .homev5-band,
body.home-v5 .homev5-grid-2,
body.home-v5 .homev5-grid-3,
body.home-v5 .homev5-grid-4,
body.home-v5 .homev5-routes {
  gap: 16px;
}

body.home-v5 .homev5-band {
  margin-top: 22px;
}

body.home-v5 .homev5-split {
  grid-template-columns: minmax(0, 1.34fr) minmax(320px, 0.66fr);
  gap: 18px;
}

body.home-v5 .homev5-side-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

body.home-v5 .homev5-band-card,
body.home-v5 .homev5-card,
body.home-v5 .homev5-long-card,
body.home-v5 .homev5-route-card,
body.home-v5 .homev5-side-card {
  box-shadow: 0 16px 34px rgba(28, 48, 86, 0.06);
}

@media (max-width: 1180px) {
  body.home-v5 .homev5-split {
    grid-template-columns: 1fr;
  }

  body.home-v5 .homev5-side-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  body.home-v5 .homev5-side-grid {
    grid-template-columns: 1fr;
  }

  body.home-v5 .homev5-hero,
  body.home-v5 .homev5-panel {
    padding: 22px;
  }
}

/* Remove old home split after deleting side cards */
body.home-v5 .homev5-split {
  grid-template-columns: 1fr !important;
}

body.home-v5 .homev5-rich-copy,
body.home-v5 .homev5-rich-copy p {
  max-width: none !important;
  width: 100%;
}

body.home-v5 .homev5-hero-actions {
  margin-top: 6px;
}

body.home-v5 .homev5-hero-points {
  margin-top: 18px;
}

body.home-v5 .homev5-process-panel {
  position: relative;
  overflow: hidden;
  border-radius: 32px;
  border: 1px solid rgba(211, 219, 233, 0.92);
  background: linear-gradient(180deg, rgba(255,255,255,0.995) 0%, rgba(247,249,253,0.99) 100%);
  box-shadow: 0 24px 56px rgba(15, 23, 42, 0.06);
}

body.home-v5 .homev5-process-panel::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.82) 0%, rgba(255,255,255,0) 46%, rgba(235, 240, 248, 0.42) 100%);
  pointer-events: none;
}

body.home-v5 .homev5-process-panel > * {
  position: relative;
  z-index: 1;
}

body.home-v5 .homev5-process-panel .section-heading {
  max-width: 46rem;
  margin-bottom: 2px;
}

body.home-v5 .homev5-process-panel .section-heading p {
  max-width: 40rem;
}

body.home-v5 .homev5-process-track {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-top: 14px;
  padding-top: 30px;
  align-items: start;
  grid-auto-rows: min-content;
}

body.home-v5 .homev5-process-track::before {
  content: "";
  position: absolute;
  top: 10px;
  left: 28px;
  right: 28px;
  height: 1px;
  border-radius: 999px;
  background: linear-gradient(
    90deg,
    rgba(164, 177, 201, 0.12) 0%,
    rgba(129, 145, 176, 0.62) 18%,
    rgba(175, 187, 209, 0.56) 50%,
    rgba(129, 145, 176, 0.62) 82%,
    rgba(164, 177, 201, 0.12) 100%
  );
}

body.home-v5 .homev5-process-track > .homev5-process-step {
  --process-accent: #3558b8;
  --process-accent-soft: rgba(53, 88, 184, 0.12);
  --process-edge: rgba(210, 218, 232, 0.92);
  position: relative;
  isolation: isolate;
  align-self: start;
  display: grid !important;
  grid-template-rows: auto auto;
  align-content: start;
  justify-items: start;
  width: 100%;
  height: auto !important;
  min-height: 0 !important;
  gap: 10px;
  overflow: visible;
  padding: 14px 16px 16px 18px;
  border-radius: 22px;
  border: 1px solid var(--process-edge);
  background: linear-gradient(180deg, rgba(255,255,255,0.998) 0%, rgba(249,250,252,0.992) 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.92), 0 14px 28px rgba(15, 23, 42, 0.045);
}

body.home-v5 .homev5-process-track > .homev5-process-step > * {
  position: relative;
  z-index: 1;
}

body.home-v5 .homev5-process-track > .homev5-process-step::before {
  content: "";
  position: absolute;
  top: -26px;
  left: 24px;
  width: 11px;
  height: 11px;
  border-radius: 999px;
  background: var(--process-accent);
  box-shadow: 0 0 0 5px rgba(255,255,255,0.99), 0 0 0 8px rgba(228, 234, 244, 0.9);
}

body.home-v5 .homev5-process-track > .homev5-process-step::after {
  content: "";
  position: absolute;
  inset: 14px auto 14px 0;
  width: 3px;
  border-radius: 0 999px 999px 0;
  background: linear-gradient(180deg, var(--process-accent) 0%, var(--process-accent-soft) 100%);
}

body.home-v5 .homev5-process-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  width: 100%;
}

body.home-v5 .homev5-process-body {
  display: grid;
  gap: 6px;
  align-content: start;
  width: 100%;
}

body.home-v5 .homev5-process-index {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 28px;
  padding: 0 11px;
  border-radius: 999px;
  border: 1px solid rgba(208, 216, 229, 0.96);
  background: rgba(255,255,255,0.98);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.96);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #5a6986;
}

body.home-v5 .homev5-process-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 12px;
  border: 1px solid rgba(208, 216, 229, 0.94);
  background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(247,249,252,0.98) 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.96);
  color: var(--process-accent);
}

body.home-v5 .homev5-process-icon svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

body.home-v5 .homev5-process-meta {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: #7a879f;
}

body.home-v5 .homev5-process-body h3,
body.home-v5 .homev5-process-body p {
  margin: 0;
}

body.home-v5 .homev5-process-body h3 {
  font-size: 1.08rem;
  line-height: 1.14;
  color: #142033;
}

body.home-v5 .homev5-process-body p {
  max-width: none;
  font-size: 0.92rem;
  line-height: 1.52;
  color: #5e6f8d;
}

body.home-v5 .homev5-process-step.blue {
  --process-accent: #3158c4;
}

body.home-v5 .homev5-process-step.violet {
  --process-accent: #6357bc;
}

body.home-v5 .homev5-process-step.mint {
  --process-accent: #1f7f66;
}

body.home-v5 .homev5-process-step.amber {
  --process-accent: #a87537;
}

@media (max-width: 1180px) {
  body.home-v5 .homev5-process-track {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  body.home-v5 .homev5-process-track {
    grid-template-columns: 1fr;
    gap: 14px;
    margin-top: 8px;
    padding-top: 14px;
  }

  body.home-v5 .homev5-process-track::before {
    display: none;
  }

  body.home-v5 .homev5-process-track > .homev5-process-step {
    padding: 16px 17px 16px 18px;
  }

  body.home-v5 .homev5-process-track > .homev5-process-step::before {
    display: none;
  }
}

body.home-v5 .group-order-panel {
  box-shadow: var(--shadow-md);
}

body.home-v5 .group-order-grid {
  align-items: stretch;
}

body.home-v5 .group-order-card {
  min-height: 100%;
}

body.home-v5 .group-order-card .homev5-mini-label {
  margin-bottom: 2px;
}

body.about-page .about-founder-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.14fr) minmax(280px, 0.86fr);
  gap: 18px;
  align-items: start;
}

body.about-page .section {
  padding: 14px 0;
}

body.about-page .about-founder-card {
  box-shadow: 0 18px 38px rgba(18, 33, 68, 0.06);
}

body.about-page .about-founder-card h3 {
  font-size: clamp(1.18rem, 1.6vw, 1.42rem);
  line-height: 1.12;
}

body.about-page .about-founder-role {
  margin: -4px 0 2px;
  color: #5f718f;
  font-size: 0.94rem;
  line-height: 1.68;
}

body.about-page .about-founder-card .homev5-mini-stack {
  margin-top: 4px;
}

body.about-page .about-founder-card .homev5-mini-stack article {
  padding: 12px 0;
}

body.about-page .homev5-rich-copy strong {
  color: var(--text);
}

body.home-v5 .nav-menu {
  gap: 10px;
}

body.home-v5 .nav-link {
  position: relative;
  padding: 12px 10px 14px;
  border-radius: 0;
  background: transparent !important;
  color: #667892;
}

body.home-v5 .nav-link::after {
  content: "";
  position: absolute;
  left: 10px;
  right: 10px;
  bottom: 6px;
  height: 1px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(98, 126, 192, 0.08), rgba(98, 126, 192, 0.54), rgba(98, 126, 192, 0.08));
  opacity: 0;
  transform: scaleX(0.45);
  transform-origin: center;
  transition: opacity 0.18s ease, transform 0.18s ease;
}

body.home-v5 .nav-link:hover {
  color: #152944;
  transform: translateY(-1px);
}

body.home-v5 .nav-link:hover::after,
body.home-v5 .nav-link.is-active::after {
  opacity: 1;
  transform: scaleX(1);
}

body.home-v5 .nav-link.is-active {
  color: var(--text);
}

body.home-v5 .homev5-card,
body.home-v5 .homev5-band-card,
body.home-v5 .homev5-long-card,
body.home-v5 .homev5-route-card,
body.home-v5 .homev5-side-card {
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

body.home-v5 .homev5-card:hover,
body.home-v5 .homev5-band-card:hover,
body.home-v5 .homev5-long-card:hover,
body.home-v5 .homev5-route-card:hover,
body.home-v5 .homev5-side-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 38px rgba(18, 33, 68, 0.07) !important;
  border-color: rgba(186, 199, 226, 0.96);
}

body.home-v5 .homev5-panel-eyebrow {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 32px;
  padding: 0 12px;
  margin-bottom: 12px;
  border-radius: 999px;
  border: 1px solid rgba(205, 214, 230, 0.92);
  background: rgba(255, 255, 255, 0.88);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: #64779b;
}

body.home-v5 .homev5-card-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 2px;
}

body.home-v5 .homev5-card-meta {
  display: grid;
  gap: 6px;
}

body.home-v5 .homev5-card-kicker {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  font-size: 0.69rem;
  font-weight: 800;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: #6f82a3;
}

body.home-v5 .homev5-card-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  flex: 0 0 auto;
  border-radius: 12px;
  border: 1px solid rgba(205, 214, 230, 0.92);
  background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(246,249,253,0.96) 100%);
  color: #5f77ac;
}

body.home-v5 .homev5-card-icon svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

body.home-v5 .homev5-card-list {
  list-style: none;
  display: grid;
  gap: 8px;
  padding: 0;
  margin: 2px 0 0;
}

body.home-v5 .homev5-card-list li {
  position: relative;
  padding-left: 15px;
  font-size: 0.9rem;
  line-height: 1.62;
  color: #5f708d;
}

body.home-v5 .homev5-card-list li::before {
  content: "";
  position: absolute;
  top: 0.72em;
  left: 0;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: rgba(98, 126, 192, 0.72);
}

body.home-v5 .status-pill.base {
  background: rgba(234, 241, 255, 0.98);
  border-color: rgba(182, 198, 229, 0.96);
  color: #355aa4;
}

body.home-v5 .status-pill.soon {
  background: rgba(245, 241, 255, 0.98);
  border-color: rgba(210, 198, 239, 0.96);
  color: #6758b9;
}

body.home-v5 .status-pill.strategic {
  background: rgba(255, 247, 235, 0.99);
  border-color: rgba(232, 205, 164, 0.96);
  color: #98692b;
}

body.home-v5 .status-pill.current {
  background: rgba(235, 250, 244, 0.98);
  border-color: rgba(182, 224, 204, 0.96);
  color: #216d58;
}

body.home-v5 .homev5-section-divider {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 4px 0 10px;
}

body.home-v5 .homev5-section-divider::before,
body.home-v5 .homev5-section-divider::after {
  content: "";
  flex: 1 1 auto;
  height: 1px;
  background: linear-gradient(90deg, rgba(182, 195, 221, 0.16), rgba(129, 145, 176, 0.78), rgba(182, 195, 221, 0.16));
}

body.home-v5 .homev5-section-divider span {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(205, 214, 230, 0.92);
  background: rgba(255,255,255,0.9);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: #7083a5;
}

body.home-v5 .homev5-reading-rail {
  position: relative;
  display: grid;
  gap: 12px;
  padding-left: 22px;
}

body.home-v5 .homev5-reading-rail::before {
  content: "";
  position: absolute;
  top: 4px;
  bottom: 4px;
  left: 0;
  width: 1px;
  background: linear-gradient(180deg, rgba(129, 145, 176, 0.16), rgba(129, 145, 176, 0.7), rgba(129, 145, 176, 0.16));
}

body.home-v5 .homev5-reading-rail > * {
  margin-bottom: 0;
}

body.home-v5 .homev5-master-card {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1.14fr) minmax(280px, 0.86fr);
  gap: 22px;
  padding: 28px;
  border-radius: 30px;
  border: 1px solid rgba(206, 215, 233, 0.96);
  background: linear-gradient(180deg, rgba(255,255,255,0.995) 0%, rgba(247,249,253,0.992) 100%);
  box-shadow: 0 22px 48px rgba(15, 23, 42, 0.055);
}

body.home-v5 .homev5-master-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at top right, rgba(228, 235, 249, 0.56), transparent 26%), linear-gradient(135deg, rgba(255,255,255,0.74) 0%, rgba(255,255,255,0) 44%);
  pointer-events: none;
}

body.home-v5 .homev5-master-card > * {
  position: relative;
  z-index: 1;
}

body.home-v5 .homev5-master-copy {
  display: grid;
  gap: 12px;
  align-content: start;
}

body.home-v5 .homev5-master-copy h2,
body.home-v5 .homev5-master-copy h3,
body.home-v5 .homev5-master-copy p {
  margin-bottom: 0;
}

body.home-v5 .homev5-master-lead {
  max-width: 24ch;
  font-size: clamp(1.18rem, 1.7vw, 1.7rem);
  line-height: 1.28;
  color: #12213a;
}

body.home-v5 .homev5-master-side {
  display: grid;
  gap: 12px;
  align-content: start;
  padding-left: 22px;
  border-left: 1px solid rgba(209, 217, 232, 0.92);
}

body.home-v5 .homev5-master-note {
  font-size: 0.93rem;
  line-height: 1.7;
  color: #60718d;
}

body.home-v5 .homev5-master-points {
  list-style: none;
  display: grid;
  gap: 0;
  margin: 0;
  padding: 0;
}

body.home-v5 .homev5-master-points li {
  display: grid;
  gap: 3px;
  padding: 12px 0;
  border-top: 1px solid rgba(214, 221, 234, 0.92);
}

body.home-v5 .homev5-master-points li:first-child {
  border-top: 0;
  padding-top: 0;
}

body.home-v5 .homev5-master-points span {
  font-size: 0.69rem;
  font-weight: 800;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: #7083a5;
}

body.home-v5 .homev5-master-points strong {
  color: var(--text);
  line-height: 1.5;
}

body.home-v5 .homev5-master-card.statement .homev5-master-lead {
  max-width: 19ch;
  font-size: clamp(1.42rem, 2.15vw, 2rem);
  line-height: 1.12;
  letter-spacing: -0.03em;
}

body.home-v5 .homev5-master-card.statement .homev5-master-side {
  gap: 14px;
}

body.home-v5 .homev5-card,
body.home-v5 .homev5-route-card,
body.home-v5 .homev5-band-card,
body.home-v5 .homev5-long-card,
body.home-v5 .homev5-side-card,
body.home-v5 .homev5-ecosystem-node,
body.home-v5 .homev5-principle-card,
body.home-v5 .homev5-principle-hero {
  position: relative;
}

body.home-v5 .homev5-card::after,
body.home-v5 .homev5-route-card::after,
body.home-v5 .homev5-band-card::after,
body.home-v5 .homev5-long-card::after,
body.home-v5 .homev5-side-card::after,
body.home-v5 .homev5-ecosystem-node::after,
body.home-v5 .homev5-principle-card::after,
body.home-v5 .homev5-principle-hero::after {
  content: "";
  position: absolute;
  top: 0;
  left: 18px;
  right: 18px;
  height: 1px;
  background: linear-gradient(90deg, rgba(98, 126, 192, 0.02), rgba(98, 126, 192, 0.52), rgba(98, 126, 192, 0.02));
  opacity: 0;
  transform: scaleX(0.35);
  transform-origin: center;
  transition: opacity 0.22s ease, transform 0.22s ease;
}

body.home-v5 .homev5-card:hover::after,
body.home-v5 .homev5-route-card:hover::after,
body.home-v5 .homev5-band-card:hover::after,
body.home-v5 .homev5-long-card:hover::after,
body.home-v5 .homev5-side-card:hover::after,
body.home-v5 .homev5-ecosystem-node:hover::after,
body.home-v5 .homev5-principle-card:hover::after,
body.home-v5 .homev5-principle-hero:hover::after {
  opacity: 1;
  transform: scaleX(1);
}

body.home-v5 .homev5-card-icon {
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease, background 0.22s ease;
}

body.home-v5 .homev5-card:hover .homev5-card-icon,
body.home-v5 .homev5-route-card:hover .homev5-card-icon,
body.home-v5 .homev5-band-card:hover .homev5-card-icon,
body.home-v5 .homev5-ecosystem-node:hover .homev5-card-icon,
body.home-v5 .homev5-principle-card:hover .homev5-card-icon,
body.home-v5 .homev5-principle-hero:hover .homev5-card-icon,
body.home-v5 .about-founder-card:hover .homev5-card-icon {
  transform: translateY(-1px) scale(1.04);
  border-color: rgba(176, 193, 226, 0.98);
  box-shadow: 0 12px 26px rgba(47, 95, 232, 0.08);
}

body.home-v5 .homev5-ecosystem-map {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-template-rows: repeat(3, auto);
  gap: 16px 18px;
  margin-top: 18px;
  padding: 22px 0;
  align-items: stretch;
}

body.home-v5 .homev5-ecosystem-map::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 12%;
  right: 12%;
  height: 1px;
  transform: translateY(-50%);
  background: linear-gradient(90deg, rgba(172, 184, 206, 0.16), rgba(129, 145, 176, 0.8), rgba(172, 184, 206, 0.16));
}

body.home-v5 .homev5-ecosystem-map::after {
  content: "";
  position: absolute;
  top: 14%;
  bottom: 14%;
  left: 50%;
  width: 1px;
  transform: translateX(-50%);
  background: linear-gradient(180deg, rgba(172, 184, 206, 0.16), rgba(129, 145, 176, 0.8), rgba(172, 184, 206, 0.16));
}

body.home-v5 .homev5-ecosystem-core,
body.home-v5 .homev5-ecosystem-node {
  position: relative;
  z-index: 1;
}

body.home-v5 .homev5-ecosystem-core {
  grid-column: 2;
  grid-row: 2;
  display: grid;
  gap: 12px;
  align-content: start;
  padding: 26px 24px;
  border-radius: 30px;
  border: 1px solid rgba(204, 214, 232, 0.96);
  background: linear-gradient(180deg, rgba(255,255,255,0.998) 0%, rgba(247,249,253,0.99) 100%);
  box-shadow: 0 22px 46px rgba(15, 23, 42, 0.06);
  text-align: center;
}

body.home-v5 .homev5-ecosystem-core h3,
body.home-v5 .homev5-ecosystem-core p {
  margin-bottom: 0;
}

body.home-v5 .homev5-ecosystem-core h3 {
  font-size: 1.36rem;
  line-height: 1.08;
}

body.home-v5 .homev5-ecosystem-meta {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
}

body.home-v5 .homev5-ecosystem-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid rgba(208, 216, 229, 0.94);
  background: rgba(255,255,255,0.98);
  font-size: 0.72rem;
  font-weight: 700;
  color: #657791;
}

body.home-v5 .homev5-ecosystem-node {
  display: grid;
  gap: 8px;
  align-content: start;
  padding: 18px;
  border-radius: 22px;
  border: 1px solid rgba(208, 216, 229, 0.94);
  background: rgba(255,255,255,0.98);
  box-shadow: var(--shadow-sm);
}

body.home-v5 .homev5-ecosystem-node h3,
body.home-v5 .homev5-ecosystem-node p {
  margin-bottom: 0;
}

body.home-v5 .homev5-ecosystem-node.top { grid-column: 2; grid-row: 1; }
body.home-v5 .homev5-ecosystem-node.left { grid-column: 1; grid-row: 2; }
body.home-v5 .homev5-ecosystem-node.right { grid-column: 3; grid-row: 2; }
body.home-v5 .homev5-ecosystem-node.bottom { grid-column: 2; grid-row: 3; }

body.home-v5 .homev5-ecosystem-node .status-pill {
  width: fit-content;
}

body.home-v5 .homev5-ecosystem-node p .status-pill {
  min-height: 24px;
  padding: 0 8px;
  font-size: 0.63rem;
  vertical-align: middle;
}

body.home-v5 .homev5-principles-board {
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: 18px;
  align-items: stretch;
}

body.home-v5 .homev5-principle-hero,
body.home-v5 .homev5-principle-card {
  display: grid;
  gap: 12px;
  align-content: start;
  min-height: 100%;
  padding: 22px;
  border-radius: 24px;
  border: 1px solid rgba(208, 216, 229, 0.94);
  background: rgba(255,255,255,0.98);
  box-shadow: var(--shadow-sm);
}

body.home-v5 .homev5-principle-hero {
  background: linear-gradient(180deg, rgba(255,255,255,0.998) 0%, rgba(247,249,253,0.99) 100%);
}

body.home-v5 .homev5-principle-hero h3 {
  font-size: clamp(1.3rem, 1.9vw, 1.86rem);
  line-height: 1.1;
  margin-bottom: 0;
}

body.home-v5 .homev5-principle-hero p,
body.home-v5 .homev5-principle-card p {
  margin-bottom: 0;
}

body.home-v5 .homev5-ceo-card h2 {
  max-width: none;
  font-size: clamp(1.6rem, 2.2vw, 2.42rem);
  line-height: 1.02;
}

body.home-v5 .homev5-node-grid {
  position: relative;
  display: grid;
  gap: 16px;
  margin-top: 18px;
  padding-top: 30px;
  align-items: start;
}

body.home-v5 .homev5-node-grid::before {
  content: "";
  position: absolute;
  top: 10px;
  left: 28px;
  right: 28px;
  height: 1px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(172, 184, 206, 0.12) 0%, rgba(129, 145, 176, 0.62) 18%, rgba(175, 187, 209, 0.56) 50%, rgba(129, 145, 176, 0.62) 82%, rgba(172, 184, 206, 0.12) 100%);
}

body.home-v5 .homev5-node-grid.cols-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body.home-v5 .homev5-node-grid.cols-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

body.home-v5 .homev5-node-card {
  --node-accent: #3158c4;
  position: relative;
  align-self: start;
  overflow: visible;
}

body.home-v5 .homev5-node-card::before {
  content: "";
  position: absolute;
  top: -25px;
  left: 24px;
  width: 11px;
  height: 11px;
  border-radius: 999px;
  background: var(--node-accent);
  box-shadow: 0 0 0 5px rgba(255,255,255,0.99), 0 0 0 8px rgba(228, 234, 244, 0.9);
}

body.home-v5 .homev5-node-card.blue {
  --node-accent: #3158c4;
}

body.home-v5 .homev5-node-card.violet {
  --node-accent: #6357bc;
}

body.home-v5 .homev5-node-card.mint {
  --node-accent: #1f7f66;
}

body.home-v5 .homev5-node-card.amber {
  --node-accent: #a87537;
}

body.home-v5 .homev5-node-card .tag,
body.home-v5 .homev5-node-card .status-pill {
  min-height: 30px;
  padding: 0 11px;
  font-size: 0.7rem;
}

body.home-v5 .footer {
  padding: 32px 0 52px;
}

body.home-v5 .footer-shell {
  grid-template-columns: minmax(0, 1.35fr) minmax(170px, 0.75fr) minmax(170px, 0.75fr);
  gap: 20px 34px;
  align-items: start;
  padding-top: 28px;
}

body.home-v5 .footer-brand {
  display: grid;
  gap: 10px;
  max-width: 34rem;
}

body.home-v5 .footer-brand strong {
  font-size: 0.74rem;
  letter-spacing: 0.18em;
  color: #627494;
}

body.home-v5 .footer-note {
  margin: 0;
  color: #677892;
  font-size: 0.92rem;
  line-height: 1.72;
}

body.home-v5 .footer-column {
  display: grid;
  gap: 10px;
  align-content: start;
}

body.home-v5 .footer-heading {
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #7a8ca8;
}

body.home-v5 .footer-links {
  display: grid;
  gap: 8px;
  align-items: start;
}

body.home-v5 .footer-links a {
  position: relative;
  width: fit-content;
  color: #60728f;
}

body.home-v5 .footer-links a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -2px;
  height: 1px;
  background: rgba(98, 126, 192, 0.34);
  opacity: 0;
  transform: scaleX(0.4);
  transform-origin: left;
  transition: opacity 0.18s ease, transform 0.18s ease;
}

body.home-v5 .footer-links a:hover::after {
  opacity: 1;
  transform: scaleX(1);
}

body.home-v5 .footer-bottom {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 12px;
  padding-top: 10px;
  border-top: 1px solid rgba(205, 214, 230, 0.9);
  color: #7586a2;
  font-size: 0.85rem;
}

@media (max-width: 1180px) {
  body.home-v5 .homev5-master-card,
  body.about-page .about-founder-grid {
    grid-template-columns: 1fr;
  }

  body.home-v5 .homev5-master-side {
    padding-left: 0;
    padding-top: 18px;
    border-left: 0;
    border-top: 1px solid rgba(209, 217, 232, 0.92);
  }

  body.home-v5 .homev5-ecosystem-map {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: auto;
    padding: 8px 0 0;
  }

  body.home-v5 .homev5-ecosystem-map::before,
  body.home-v5 .homev5-ecosystem-map::after {
    display: none;
  }

  body.home-v5 .homev5-ecosystem-core {
    grid-column: 1 / -1;
    grid-row: auto;
  }

  body.home-v5 .homev5-ecosystem-node.top,
  body.home-v5 .homev5-ecosystem-node.left,
  body.home-v5 .homev5-ecosystem-node.right,
  body.home-v5 .homev5-ecosystem-node.bottom {
    grid-column: auto;
    grid-row: auto;
  }

  body.home-v5 .homev5-principles-board {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.home-v5 .homev5-principle-hero {
    grid-column: 1 / -1;
  }

  body.home-v5 .homev5-node-grid.cols-4,
  body.home-v5 .homev5-node-grid.cols-3,
  body.home-v5 .footer-shell {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.home-v5 .footer-brand,
  body.home-v5 .footer-bottom {
    grid-column: 1 / -1;
  }
}

@media (max-width: 760px) {
  body.home-v5 .homev5-master-card,
  body.home-v5 .homev5-principles-board,
  body.home-v5 .homev5-ecosystem-map,
  body.home-v5 .homev5-node-grid.cols-4,
  body.home-v5 .homev5-node-grid.cols-3,
  body.home-v5 .footer-shell {
    grid-template-columns: 1fr;
  }

  body.home-v5 .homev5-reading-rail {
    padding-left: 16px;
  }

  body.home-v5 .homev5-master-card {
    padding: 22px;
  }

  body.home-v5 .homev5-ecosystem-core,
  body.home-v5 .homev5-ecosystem-node,
  body.home-v5 .homev5-principle-hero,
  body.home-v5 .homev5-principle-card {
    padding: 18px;
  }

  body.home-v5 .homev5-node-grid {
    padding-top: 12px;
  }

  body.home-v5 .homev5-node-grid::before,
  body.home-v5 .homev5-node-card::before {
    display: none;
  }

body.home-v5 .footer-bottom {
  flex-direction: column;
}
}

/* Premium design-system refinement pass */
body.home-page,
body.company-page {
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

body.home-page .btn,
body.company-page .btn {
  min-height: 48px;
  padding: 0 20px;
  border-radius: 15px;
  letter-spacing: -0.01em;
  font-weight: 700;
  transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

body.home-page .btn:active,
body.company-page .btn:active {
  transform: translateY(0);
}

body.home-page .btn:focus-visible,
body.company-page .btn:focus-visible,
body.home-page .nav-link:focus-visible,
body.company-page .nav-link:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(47, 95, 232, 0.12), 0 0 0 1px rgba(47, 95, 232, 0.36);
}

body.home-page .btn-primary,
body.company-page .btn-primary {
  background: linear-gradient(135deg, #2e5ce1 0%, #4a6ef1 100%);
  box-shadow: 0 14px 30px rgba(47, 95, 232, 0.2), inset 0 1px 0 rgba(255,255,255,0.16);
}

body.home-page .btn-primary:hover,
body.company-page .btn-primary:hover {
  box-shadow: 0 18px 34px rgba(47, 95, 232, 0.24), inset 0 1px 0 rgba(255,255,255,0.18);
}

body.home-page .btn-secondary,
body.company-page .btn-secondary {
  background: rgba(255,255,255,0.96);
  border-color: rgba(194, 207, 232, 0.96);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.92);
}

body.home-page .btn-secondary:hover,
body.home-page .btn-ghost:hover,
body.company-page .btn-secondary:hover,
body.company-page .btn-ghost:hover {
  border-color: rgba(170, 189, 224, 0.98);
  box-shadow: 0 12px 24px rgba(19, 32, 62, 0.06), inset 0 1px 0 rgba(255,255,255,0.96);
}

body.home-page .tag,
body.home-page .status-pill,
body.home-page .metric-label,
body.home-page .filter-chip,
body.home-page .info-pill,
body.company-page .tag,
body.company-page .status-pill,
body.company-page .metric-label,
body.company-page .filter-chip,
body.company-page .info-pill {
  min-height: 32px;
  padding: 0 11px;
  border-color: rgba(206, 216, 232, 0.98);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.9);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.11em;
  color: #617492;
}

body.home-v5 .site-header {
  background: rgba(252, 253, 255, 0.88);
  border-bottom: 1px solid rgba(198, 210, 231, 0.58);
  box-shadow: 0 10px 26px rgba(17, 29, 56, 0.035);
}

body.home-v5 h1 {
  max-width: 17ch;
  font-size: clamp(2.9rem, 4.95vw, 5.35rem);
  line-height: 0.92;
  letter-spacing: -0.06em;
}

body.home-v5 h2 {
  font-size: clamp(2.02rem, 2.75vw, 3.18rem);
  line-height: 0.98;
  letter-spacing: -0.045em;
}

body.home-v5 h3 {
  font-size: 1.13rem;
  line-height: 1.16;
}

body.home-v5 .lead {
  font-size: 0.99rem;
  line-height: 1.72;
}

body.home-v5 p,
body.home-v5 li {
  font-size: 0.94rem;
  line-height: 1.68;
}

body.home-v5 .homev5-copy .lead {
  max-width: 54ch;
}

body.home-v5 .homev5-copy .homev5-sublead {
  max-width: 52ch;
}

body.home-v5 .homev5-rich-copy p {
  max-width: 74ch !important;
}

body.home-v5 .homev5-reading-rail p {
  max-width: 68ch !important;
}

body.home-v5 .page {
  padding-top: 20px;
}

body.home-v5 .section {
  position: relative;
  padding: 18px 0;
}

body.home-v5 .section-heading {
  gap: 10px;
  margin-bottom: 24px;
}

body.home-v5 .section-heading p {
  max-width: 58ch;
}

body.home-v5 .homev5-hero,
body.home-v5 .homev5-panel {
  border-radius: 32px;
  border: 1px solid rgba(203, 214, 233, 0.9);
  box-shadow: 0 18px 42px rgba(15, 23, 42, 0.05);
}

body.home-v5 .homev5-hero,
body.home-v5 .homev5-panel,
body.home-v5 .homev5-master-card,
body.home-v5 .homev5-ecosystem-core,
body.home-v5 .homev5-principle-hero,
body.home-v5 .about-founder-card {
  backdrop-filter: blur(10px);
}

body.home-v5 .homev5-hero::after,
body.home-v5 .homev5-panel:not(.homev5-process-panel)::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 88% 14%, rgba(231, 237, 250, 0.44), transparent 22%), radial-gradient(circle at 8% 8%, rgba(242, 236, 255, 0.24), transparent 18%);
  pointer-events: none;
}

body.home-v5 .homev5-hero > *,
body.home-v5 .homev5-panel > * {
  position: relative;
  z-index: 1;
}

body.home-v5 .homev5-soft {
  background: linear-gradient(180deg, rgba(255,255,255,0.992) 0%, rgba(246,249,255,0.988) 100%);
}

body.home-v5 .section:nth-of-type(odd) .homev5-panel.homev5-soft {
  background: linear-gradient(180deg, rgba(255,255,255,0.992) 0%, rgba(246,249,255,0.988) 100%);
}

body.home-v5 .section:nth-of-type(even) .homev5-panel.homev5-soft {
  background: linear-gradient(180deg, rgba(255,255,255,0.992) 0%, rgba(249,248,255,0.988) 100%);
}

body.home-v5 .homev5-card,
body.home-v5 .homev5-band-card,
body.home-v5 .homev5-long-card,
body.home-v5 .homev5-route-card,
body.home-v5 .homev5-side-card,
body.home-v5 .homev5-ecosystem-node,
body.home-v5 .homev5-principle-card,
body.home-v5 .homev5-principle-hero {
  border-color: rgba(203, 214, 233, 0.88);
  border-radius: 24px;
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.045);
}

body.home-v5 .homev5-card,
body.home-v5 .homev5-band-card,
body.home-v5 .homev5-long-card,
body.home-v5 .homev5-route-card,
body.home-v5 .homev5-side-card {
  padding: 19px 19px 19px 23px;
}

body.home-v5 .homev5-master-card,
body.home-v5 .homev5-ecosystem-core,
body.home-v5 .homev5-principle-hero,
body.home-v5 .about-founder-card {
  box-shadow: 0 24px 52px rgba(15, 23, 42, 0.06);
}

body.home-v5 .homev5-master-card {
  gap: 24px;
  padding: 30px;
  border-radius: 32px;
}

body.home-v5 .homev5-master-lead {
  max-width: 22ch;
  line-height: 1.22;
}

body.home-v5 .homev5-master-card.statement .homev5-master-lead {
  max-width: 18ch;
}

body.home-v5 .homev5-card-icon,
body.home-v5 .homev5-process-icon {
  border-color: rgba(206, 216, 232, 0.96);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.94);
}

body.home-v5 .homev5-card-icon svg,
body.home-v5 .homev5-process-icon svg,
body.home-v5 .homev5-card-icon path,
body.home-v5 .homev5-process-icon path,
body.home-v5 .homev5-card-icon rect,
body.home-v5 .homev5-process-icon rect,
body.home-v5 .homev5-card-icon circle,
body.home-v5 .homev5-process-icon circle {
  stroke-width: 1.75;
}

body.home-v5 .homev5-panel-eyebrow,
body.home-v5 .homev5-section-divider span,
body.home-v5 .homev5-card-kicker,
body.home-v5 .homev5-master-points span,
body.home-v5 .footer-heading {
  letter-spacing: 0.14em;
}

body.home-v5 .homev5-band,
body.home-v5 .homev5-grid-2,
body.home-v5 .homev5-grid-3,
body.home-v5 .homev5-grid-4,
body.home-v5 .homev5-routes,
body.home-v5 .homev5-principles-board,
body.home-v5 .homev5-ecosystem-map {
  gap: 18px;
}

body.home-v5 .homev5-band {
  margin-top: 20px;
}

body.home-v5 .homev5-rich-copy {
  gap: 13px;
}

body.home-v5 .homev5-card:hover,
body.home-v5 .homev5-band-card:hover,
body.home-v5 .homev5-long-card:hover,
body.home-v5 .homev5-route-card:hover,
body.home-v5 .homev5-side-card:hover,
body.home-v5 .homev5-ecosystem-node:hover,
body.home-v5 .homev5-principle-card:hover,
body.home-v5 .homev5-principle-hero:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 38px rgba(18, 33, 68, 0.065) !important;
}

body.home-v5 .footer-shell {
  gap: 22px 36px;
}

body.home-v5 .footer-brand {
  max-width: 35rem;
}

@media (max-width: 1180px) {
  body.home-v5 .homev5-rich-copy p,
  body.home-v5 .homev5-reading-rail p {
    max-width: none !important;
  }

  body.home-v5 .homev5-master-card {
    padding: 26px;
  }
}

@media (max-width: 760px) {
  body.home-page .btn,
  body.company-page .btn {
    min-height: 46px;
    padding: 0 18px;
  }

  body.home-v5 h1 {
    max-width: none;
    font-size: clamp(2.38rem, 11vw, 3.3rem);
  }

  body.home-v5 h2 {
    font-size: clamp(1.72rem, 8vw, 2.28rem);
  }

  body.home-v5 .section {
    padding: 14px 0;
  }

  body.home-v5 .homev5-hero,
  body.home-v5 .homev5-panel,
  body.home-v5 .homev5-master-card {
    padding: 22px;
  }
}


body.companies-page .companies-overview-band {
  margin-top: 22px;
}

body.companies-page .companies-stat-card,
body.companies-page .companies-company-card {
  min-height: 100%;
}

body.companies-page .companies-stat-card {
  align-content: start;
}

body.companies-page .companies-stat-value {
  display: block;
  font-size: 1.92rem;
  line-height: 1;
  font-weight: 800;
  color: var(--text);
  margin-bottom: 2px;
}

body.companies-page .companies-main-panel {
  box-shadow: var(--shadow-md);
}

body.companies-page .companies-company-grid {
  align-items: stretch;
}

body.companies-page .companies-company-card .company-actions {
  margin-top: auto;
}

/* Home landing refinement */
body.home-landing .home-landing-hero {
  box-shadow: var(--shadow-lg);
}

body.home-landing .home-landing-hero-grid,
body.home-landing .home-landing-definition-grid,
body.home-landing .home-landing-footer-top,
body.home-landing .home-landing-footer-grid,
body.home-landing .home-landing-highlights,
body.home-landing .home-landing-process-grid,
body.home-landing .home-landing-nav-grid {
  display: grid;
  gap: 16px;
}

body.home-landing .home-landing-hero-grid,
body.home-landing .home-landing-definition-grid {
  grid-template-columns: minmax(0, 1.14fr) minmax(300px, 0.86fr);
  align-items: start;
}

body.home-landing .home-landing-copy,
body.home-landing .home-landing-aside,
body.home-landing .home-landing-definition-copy,
body.home-landing .home-landing-definition-side {
  display: grid;
  gap: 14px;
}

body.home-landing .home-landing-aside,
body.home-landing .home-landing-nav-shell,
body.home-landing .home-landing-step,
body.home-landing .home-landing-nav-card {
  position: relative;
  border: 1px solid rgba(195, 208, 232, 0.84);
  background: rgba(255, 255, 255, 0.97);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

body.home-landing .home-landing-aside,
body.home-landing .home-landing-nav-shell {
  border-radius: 28px;
  padding: 24px;
}

body.home-landing .home-landing-step,
body.home-landing .home-landing-nav-card {
  border-radius: 22px;
  padding: 20px;
}

body.home-landing .home-landing-aside::before,
body.home-landing .home-landing-nav-shell::before,
body.home-landing .home-landing-step::before,
body.home-landing .home-landing-nav-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 18px;
  right: 18px;
  height: 1px;
  background: linear-gradient(90deg, rgba(98, 126, 192, 0.24), transparent);
}

body.home-landing .home-landing-aside {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(245, 248, 255, 0.98) 100%);
}

body.home-landing .home-landing-aside-head {
  display: grid;
  gap: 6px;
}

body.home-landing .home-landing-stack {
  display: grid;
  gap: 12px;
}

body.home-landing .home-landing-stack-item {
  display: grid;
  gap: 8px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(219, 228, 244, 0.8);
}

body.home-landing .home-landing-stack-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

body.home-landing .home-landing-highlights {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 22px;
}

body.home-landing .home-landing-highlight {
  position: relative;
  border: 1px solid rgba(195, 208, 232, 0.84);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: var(--shadow-sm);
  border-radius: 20px;
  padding: 18px 18px 18px 22px;
  min-height: 100%;
}

body.home-landing .home-landing-highlight::after,
body.home-landing .home-landing-step::after,
body.home-landing .home-landing-nav-card::after {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: linear-gradient(180deg, rgba(47,95,232,0.82), rgba(47,95,232,0.12));
}

body.home-landing .home-landing-highlight.violet::after,
body.home-landing .home-landing-step.violet::after,
body.home-landing .home-landing-nav-card.violet::after {
  background: linear-gradient(180deg, rgba(123,92,255,0.82), rgba(123,92,255,0.12));
}

body.home-landing .home-landing-highlight.mint::after,
body.home-landing .home-landing-step.mint::after,
body.home-landing .home-landing-nav-card.mint::after {
  background: linear-gradient(180deg, rgba(31,157,116,0.82), rgba(31,157,116,0.12));
}

body.home-landing .home-landing-highlight.amber::after,
body.home-landing .home-landing-step.amber::after,
body.home-landing .home-landing-nav-card.amber::after {
  background: linear-gradient(180deg, rgba(217,137,43,0.82), rgba(217,137,43,0.12));
}

body.home-landing .home-landing-highlight strong,
body.home-landing .home-landing-step h3,
body.home-landing .home-landing-nav-card h3,
body.home-landing .home-landing-stack-item h3 {
  margin-bottom: 0;
  color: var(--text);
}

body.home-landing .home-landing-highlight p,
body.home-landing .home-landing-step p,
body.home-landing .home-landing-nav-card p,
body.home-landing .home-landing-stack-item p,
body.home-landing .home-landing-footer-block p {
  margin-bottom: 0;
}

body.home-landing .home-landing-active-grid,
body.home-landing .home-landing-company-card {
  align-items: stretch;
}

body.home-landing .home-landing-company-card .company-actions {
  margin-top: auto;
}

body.home-landing .home-landing-definition-side {
  align-content: start;
}

body.home-landing .home-landing-process-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

body.home-landing .home-landing-step {
  padding-left: 22px;
  min-height: 100%;
}

body.home-landing .home-landing-step-index {
  display: inline-block;
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #60729b;
}

body.home-landing .home-landing-nav-shell {
  background: linear-gradient(180deg, rgba(255,255,255,0.99) 0%, rgba(246,249,255,0.99) 100%);
  box-shadow: var(--shadow-md);
}

body.home-landing .home-landing-nav-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.home-landing .home-landing-nav-card {
  padding-left: 22px;
  min-height: 100%;
}

body.home-landing .home-landing-link {
  margin-top: auto;
  font-weight: 600;
  color: var(--text);
  text-decoration: none;
}

body.home-landing .home-landing-link:hover {
  color: var(--blue);
}

body.home-landing .home-landing-footer {
  padding-top: 8px;
}

body.home-landing .home-landing-footer-shell {
  display: grid;
  gap: 18px;
  padding-top: 24px;
}

body.home-landing .home-landing-footer-top {
  grid-template-columns: minmax(0, 1.2fr) auto;
  align-items: end;
}

body.home-landing .home-landing-footer-meta {
  display: grid;
  gap: 6px;
  text-align: right;
  color: #60728f;
  font-size: 0.9rem;
}

body.home-landing .home-landing-footer-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body.home-landing .home-landing-footer-block {
  display: grid;
  gap: 10px;
}

body.home-landing .home-landing-footer-block .footer-links {
  display: grid;
  gap: 8px;
}

body.home-landing .home-landing-footer-bottom {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding-top: 8px;
  color: #60728f;
  font-size: 0.9rem;
}

@media (max-width: 1180px) {
  body.home-landing .home-landing-hero-grid,
  body.home-landing .home-landing-definition-grid,
  body.home-landing .home-landing-process-grid,
  body.home-landing .home-landing-highlights,
  body.home-landing .home-landing-footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.home-landing .home-landing-hero-grid,
  body.home-landing .home-landing-definition-grid,
  body.home-landing .home-landing-footer-top {
    grid-template-columns: 1fr;
  }

  body.home-landing .home-landing-footer-meta {
    text-align: left;
  }
}

@media (max-width: 760px) {
  body.home-landing .home-landing-highlights,
  body.home-landing .home-landing-process-grid,
  body.home-landing .home-landing-nav-grid,
  body.home-landing .home-landing-footer-grid {
    grid-template-columns: 1fr;
  }

  body.home-landing .home-landing-aside,
  body.home-landing .home-landing-nav-shell,
  body.home-landing .home-landing-step,
  body.home-landing .home-landing-nav-card {
    padding: 18px;
  }

  body.home-landing .home-landing-footer-bottom {
    flex-direction: column;
  }
}

/* Home premium rebuild */
body.home-premium {
  background: linear-gradient(180deg, #fcfdff 0%, #f8fafc 50%, #fcfdff 100%);
}

body.home-premium::before,
body.home-premium::after {
  opacity: 0.16;
  filter: blur(138px);
}

body.home-premium .container {
  width: min(1120px, calc(100% - 48px));
}

body.home-premium .site-header {
  background: rgba(252, 253, 255, 0.68);
  backdrop-filter: blur(18px) saturate(136%);
  border-bottom: 1px solid rgba(15, 35, 66, 0.05);
  box-shadow: 0 10px 28px rgba(15, 35, 66, 0.03);
}

body.home-premium .nav-shell {
  min-height: 78px;
}

body.home-premium .brand-mark {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  border-color: rgba(195, 208, 232, 0.68);
  background: linear-gradient(180deg, #ffffff 0%, #f4f7fd 100%);
  color: #17376e;
  box-shadow: 0 8px 20px rgba(28, 48, 86, 0.05);
}

body.home-premium .brand-copy {
  gap: 3px;
}

body.home-premium .brand-copy strong {
  font-size: 0.7rem;
  letter-spacing: 0.18em;
}

body.home-premium .brand-copy small {
  font-size: 0.94rem;
  font-weight: 680;
}

body.home-premium .nav-menu {
  gap: 8px;
}

body.home-premium .nav-link {
  padding: 10px 8px;
  border-radius: 0;
  background: transparent;
  color: #62738e;
  font-size: 0.9rem;
}

body.home-premium .nav-link:hover {
  background: transparent;
  color: #173055;
}

body.home-premium .nav-link.is-active {
  position: relative;
  background: transparent;
  color: #132948;
}

body.home-premium .nav-link.is-active::after {
  content: "";
  position: absolute;
  left: 8px;
  right: 8px;
  bottom: 2px;
  height: 1px;
  border-radius: 999px;
  background: rgba(23, 55, 110, 0.46);
}

body.home-premium h1 {
  font-size: clamp(2.9rem, 4vw, 3.25rem) !important;
  line-height: 1.02 !important;
  letter-spacing: -0.046em !important;
  max-width: 11.2ch;
}

body.home-premium h2 {
  font-size: clamp(1.72rem, 2.2vw, 2.125rem) !important;
  line-height: 1.08 !important;
  letter-spacing: -0.038em !important;
}

body.home-premium .lead {
  max-width: 34rem;
  font-size: 1.125rem;
  line-height: 1.62;
  color: #495874;
}

body.home-premium .home-premium-sublead {
  max-width: 32rem;
  margin: 0;
  color: #53627c;
  font-size: 1.03125rem;
  line-height: 1.72;
}

body.home-premium .home-premium-kicker,
body.home-premium .home-premium-label {
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #687896;
}

body.home-premium .home-premium-hero {
  box-shadow: 0 34px 88px rgba(20, 38, 72, 0.11);
  min-height: auto;
  display: grid;
  align-items: center;
  padding: 74px 56px;
}

body.home-premium .home-premium-hero-grid,
body.home-premium .home-premium-editorial-grid,
body.home-premium .home-premium-company-grid,
body.home-premium .home-premium-nav-grid,
body.home-premium .home-premium-footer-grid {
  display: grid;
  gap: 20px;
}

body.home-premium .home-premium-hero-grid,
body.home-premium .home-premium-editorial-grid {
  grid-template-columns: minmax(0, 1.02fr) minmax(320px, 0.74fr);
  align-items: start;
  gap: 40px;
}

body.home-premium .home-premium-copy,
body.home-premium .home-premium-panel,
body.home-premium .home-premium-editorial-title,
body.home-premium .home-premium-editorial-copy {
  display: grid;
  gap: 20px;
}

body.home-premium .home-premium-copy {
  max-width: 40rem;
}

body.home-premium .home-premium-actions {
  margin-top: 16px;
  gap: 10px;
}

body.home-premium .btn {
  min-height: 44px;
  padding: 0 17px;
  border-radius: 14px;
  font-size: 0.94rem;
  box-shadow: none;
}

body.home-premium .btn-primary {
  background: #18345f;
  color: #ffffff;
  box-shadow: 0 14px 28px rgba(24, 52, 95, 0.12);
}

body.home-premium .btn-primary:hover {
  background: #132a4f;
  box-shadow: 0 18px 34px rgba(24, 52, 95, 0.15);
}

body.home-premium .btn-secondary {
  background: rgba(255, 255, 255, 0.58);
  border-color: rgba(15, 35, 66, 0.1);
  color: #173055;
}

body.home-premium .btn-secondary:hover {
  background: rgba(255, 255, 255, 0.82);
  border-color: rgba(15, 35, 66, 0.14);
  box-shadow: 0 10px 22px rgba(15, 35, 66, 0.06);
}

body.home-premium .home-premium-panel,
body.home-premium .home-premium-timeline-shell,
body.home-premium .home-premium-nav-shell,
body.home-premium .home-premium-company-card,
body.home-premium .home-premium-nav-card {
  position: relative;
  border: 1px solid rgba(15, 35, 66, 0.08);
  background: rgba(255, 255, 255, 0.7);
  box-shadow: none;
  overflow: hidden;
}

body.home-premium .home-premium-panel,
body.home-premium .home-premium-nav-shell,
body.home-premium .home-premium-timeline-shell {
  border-radius: 0;
  padding: 0;
  border-left: none;
  border-right: none;
  background: transparent;
}

body.home-premium .home-premium-company-card,
body.home-premium .home-premium-nav-card {
  border-radius: 20px;
  padding: 22px;
}

body.home-premium .home-premium-panel::before,
body.home-premium .home-premium-nav-shell::before,
body.home-premium .home-premium-timeline-shell::before,
body.home-premium .home-premium-company-card::before,
body.home-premium .home-premium-nav-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, rgba(15, 35, 66, 0.14), rgba(15, 35, 66, 0.02) 78%, transparent);
}

body.home-premium .home-premium-nav-shell::before,
body.home-premium .home-premium-timeline-shell::before {
  display: none;
}

body.home-premium .home-premium-panel {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(246, 249, 255, 0.98) 100%);
  border: 1px solid rgba(158, 176, 206, 0.46);
  border-radius: 26px;
  box-shadow: 0 28px 72px rgba(20, 38, 72, 0.09);
  max-width: 470px;
  justify-self: end;
  padding: 30px 28px;
}

body.home-premium .home-premium-panel-head {
  display: grid;
  gap: 8px;
}

body.home-premium .home-premium-panel-head strong {
  font-size: 1rem;
  letter-spacing: -0.02em;
}

body.home-premium .home-premium-panel-head p,
body.home-premium .home-premium-panel-item p,
body.home-premium .home-premium-company-card p,
body.home-premium .home-premium-nav-card p,
body.home-premium .home-premium-editorial-title p,
body.home-premium .home-premium-idea-item p,
body.home-premium .home-premium-timeline-item p,
body.home-premium .home-premium-footer-block p {
  margin-bottom: 0;
  font-size: 1.03125rem;
  line-height: 1.72;
  color: #586780;
}

body.home-premium .home-premium-panel-list {
  display: grid;
  gap: 0;
}

body.home-premium .home-premium-panel-item {
  display: grid;
  gap: 8px;
  padding: 16px 0;
  border-bottom: 1px solid rgba(15, 35, 66, 0.08);
}

body.home-premium .home-premium-panel-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

body.home-premium .home-premium-panel-item h3 {
  font-size: 1.25rem !important;
  line-height: 1.18 !important;
  letter-spacing: -0.03em !important;
}

body.home-premium .home-premium-panel-item h3,
body.home-premium .home-premium-company-card h3,
body.home-premium .home-premium-nav-card h3,
body.home-premium .home-premium-timeline-item h3,
body.home-premium .home-premium-idea-item strong {
  margin-bottom: 0;
  color: var(--text);
}

body.home-premium .home-premium-active {
  border: none;
  border-radius: 0;
  box-shadow: none;
  background: transparent;
  padding: 0;
}

body.home-premium .home-premium-company-grid {
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.16fr) minmax(0, 0.92fr);
  align-items: stretch;
  gap: 18px;
}

body.home-premium .home-premium-company-card {
  display: grid;
  gap: 12px;
  min-height: 100%;
  background: rgba(255, 255, 255, 0.38);
  border-color: rgba(15, 35, 66, 0.06);
  box-shadow: none;
}

body.home-premium .home-premium-company-grid > .home-premium-company-card:first-child,
body.home-premium .home-premium-company-grid > .home-premium-company-card:last-child {
  margin-top: 18px;
}

body.home-premium .home-premium-company-card.is-featured {
  transform: translateY(-8px);
  border-color: rgba(123, 145, 182, 0.22);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 250, 255, 0.94) 100%);
  box-shadow: 0 20px 46px rgba(20, 38, 72, 0.07);
}

body.home-premium .home-premium-company-card.is-featured h3 {
  font-size: 1.25rem !important;
}

body.home-premium .home-premium-company-card .home-premium-link {
  margin-top: auto;
}

body.home-premium .home-premium-editorial {
  box-shadow: none;
  border: none;
  border-radius: 0;
  background: transparent;
  padding: 0;
}

body.home-premium .home-premium-editorial-title h2 {
  font-size: clamp(1.9rem, 2.5vw, 2.5rem) !important;
  line-height: 1.02 !important;
  max-width: 10ch;
}

body.home-premium .home-premium-editorial-copy {
  max-width: 39rem;
}

body.home-premium .home-premium-idea-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  margin-top: 26px;
  padding-top: 14px;
  border-top: 1px solid rgba(15, 35, 66, 0.09);
}

body.home-premium .home-premium-idea-item {
  display: grid;
  gap: 5px;
  padding: 0 18px;
  border-right: 1px solid rgba(15, 35, 66, 0.08);
}

body.home-premium .home-premium-idea-item:first-child {
  padding-left: 0;
}

body.home-premium .home-premium-idea-item:last-child {
  padding-right: 0;
  border-right: none;
}

body.home-premium .home-premium-idea-item strong {
  font-size: 0.95rem;
  letter-spacing: -0.01em;
}

body.home-premium .home-premium-timeline-shell {
  background: transparent;
  box-shadow: none;
}

body.home-premium .home-premium-timeline {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 24px;
  margin-top: 8px;
}

body.home-premium .home-premium-timeline::before {
  content: "";
  position: absolute;
  top: 18px;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, rgba(15, 35, 66, 0.1), rgba(15, 35, 66, 0.05));
}

body.home-premium .home-premium-timeline-item {
  position: relative;
  display: grid;
  gap: 10px;
  padding-top: 34px;
}

body.home-premium .home-premium-timeline-item h3 {
  font-size: 1.25rem !important;
  line-height: 1.16 !important;
  letter-spacing: -0.03em !important;
}

body.home-premium .home-premium-timeline-item::before {
  content: "";
  position: absolute;
  top: 14px;
  left: 0;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: rgba(23, 55, 110, 0.92);
  box-shadow: 0 0 0 6px rgba(23, 55, 110, 0.06);
}

body.home-premium .home-premium-timeline-index {
  font-size: 0.6875rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #6a7991;
}

body.home-premium .home-premium-nav-shell {
  background: transparent;
  box-shadow: none;
}

body.home-premium .home-premium-nav-grid {
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
  grid-template-areas:
    "group group"
    "companies vision"
    "contact vision";
}

body.home-premium .home-premium-nav-card {
  display: grid;
  gap: 12px;
  min-height: 100%;
  background: rgba(255, 255, 255, 0.42);
  border-color: rgba(15, 35, 66, 0.06);
  box-shadow: none;
}

body.home-premium .home-premium-nav-card.is-group {
  grid-area: group;
  min-height: 208px;
  padding: 28px;
  background: linear-gradient(180deg, rgba(255,255,255,0.94) 0%, rgba(248,250,255,0.88) 100%);
  border-color: rgba(123, 145, 182, 0.14);
}

body.home-premium .home-premium-nav-card.is-companies {
  grid-area: companies;
}

body.home-premium .home-premium-nav-card.is-vision {
  grid-area: vision;
}

body.home-premium .home-premium-nav-card.is-contact {
  grid-area: contact;
  min-height: 120px;
}

body.home-premium .home-premium-link {
  margin-top: auto;
  font-weight: 600;
  color: var(--text);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 0.95rem;
}

body.home-premium .home-premium-link::after {
  content: "→";
  font-size: 0.84em;
}

body.home-premium .home-premium-link:hover {
  color: #18345f;
}

body.home-premium .home-premium-footer {
  padding-top: 18px;
}

body.home-premium .home-premium-footer-shell {
  display: grid;
  gap: 24px;
  padding-top: 34px;
  border-top: 1px solid rgba(15, 35, 66, 0.08);
}

body.home-premium .home-premium-footer-top {
  display: grid;
  gap: 10px;
}

body.home-premium .home-premium-footer-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  padding-top: 6px;
  gap: 34px;
}

body.home-premium .home-premium-footer-block {
  display: grid;
  gap: 10px;
}

body.home-premium .home-premium-footer-block p {
  font-size: 0.95rem;
  color: #667791;
}

body.home-premium .home-premium-footer-block .footer-links {
  display: grid;
  gap: 8px;
}

@media (max-width: 1180px) {
  body.home-premium .home-premium-hero-grid,
  body.home-premium .home-premium-editorial-grid,
  body.home-premium .home-premium-company-grid,
  body.home-premium .home-premium-idea-strip,
  body.home-premium .home-premium-timeline,
  body.home-premium .home-premium-footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.home-premium .home-premium-hero-grid,
  body.home-premium .home-premium-editorial-grid {
    grid-template-columns: 1fr;
  }

  body.home-premium .home-premium-nav-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-areas:
      "group group"
      "companies vision"
      "contact contact";
  }

  body.home-premium .home-premium-company-grid > .home-premium-company-card:first-child,
  body.home-premium .home-premium-company-grid > .home-premium-company-card:last-child {
    margin-top: 0;
  }
}

@media (max-width: 760px) {
  body.home-premium h1 {
    font-size: clamp(2rem, 8vw, 2.4rem) !important;
    max-width: 100%;
  }

  body.home-premium h2 {
    font-size: clamp(1.48rem, 5vw, 1.8rem) !important;
  }

  body.home-premium .home-premium-company-grid,
  body.home-premium .home-premium-idea-strip,
  body.home-premium .home-premium-timeline,
  body.home-premium .home-premium-nav-grid,
  body.home-premium .home-premium-footer-grid {
    grid-template-columns: 1fr;
  }

  body.home-premium .home-premium-nav-grid {
    grid-template-areas:
      "group"
      "companies"
      "vision"
      "contact";
  }

  body.home-premium .home-premium-panel,
  body.home-premium .home-premium-nav-shell,
  body.home-premium .home-premium-timeline-shell,
  body.home-premium .home-premium-company-card,
  body.home-premium .home-premium-nav-card {
    padding: 18px;
  }

  body.home-premium .home-premium-hero {
    min-height: auto;
    padding: 36px 22px;
  }

  body.home-premium .home-premium-company-card.is-featured {
    transform: none;
  }

  body.home-premium .home-premium-timeline::before {
    display: none;
  }

  body.home-premium .home-premium-idea-item {
    padding: 0;
    border-right: none;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(219, 228, 244, 0.85);
  }

  body.home-premium .home-premium-idea-item:last-child {
    padding-bottom: 0;
    border-bottom: none;
  }
}

/* Home premium art direction v2 */
body.home-premium {
  background:
    radial-gradient(circle at 12% 12%, rgba(213, 224, 247, 0.58), transparent 20%),
    radial-gradient(circle at 84% 18%, rgba(226, 234, 249, 0.48), transparent 24%),
    linear-gradient(180deg, #f5f7fb 0%, #f7f9fc 48%, #f5f7fb 100%);
}

body.home-premium::before,
body.home-premium::after {
  opacity: 0.11;
  filter: blur(160px);
}

body.home-premium .page {
  padding-top: 4px;
  padding-bottom: 104px;
}

body.home-premium .section {
  padding: 34px 0;
}

body.home-premium .site-header {
  position: sticky;
  top: 0;
  background: transparent;
  border: none;
  box-shadow: none;
  backdrop-filter: none;
  padding-top: 18px;
}

body.home-premium .nav-shell {
  width: min(1140px, calc(100% - 48px));
  margin: 0 auto;
  min-height: 76px;
  padding: 0 22px;
  border: 1px solid rgba(15, 23, 40, 0.08);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.72);
  backdrop-filter: blur(20px) saturate(135%);
  box-shadow: 0 18px 34px rgba(15, 23, 40, 0.045);
}

body.home-premium .brand-mark {
  width: 42px;
  height: 42px;
  border-radius: 13px;
  border: 1px solid rgba(15, 23, 40, 0.09);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(245, 247, 251, 0.96) 100%);
  color: #0f274d;
  font-size: 1rem;
  box-shadow: 0 10px 20px rgba(15, 23, 40, 0.04);
}

body.home-premium .nav-actions {
  gap: 14px;
}

body.home-premium .nav-menu {
  gap: 16px;
}

body.home-premium .nav-link {
  padding: 10px 4px;
  font-size: 0.93rem;
  letter-spacing: -0.01em;
}

body.home-premium .nav-link.is-active::after {
  left: 0;
  right: 0;
  bottom: 1px;
  background: rgba(15, 39, 77, 0.46);
}

body.home-premium h1 {
  font-size: clamp(2.65rem, 3.5vw, 2.875rem) !important;
  line-height: 1.02 !important;
  letter-spacing: -0.048em !important;
  max-width: 11.4ch;
}

body.home-premium h2 {
  font-size: clamp(1.64rem, 2vw, 1.875rem) !important;
  line-height: 1.08 !important;
}

body.home-premium .lead {
  font-size: 1.125rem;
  line-height: 1.62;
  max-width: 32rem;
}

body.home-premium .home-premium-sublead {
  max-width: 30rem;
  font-size: 1rem;
}

body.home-premium .home-premium-kicker,
body.home-premium .home-premium-label {
  font-size: 0.6875rem;
  letter-spacing: 0.18em;
}

body.home-premium .section-heading {
  display: grid;
  gap: 10px;
  margin-bottom: 24px;
}

body.home-premium .section-heading p {
  max-width: 36rem;
  margin: 0;
  font-size: 1rem;
  line-height: 1.72;
  color: #5b6474;
}

body.home-premium .home-premium-hero {
  position: relative;
  border: 1px solid rgba(15, 23, 40, 0.07);
  border-radius: 34px;
  background:
    radial-gradient(circle at 12% 16%, rgba(213, 223, 247, 0.78), transparent 26%),
    radial-gradient(circle at 86% 24%, rgba(224, 233, 248, 0.66), transparent 30%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.94) 0%, rgba(249, 251, 254, 0.92) 100%);
  box-shadow: 0 30px 80px rgba(15, 23, 40, 0.08);
  padding: 76px 58px;
  overflow: hidden;
}

body.home-premium .home-premium-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(255,255,255,0.22), transparent 24%, transparent 78%, rgba(255,255,255,0.12));
  pointer-events: none;
}

body.home-premium .home-premium-hero-grid {
  position: relative;
  grid-template-columns: minmax(0, 1.06fr) minmax(320px, 0.74fr);
  gap: 54px;
}

body.home-premium .home-premium-hero-grid::after {
  content: "";
  position: absolute;
  top: 10px;
  bottom: 10px;
  left: calc(100% - 320px - 27px);
  width: 1px;
  background: linear-gradient(180deg, transparent, rgba(15, 23, 40, 0.08) 14%, rgba(15, 23, 40, 0.08) 84%, transparent);
}

body.home-premium .home-premium-copy {
  max-width: 34rem;
  gap: 18px;
}

body.home-premium .home-premium-actions {
  gap: 10px;
  margin-top: 12px;
}

body.home-premium .btn {
  min-height: 42px;
  padding: 0 16px;
  border-radius: 14px;
  font-size: 0.93rem;
}

body.home-premium .btn-primary {
  background: #0f274d;
  box-shadow: 0 14px 30px rgba(15, 39, 77, 0.12);
}

body.home-premium .btn-primary:hover {
  background: #0b1f3d;
}

body.home-premium .btn-secondary {
  background: rgba(255, 255, 255, 0.54);
  border-color: rgba(15, 23, 40, 0.08);
}

body.home-premium .home-premium-panel {
  position: relative;
  max-width: 420px;
  justify-self: end;
  padding: 28px 26px;
  border: 1px solid rgba(255, 255, 255, 0.48);
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255,255,255,0.56) 0%, rgba(248,250,253,0.34) 100%);
  box-shadow: 0 26px 54px rgba(15, 23, 40, 0.08);
  backdrop-filter: blur(18px) saturate(135%);
}

body.home-premium .home-premium-panel::before {
  left: 18px;
  right: 18px;
  background: linear-gradient(90deg, rgba(15, 39, 77, 0.18), transparent);
}

body.home-premium .home-premium-panel-item {
  padding: 16px 0;
  border-bottom-color: rgba(15, 23, 40, 0.08);
}

body.home-premium .home-premium-panel-item h3 {
  font-size: 1.1875rem !important;
}

body.home-premium a.home-premium-company-card,
body.home-premium a.home-premium-nav-card {
  color: inherit;
  text-decoration: none;
}

body.home-premium .home-premium-active,
body.home-premium .home-premium-editorial,
body.home-premium .home-premium-timeline-shell,
body.home-premium .home-premium-nav-shell {
  border: none;
  background: transparent;
  box-shadow: none;
  padding: 0;
}

body.home-premium .home-premium-company-grid {
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.18fr) minmax(0, 0.9fr);
  grid-template-areas: "studio labs systems";
  align-items: start;
  gap: 20px;
}

body.home-premium .home-premium-company-card {
  position: relative;
  display: grid;
  gap: 12px;
  min-height: 250px;
  padding: 24px 22px;
  border: 1px solid rgba(15, 23, 40, 0.07);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.48);
  box-shadow: 0 12px 30px rgba(15, 23, 40, 0.03);
  transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
}

body.home-premium .home-premium-company-card:hover,
body.home-premium .home-premium-nav-card:hover {
  transform: translateY(-4px);
  border-color: rgba(15, 39, 77, 0.14);
  box-shadow: 0 20px 40px rgba(15, 23, 40, 0.05);
}

body.home-premium .home-premium-company-card.is-studio {
  grid-area: studio;
  margin-top: 38px;
}

body.home-premium .home-premium-company-card.is-labs {
  grid-area: labs;
  min-height: 332px;
  padding: 30px 28px;
  background: linear-gradient(180deg, rgba(255,255,255,0.96) 0%, rgba(247,250,255,0.94) 100%);
  border-color: rgba(15, 39, 77, 0.1);
  box-shadow: 0 26px 62px rgba(15, 39, 77, 0.08);
  transform: translateY(-10px);
}

body.home-premium .home-premium-company-card.is-labs .home-premium-label {
  color: #4e6284;
}

body.home-premium .home-premium-company-card.is-systems {
  grid-area: systems;
  margin-top: 72px;
}

body.home-premium .home-premium-company-card h3,
body.home-premium .home-premium-nav-card h3,
body.home-premium .home-premium-timeline-item h3 {
  font-size: 1.1875rem !important;
  line-height: 1.18 !important;
  letter-spacing: -0.03em !important;
}

body.home-premium .home-premium-company-card p,
body.home-premium .home-premium-nav-card p,
body.home-premium .home-premium-editorial-copy p,
body.home-premium .home-premium-idea-item p,
body.home-premium .home-premium-timeline-item p,
body.home-premium .home-premium-footer-block p {
  font-size: 1rem;
  line-height: 1.72;
  color: #5b6474;
}

body.home-premium .home-premium-link {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 0.93rem;
  font-weight: 600;
  color: #0f274d;
}

body.home-premium .home-premium-link::after {
  content: "→";
  font-size: 0.82em;
}

body.home-premium .home-premium-editorial-grid {
  grid-template-columns: minmax(0, 0.78fr) minmax(0, 1.22fr);
  gap: 60px;
  align-items: start;
}

body.home-premium .home-premium-editorial-title {
  max-width: 18rem;
}

body.home-premium .home-premium-editorial-title h2 {
  max-width: 9.5ch;
}

body.home-premium .home-premium-editorial-copy {
  max-width: 38rem;
  gap: 16px;
}

body.home-premium .home-premium-idea-strip {
  margin-top: 26px;
  padding-top: 16px;
  border-top: 1px solid rgba(15, 23, 40, 0.08);
}

body.home-premium .home-premium-idea-item {
  padding: 0 20px;
  border-right: 1px solid rgba(15, 23, 40, 0.08);
}

body.home-premium .home-premium-idea-item strong {
  font-size: 0.95rem;
  letter-spacing: -0.01em;
}

body.home-premium .home-premium-timeline {
  position: relative;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 24px;
  margin-top: 12px;
  padding-top: 24px;
}

body.home-premium .home-premium-timeline::before {
  content: "";
  position: absolute;
  top: 28px;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, rgba(15, 23, 40, 0.1), rgba(15, 23, 40, 0.04));
}

body.home-premium .home-premium-timeline-item {
  position: relative;
  display: grid;
  gap: 10px;
  padding-top: 30px;
}

body.home-premium .home-premium-timeline-item:nth-child(2),
body.home-premium .home-premium-timeline-item:nth-child(4) {
  margin-top: 42px;
}

body.home-premium .home-premium-timeline-item::before {
  content: "";
  position: absolute;
  top: 22px;
  left: 0;
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: #0f274d;
  box-shadow: 0 0 0 6px rgba(15, 39, 77, 0.06);
}

body.home-premium .home-premium-timeline-index {
  font-size: 0.6875rem;
  letter-spacing: 0.16em;
  color: #6b7484;
}

body.home-premium .home-premium-nav-grid {
  grid-template-columns: minmax(0, 1.14fr) minmax(0, 0.86fr) minmax(0, 0.86fr);
  grid-template-areas:
    "group companies vision"
    "group contact vision";
  gap: 18px;
}

body.home-premium .home-premium-nav-card {
  position: relative;
  display: grid;
  gap: 10px;
  min-height: 180px;
  padding: 24px 22px;
  border: 1px solid rgba(15, 23, 40, 0.07);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.44);
}

body.home-premium .home-premium-nav-card.is-group {
  grid-area: group;
  min-height: 362px;
  padding: 28px;
  background: linear-gradient(180deg, rgba(255,255,255,0.96) 0%, rgba(247,250,255,0.92) 100%);
}

body.home-premium .home-premium-nav-card.is-companies {
  grid-area: companies;
}

body.home-premium .home-premium-nav-card.is-vision {
  grid-area: vision;
  min-height: 362px;
}

body.home-premium .home-premium-nav-card.is-contact {
  grid-area: contact;
  min-height: 164px;
}

body.home-premium .home-premium-footer {
  padding-top: 12px;
}

body.home-premium .home-premium-footer-shell {
  gap: 18px;
  padding-top: 32px;
  border-top: 1px solid rgba(15, 23, 40, 0.08);
}

body.home-premium .home-premium-footer-top {
  max-width: 34rem;
}

body.home-premium .home-premium-footer-grid {
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 0.9fr) minmax(0, 0.9fr);
  gap: 32px;
}

body.home-premium .home-premium-footer-block .footer-links {
  gap: 7px;
}

@media (max-width: 1180px) {
  body.home-premium .nav-shell {
    width: min(1140px, calc(100% - 36px));
  }

  body.home-premium .home-premium-hero {
    padding: 64px 38px;
  }

  body.home-premium .home-premium-hero-grid,
  body.home-premium .home-premium-editorial-grid {
    grid-template-columns: 1fr;
    gap: 30px;
  }

  body.home-premium .home-premium-hero-grid::after {
    display: none;
  }

  body.home-premium .home-premium-panel {
    max-width: none;
    justify-self: stretch;
  }

  body.home-premium .home-premium-company-grid,
  body.home-premium .home-premium-nav-grid,
  body.home-premium .home-premium-footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.home-premium .home-premium-company-grid {
    grid-template-areas:
      "labs labs"
      "studio systems";
  }

  body.home-premium .home-premium-company-card.is-studio,
  body.home-premium .home-premium-company-card.is-systems,
  body.home-premium .home-premium-company-card.is-labs {
    margin-top: 0;
    transform: none;
  }

  body.home-premium .home-premium-nav-grid {
    grid-template-areas:
      "group group"
      "companies vision"
      "contact contact";
  }

  body.home-premium .home-premium-nav-card.is-group,
  body.home-premium .home-premium-nav-card.is-vision {
    min-height: 220px;
  }
}

@media (max-width: 760px) {
  body.home-premium .site-header {
    padding-top: 12px;
  }

  body.home-premium .nav-shell {
    width: calc(100% - 24px);
    min-height: 68px;
    padding: 0 16px;
    border-radius: 18px;
  }

  body.home-premium h1 {
    font-size: clamp(2rem, 8vw, 2.35rem) !important;
    max-width: 100%;
  }

  body.home-premium h2 {
    font-size: clamp(1.45rem, 5.6vw, 1.8rem) !important;
  }

  body.home-premium .home-premium-hero {
    padding: 38px 22px;
    border-radius: 26px;
  }

  body.home-premium .home-premium-company-grid,
  body.home-premium .home-premium-idea-strip,
  body.home-premium .home-premium-timeline,
  body.home-premium .home-premium-nav-grid,
  body.home-premium .home-premium-footer-grid {
    grid-template-columns: 1fr;
  }

  body.home-premium .home-premium-company-grid,
  body.home-premium .home-premium-nav-grid {
    grid-template-areas: none;
  }

  body.home-premium .home-premium-company-card.is-studio,
  body.home-premium .home-premium-company-card.is-labs,
  body.home-premium .home-premium-company-card.is-systems,
  body.home-premium .home-premium-nav-card.is-group,
  body.home-premium .home-premium-nav-card.is-companies,
  body.home-premium .home-premium-nav-card.is-vision,
  body.home-premium .home-premium-nav-card.is-contact {
    grid-area: auto;
    margin-top: 0;
    transform: none;
  }

  body.home-premium .home-premium-company-card,
  body.home-premium .home-premium-nav-card,
  body.home-premium .home-premium-panel {
    padding: 20px 18px;
    min-height: auto;
  }

  body.home-premium .home-premium-timeline::before {
    display: none;
  }

  body.home-premium .home-premium-timeline-item:nth-child(2),
  body.home-premium .home-premium-timeline-item:nth-child(4) {
    margin-top: 0;
  }

  body.home-premium .home-premium-idea-item {
    padding: 0 0 12px;
    border-right: none;
    border-bottom: 1px solid rgba(15, 23, 40, 0.08);
  }

  body.home-premium .home-premium-idea-item:last-child {
    padding-bottom: 0;
    border-bottom: none;
  }
}

/* Group page refresh */
body.group-page .topbar {
  display: none;
}

body.group-page .nav-actions > .btn {
  display: none;
}

body.group-page .container {
  width: min(1040px, calc(100% - 40px));
}

body.group-page .page {
  padding-top: 18px;
}

body.group-page .section {
  padding: 16px 0;
}

body.group-page h1 {
  font-size: clamp(1.86rem, 2.2vw, 2.58rem);
  line-height: 1.02;
  letter-spacing: -0.046em;
  max-width: 15.5ch;
  text-wrap: balance;
}

body.group-page h2 {
  font-size: clamp(1.44rem, 1.74vw, 1.9rem);
  line-height: 1.08;
  letter-spacing: -0.032em;
  text-wrap: balance;
}

body.group-page h3 {
  font-size: 1rem;
}

body.group-page .lead,
body.group-page p,
body.group-page li {
  font-size: 0.95rem;
  line-height: 1.72;
}

body.group-page .lead {
  max-width: 74ch;
}

.groupv2-hero,
.groupv2-section,
.groupv2-closing,
.groupv2-side,
.groupv2-summary,
.groupv2-note,
.groupv2-priority {
  position: relative;
  border: 1px solid rgba(195, 208, 232, 0.84);
  background: rgba(255, 255, 255, 0.97);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.groupv2-hero,
.groupv2-section,
.groupv2-closing {
  padding: 30px;
  border-radius: 30px;
}

.groupv2-summary,
.groupv2-note,
.groupv2-priority,
.groupv2-side {
  padding: 22px;
  border-radius: 24px;
}

.groupv2-hero::before,
.groupv2-section::before,
.groupv2-closing::before,
.groupv2-summary::before,
.groupv2-note::before,
.groupv2-priority::before,
.groupv2-side::before {
  content: "";
  position: absolute;
  top: 0;
  left: 18px;
  right: 18px;
  height: 1px;
  background: linear-gradient(90deg, rgba(98, 126, 192, 0.28), transparent);
}

.groupv2-hero,
.groupv2-closing {
  background:
    radial-gradient(circle at top left, rgba(209, 221, 255, 0.48), transparent 24%),
    radial-gradient(circle at top right, rgba(236, 228, 255, 0.4), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(248, 250, 255, 0.99) 100%);
  box-shadow: var(--shadow-lg);
}

.groupv2-section-soft,
.groupv2-side,
.groupv2-summary,
.groupv2-note,
.groupv2-priority {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(246, 249, 255, 0.98) 100%);
}

.groupv2-note-warm {
  background: linear-gradient(180deg, rgba(255, 249, 241, 0.99) 0%, rgba(255, 255, 255, 0.98) 100%);
}

.groupv2-hero-grid,
.groupv2-editorial,
.groupv2-grid,
.groupv2-rule-grid,
.groupv2-side,
.groupv2-summary {
  display: grid;
  gap: 18px;
}

.groupv2-hero-grid,
.groupv2-grid,
.groupv2-grid-bottom {
  grid-template-columns: minmax(0, 1.14fr) minmax(280px, 0.86fr);
  align-items: start;
}

.groupv2-copy,
.groupv2-editorial-copy,
.groupv2-principles,
.groupv2-summary,
.groupv2-side,
.groupv2-priority {
  display: grid;
  gap: 14px;
}

.groupv2-soft {
  margin-bottom: 0;
}

.groupv2-kicker {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #60729b;
}

.groupv2-summary-item,
.groupv2-principle,
.groupv2-rail-item {
  padding: 14px 0;
  border-bottom: 1px solid rgba(219, 228, 244, 0.8);
}

.groupv2-summary-item:first-child,
.groupv2-principle:first-child,
.groupv2-rail-item:first-child {
  padding-top: 0;
}

.groupv2-summary-item:last-child,
.groupv2-principle:last-child,
.groupv2-rail-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.groupv2-summary-item strong,
.groupv2-principle h3,
.groupv2-note h3,
.groupv2-rule h3,
.groupv2-rail-item h3,
.groupv2-priority h3 {
  color: var(--text);
  margin-bottom: 0;
}

.groupv2-summary-item p,
.groupv2-principle p,
.groupv2-note p,
.groupv2-rule p,
.groupv2-rail-item p,
.groupv2-priority p,
.groupv2-closing p {
  margin-bottom: 0;
}

.groupv2-principle {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  align-items: start;
}

.groupv2-index {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  border: 1px solid var(--line-strong);
  background: rgba(255, 255, 255, 0.92);
  font-size: 0.78rem;
  font-weight: 800;
  color: var(--text);
}

.group-list {
  display: grid;
  gap: 8px;
  margin: 0;
  padding-left: 18px;
}

.group-list li::marker {
  color: var(--blue);
}

.groupv2-rail {
  display: grid;
  gap: 0;
}

.groupv2-rail-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: 8px;
}

.groupv2-rule-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.groupv2-rule {
  position: relative;
  padding: 18px;
  border-radius: 20px;
  border: 1px solid rgba(195, 208, 232, 0.84);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: var(--shadow-sm);
}

.groupv2-rule::before {
  content: "";
  position: absolute;
  top: 0;
  left: 16px;
  right: 16px;
  height: 1px;
  background: linear-gradient(90deg, rgba(98, 126, 192, 0.24), transparent);
}

@media (max-width: 1180px) {
  .groupv2-hero-grid,
  .groupv2-grid,
  .groupv2-grid-bottom,
  .groupv2-rule-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .groupv2-hero-grid,
  .groupv2-grid,
  .groupv2-grid-bottom,
  .groupv2-editorial {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  body.group-page h1 {
    font-size: clamp(1.7rem, 7vw, 2.22rem);
    max-width: 100%;
  }

  body.group-page h2 {
    font-size: clamp(1.32rem, 5vw, 1.72rem);
  }

  .groupv2-hero,
  .groupv2-section,
  .groupv2-closing {
    padding: 22px;
  }

  .groupv2-summary,
  .groupv2-note,
  .groupv2-priority,
  .groupv2-side {
    padding: 18px;
  }

  .groupv2-rule-grid {
    grid-template-columns: 1fr;
  }

  .groupv2-principle {
    grid-template-columns: 1fr;
  }
}

/* Global cleanup pass */
.topbar {
  display: none !important;
}

.site-header .nav-actions > .btn {
  display: none !important;
}

.eyebrow {
  display: none !important;
}

.tag-row {
  display: none !important;
}

.nav-shell {
  min-height: 68px;
}

.page {
  padding-top: 18px;
}

h1 {
  font-size: clamp(1.9rem, 2.6vw, 3rem) !important;
  line-height: 1.04 !important;
  letter-spacing: -0.045em !important;
}

h2 {
  font-size: clamp(1.44rem, 1.9vw, 2.08rem) !important;
  line-height: 1.1 !important;
  letter-spacing: -0.03em !important;
}

h3 {
  font-size: 1.02rem !important;
  line-height: 1.25 !important;
}

p,
li {
  font-size: 0.95rem;
}

.hero-shell,
.page-shell,
.homev5-hero,
.homev5-panel,
.surface-card,
.quote-card,
.intake-card,
.contact-card,
.company-story-card,
.company-highlight-card,
.company-minimal-card,
.company-disclosure,
.timeline-card,
.metric-card,
.upcoming-card,
.company-spotlight,
.homev5-card,
.homev5-long-card,
.homev5-band-card,
.homev5-route-card {
  box-shadow: var(--shadow-sm) !important;
}

body.company-page h1 {
  font-size: clamp(1.8rem, 2.2vw, 2.55rem) !important;
  max-width: 16ch;
}

body.company-page .hero-panel,
body.company-page .company-summary-strip,
body.company-page .company-hero-band {
  display: grid !important;
}

body.company-page .company-local-nav {
  display: flex !important;
}

body.company-page .detail-hero-grid {
  grid-template-columns: minmax(0, 1.08fr) minmax(300px, 0.92fr) !important;
  align-items: start;
}

body.company-page .detail-hero-grid > div:first-child {
  max-width: 38rem;
}

body.company-page .hero-panel {
  align-self: stretch;
}

body.company-page .hero-shell {
  padding: 28px !important;
}

body.company-page .section {
  padding: 16px 0;
}

body.company-page .company-story-card,
body.company-page .company-disclosure,
body.company-page .company-highlight-card,
body.company-page .company-minimal-card {
  border-radius: 22px !important;
}

body.company-page .section > .container:not(.company-story-card) {
  padding: 28px !important;
  border-radius: 28px;
  border: 1px solid var(--line);
  background:
    radial-gradient(circle at top left, rgba(212, 222, 255, 0.48), transparent 24%),
    radial-gradient(circle at top right, rgba(235, 229, 255, 0.46), transparent 22%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(248, 250, 255, 0.98) 100%);
  box-shadow: var(--shadow-sm);
  box-sizing: border-box;
}

body.company-page .section > .container:not(.company-story-card) .section-heading {
  margin-bottom: 20px;
}

body.company-page .company-page-actions {
  margin-top: 16px;
}

body.company-page .company-page-actions .btn {
  min-width: 126px;
  justify-content: center;
}

@media (max-width: 760px) {
  .site-header {
    position: sticky;
  }

  h1 {
    font-size: clamp(1.68rem, 7vw, 2.2rem) !important;
  }

  h2 {
    font-size: clamp(1.28rem, 5vw, 1.7rem) !important;
  }

  .homev5-hero,
  .homev5-panel,
  .hero-shell,
  .page-shell,
  .surface-card,
  .quote-card,
  .intake-card,
  .contact-card,
  .company-story-card {
    padding: 22px !important;
  }

  body.company-page .section > .container:not(.company-story-card) {
    padding: 22px !important;
    border-radius: 24px;
  }

  body.company-page .detail-hero-grid {
    grid-template-columns: 1fr !important;
  }

  body.company-page .detail-hero-grid > div:first-child {
    max-width: 100%;
  }
}

/* Neyvon Group home redesign */
body.ng-home {
  --ng-bg: #07111d;
  --ng-bg-soft: #0b1727;
  --ng-surface: rgba(12, 21, 37, 0.78);
  --ng-surface-strong: rgba(14, 24, 43, 0.94);
  --ng-surface-soft: rgba(11, 20, 35, 0.58);
  --ng-line: rgba(255, 255, 255, 0.08);
  --ng-line-strong: rgba(129, 162, 255, 0.18);
  --ng-text: #edf2ff;
  --ng-text-soft: rgba(226, 233, 255, 0.72);
  --ng-text-faint: rgba(226, 233, 255, 0.5);
  --ng-accent: #4b7bff;
  --ng-accent-soft: rgba(75, 123, 255, 0.18);
  --ng-accent-strong: #88a9ff;
  --ng-shadow-lg: 0 34px 96px rgba(0, 0, 0, 0.36);
  --ng-shadow-md: 0 18px 42px rgba(0, 0, 0, 0.28);
  --ng-shadow-sm: 0 12px 26px rgba(0, 0, 0, 0.16);
  background:
    radial-gradient(circle at 10% 10%, rgba(63, 95, 167, 0.26), transparent 22%),
    radial-gradient(circle at 88% 14%, rgba(44, 74, 134, 0.24), transparent 24%),
    radial-gradient(circle at 62% 44%, rgba(26, 46, 87, 0.26), transparent 20%),
    linear-gradient(180deg, #06101b 0%, #091320 42%, #07111d 100%);
  color: var(--ng-text);
}

body.ng-home::before,
body.ng-home::after {
  content: "";
  position: fixed;
  z-index: -1;
  pointer-events: none;
  border-radius: 999px;
  filter: blur(140px);
  opacity: 0.28;
}

body.ng-home::before {
  width: 26rem;
  height: 26rem;
  top: -8rem;
  right: -8rem;
  background: rgba(73, 111, 199, 0.42);
}

body.ng-home::after {
  width: 20rem;
  height: 20rem;
  left: -6rem;
  top: 30rem;
  background: rgba(57, 91, 170, 0.26);
}

body.ng-home p,
body.ng-home li,
body.ng-home span,
body.ng-home small,
body.ng-home label {
  color: var(--ng-text-soft);
}

body.ng-home h1,
body.ng-home h2,
body.ng-home h3,
body.ng-home h4,
body.ng-home strong,
body.ng-home .btn,
body.ng-home .nav-link,
body.ng-home .brand-copy strong,
body.ng-home .brand-copy small {
  color: var(--ng-text);
}

body.ng-home .container {
  width: min(1220px, calc(100% - 48px));
}

body.ng-home .site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  padding-top: 18px;
  background: transparent;
  border: none;
  backdrop-filter: none;
}

body.ng-home .ng-nav-shell {
  width: min(1220px, calc(100% - 48px));
  min-height: 80px;
  margin: 0 auto;
  padding: 0 24px;
  border: 1px solid var(--ng-line);
  border-radius: 24px;
  background: rgba(10, 18, 31, 0.72);
  backdrop-filter: blur(20px) saturate(136%);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.22);
}

body.ng-home .brand {
  gap: 14px;
}

body.ng-home .brand-mark {
  width: 46px;
  height: 46px;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: linear-gradient(180deg, rgba(255,255,255,0.08) 0%, rgba(255,255,255,0.03) 100%);
  color: var(--ng-text);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.08), 0 12px 24px rgba(0,0,0,0.18);
}

body.ng-home .brand-copy {
  gap: 3px;
}

body.ng-home .brand-copy strong {
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  color: rgba(236, 242, 255, 0.68);
}

body.ng-home .brand-copy small {
  font-size: 1rem;
  font-weight: 650;
}

body.ng-home .ng-nav-meta {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-left: 10px;
}

body.ng-home .ng-nav-chip,
body.ng-home .ng-nav-caption {
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(236, 242, 255, 0.52);
}

body.ng-home .ng-nav-divider {
  width: 22px;
  height: 1px;
  background: rgba(255, 255, 255, 0.14);
}

body.ng-home .nav-actions {
  gap: 18px;
}

body.ng-home .nav-menu {
  gap: 16px;
}

body.ng-home .nav-link {
  padding: 10px 4px;
  border-radius: 0;
  background: transparent;
  color: rgba(236, 242, 255, 0.72);
  font-size: 0.94rem;
  letter-spacing: -0.01em;
}

body.ng-home .nav-link:hover {
  background: transparent;
  color: var(--ng-text);
}

body.ng-home .nav-link.is-active {
  position: relative;
  background: transparent;
}

body.ng-home .nav-link.is-active::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 2px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(136, 169, 255, 0.85), transparent);
}

body.ng-home .nav-toggle {
  border-color: rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.04);
  color: var(--ng-text);
}

body.ng-home .ng-page {
  padding-top: 8px;
  padding-bottom: 112px;
}

body.ng-home .ng-section,
body.ng-home .ng-hero {
  padding: 38px 0;
}

body.ng-home .ng-kicker {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(236, 242, 255, 0.52);
}

body.ng-home .ng-section-head {
  display: grid;
  gap: 12px;
  margin-bottom: 28px;
  max-width: 52rem;
}

body.ng-home .ng-section-head.is-compact {
  margin-bottom: 22px;
}

body.ng-home .ng-section-head h2 {
  font-size: clamp(1.95rem, 3vw, 2.8rem) !important;
  line-height: 1.02 !important;
  letter-spacing: -0.05em !important;
  margin-bottom: 0;
  max-width: 16ch;
  text-wrap: balance;
}

body.ng-home .ng-section-head p {
  margin-bottom: 0;
  max-width: 42rem;
  font-size: 1.02rem;
  line-height: 1.78;
}

body.ng-home .ng-hero-shell {
  position: relative;
  padding: 42px 0 0;
}

body.ng-home .ng-hero-grid {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(360px, 0.98fr);
  gap: 42px;
  align-items: stretch;
}

body.ng-home .ng-hero-grid::after {
  content: "";
  position: absolute;
  top: 22px;
  bottom: 22px;
  left: calc(100% - 360px - 21px);
  width: 1px;
  background: linear-gradient(180deg, transparent, rgba(255,255,255,0.12) 16%, rgba(255,255,255,0.12) 84%, transparent);
}

body.ng-home .ng-hero-copy {
  display: grid;
  gap: 18px;
  align-content: center;
  min-height: 100%;
  padding: 18px 0 28px;
}

body.ng-home .ng-hero-copy h1 {
  font-size: clamp(3.12rem, 5vw, 4.3rem) !important;
  line-height: 0.95 !important;
  letter-spacing: -0.062em !important;
  margin-bottom: 0;
  max-width: 10.5ch;
  text-wrap: balance;
}

body.ng-home .ng-lead {
  margin-bottom: 0;
  max-width: 34rem;
  font-size: 1.125rem;
  line-height: 1.68;
}

body.ng-home .ng-sublead {
  max-width: 31rem;
  margin: 0;
  font-size: 1rem;
  line-height: 1.78;
  color: rgba(236, 242, 255, 0.62);
}

body.ng-home .ng-hero-actions {
  gap: 12px;
  margin-top: 8px;
}

body.ng-home .btn {
  min-height: 46px;
  padding: 0 18px;
  border-radius: 15px;
  font-size: 0.95rem;
}

body.ng-home .btn-primary {
  background: linear-gradient(135deg, #4474ff 0%, #274bd0 100%);
  color: #ffffff;
  box-shadow: 0 18px 34px rgba(36, 74, 195, 0.26);
}

body.ng-home .btn-primary:hover {
  background: linear-gradient(135deg, #4f7eff 0%, #2a4fd7 100%);
}

body.ng-home .btn-secondary {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.12);
  color: var(--ng-text);
}

body.ng-home .btn-secondary:hover {
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(255, 255, 255, 0.18);
  box-shadow: 0 12px 26px rgba(0,0,0,0.18);
}

body.ng-home .ng-hero-signals {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 10px;
}

body.ng-home .ng-signal {
  display: grid;
  gap: 6px;
  padding-top: 16px;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
}

body.ng-home .ng-signal-label,
body.ng-home .ng-node-label,
body.ng-home .ng-rail-index,
body.ng-home .ng-process-index {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(236, 242, 255, 0.46);
}

body.ng-home .ng-signal strong {
  font-size: 0.95rem;
  font-weight: 600;
}

body.ng-home .ng-hero-visual {
  position: relative;
}

body.ng-home .ng-hero-visual-topline {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 12px;
}

body.ng-home .ng-pill,
body.ng-home .ng-label-pill {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 11px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.04);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(236, 242, 255, 0.62);
}

body.ng-home .ng-pill.is-muted,
body.ng-home .ng-label-pill.is-accent {
  border-color: rgba(136, 169, 255, 0.18);
  background: rgba(75, 123, 255, 0.09);
  color: rgba(192, 209, 255, 0.86);
}

body.ng-home .ng-hero-frame {
  position: relative;
  min-height: 100%;
  padding: 28px;
  border: 1px solid var(--ng-line);
  border-radius: 30px;
  background:
    linear-gradient(180deg, rgba(16, 26, 46, 0.82) 0%, rgba(10, 17, 30, 0.92) 100%);
  box-shadow: var(--ng-shadow-lg);
  overflow: hidden;
}

body.ng-home .ng-hero-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,0.05), transparent 26%, transparent 72%, rgba(255,255,255,0.03));
  pointer-events: none;
}

body.ng-home .ng-frame-grid {
  position: absolute;
  inset: 0;
  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: 54px 54px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,0.54), transparent 86%);
  opacity: 0.42;
}

body.ng-home .ng-hero-orb {
  position: absolute;
  width: 16rem;
  height: 16rem;
  top: -4rem;
  right: -3rem;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(91, 137, 255, 0.42) 0%, rgba(91, 137, 255, 0.08) 42%, transparent 68%);
  filter: blur(8px);
  opacity: 0.62;
}

body.ng-home .ng-hero-core {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 18px;
}

body.ng-home .ng-hero-core-header {
  display: grid;
  gap: 8px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

body.ng-home .ng-hero-core-header strong {
  font-size: 1.05rem;
  letter-spacing: -0.02em;
}

body.ng-home .ng-hero-core-header p,
body.ng-home .ng-hero-node p,
body.ng-home .ng-hero-node h3,
body.ng-home .ng-hero-node h2 {
  margin-bottom: 0;
}

body.ng-home .ng-hero-core-grid {
  display: grid;
  gap: 14px;
}

body.ng-home .ng-hero-node {
  position: relative;
  display: grid;
  gap: 8px;
  padding: 18px 18px 18px 20px;
  border-radius: 22px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.03);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}

body.ng-home .ng-hero-node::before {
  content: "";
  position: absolute;
  left: 0;
  top: 18px;
  bottom: 18px;
  width: 1px;
  background: linear-gradient(180deg, transparent, rgba(136,169,255,0.52), transparent);
}

body.ng-home .ng-hero-node.is-primary {
  background: linear-gradient(180deg, rgba(76, 122, 255, 0.14) 0%, rgba(255,255,255,0.04) 100%);
  border-color: rgba(136, 169, 255, 0.18);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06), 0 18px 36px rgba(16, 26, 46, 0.22);
}

body.ng-home .ng-hero-node.is-primary h2,
body.ng-home .ng-hero-node h3 {
  font-size: 1.12rem;
  line-height: 1.22;
  letter-spacing: -0.03em;
  color: var(--ng-text);
}

body.ng-home .ng-hero-side-tag {
  position: absolute;
  z-index: 1;
  min-height: 32px;
  display: inline-flex;
  align-items: center;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(6, 12, 22, 0.78);
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(236, 242, 255, 0.48);
  backdrop-filter: blur(12px);
}

body.ng-home .ng-hero-side-tag.is-left {
  left: -10px;
  top: 112px;
}

body.ng-home .ng-hero-side-tag.is-right {
  right: 16px;
  bottom: 20px;
}

body.ng-home .ng-hero-rail {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  margin-top: 28px;
  border-top: 1px solid rgba(255,255,255,0.08);
  border-bottom: 1px solid rgba(255,255,255,0.04);
}

body.ng-home .ng-rail-item {
  display: grid;
  gap: 8px;
  padding: 18px 18px 20px;
  border-right: 1px solid rgba(255,255,255,0.08);
}

body.ng-home .ng-rail-item:last-child {
  border-right: none;
}

body.ng-home .ng-rail-item strong {
  font-size: 0.98rem;
  font-weight: 600;
}

body.ng-home .ng-rail-item p {
  margin-bottom: 0;
  font-size: 0.96rem;
  line-height: 1.7;
}

body.ng-home .ng-active-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.18fr) minmax(0, 0.92fr);
  grid-template-areas: "studio labs systems";
  gap: 20px;
  align-items: start;
}

body.ng-home .ng-active-card,
body.ng-home .ng-map-card {
  position: relative;
  display: grid;
  gap: 12px;
  padding: 24px 22px;
  border-radius: 26px;
  border: 1px solid var(--ng-line);
  background: linear-gradient(180deg, rgba(12, 21, 37, 0.82) 0%, rgba(8, 15, 28, 0.94) 100%);
  box-shadow: var(--ng-shadow-md);
  text-decoration: none;
  color: inherit;
  overflow: hidden;
  transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease, background 0.22s ease;
}

body.ng-home .ng-active-card::before,
body.ng-home .ng-map-card::before,
body.ng-home .ng-editorial-shell::before,
body.ng-home .ng-footer-shell::before {
  content: "";
  position: absolute;
  top: 0;
  left: 18px;
  right: 18px;
  height: 1px;
  background: linear-gradient(90deg, rgba(136,169,255,0.28), transparent);
}

body.ng-home .ng-active-card:hover,
body.ng-home .ng-map-card:hover {
  transform: translateY(-4px);
  border-color: rgba(136, 169, 255, 0.18);
  box-shadow: 0 26px 52px rgba(0,0,0,0.28);
}

body.ng-home .ng-card-topline {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
}

body.ng-home .ng-active-card h3,
body.ng-home .ng-map-card h3,
body.ng-home .ng-process-step h3,
body.ng-home .ng-band-item strong,
body.ng-home .ng-editorial-point strong {
  margin-bottom: 0;
  font-size: 1.28rem;
  line-height: 1.14;
  letter-spacing: -0.03em;
}

body.ng-home .ng-active-card p,
body.ng-home .ng-map-card p,
body.ng-home .ng-band-item p,
body.ng-home .ng-editorial-note p,
body.ng-home .ng-editorial-point p,
body.ng-home .ng-process-step p,
body.ng-home .ng-footer-column p,
body.ng-home .ng-footer-bottom span,
body.ng-home .ng-footer-brand h2 {
  margin-bottom: 0;
}

body.ng-home .ng-card-list {
  display: grid;
  gap: 8px;
  margin: 0;
  padding-left: 18px;
}

body.ng-home .ng-card-list li {
  line-height: 1.65;
}

body.ng-home .ng-card-list li::marker {
  color: var(--ng-accent-strong);
}

body.ng-home .ng-inline-link {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--ng-text);
}

body.ng-home .ng-inline-link::after {
  content: "→";
  font-size: 0.82em;
  color: rgba(192, 209, 255, 0.92);
}

body.ng-home .ng-active-card.is-studio {
  grid-area: studio;
  min-height: 310px;
  margin-top: 38px;
}

body.ng-home .ng-active-card.is-labs {
  grid-area: labs;
  min-height: 386px;
  padding: 30px 28px;
  margin-top: 0;
  background:
    radial-gradient(circle at 78% 18%, rgba(75,123,255,0.18), transparent 28%),
    linear-gradient(180deg, rgba(18, 31, 58, 0.98) 0%, rgba(10, 18, 33, 0.98) 100%);
  border-color: rgba(136, 169, 255, 0.18);
  box-shadow: 0 30px 64px rgba(0,0,0,0.32);
}

body.ng-home .ng-active-card.is-systems {
  grid-area: systems;
  min-height: 290px;
  margin-top: 74px;
}

body.ng-home .ng-card-meter {
  height: 5px;
  border-radius: 999px;
  background: rgba(255,255,255,0.06);
  overflow: hidden;
}

body.ng-home .ng-card-meter span {
  display: block;
  width: 68%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(73,123,255,0.92), rgba(136,169,255,0.95));
}

body.ng-home .ng-editorial-shell {
  position: relative;
  padding: 34px 0 0;
}

body.ng-home .ng-editorial-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.9fr);
  gap: 42px;
  align-items: start;
}

body.ng-home .ng-editorial-main {
  display: grid;
  gap: 16px;
}

body.ng-home .ng-editorial-copy {
  display: grid;
  gap: 16px;
  max-width: 42rem;
}

body.ng-home .ng-editorial-copy p {
  font-size: 1.08rem;
  line-height: 1.86;
}

body.ng-home .ng-editorial-side {
  display: grid;
  gap: 16px;
}

body.ng-home .ng-editorial-note,
body.ng-home .ng-editorial-point {
  border: 1px solid var(--ng-line);
  background: rgba(255,255,255,0.03);
  box-shadow: var(--ng-shadow-sm);
}

body.ng-home .ng-editorial-note {
  display: grid;
  gap: 10px;
  padding: 22px;
  border-radius: 22px;
}

body.ng-home .ng-editorial-points {
  display: grid;
  gap: 12px;
}

body.ng-home .ng-editorial-point {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  padding: 18px;
  border-radius: 20px;
}

body.ng-home .ng-editorial-point span {
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04);
  font-size: 0.76rem;
  font-weight: 800;
  color: var(--ng-text);
}

body.ng-home .ng-editorial-band {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  margin-top: 30px;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,0.08);
}

body.ng-home .ng-band-item {
  display: grid;
  gap: 8px;
  padding: 0 18px;
  border-right: 1px solid rgba(255,255,255,0.08);
}

body.ng-home .ng-band-item:first-child {
  padding-left: 0;
}

body.ng-home .ng-band-item:last-child {
  padding-right: 0;
  border-right: none;
}

body.ng-home .ng-process-shell {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 26px;
  margin-top: 12px;
  padding-top: 28px;
}

body.ng-home .ng-process-line {
  position: absolute;
  left: 0;
  right: 0;
  top: 36px;
  height: 1px;
  background: linear-gradient(90deg, rgba(255,255,255,0.08), rgba(136,169,255,0.16), rgba(255,255,255,0.08));
}

body.ng-home .ng-process-step {
  position: relative;
  display: grid;
  gap: 10px;
  padding-top: 38px;
}

body.ng-home .ng-process-step:nth-child(3),
body.ng-home .ng-process-step:nth-child(5) {
  margin-top: 48px;
}

body.ng-home .ng-process-step::before {
  content: "";
  position: absolute;
  left: 0;
  top: 30px;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--ng-accent);
  box-shadow: 0 0 0 8px rgba(75,123,255,0.12);
}

body.ng-home .ng-map-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(0, 0.86fr) minmax(0, 0.86fr);
  grid-template-areas:
    "group companies vision"
    "group contact vision";
  gap: 18px;
}

body.ng-home .ng-map-card {
  min-height: 190px;
}

body.ng-home .ng-map-card.is-group {
  grid-area: group;
  min-height: 388px;
  padding: 30px 28px;
  background:
    radial-gradient(circle at 85% 18%, rgba(75,123,255,0.16), transparent 30%),
    linear-gradient(180deg, rgba(14,24,43,0.98) 0%, rgba(8,15,28,0.98) 100%);
}

body.ng-home .ng-map-card.is-companies {
  grid-area: companies;
}

body.ng-home .ng-map-card.is-vision {
  grid-area: vision;
  min-height: 388px;
}

body.ng-home .ng-map-card.is-contact {
  grid-area: contact;
  min-height: 180px;
}

body.ng-home .ng-map-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: auto;
}

body.ng-home .ng-map-meta span,
body.ng-home .ng-footer-markers span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 11px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03);
  font-size: 0.74rem;
  color: rgba(236, 242, 255, 0.56);
}

body.ng-home .ng-footer {
  padding-top: 20px;
}

body.ng-home .ng-footer-shell {
  position: relative;
  display: grid;
  gap: 28px;
  padding-top: 34px;
  border-top: 1px solid rgba(255,255,255,0.08);
}

body.ng-home .ng-footer-top {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(220px, 0.8fr);
  gap: 20px;
  align-items: end;
}

body.ng-home .ng-footer-brand {
  display: grid;
  gap: 12px;
  max-width: 44rem;
}

body.ng-home .ng-footer-brand h2 {
  font-size: clamp(1.6rem, 2.2vw, 2.2rem);
  line-height: 1.1;
  letter-spacing: -0.04em;
}

body.ng-home .ng-footer-markers {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

body.ng-home .ng-footer-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 24px;
}

body.ng-home .ng-footer-column {
  display: grid;
  gap: 10px;
}

body.ng-home .ng-footer-column strong {
  font-size: 0.86rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(236, 242, 255, 0.58);
}

body.ng-home .ng-footer-column .footer-links {
  display: grid;
  gap: 8px;
}

body.ng-home .ng-footer-column .footer-links a {
  color: rgba(236, 242, 255, 0.76);
}

body.ng-home .ng-footer-column .footer-links a:hover {
  color: var(--ng-text);
}

body.ng-home .ng-footer-bottom {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 12px;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,0.08);
}

body.ng-home .ng-footer-bottom span {
  color: rgba(236, 242, 255, 0.48);
  font-size: 0.88rem;
}

@media (max-width: 1180px) {
  body.ng-home .ng-nav-shell,
  body.ng-home .container {
    width: min(1220px, calc(100% - 36px));
  }

  body.ng-home .ng-nav-meta {
    display: none;
  }

  body.ng-home .ng-hero-grid {
    grid-template-columns: 1fr;
    gap: 26px;
  }

  body.ng-home .ng-hero-grid::after {
    display: none;
  }

  body.ng-home .ng-active-layout {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-areas:
      "labs labs"
      "studio systems";
  }

  body.ng-home .ng-active-card.is-studio,
  body.ng-home .ng-active-card.is-labs,
  body.ng-home .ng-active-card.is-systems {
    margin-top: 0;
    min-height: auto;
  }

  body.ng-home .ng-editorial-layout {
    grid-template-columns: 1fr;
  }

  body.ng-home .ng-process-shell {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.ng-home .ng-process-step:nth-child(3),
  body.ng-home .ng-process-step:nth-child(5) {
    margin-top: 0;
  }

  body.ng-home .ng-map-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-areas:
      "group group"
      "companies vision"
      "contact contact";
  }

  body.ng-home .ng-map-card.is-group,
  body.ng-home .ng-map-card.is-vision {
    min-height: 240px;
  }

  body.ng-home .ng-footer-top,
  body.ng-home .ng-footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.ng-home .ng-footer-markers {
    justify-content: flex-start;
  }
}

@media (max-width: 820px) {
  body.ng-home .site-header {
    padding-top: 12px;
  }

  body.ng-home .ng-nav-shell {
    width: calc(100% - 24px);
    min-height: 72px;
    padding: 0 16px;
    border-radius: 20px;
  }

  body.ng-home .nav-menu {
    gap: 10px;
  }

  body.ng-home .nav-menu.is-open {
    background: rgba(9, 16, 29, 0.94);
    border: 1px solid rgba(255,255,255,0.08);
    box-shadow: 0 18px 36px rgba(0,0,0,0.28);
  }

  body.ng-home .ng-page {
    padding-bottom: 88px;
  }

  body.ng-home .ng-hero,
  body.ng-home .ng-section {
    padding: 28px 0;
  }

  body.ng-home .ng-hero-copy h1 {
    font-size: clamp(2.28rem, 9vw, 3rem) !important;
    max-width: 100%;
  }

  body.ng-home .ng-section-head h2 {
    font-size: clamp(1.64rem, 7vw, 2.08rem) !important;
    max-width: 100%;
  }

  body.ng-home .ng-hero-signals,
  body.ng-home .ng-hero-rail,
  body.ng-home .ng-active-layout,
  body.ng-home .ng-editorial-band,
  body.ng-home .ng-process-shell,
  body.ng-home .ng-map-grid,
  body.ng-home .ng-footer-top,
  body.ng-home .ng-footer-grid {
    grid-template-columns: 1fr;
  }

  body.ng-home .ng-active-layout,
  body.ng-home .ng-map-grid {
    grid-template-areas: none;
  }

  body.ng-home .ng-active-card.is-studio,
  body.ng-home .ng-active-card.is-labs,
  body.ng-home .ng-active-card.is-systems,
  body.ng-home .ng-map-card.is-group,
  body.ng-home .ng-map-card.is-companies,
  body.ng-home .ng-map-card.is-vision,
  body.ng-home .ng-map-card.is-contact {
    grid-area: auto;
    min-height: auto;
  }

  body.ng-home .ng-hero-frame,
  body.ng-home .ng-active-card,
  body.ng-home .ng-map-card,
  body.ng-home .ng-editorial-note,
  body.ng-home .ng-editorial-point {
    padding: 20px 18px;
    border-radius: 22px;
  }

  body.ng-home .ng-hero-side-tag {
    position: static;
    width: fit-content;
  }

  body.ng-home .ng-process-line {
    display: none;
  }

  body.ng-home .ng-process-step {
    padding-top: 30px;
  }

  body.ng-home .ng-band-item,
  body.ng-home .ng-rail-item {
    padding: 0 0 14px;
    border-right: none;
    border-bottom: 1px solid rgba(255,255,255,0.08);
  }

  body.ng-home .ng-band-item:last-child,
  body.ng-home .ng-rail-item:last-child {
    padding-bottom: 0;
    border-bottom: none;
  }

  body.ng-home .ng-footer-bottom {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* Neyvon Group subpages */
body.ng-subpage .ng-page {
  padding-top: 10px;
  padding-bottom: 108px;
}

body.ng-subpage .ng-subhero-shell,
body.ng-subpage .ng-sub-shell {
  position: relative;
  padding-top: 36px;
}

body.ng-subpage .ng-subhero-grid {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(340px, 0.96fr);
  gap: 36px;
  align-items: start;
}

body.ng-subpage .ng-subhero-grid::after {
  content: "";
  position: absolute;
  top: 18px;
  bottom: 18px;
  left: calc(100% - 340px - 18px);
  width: 1px;
  background: linear-gradient(180deg, transparent, rgba(255,255,255,0.12) 16%, rgba(255,255,255,0.12) 84%, transparent);
}

body.ng-subpage .ng-subhero-copy {
  display: grid;
  gap: 18px;
  align-content: center;
  max-width: 40rem;
}

body.ng-subpage .ng-subhero-copy h1 {
  font-size: clamp(2.72rem, 4.2vw, 3.6rem) !important;
  line-height: 0.98 !important;
  letter-spacing: -0.055em !important;
  margin-bottom: 0;
  max-width: 12ch;
  text-wrap: balance;
}

body.ng-subpage .ng-subhero-lead {
  margin-bottom: 0;
  max-width: 36rem;
  font-size: 1.08rem;
  line-height: 1.76;
}

body.ng-subpage .ng-subhero-sublead {
  margin: 0;
  max-width: 32rem;
  font-size: 1rem;
  line-height: 1.8;
  color: rgba(236, 242, 255, 0.62);
}

body.ng-subpage .ng-subhero-side {
  position: relative;
}

body.ng-subpage .ng-side-frame {
  position: relative;
  padding: 24px;
  border: 1px solid var(--ng-line);
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(14,24,43,0.92) 0%, rgba(9,16,29,0.96) 100%);
  box-shadow: var(--ng-shadow-lg);
  overflow: hidden;
}

body.ng-subpage .ng-side-frame::before,
body.ng-subpage .ng-stage-card::before,
body.ng-subpage .ng-simple-card::before,
body.ng-subpage .ng-route-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 18px;
  right: 18px;
  height: 1px;
  background: linear-gradient(90deg, rgba(136,169,255,0.28), transparent);
}

body.ng-subpage .ng-side-head {
  display: grid;
  gap: 8px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

body.ng-subpage .ng-side-head strong {
  font-size: 1.02rem;
  letter-spacing: -0.02em;
}

body.ng-subpage .ng-side-head p {
  margin-bottom: 0;
}

body.ng-subpage .ng-side-stack {
  display: grid;
  gap: 12px;
  margin-top: 14px;
}

body.ng-subpage .ng-side-card,
body.ng-subpage .ng-simple-card,
body.ng-subpage .ng-stage-card,
body.ng-subpage .ng-route-card {
  position: relative;
  display: grid;
  gap: 10px;
  padding: 20px 18px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03);
  box-shadow: var(--ng-shadow-sm);
  overflow: hidden;
}

body.ng-subpage .ng-side-card.is-accent,
body.ng-subpage .ng-stage-card.is-active,
body.ng-subpage .ng-route-card.is-primary {
  border-color: rgba(136, 169, 255, 0.18);
  background: linear-gradient(180deg, rgba(75,123,255,0.12) 0%, rgba(255,255,255,0.03) 100%);
}

body.ng-subpage .ng-stage-card.is-ready {
  background: linear-gradient(180deg, rgba(255,255,255,0.05) 0%, rgba(255,255,255,0.03) 100%);
}

body.ng-subpage .ng-stage-card.is-pause {
  background: linear-gradient(180deg, rgba(48, 64, 97, 0.22) 0%, rgba(255,255,255,0.03) 100%);
}

body.ng-subpage .ng-side-card h3,
body.ng-subpage .ng-simple-card h3,
body.ng-subpage .ng-stage-card h3,
body.ng-subpage .ng-route-card h3,
body.ng-subpage .ng-vision-step h3 {
  margin-bottom: 0;
  font-size: 1.16rem;
  line-height: 1.18;
  letter-spacing: -0.03em;
}

body.ng-subpage .ng-side-card p,
body.ng-subpage .ng-simple-card p,
body.ng-subpage .ng-stage-card p,
body.ng-subpage .ng-route-card p,
body.ng-subpage .ng-vision-step p,
body.ng-subpage .ng-info-item p,
body.ng-subpage .ng-feature-copy p,
body.ng-subpage .ng-footer-column p {
  margin-bottom: 0;
  font-size: 1rem;
  line-height: 1.78;
}

body.ng-subpage .ng-info-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  margin-top: 28px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,0.08);
}

body.ng-subpage .ng-info-item {
  display: grid;
  gap: 8px;
  padding: 0 18px;
  border-right: 1px solid rgba(255,255,255,0.08);
}

body.ng-subpage .ng-info-item:first-child {
  padding-left: 0;
}

body.ng-subpage .ng-info-item:last-child {
  padding-right: 0;
  border-right: none;
}

body.ng-subpage .ng-info-item strong {
  font-size: 0.98rem;
  font-weight: 600;
}

body.ng-subpage .ng-feature-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
  gap: 36px;
  align-items: start;
}

body.ng-subpage .ng-feature-copy {
  display: grid;
  gap: 16px;
  max-width: 42rem;
}

body.ng-subpage .ng-simple-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

body.ng-subpage .ng-simple-grid.three,
body.ng-subpage .ng-stage-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body.ng-subpage .ng-stage-grid,
body.ng-subpage .ng-route-grid,
body.ng-subpage .ng-vision-timeline {
  display: grid;
  gap: 18px;
}

body.ng-subpage .ng-stage-card ul {
  display: grid;
  gap: 8px;
  margin: 0;
  padding-left: 18px;
}

body.ng-subpage .ng-stage-card li::marker {
  color: var(--ng-accent-strong);
}

body.ng-subpage .ng-route-grid {
  grid-template-columns: minmax(0, 1.16fr) minmax(0, 0.84fr) minmax(0, 0.84fr);
}

body.ng-subpage .ng-route-card {
  min-height: 220px;
  text-decoration: none;
  color: inherit;
  transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
}

body.ng-subpage .ng-route-card:hover,
body.ng-subpage .ng-simple-card:hover,
body.ng-subpage .ng-stage-card:hover {
  transform: translateY(-4px);
  border-color: rgba(136, 169, 255, 0.16);
  box-shadow: 0 24px 48px rgba(0,0,0,0.24);
}

body.ng-subpage .ng-vision-timeline {
  position: relative;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  margin-top: 12px;
  padding-top: 30px;
}

body.ng-subpage .ng-vision-timeline::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 38px;
  height: 1px;
  background: linear-gradient(90deg, rgba(255,255,255,0.08), rgba(136,169,255,0.18), rgba(255,255,255,0.08));
}

body.ng-subpage .ng-vision-step {
  position: relative;
  display: grid;
  gap: 10px;
  padding-top: 40px;
}

body.ng-subpage .ng-vision-step:nth-child(2),
body.ng-subpage .ng-vision-step:nth-child(4) {
  margin-top: 42px;
}

body.ng-subpage .ng-vision-step::before {
  content: "";
  position: absolute;
  left: 0;
  top: 32px;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--ng-accent);
  box-shadow: 0 0 0 8px rgba(75,123,255,0.12);
}

@media (max-width: 1180px) {
  body.ng-subpage .ng-subhero-grid,
  body.ng-subpage .ng-feature-layout {
    grid-template-columns: 1fr;
  }

  body.ng-subpage .ng-subhero-grid::after {
    display: none;
  }

  body.ng-subpage .ng-simple-grid,
  body.ng-subpage .ng-stage-grid,
  body.ng-subpage .ng-route-grid,
  body.ng-subpage .ng-vision-timeline {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.ng-subpage .ng-simple-grid.three {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 820px) {
  body.ng-subpage .ng-page {
    padding-bottom: 88px;
  }

  body.ng-subpage .ng-subhero-copy h1 {
    font-size: clamp(2.1rem, 8vw, 2.7rem) !important;
    max-width: 100%;
  }

  body.ng-subpage .ng-info-strip,
  body.ng-subpage .ng-simple-grid,
  body.ng-subpage .ng-simple-grid.three,
  body.ng-subpage .ng-stage-grid,
  body.ng-subpage .ng-route-grid,
  body.ng-subpage .ng-vision-timeline {
    grid-template-columns: 1fr;
  }

  body.ng-subpage .ng-subhero-shell,
  body.ng-subpage .ng-sub-shell {
    padding-top: 26px;
  }

  body.ng-subpage .ng-side-frame,
  body.ng-subpage .ng-side-card,
  body.ng-subpage .ng-simple-card,
  body.ng-subpage .ng-stage-card,
  body.ng-subpage .ng-route-card {
    padding: 18px;
    border-radius: 20px;
  }

  body.ng-subpage .ng-info-item {
    padding: 0 0 14px;
    border-right: none;
    border-bottom: 1px solid rgba(255,255,255,0.08);
  }

  body.ng-subpage .ng-info-item:last-child {
    padding-bottom: 0;
    border-bottom: none;
  }

  body.ng-subpage .ng-vision-timeline::before {
    display: none;
  }

  body.ng-subpage .ng-vision-step:nth-child(2),
  body.ng-subpage .ng-vision-step:nth-child(4) {
    margin-top: 0;
  }
}

/* Neyvon Group home premium refinement */
body.ng-home:not(.ng-subpage) .ng-page {
  padding-top: 4px;
  padding-bottom: 104px;
}

body.ng-home:not(.ng-subpage) .ng-hero {
  padding: 30px 0 34px;
}

body.ng-home:not(.ng-subpage) .ng-section {
  padding: 34px 0;
}

body.ng-home:not(.ng-subpage) .ng-nav-shell {
  min-height: 78px;
  padding: 0 22px;
  border-radius: 22px;
  background: rgba(10, 18, 31, 0.68);
  box-shadow: 0 16px 36px rgba(0, 0, 0, 0.2);
}

body.ng-home:not(.ng-subpage) .brand-copy strong {
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  color: rgba(236, 242, 255, 0.6);
}

body.ng-home:not(.ng-subpage) .brand-copy small {
  font-size: 0.97rem;
  font-weight: 620;
}

body.ng-home:not(.ng-subpage) .nav-actions {
  gap: 14px;
}

body.ng-home:not(.ng-subpage) .nav-menu {
  gap: 14px;
}

body.ng-home:not(.ng-subpage) .nav-link {
  padding: 10px 3px;
  font-size: 0.91rem;
}

body.ng-home:not(.ng-subpage) .ng-kicker {
  font-size: 0.66rem;
  letter-spacing: 0.17em;
  color: rgba(236, 242, 255, 0.42);
}

body.ng-home:not(.ng-subpage) .ng-section-head {
  gap: 10px;
  margin-bottom: 24px;
  max-width: 46rem;
}

body.ng-home:not(.ng-subpage) .ng-section-head.is-compact {
  margin-bottom: 18px;
}

body.ng-home:not(.ng-subpage) .ng-section-head h2 {
  font-size: clamp(1.78rem, 2.6vw, 2.42rem) !important;
  line-height: 1.04 !important;
  letter-spacing: -0.046em !important;
  max-width: 16.4ch;
}

body.ng-home:not(.ng-subpage) .ng-section-head p {
  max-width: 38rem;
  font-size: 0.98rem;
  line-height: 1.76;
}

body.ng-home:not(.ng-subpage) .ng-hero-shell {
  padding-top: 28px;
}

body.ng-home:not(.ng-subpage) .ng-hero-grid {
  grid-template-columns: minmax(0, 1.04fr) minmax(340px, 0.96fr);
  gap: 38px;
  align-items: center;
}

body.ng-home:not(.ng-subpage) .ng-hero-grid::after {
  top: 28px;
  bottom: 28px;
  left: calc(100% - 340px - 19px);
}

body.ng-home:not(.ng-subpage) .ng-hero-copy {
  gap: 16px;
  max-width: 36.5rem;
  padding: 10px 0 20px;
}

body.ng-home:not(.ng-subpage) .ng-hero-copy h1 {
  font-size: clamp(2.92rem, 4.55vw, 3.82rem) !important;
  line-height: 0.97 !important;
  letter-spacing: -0.058em !important;
  max-width: 10.9ch;
}

body.ng-home:not(.ng-subpage) .ng-lead {
  max-width: 30rem;
  font-size: 1.04rem;
  line-height: 1.72;
}

body.ng-home:not(.ng-subpage) .ng-sublead {
  max-width: 29rem;
  font-size: 0.985rem;
  line-height: 1.8;
}

body.ng-home:not(.ng-subpage) .ng-hero-actions {
  gap: 10px;
  margin-top: 4px;
}

body.ng-home:not(.ng-subpage) .btn {
  min-height: 44px;
  padding: 0 16px;
  border-radius: 14px;
  font-size: 0.92rem;
}

body.ng-home:not(.ng-subpage) .btn-primary {
  box-shadow: 0 16px 30px rgba(36, 74, 195, 0.22);
}

body.ng-home:not(.ng-subpage) .ng-hero-signals {
  margin-top: 12px;
  gap: 18px;
}

body.ng-home:not(.ng-subpage) .ng-signal {
  gap: 7px;
  padding-top: 14px;
}

body.ng-home:not(.ng-subpage) .ng-signal strong {
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: -0.01em;
}

body.ng-home:not(.ng-subpage) .ng-signal p {
  margin: 0;
  font-size: 0.94rem;
  line-height: 1.7;
  color: rgba(236, 242, 255, 0.62);
}

body.ng-home:not(.ng-subpage) .ng-hero-frame {
  padding: 24px;
  border-radius: 28px;
  box-shadow: 0 28px 72px rgba(0, 0, 0, 0.32);
}

body.ng-home:not(.ng-subpage) .ng-frame-grid {
  opacity: 0.28;
  background-size: 64px 64px;
}

body.ng-home:not(.ng-subpage) .ng-hero-orb {
  width: 13rem;
  height: 13rem;
  top: -3.5rem;
  right: -2.4rem;
  opacity: 0.42;
  filter: blur(10px);
}

body.ng-home:not(.ng-subpage) .ng-hero-core {
  gap: 16px;
}

body.ng-home:not(.ng-subpage) .ng-hero-core-header {
  gap: 7px;
  padding-bottom: 14px;
}

body.ng-home:not(.ng-subpage) .ng-hero-core-header strong {
  font-size: 0.98rem;
}

body.ng-home:not(.ng-subpage) .ng-hero-core-header p {
  max-width: 24rem;
  font-size: 0.92rem;
  line-height: 1.68;
}

body.ng-home:not(.ng-subpage) .ng-hero-core-grid {
  gap: 12px;
}

body.ng-home:not(.ng-subpage) .ng-node-label,
body.ng-home:not(.ng-subpage) .ng-rail-index,
body.ng-home:not(.ng-subpage) .ng-process-index {
  font-size: 0.67rem;
  letter-spacing: 0.14em;
}

body.ng-home:not(.ng-subpage) .ng-hero-node {
  gap: 7px;
  padding: 16px 16px 16px 18px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.028);
}

body.ng-home:not(.ng-subpage) .ng-hero-node.is-primary h2,
body.ng-home:not(.ng-subpage) .ng-hero-node h3 {
  font-size: 1.04rem;
  line-height: 1.22;
}

body.ng-home:not(.ng-subpage) .ng-hero-node p {
  font-size: 0.93rem;
  line-height: 1.7;
  color: rgba(236, 242, 255, 0.62);
}

body.ng-home:not(.ng-subpage) .ng-hero-rail {
  margin-top: 24px;
  border-bottom: none;
}

body.ng-home:not(.ng-subpage) .ng-rail-item {
  gap: 7px;
  padding: 16px 16px 18px;
}

body.ng-home:not(.ng-subpage) .ng-rail-item strong {
  font-size: 0.93rem;
}

body.ng-home:not(.ng-subpage) .ng-rail-item p {
  font-size: 0.92rem;
  line-height: 1.66;
}

body.ng-home:not(.ng-subpage) .ng-active-layout {
  gap: 18px;
  align-items: stretch;
}

body.ng-home:not(.ng-subpage) .ng-active-card {
  gap: 10px;
  padding: 22px 20px;
  border-radius: 24px;
}

body.ng-home:not(.ng-subpage) .ng-active-card:hover,
body.ng-home:not(.ng-subpage) .ng-map-card:hover {
  transform: translateY(-3px);
}

body.ng-home:not(.ng-subpage) .ng-active-card h3,
body.ng-home:not(.ng-subpage) .ng-map-card h3,
body.ng-home:not(.ng-subpage) .ng-process-step h3,
body.ng-home:not(.ng-subpage) .ng-band-item strong,
body.ng-home:not(.ng-subpage) .ng-editorial-point strong {
  font-size: 1.16rem;
  line-height: 1.18;
}

body.ng-home:not(.ng-subpage) .ng-active-card p,
body.ng-home:not(.ng-subpage) .ng-map-card p,
body.ng-home:not(.ng-subpage) .ng-band-item p,
body.ng-home:not(.ng-subpage) .ng-editorial-note p,
body.ng-home:not(.ng-subpage) .ng-editorial-point p,
body.ng-home:not(.ng-subpage) .ng-process-step p,
body.ng-home:not(.ng-subpage) .ng-footer-column p {
  font-size: 0.95rem;
  line-height: 1.74;
}

body.ng-home:not(.ng-subpage) .ng-card-list {
  gap: 7px;
  padding-left: 17px;
}

body.ng-home:not(.ng-subpage) .ng-card-list li {
  font-size: 0.9rem;
  line-height: 1.6;
}

body.ng-home:not(.ng-subpage) .ng-inline-link {
  margin-top: 8px;
  font-size: 0.89rem;
}

body.ng-home:not(.ng-subpage) .ng-active-card.is-studio {
  min-height: 292px;
  margin-top: 24px;
}

body.ng-home:not(.ng-subpage) .ng-active-card.is-labs {
  min-height: 338px;
  padding: 24px 22px;
  box-shadow: 0 26px 58px rgba(0, 0, 0, 0.28);
}

body.ng-home:not(.ng-subpage) .ng-active-card.is-systems {
  min-height: 278px;
  margin-top: 52px;
}

body.ng-home:not(.ng-subpage) .ng-editorial-shell {
  padding-top: 24px;
}

body.ng-home:not(.ng-subpage) .ng-editorial-layout {
  grid-template-columns: minmax(0, 1.08fr) minmax(300px, 0.82fr);
  gap: 52px;
}

body.ng-home:not(.ng-subpage) .ng-editorial-copy {
  gap: 14px;
  max-width: 37rem;
}

body.ng-home:not(.ng-subpage) .ng-editorial-copy p {
  font-size: 1.01rem;
  line-height: 1.82;
}

body.ng-home:not(.ng-subpage) .ng-editorial-note {
  padding: 20px;
  border-radius: 20px;
}

body.ng-home:not(.ng-subpage) .ng-editorial-note p {
  font-size: 0.96rem;
  line-height: 1.72;
}

body.ng-home:not(.ng-subpage) .ng-editorial-points {
  gap: 10px;
}

body.ng-home:not(.ng-subpage) .ng-editorial-point {
  padding: 16px;
  gap: 12px;
  border-radius: 18px;
}

body.ng-home:not(.ng-subpage) .ng-editorial-point span {
  width: 34px;
  height: 34px;
  border-radius: 11px;
  font-size: 0.72rem;
}

body.ng-home:not(.ng-subpage) .ng-editorial-band {
  margin-top: 26px;
  padding-top: 16px;
}

body.ng-home:not(.ng-subpage) .ng-band-item {
  gap: 6px;
  padding: 0 16px;
}

body.ng-home:not(.ng-subpage) .ng-band-item p {
  font-size: 0.9rem;
  line-height: 1.66;
}

body.ng-home:not(.ng-subpage) .ng-process-shell {
  gap: 22px;
  margin-top: 10px;
  padding-top: 24px;
}

body.ng-home:not(.ng-subpage) .ng-process-line {
  top: 30px;
  background: linear-gradient(90deg, rgba(255,255,255,0.06), rgba(136,169,255,0.18), rgba(255,255,255,0.06));
}

body.ng-home:not(.ng-subpage) .ng-process-step {
  gap: 8px;
  padding-top: 32px;
}

body.ng-home:not(.ng-subpage) .ng-process-step:nth-child(3),
body.ng-home:not(.ng-subpage) .ng-process-step:nth-child(5) {
  margin-top: 34px;
}

body.ng-home:not(.ng-subpage) .ng-process-step::before {
  top: 24px;
  width: 8px;
  height: 8px;
  box-shadow: 0 0 0 7px rgba(75,123,255,0.1);
}

body.ng-home:not(.ng-subpage) .ng-process-step p {
  max-width: 18rem;
  font-size: 0.93rem;
  line-height: 1.72;
}

body.ng-home:not(.ng-subpage) .ng-map-grid {
  gap: 16px;
}

body.ng-home:not(.ng-subpage) .ng-map-card {
  gap: 10px;
  min-height: 164px;
  padding: 22px 20px;
  border-radius: 24px;
}

body.ng-home:not(.ng-subpage) .ng-map-card.is-group {
  min-height: 332px;
  padding: 26px 24px;
}

body.ng-home:not(.ng-subpage) .ng-map-card.is-vision {
  min-height: 332px;
}

body.ng-home:not(.ng-subpage) .ng-map-card.is-contact {
  min-height: 150px;
}

body.ng-home:not(.ng-subpage) .ng-map-card p {
  max-width: 25rem;
}

body.ng-home:not(.ng-subpage) .ng-footer {
  padding-top: 12px;
}

body.ng-home:not(.ng-subpage) .ng-footer-shell {
  gap: 24px;
  padding-top: 30px;
}

body.ng-home:not(.ng-subpage) .ng-footer-top {
  grid-template-columns: 1fr;
  gap: 10px;
}

body.ng-home:not(.ng-subpage) .ng-footer-brand {
  gap: 8px;
  max-width: 36rem;
}

body.ng-home:not(.ng-subpage) .ng-footer-brand strong {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(236, 242, 255, 0.48);
}

body.ng-home:not(.ng-subpage) .ng-footer-brand h2 {
  font-size: clamp(1.42rem, 2vw, 1.9rem);
  line-height: 1.12;
  letter-spacing: -0.04em;
}

body.ng-home:not(.ng-subpage) .ng-footer-grid {
  gap: 20px;
}

body.ng-home:not(.ng-subpage) .ng-footer-column {
  gap: 8px;
}

body.ng-home:not(.ng-subpage) .ng-footer-column strong {
  font-size: 0.78rem;
  letter-spacing: 0.14em;
  color: rgba(236, 242, 255, 0.52);
}

body.ng-home:not(.ng-subpage) .ng-footer-column .footer-links {
  gap: 7px;
}

body.ng-home:not(.ng-subpage) .ng-footer-column .footer-links a,
body.ng-home:not(.ng-subpage) .ng-footer-column p {
  font-size: 0.91rem;
  line-height: 1.7;
}

body.ng-home:not(.ng-subpage) .ng-footer-bottom {
  gap: 10px;
  padding-top: 16px;
}

body.ng-home:not(.ng-subpage) .ng-footer-bottom span {
  font-size: 0.84rem;
  color: rgba(236, 242, 255, 0.44);
}

@media (max-width: 1180px) {
  body.ng-home:not(.ng-subpage) .ng-hero-grid,
  body.ng-home:not(.ng-subpage) .ng-editorial-layout {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  body.ng-home:not(.ng-subpage) .ng-hero-grid::after {
    display: none;
  }

  body.ng-home:not(.ng-subpage) .ng-hero-frame {
    padding: 22px;
  }
}

@media (max-width: 820px) {
  body.ng-home:not(.ng-subpage) .ng-page {
    padding-bottom: 84px;
  }

  body.ng-home:not(.ng-subpage) .ng-hero,
  body.ng-home:not(.ng-subpage) .ng-section {
    padding: 28px 0;
  }

  body.ng-home:not(.ng-subpage) .ng-hero-copy h1 {
    font-size: clamp(2.18rem, 8.8vw, 2.86rem) !important;
    max-width: 100%;
  }

  body.ng-home:not(.ng-subpage) .ng-section-head h2 {
    font-size: clamp(1.56rem, 6.6vw, 2rem) !important;
    max-width: 100%;
  }

  body.ng-home:not(.ng-subpage) .ng-hero-frame,
  body.ng-home:not(.ng-subpage) .ng-active-card,
  body.ng-home:not(.ng-subpage) .ng-map-card,
  body.ng-home:not(.ng-subpage) .ng-editorial-note,
  body.ng-home:not(.ng-subpage) .ng-editorial-point {
    padding: 18px;
    border-radius: 20px;
  }

  body.ng-home:not(.ng-subpage) .ng-process-step:nth-child(3),
  body.ng-home:not(.ng-subpage) .ng-process-step:nth-child(5) {
    margin-top: 0;
  }
}

/* Neyvon core pages width alignment */
body.home-v5.home-page .container,
body.home-v5.group-page .container,
body.home-v5.companies-page .container,
body.home-v5.vision-page .container,
body.home-v5.contact-page .container {
  width: min(1200px, calc(100% - 40px)) !important;
}

body.home-v5.home-page .homev5-hero,
body.home-v5.group-page .homev5-hero,
body.home-v5.companies-page .homev5-hero,
body.home-v5.vision-page .homev5-hero,
body.home-v5.contact-page .homev5-hero,
body.home-v5.home-page .homev5-panel,
body.home-v5.group-page .homev5-panel,
body.home-v5.companies-page .homev5-panel,
body.home-v5.vision-page .homev5-panel,
body.home-v5.contact-page .homev5-panel {
  width: 100%;
  box-sizing: border-box;
}

@media (max-width: 640px) {
  body.home-v5.home-page .container,
  body.home-v5.group-page .container,
  body.home-v5.companies-page .container,
  body.home-v5.vision-page .container,
  body.home-v5.contact-page .container {
    width: calc(100% - 24px) !important;
  }
}

/* MPanel / Access */
body.access-page .status-pill.blue,
body.mpanel-page .status-pill.blue {
  background: rgba(47, 95, 232, 0.12);
  color: var(--blue);
  border-color: rgba(47, 95, 232, 0.18);
}

body.access-page .status-pill.violet,
body.mpanel-page .status-pill.violet {
  background: rgba(127, 88, 255, 0.12);
  color: #6650d6;
  border-color: rgba(127, 88, 255, 0.16);
}

body.access-page .status-pill.mint,
body.mpanel-page .status-pill.mint {
  background: rgba(41, 171, 115, 0.12);
  color: #20895c;
  border-color: rgba(41, 171, 115, 0.16);
}

body.access-page .status-pill.amber,
body.mpanel-page .status-pill.amber {
  background: rgba(255, 171, 51, 0.16);
  color: #a96b07;
  border-color: rgba(255, 171, 51, 0.2);
}

body.access-page .access-stage,
body.mpanel-page .mpanel-hero {
  padding: clamp(28px, 5vw, 44px);
  border-radius: 34px;
  border: 1px solid rgba(195, 208, 232, 0.78);
  background:
    radial-gradient(circle at top left, rgba(47, 95, 232, 0.08), transparent 28%),
    radial-gradient(circle at top right, rgba(127, 88, 255, 0.08), transparent 26%),
    rgba(255, 255, 255, 0.94);
  box-shadow: var(--shadow-md);
}

body.access-page .access-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(360px, 0.88fr);
  gap: 28px;
  align-items: stretch;
}

body.access-page .access-brand-panel,
body.mpanel-page .mpanel-hero-top,
body.mpanel-page .mpanel-shell {
  min-width: 0;
}

body.access-page .access-brand-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
}

body.access-page .access-brand-panel h1,
body.mpanel-page .mpanel-hero-top h1 {
  margin-bottom: 18px;
}

body.access-page .access-brand-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 28px;
}

body.access-page .access-brand-card,
body.mpanel-page .mpanel-summary-card,
body.mpanel-page .mpanel-card,
body.mpanel-page .mpanel-panel,
body.mpanel-page .mpanel-role-card,
body.mpanel-page .mpanel-user-card,
body.mpanel-page .mpanel-hero-side {
  border-radius: 24px;
  border: 1px solid rgba(195, 208, 232, 0.72);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: var(--shadow-sm);
}

body.access-page .access-brand-card {
  padding: 18px;
}

body.access-page .access-brand-card span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  margin-bottom: 12px;
  border-radius: 999px;
  font-weight: 700;
  color: var(--text);
  background: rgba(15, 35, 66, 0.06);
}

body.access-page .access-brand-card strong,
body.mpanel-page .mpanel-feature-list strong,
body.mpanel-page .mpanel-summary-card strong,
body.mpanel-page .mpanel-card strong,
body.mpanel-page .mpanel-panel strong,
body.mpanel-page .mpanel-role-card strong,
body.mpanel-page .mpanel-user-card strong {
  color: var(--text);
}

body.access-page .access-brand-card.blue {
  background: linear-gradient(180deg, rgba(234, 240, 255, 0.9), rgba(255, 255, 255, 0.94));
}

body.access-page .access-brand-card.violet {
  background: linear-gradient(180deg, rgba(241, 236, 255, 0.92), rgba(255, 255, 255, 0.94));
}

body.access-page .access-brand-card.mint {
  background: linear-gradient(180deg, rgba(236, 250, 244, 0.92), rgba(255, 255, 255, 0.94));
}

body.access-page .access-brand-card.amber {
  background: linear-gradient(180deg, rgba(255, 245, 232, 0.94), rgba(255, 255, 255, 0.94));
}

body.access-page .super-auth-card {
  padding: 24px;
  border-radius: 30px;
  border: 1px solid rgba(195, 208, 232, 0.8);
  background: rgba(255, 255, 255, 0.98);
  box-shadow: var(--shadow-lg);
}

body.access-page .auth-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 18px;
}

body.access-page .auth-hash-nav,
body.access-page .demo-role-row,
body.mpanel-page .mpanel-user-tags,
body.mpanel-page .mpanel-role-modules,
body.mpanel-page .mpanel-company-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

body.access-page .auth-pill,
body.access-page .demo-role-pill,
body.mpanel-page .mpanel-filter,
body.mpanel-page .mpanel-nav-item {
  appearance: none;
  border: 1px solid rgba(195, 208, 232, 0.8);
  background: rgba(247, 249, 255, 0.9);
  color: var(--text);
  border-radius: 999px;
  cursor: pointer;
  transition: 0.18s ease;
}

body.access-page .auth-pill {
  padding: 9px 14px;
  font-weight: 600;
}

body.access-page .auth-pill.is-active,
body.access-page .demo-role-pill:hover,
body.mpanel-page .mpanel-filter.is-active,
body.mpanel-page .mpanel-nav-item.is-active,
body.mpanel-page .mpanel-nav-item:hover,
body.mpanel-page .mpanel-filter:hover {
  background: rgba(47, 95, 232, 0.1);
  border-color: rgba(47, 95, 232, 0.24);
  color: var(--blue);
  box-shadow: 0 10px 26px rgba(47, 95, 232, 0.12);
}

body.access-page .demo-role-row {
  align-items: center;
  margin-bottom: 18px;
  padding: 14px;
  border-radius: 20px;
  border: 1px solid rgba(219, 228, 244, 0.9);
  background: rgba(247, 249, 255, 0.8);
}

body.access-page .demo-role-row > span {
  font-size: 0.94rem;
  font-weight: 600;
  color: var(--text);
}

body.access-page .demo-role-pill {
  padding: 8px 12px;
  font-size: 0.92rem;
}

body.access-page .auth-view {
  display: none;
}

body.access-page .auth-view.is-active,
body.mpanel-page .mpanel-section.is-active {
  display: block;
}

body.access-page .auth-form,
body.mpanel-page .mpanel-form {
  display: grid;
  gap: 14px;
}

body.access-page .field,
body.mpanel-page .field {
  display: grid;
  gap: 8px;
}

body.access-page .field span,
body.mpanel-page .field span {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text);
}

body.access-page input,
body.access-page textarea,
body.access-page select,
body.mpanel-page input,
body.mpanel-page textarea,
body.mpanel-page select {
  width: 100%;
  padding: 13px 14px;
  border-radius: 16px;
  border: 1px solid rgba(195, 208, 232, 0.9);
  background: rgba(255, 255, 255, 0.98);
  color: var(--text);
  outline: none;
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

body.access-page input:focus,
body.access-page textarea:focus,
body.access-page select:focus,
body.mpanel-page input:focus,
body.mpanel-page textarea:focus,
body.mpanel-page select:focus {
  border-color: rgba(47, 95, 232, 0.38);
  box-shadow: 0 0 0 4px rgba(47, 95, 232, 0.08);
}

body.access-page .auth-inline-row,
body.mpanel-page .auth-inline-row,
body.access-page .auth-actions,
body.mpanel-page .auth-actions,
body.mpanel-page .mpanel-card-actions,
body.mpanel-page .mpanel-user-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

body.access-page .align-left,
body.mpanel-page .align-left {
  justify-content: flex-start;
}

body.access-page .link-btn,
body.mpanel-page .link-btn {
  appearance: none;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--blue);
  cursor: pointer;
  font-weight: 600;
}

body.access-page .auth-feedback,
body.mpanel-page .auth-feedback {
  min-height: 1.4em;
  margin: 0;
  font-size: 0.94rem;
  color: var(--blue);
}

body.access-page .auth-note {
  margin: 0;
  padding: 14px 16px;
  border-radius: 16px;
  background: rgba(247, 249, 255, 0.9);
  border: 1px solid rgba(219, 228, 244, 0.9);
}

body.mpanel-page .mpanel-hero-top {
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(320px, 0.88fr);
  gap: 28px;
  align-items: start;
}

body.mpanel-page .mpanel-hero-side,
body.mpanel-page .mpanel-panel,
body.mpanel-page .mpanel-card,
body.mpanel-page .mpanel-role-card,
body.mpanel-page .mpanel-user-card {
  padding: 22px;
}

body.mpanel-page .mpanel-feature-list,
body.mpanel-page .mpanel-line-list {
  display: grid;
  gap: 12px;
  margin-top: 16px;
}

body.mpanel-page .mpanel-feature-list article,
body.mpanel-page .mpanel-line-item,
body.mpanel-page .mpanel-role-modules span {
  border-radius: 18px;
  border: 1px solid rgba(219, 228, 244, 0.8);
  background: rgba(247, 249, 255, 0.74);
}

body.mpanel-page .mpanel-feature-list article {
  padding: 14px 16px;
}

body.mpanel-page .mpanel-shell {
  display: grid;
  grid-template-columns: minmax(250px, 280px) minmax(0, 1fr);
  gap: 22px;
  align-items: start;
}

body.mpanel-page .mpanel-sidebar {
  position: sticky;
  top: 100px;
  display: grid;
  gap: 16px;
}

body.mpanel-page .mpanel-user-card {
  display: grid;
  gap: 12px;
}

body.mpanel-page .mpanel-user-card h3,
body.mpanel-page .mpanel-card h3,
body.mpanel-page .mpanel-panel h3,
body.mpanel-page .mpanel-role-card h3 {
  margin-bottom: 0;
}

body.mpanel-page .mpanel-user-meta {
  display: grid;
  gap: 6px;
  font-size: 0.94rem;
}

body.mpanel-page .mpanel-nav {
  display: grid;
  gap: 10px;
}

body.mpanel-page .mpanel-nav-item {
  text-align: left;
  padding: 12px 15px;
  font-weight: 600;
}

body.mpanel-page .mpanel-content,
body.mpanel-page .mpanel-app {
  min-width: 0;
}

body.mpanel-page .mpanel-section {
  display: none;
}

body.mpanel-page .mpanel-summary-grid,
body.mpanel-page .mpanel-card-grid,
body.mpanel-page .mpanel-grid-two,
body.mpanel-page .mpanel-role-grid {
  display: grid;
  gap: 16px;
}

body.mpanel-page .mpanel-summary-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-bottom: 16px;
}

body.mpanel-page .mpanel-summary-card {
  padding: 18px;
}

body.mpanel-page .mpanel-summary-card span {
  display: block;
  margin-bottom: 10px;
  font-size: 0.92rem;
  font-weight: 600;
}

body.mpanel-page .mpanel-summary-card strong {
  display: block;
  font-size: 1.6rem;
  line-height: 1.12;
  margin-bottom: 6px;
}

body.mpanel-page .mpanel-summary-card.blue {
  background: linear-gradient(180deg, rgba(234, 240, 255, 0.9), rgba(255, 255, 255, 0.94));
}

body.mpanel-page .mpanel-summary-card.violet {
  background: linear-gradient(180deg, rgba(241, 236, 255, 0.92), rgba(255, 255, 255, 0.94));
}

body.mpanel-page .mpanel-summary-card.amber {
  background: linear-gradient(180deg, rgba(255, 245, 232, 0.94), rgba(255, 255, 255, 0.94));
}

body.mpanel-page .mpanel-summary-card.mint {
  background: linear-gradient(180deg, rgba(236, 250, 244, 0.92), rgba(255, 255, 255, 0.94));
}

body.mpanel-page .mpanel-grid-two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.mpanel-page .mpanel-card-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.mpanel-page .mpanel-card-grid.plans {
  margin-top: 14px;
}

body.mpanel-page .mpanel-card-head,
body.mpanel-page .mpanel-line-item,
body.mpanel-page .mpanel-inline-status {
  display: flex;
  gap: 12px;
}

body.mpanel-page .mpanel-card-head,
body.mpanel-page .mpanel-line-item {
  align-items: flex-start;
  justify-content: space-between;
}

body.mpanel-page .mpanel-kicker {
  display: inline-block;
  margin-bottom: 6px;
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-faint);
}

body.mpanel-page .mpanel-price {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--text);
  margin: 18px 0 12px;
}

body.mpanel-page .mpanel-meta-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 16px;
}

body.mpanel-page .mpanel-meta-grid.compact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.mpanel-page .mpanel-meta-grid.account-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.mpanel-page .mpanel-meta-grid > div {
  padding: 12px 14px;
  border-radius: 18px;
  background: rgba(247, 249, 255, 0.72);
  border: 1px solid rgba(219, 228, 244, 0.8);
}

body.mpanel-page .mpanel-meta-grid span {
  display: block;
  margin-bottom: 4px;
  font-size: 0.88rem;
}

body.mpanel-page .mpanel-card.blue,
body.mpanel-page .mpanel-role-card.blue {
  background: linear-gradient(180deg, rgba(234, 240, 255, 0.9), rgba(255, 255, 255, 0.94));
}

body.mpanel-page .mpanel-card.violet,
body.mpanel-page .mpanel-role-card.violet {
  background: linear-gradient(180deg, rgba(241, 236, 255, 0.92), rgba(255, 255, 255, 0.94));
}

body.mpanel-page .mpanel-card.mint,
body.mpanel-page .mpanel-role-card.mint {
  background: linear-gradient(180deg, rgba(236, 250, 244, 0.92), rgba(255, 255, 255, 0.94));
}

body.mpanel-page .mpanel-card.amber,
body.mpanel-page .mpanel-role-card.amber {
  background: linear-gradient(180deg, rgba(255, 245, 232, 0.94), rgba(255, 255, 255, 0.94));
}

body.mpanel-page .mpanel-line-item {
  padding: 14px 16px;
}

body.mpanel-page .mpanel-inline-status {
  flex-direction: column;
  align-items: flex-end;
}

body.mpanel-page .mpanel-empty {
  padding: 18px;
  border-radius: 18px;
  border: 1px dashed rgba(195, 208, 232, 0.9);
  background: rgba(247, 249, 255, 0.76);
}

body.mpanel-page .mpanel-empty.large {
  min-height: 140px;
  display: grid;
  place-items: center;
  text-align: center;
}

body.mpanel-page .mpanel-ticket-list {
  display: grid;
  gap: 14px;
}

body.mpanel-page .mpanel-ticket {
  padding: 18px;
  border-radius: 22px;
  border: 1px solid rgba(219, 228, 244, 0.88);
  background: rgba(247, 249, 255, 0.88);
}

body.mpanel-page .mpanel-ticket.high {
  border-color: rgba(255, 171, 51, 0.35);
}

body.mpanel-page .mpanel-ticket.critical {
  border-color: rgba(214, 74, 74, 0.35);
}

body.mpanel-page .mpanel-role-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.mpanel-page .mpanel-role-card p {
  margin: 12px 0 16px;
}

body.mpanel-page .mpanel-role-modules span {
  padding: 9px 12px;
  font-size: 0.92rem;
  font-weight: 600;
}

body.mpanel-page .mpanel-company-filter {
  margin: 12px 0 4px;
}

body.mpanel-page .mpanel-filter {
  padding: 9px 14px;
  font-weight: 600;
}

body.mpanel-page .top-gap,
body.access-page .top-gap {
  margin-top: 16px;
}

@media (max-width: 1100px) {
  body.access-page .access-layout,
  body.mpanel-page .mpanel-hero-top,
  body.mpanel-page .mpanel-shell {
    grid-template-columns: 1fr;
  }

  body.mpanel-page .mpanel-sidebar {
    position: static;
  }

  body.mpanel-page .mpanel-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 820px) {
  body.access-page .access-stage,
  body.mpanel-page .mpanel-hero {
    padding: 22px;
    border-radius: 26px;
  }

  body.access-page .super-auth-card,
  body.mpanel-page .mpanel-hero-side,
  body.mpanel-page .mpanel-panel,
  body.mpanel-page .mpanel-card,
  body.mpanel-page .mpanel-role-card,
  body.mpanel-page .mpanel-user-card {
    padding: 18px;
    border-radius: 22px;
  }

  body.access-page .access-brand-grid,
  body.mpanel-page .mpanel-grid-two,
  body.mpanel-page .mpanel-card-grid,
  body.mpanel-page .mpanel-role-grid,
  body.mpanel-page .mpanel-meta-grid,
  body.mpanel-page .mpanel-meta-grid.account-grid,
  body.mpanel-page .mpanel-meta-grid.compact {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  body.access-page .auth-topbar,
  body.mpanel-page .mpanel-card-head,
  body.mpanel-page .mpanel-line-item {
    flex-direction: column;
    align-items: stretch;
  }

  body.mpanel-page .mpanel-inline-status {
    align-items: flex-start;
  }

  body.access-page .access-brand-grid,
  body.mpanel-page .mpanel-summary-grid {
    grid-template-columns: 1fr;
  }
}
