:root{
  --test-bg: #050913;
  --test-bg-deep: #07101f;
  --test-surface: rgba(10, 18, 32, 0.76);
  --test-surface-strong: rgba(12, 22, 38, 0.92);
  --test-surface-soft: rgba(17, 28, 46, 0.78);
  --test-border: rgba(148, 163, 184, 0.16);
  --test-border-strong: rgba(96, 165, 250, 0.28);
  --test-text: #f5f7fb;
  --test-text-soft: #d5deeb;
  --test-text-muted: #8fa0b9;
  --test-blue: #3b82f6;
  --test-blue-soft: rgba(59, 130, 246, 0.18);
  --test-cyan: #38bdf8;
  --test-orange: #f97316;
  --test-orange-soft: rgba(249, 115, 22, 0.18);
  --test-gold: #fbbf24;
  --test-green: #34d399;
  --test-shadow-lg: 0 22px 60px rgba(2, 6, 23, 0.44);
  --test-shadow-card: 0 18px 42px rgba(2, 6, 23, 0.36);
  --test-radius-xl: 30px;
  --test-radius-lg: 22px;
  --test-radius-md: 16px;
}

body.cygniax-premium-mode{
  background:
    radial-gradient(circle at 12% 12%, rgba(56, 189, 248, 0.14) 0%, transparent 24%),
    radial-gradient(circle at 85% 10%, rgba(249, 115, 22, 0.12) 0%, transparent 28%),
    radial-gradient(circle at 50% 78%, rgba(59, 130, 246, 0.08) 0%, transparent 30%),
    linear-gradient(180deg, var(--test-bg-deep) 0%, var(--test-bg) 55%, #04070f 100%);
  color: var(--test-text);
}

body.cygniax-premium-mode::before{
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(115deg, rgba(255, 255, 255, 0.035) 0%, rgba(255, 255, 255, 0) 32%),
    linear-gradient(180deg, rgba(6, 12, 23, 0.2) 0%, rgba(6, 12, 23, 0) 28%);
  opacity: 0.92;
  z-index: 0;
}

body.cygniax-premium-mode .shell,
body.cygniax-premium-mode .cygniax-premium-story-shell,
body.cygniax-premium-mode .tabs,
body.cygniax-premium-mode .tab-content,
body.cygniax-premium-mode .header,
body.cygniax-premium-mode .footer{
  position: relative;
  z-index: 1;
}

body.cygniax-premium-public .shell{
  min-height: 100vh;
  padding: clamp(5.5rem, 9vw, 7.25rem) clamp(1.2rem, 4vw, 2.4rem) 3rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

body.cygniax-premium-public .card{
  position: relative;
  width: min(1120px, 100%);
  border-radius: clamp(24px, 4vw, 34px);
  border: 1px solid rgba(96, 165, 250, 0.16);
  background:
    linear-gradient(155deg, rgba(14, 25, 43, 0.88) 0%, rgba(10, 18, 32, 0.9) 48%, rgba(7, 13, 23, 0.94) 100%);
  box-shadow: var(--test-shadow-lg);
  backdrop-filter: blur(22px);
  padding: clamp(2rem, 3vw, 3rem);
  overflow: hidden;
}

body.cygniax-premium-public .card::before{
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 0% 0%, rgba(56, 189, 248, 0.16) 0%, transparent 34%),
    radial-gradient(circle at 100% 0%, rgba(249, 115, 22, 0.14) 0%, transparent 30%),
    linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0));
  pointer-events: none;
}

.cygniax-premium-public-badge{
  position: absolute;
  top: 1.1rem;
  left: 1.1rem;
  padding: 0.45rem 0.8rem;
  border-radius: 999px;
  font-size: 0.64rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #dbeafe;
  background: rgba(59, 130, 246, 0.14);
  border: 1px solid rgba(96, 165, 250, 0.24);
}

body.cygniax-premium-public .eyebrow{
  color: #93c5fd;
  letter-spacing: 0.18em;
  font-size: 0.68rem;
  margin-bottom: 0.9rem;
}

body.cygniax-premium-public h1{
  font-size: clamp(2.35rem, 5vw, 4.6rem);
  line-height: 0.94;
  letter-spacing: -0.05em;
  max-width: 11ch;
  margin-bottom: 1rem;
  background: linear-gradient(135deg, #ffffff 0%, #cfe3ff 42%, #f4f7ff 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

body.cygniax-premium-public .lead{
  color: var(--test-text-soft);
  font-size: clamp(1rem, 1.8vw, 1.18rem);
  line-height: 1.65;
  max-width: 60ch;
  margin-bottom: 1.8rem;
}

body.cygniax-premium-public .login-language-toolbar{
  position: fixed;
  top: max(1rem, env(safe-area-inset-top, 0px));
  right: max(1rem, env(safe-area-inset-right, 0px));
  z-index: 20;
}

body.cygniax-premium-public .login-language-group{
  padding: 0.34rem;
  background: rgba(9, 17, 31, 0.8);
  border: 1px solid rgba(96, 165, 250, 0.2);
  box-shadow: 0 16px 32px rgba(2, 6, 23, 0.32);
}

body.cygniax-premium-public .subcard,
body.cygniax-premium-public .public-flow-card,
body.cygniax-premium-public .admin-section,
body.cygniax-premium-public .summary-card,
body.cygniax-premium-public .admin-user-card,
body.cygniax-premium-public .admin-detail-card,
body.cygniax-premium-public .preview-card,
body.cygniax-premium-public .technical-card{
  background: linear-gradient(180deg, rgba(14, 22, 37, 0.92) 0%, rgba(10, 18, 32, 0.82) 100%);
  border: 1px solid rgba(148, 163, 184, 0.12);
  border-radius: 22px;
  box-shadow: var(--test-shadow-card);
}

body.cygniax-premium-public .public-flow-card{
  padding: 1.4rem;
}

body.cygniax-premium-public .stack{
  gap: 1rem;
}

body.cygniax-premium-public .field span,
body.cygniax-premium-public .panel-head h2,
body.cygniax-premium-public .account-summary-name,
body.cygniax-premium-public .wizard-step span:last-child,
body.cygniax-premium-public .admin-user-head h3,
body.cygniax-premium-public .summary-label{
  color: var(--test-text);
}

body.cygniax-premium-public .field input,
body.cygniax-premium-public .field textarea,
body.cygniax-premium-public .field select,
body.cygniax-premium-public .admin-select,
body.cygniax-premium-public .textarea{
  border-radius: 16px;
  border: 1px solid rgba(96, 165, 250, 0.14);
  background: rgba(5, 12, 22, 0.72);
  color: var(--test-text);
  padding: 0.95rem 1rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

body.cygniax-premium-public .field input:focus,
body.cygniax-premium-public .field textarea:focus,
body.cygniax-premium-public .field select:focus,
body.cygniax-premium-public .admin-select:focus,
body.cygniax-premium-public .textarea:focus{
  outline: none;
  border-color: rgba(56, 189, 248, 0.56);
  box-shadow: 0 0 0 1px rgba(56, 189, 248, 0.38), 0 0 24px rgba(59, 130, 246, 0.16);
}

body.cygniax-premium-mode .button,
body.cygniax-premium-mode .button-secondary,
body.cygniax-premium-mode .button-ghost,
body.cygniax-premium-mode .language-switch-button,
body.cygniax-premium-mode .admin-action-button,
body.cygniax-premium-mode .cygniax-logout-button,
body.cygniax-premium-mode .cygniax-dashboard-button,
body.cygniax-premium-mode .cygniax-language-button{
  border-radius: 999px;
  border: 1px solid rgba(96, 165, 250, 0.22);
  background: rgba(14, 22, 37, 0.78);
  color: var(--test-text-soft);
  font-weight: 500;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.03);
  transition: transform 0.24s ease, border-color 0.24s ease, background 0.24s ease, box-shadow 0.24s ease, color 0.24s ease;
}

body.cygniax-premium-mode .button:hover,
body.cygniax-premium-mode .button:focus-visible,
body.cygniax-premium-mode .button-secondary:hover,
body.cygniax-premium-mode .button-secondary:focus-visible,
body.cygniax-premium-mode .button-ghost:hover,
body.cygniax-premium-mode .button-ghost:focus-visible,
body.cygniax-premium-mode .language-switch-button:not(.active):hover,
body.cygniax-premium-mode .language-switch-button:not(.active):focus-visible,
body.cygniax-premium-mode .admin-action-button:hover,
body.cygniax-premium-mode .admin-action-button:focus-visible,
body.cygniax-premium-mode .cygniax-logout-button:hover,
body.cygniax-premium-mode .cygniax-logout-button:focus-visible,
body.cygniax-premium-mode .cygniax-dashboard-button:hover,
body.cygniax-premium-mode .cygniax-dashboard-button:focus-visible,
body.cygniax-premium-mode .cygniax-language-button:not(.active):hover,
body.cygniax-premium-mode .cygniax-language-button:not(.active):focus-visible{
  transform: translateY(-1px);
  color: #f8fbff;
  border-color: rgba(59, 130, 246, 0.95);
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.22), rgba(96, 165, 250, 0.14));
  box-shadow:
    0 0 0 1px rgba(59, 130, 246, 0.48),
    0 0 18px rgba(59, 130, 246, 0.34),
    0 0 34px rgba(59, 130, 246, 0.16),
    inset 0 0 0 1px rgba(255,255,255,0.04);
}

body.cygniax-premium-mode .language-switch-button.active,
body.cygniax-premium-mode .cygniax-language-button.active,
body.cygniax-premium-mode .tab.active,
body.cygniax-premium-mode .button.is-active{
  color: #fff6ef;
  border-color: rgba(249, 115, 22, 0.96);
  background: linear-gradient(135deg, rgba(249, 115, 22, 0.24), rgba(251, 146, 60, 0.16));
  box-shadow:
    0 0 0 1px rgba(249, 115, 22, 0.5),
    0 0 18px rgba(249, 115, 22, 0.36),
    0 0 34px rgba(249, 115, 22, 0.16),
    inset 0 0 0 1px rgba(255,255,255,0.04);
}

body.cygniax-premium-public .message{
  border-radius: 18px;
  border-width: 1px;
  box-shadow: var(--test-shadow-card);
}

body.cygniax-premium-public .wizard-steps{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.75rem;
  margin-bottom: 1.25rem;
}

body.cygniax-premium-public .wizard-step{
  min-width: 0;
  padding: 0.95rem 1rem;
  border-radius: 16px;
  border: 1px solid rgba(148, 163, 184, 0.1);
  background: rgba(9, 16, 29, 0.72);
}

body.cygniax-premium-public .wizard-step.active,
body.cygniax-premium-public .wizard-step.complete{
  border-color: rgba(96, 165, 250, 0.24);
  background: rgba(18, 30, 52, 0.85);
}

body.cygniax-premium-public .wizard-index{
  width: 2rem;
  height: 2rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(59, 130, 246, 0.12);
  color: #bfdbfe;
  margin-bottom: 0.6rem;
}

body.cygniax-premium-public .wizard-step.active .wizard-index,
body.cygniax-premium-public .wizard-step.complete .wizard-index{
  background: linear-gradient(135deg, rgba(249, 115, 22, 0.24), rgba(251, 146, 60, 0.16));
  color: #fff7ed;
}

body.cygniax-premium-admin .card{
  width: min(1360px, 100%);
}

body.cygniax-premium-admin .admin-toolbar,
body.cygniax-premium-admin .admin-bulk-toolbar,
body.cygniax-premium-admin .admin-filters,
body.cygniax-premium-admin .admin-quick-filters,
body.cygniax-premium-admin .admin-audit-filters{
  gap: 0.9rem;
}

body.cygniax-premium-admin .admin-users-grid,
body.cygniax-premium-admin .admin-summary-grid{
  gap: 1rem;
}

body.cygniax-premium-admin .status-pill,
body.cygniax-premium-admin .risk-chip{
  border-radius: 999px;
}

body.cygniax-premium-admin .audit-list li,
body.cygniax-premium-admin .backup-list li{
  border-radius: 18px;
  background: rgba(10, 18, 32, 0.76);
  border: 1px solid rgba(148, 163, 184, 0.1);
  padding: 1rem 1.1rem;
}

body.cygniax-premium-portal{
  color: var(--test-text);
}

body.cygniax-premium-portal .cygniax-top-chrome{
  background:
    linear-gradient(180deg, rgba(5, 11, 21, 0.98) 0%, rgba(7, 14, 26, 0.98) 62%, rgba(7, 14, 26, 0.92) 100%);
  border-bottom-color: rgba(96, 165, 250, 0.16);
  box-shadow: 0 18px 52px rgba(2, 6, 23, 0.42);
}

body.cygniax-premium-portal .cygniax-top-line{
  gap: 1rem;
}

body.cygniax-premium-portal .cygniax-account-name{
  font-size: 0.98rem;
}

body.cygniax-premium-portal .cygniax-account-email{
  color: #a7b7cf;
}

body.cygniax-premium-portal .header{
  min-height: 84vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: clamp(8.8rem, 12vw, 10rem) clamp(1.4rem, 4vw, 2.8rem) clamp(4rem, 8vw, 5.5rem) !important;
  background:
    radial-gradient(circle at 20% 20%, rgba(56, 189, 248, 0.16) 0%, transparent 28%),
    radial-gradient(circle at 80% 15%, rgba(249, 115, 22, 0.14) 0%, transparent 26%),
    radial-gradient(circle at 50% 70%, rgba(99, 102, 241, 0.13) 0%, transparent 36%),
    linear-gradient(180deg, #08111f 0%, #091423 40%, #08111d 100%) !important;
  border-bottom: 1px solid rgba(96, 165, 250, 0.16);
}

body.cygniax-premium-portal .header::before{
  opacity: 1;
  background:
    radial-gradient(ellipse at 25% 40%, rgba(59, 130, 246, 0.2) 0%, transparent 48%),
    radial-gradient(ellipse at 75% 35%, rgba(249, 115, 22, 0.14) 0%, transparent 42%),
    radial-gradient(ellipse at 50% 100%, rgba(17, 24, 39, 0.1) 0%, transparent 52%);
  animation: cygniaxTestPulse 11s ease-in-out infinite alternate;
}

@keyframes cygniaxTestPulse{
  0% { transform: scale(1); opacity: 0.86; }
  100% { transform: scale(1.06); opacity: 1; }
}

body.cygniax-premium-portal .cygniax-premium-hero-chip{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.9rem;
  padding: 0.44rem 0.84rem;
  border-radius: 999px;
  border: 1px solid rgba(96, 165, 250, 0.24);
  background: rgba(59, 130, 246, 0.1);
  color: #dbeafe;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

body.cygniax-premium-portal .cygniax-premium-hero-kicker{
  position: relative;
  color: rgba(191, 219, 254, 0.78);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin-bottom: 0.9rem;
}

body.cygniax-premium-portal .header h1{
  font-size: clamp(3rem, 6vw, 6.2rem);
  letter-spacing: -0.06em;
  line-height: 0.92;
  max-width: 11ch;
  margin-bottom: 1rem;
  text-shadow: 0 14px 48px rgba(2, 6, 23, 0.45);
}

body.cygniax-premium-portal .header .subtitle{
  max-width: 70ch;
  font-size: clamp(0.9rem, 1.5vw, 1.05rem);
  letter-spacing: 0.18em;
  color: #b8c7dc;
  margin-bottom: 1.8rem;
}

body.cygniax-premium-portal .kpi-bar{
  width: min(1120px, 100%);
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1.8rem;
}

body.cygniax-premium-portal .kpi{
  padding: 1.1rem 0.85rem;
  border-radius: 22px;
  border: 1px solid rgba(148, 163, 184, 0.1);
  background: linear-gradient(180deg, rgba(14, 22, 37, 0.82) 0%, rgba(10, 18, 32, 0.68) 100%);
  box-shadow: var(--test-shadow-card);
  backdrop-filter: blur(16px);
}

body.cygniax-premium-portal .kpi-value{
  font-size: clamp(1.6rem, 2.8vw, 2.4rem);
  letter-spacing: -0.05em;
}

body.cygniax-premium-portal .kpi-label{
  font-size: 0.62rem;
  color: #93a6c0;
  letter-spacing: 0.18em;
  margin-top: 0.4rem;
}

body.cygniax-premium-portal .kpi{
  position: relative;
  overflow: hidden;
}

body.cygniax-premium-portal .kpi::before{
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(59, 130, 246, 0.16) 0%, rgba(139, 92, 246, 0.08) 36%, rgba(255,255,255,0) 56%);
  opacity: 0.95;
}

body.cygniax-premium-portal .kpi-value{
  position: relative;
  z-index: 1;
  font-size: clamp(1.7rem, 2.9vw, 2.6rem);
  letter-spacing: -0.06em;
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent2) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 0 24px rgba(59, 130, 246, 0.16);
}

body.cygniax-premium-portal .kpi-label{
  position: relative;
  z-index: 1;
}

.cygniax-premium-story-shell{
  width: min(1360px, calc(100% - 2rem));
  margin: -2.4rem auto 0;
  padding: 1.25rem 1.25rem 1.15rem;
  border-radius: var(--test-radius-xl);
  border: 1px solid rgba(96, 165, 250, 0.16);
  background: linear-gradient(180deg, rgba(9, 16, 29, 0.92) 0%, rgba(8, 15, 26, 0.84) 100%);
  box-shadow: var(--test-shadow-lg);
  backdrop-filter: blur(18px);
}

.cygniax-premium-story-head{
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1.2rem;
  margin-bottom: 1rem;
}

.cygniax-premium-story-kicker{
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: #93c5fd;
  margin-bottom: 0.35rem;
}

.cygniax-premium-story-intro{
  font-size: 0.95rem;
  line-height: 1.65;
  color: var(--test-text-soft);
  max-width: 74ch;
}

.cygniax-premium-progress-shell{
  min-width: min(280px, 42vw);
}

.cygniax-premium-progress-label{
  display: block;
  margin-bottom: 0.5rem;
  font-size: 0.64rem;
  color: #9ab0ca;
  text-transform: uppercase;
  letter-spacing: 0.18em;
}

.cygniax-premium-progress-track{
  height: 0.52rem;
  border-radius: 999px;
  background: rgba(148, 163, 184, 0.12);
  overflow: hidden;
}

#cygniax-premium-progress-bar{
  display: block;
  width: 0%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--test-cyan) 0%, var(--test-blue) 50%, var(--test-orange) 100%);
  transition: width 0.36s ease;
}

.cygniax-premium-story-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin-bottom: 1rem;
}

.cygniax-premium-story-card,
.cygniax-premium-guided-chip{
  border-radius: 22px;
  border: 1px solid rgba(148, 163, 184, 0.1);
  background: rgba(10, 18, 32, 0.74);
  box-shadow: var(--test-shadow-card);
}

.cygniax-premium-story-card{
  padding: 1.2rem 1.25rem;
}

.cygniax-premium-story-card span{
  display: inline-flex;
  margin-bottom: 0.65rem;
  color: #93c5fd;
  font-size: 0.68rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.cygniax-premium-story-card h3{
  font-size: 1rem;
  margin-bottom: 0.45rem;
  color: var(--test-text);
}

.cygniax-premium-story-card p{
  font-size: 0.84rem;
  line-height: 1.6;
  color: var(--test-text-muted);
}

body.cygniax-premium-portal .tabs{
  width: min(1360px, calc(100% - 2rem)) !important;
  margin: 1rem auto 0 !important;
  border-radius: 24px;
  padding: 0.9rem !important;
  top: var(--cygniax-tabs-top, 5.75rem) !important;
  background: rgba(7, 14, 26, 0.9) !important;
  border: 1px solid rgba(96, 165, 250, 0.14);
}

body.cygniax-premium-portal .tab{
  min-height: 3.6rem;
  border-radius: 18px !important;
  border: 1px solid rgba(148, 163, 184, 0.12) !important;
  color: #a6b6cc !important;
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.78) 0%, rgba(10, 18, 32, 0.78) 100%) !important;
  font-weight: 500 !important;
  letter-spacing: 0.04em;
}

body.cygniax-premium-portal .tab-content{
  width: min(1400px, calc(100% - 1.6rem)) !important;
  padding: 2.4rem 0 5.5rem !important;
}

body.cygniax-premium-portal .tab-content > div[style],
body.cygniax-premium-portal .tab-content > div{
  width: 100% !important;
}

body.cygniax-premium-portal .tab-content > div[style*="max-width"],
body.cygniax-premium-portal [style*="max-width:1400px"],
body.cygniax-premium-portal [style*="max-width:1200px"]{
  max-width: none !important;
  width: 100% !important;
}

body.cygniax-premium-portal .year-card,
body.cygniax-premium-portal .chart-section,
body.cygniax-premium-portal .scenario-card,
body.cygniax-premium-portal .sub-detail-card,
body.cygniax-premium-portal .org-sub-card,
body.cygniax-premium-portal .rm-year-panel,
body.cygniax-premium-portal .final-section{
  border-radius: 28px;
  border-color: rgba(148, 163, 184, 0.12);
  background: linear-gradient(180deg, rgba(12, 20, 34, 0.9) 0%, rgba(9, 16, 28, 0.86) 100%);
  box-shadow: var(--test-shadow-card);
}

body.cygniax-premium-portal .year-card,
body.cygniax-premium-portal .scenario-card,
body.cygniax-premium-portal .chart-section,
body.cygniax-premium-portal .sub-detail-card,
body.cygniax-premium-portal .org-sub-card,
body.cygniax-premium-portal .rm-year-panel,
body.cygniax-premium-portal .vt-card{
  transition: transform 0.28s ease, border-color 0.28s ease, box-shadow 0.28s ease;
}

body.cygniax-premium-portal .year-card:hover,
body.cygniax-premium-portal .scenario-card:hover,
body.cygniax-premium-portal .chart-section:hover,
body.cygniax-premium-portal .sub-detail-card:hover,
body.cygniax-premium-portal .org-sub-card:hover,
body.cygniax-premium-portal .rm-year-panel:hover,
body.cygniax-premium-portal .vt-card:hover{
  transform: translateY(-4px);
  border-color: rgba(96, 165, 250, 0.22);
  box-shadow: 0 24px 52px rgba(2, 6, 23, 0.38);
}

body.cygniax-premium-portal .year-top,
body.cygniax-premium-portal .rm-panel-header,
body.cygniax-premium-portal .org-sub-header{
  background: linear-gradient(180deg, rgba(17, 28, 46, 0.76) 0%, rgba(12, 22, 38, 0.4) 100%);
}

body.cygniax-premium-portal .year-body,
body.cygniax-premium-portal .rm-section,
body.cygniax-premium-portal .sub-detail-card .inner{
  padding: 1.5rem 1.6rem;
}

body.cygniax-premium-portal .detail-block h4,
body.cygniax-premium-portal .rm-section-title,
body.cygniax-premium-portal .section-sep,
body.cygniax-premium-portal .final-section p,
body.cygniax-premium-portal .sdl,
body.cygniax-premium-portal .subtitle,
body.cygniax-premium-portal .ml,
body.cygniax-premium-portal .rm-ml,
body.cygniax-premium-portal .vt-ml,
body.cygniax-premium-portal .sdl,
body.cygniax-premium-portal .stream-card .ss,
body.cygniax-premium-portal .office-chip,
body.cygniax-premium-portal .rm-cal,
body.cygniax-premium-portal .ydesc,
body.cygniax-premium-portal .detail-block li,
body.cygniax-premium-portal .vt-card p,
body.cygniax-premium-portal .vt-cat-item,
body.cygniax-premium-portal .rm-milestone-item,
body.cygniax-premium-portal .rm-cat-items li,
body.cygniax-premium-portal .sub-legend-item,
body.cygniax-premium-portal .org-sub-stats,
body.cygniax-premium-portal .org-dept-chip,
body.cygniax-premium-portal .sdv{
  color: #a4b5cb !important;
}

body.cygniax-premium-portal .mv.revenue,
body.cygniax-premium-portal .rm-mv[style*="green"],
body.cygniax-premium-portal .fkv.green,
body.cygniax-premium-portal .sv{
  color: var(--test-green) !important;
}

body.cygniax-premium-portal .year-badge,
body.cygniax-premium-portal .rm-panel-badge{
  background: linear-gradient(180deg, rgba(19, 31, 52, 0.88) 0%, rgba(13, 23, 40, 0.92) 100%);
}

body.cygniax-premium-portal .vtimeline{
  padding: 2rem 0 0.5rem;
}

body.cygniax-premium-portal .vtimeline::before{
  width: 4px;
  box-shadow: 0 0 22px rgba(59, 130, 246, 0.22);
}

body.cygniax-premium-portal .vt-label{
  padding: 0.7rem 1rem;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(17, 28, 46, 0.94) 0%, rgba(11, 21, 36, 0.94) 100%);
  box-shadow: 0 16px 36px rgba(2, 6, 23, 0.34);
}

body.cygniax-premium-portal .vt-card{
  border-radius: 24px;
  border: 1px solid rgba(148, 163, 184, 0.12);
  background: linear-gradient(180deg, rgba(12, 20, 34, 0.9) 0%, rgba(10, 18, 32, 0.84) 100%);
}

body.cygniax-premium-portal .vt-dot{
  box-shadow: 0 0 0 8px rgba(8, 15, 26, 0.86), 0 0 18px rgba(59, 130, 246, 0.22);
}

body.cygniax-premium-portal .cygniax-premium-reveal{
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

body.cygniax-premium-portal .cygniax-premium-reveal.is-visible{
  opacity: 1;
  transform: translateY(0);
}

body.cygniax-premium-portal .tab-content.cygniax-tab-enter{
  animation: cygniaxTabIn 0.32s ease;
}

@keyframes cygniaxTabIn{
  from { opacity: 0; transform: translateY(14px); }
  to { opacity: 1; transform: translateY(0); }
}

@media (max-width: 1280px){
body.cygniax-premium-portal .kpi-bar{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

.cygniax-premium-story-grid{
    grid-template-columns: 1fr;
  }

}

@media (max-width: 980px){
body.cygniax-premium-public .wizard-steps{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

body.cygniax-premium-portal .header{
    min-height: auto;
    padding-top: 8rem !important;
  }

body.cygniax-premium-portal .header h1{
    max-width: 13ch;
  }

body.cygniax-premium-portal .kpi-bar{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

.cygniax-premium-story-head{
    flex-direction: column;
    align-items: stretch;
  }

.cygniax-premium-progress-shell{
    min-width: 0;
  }

}

@media (max-width: 720px){
body.cygniax-premium-public .card{
    padding: 1.4rem;
  }

body.cygniax-premium-public h1{
    font-size: 2.2rem;
  }

body.cygniax-premium-portal .cygniax-top-line{
    align-items: flex-start;
    gap: 0.6rem;
  }

body.cygniax-premium-portal .cygniax-language-shell{
    flex-wrap: wrap;
    justify-content: flex-end;
  }

body.cygniax-premium-portal .kpi-bar{
    grid-template-columns: 1fr;
  }

.cygniax-premium-story-shell,
body.cygniax-premium-portal .tabs,
body.cygniax-premium-portal .tab-content{
    width: calc(100% - 1rem) !important;
  }

body.cygniax-premium-portal .tab{
    min-height: 3.2rem;
    font-size: 0.58rem !important;
    padding: 0.55rem 0.35rem !important;
  }

body.cygniax-premium-portal .year-top,
body.cygniax-premium-portal .rm-panel-header{
    flex-direction: column;
  }

body.cygniax-premium-portal .year-badge,
body.cygniax-premium-portal .rm-panel-badge{
    border-right: none;
    border-bottom: 1px solid rgba(148, 163, 184, 0.12);
    min-width: auto;
  }

}

body.cygniax-premium-portal .cygniax-map-card{
  margin: 0 0 2rem;
  padding: 1.35rem;
  border-radius: 30px;
  border: 1px solid rgba(96, 165, 250, 0.16);
  background:
    radial-gradient(circle at top left, rgba(59, 130, 246, 0.12), transparent 28%),
    radial-gradient(circle at bottom right, rgba(249, 115, 22, 0.1), transparent 32%),
    linear-gradient(180deg, rgba(8, 15, 27, 0.94) 0%, rgba(7, 12, 22, 0.9) 100%);
  box-shadow: var(--test-shadow-card);
}

body.cygniax-premium-portal .cygniax-map-copy{
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}

body.cygniax-premium-portal .cygniax-map-kicker{
  display: inline-flex;
  margin-bottom: 0.6rem;
  padding: 0.38rem 0.72rem;
  border-radius: 999px;
  border: 1px solid rgba(59, 130, 246, 0.22);
  background: rgba(13, 27, 46, 0.7);
  color: #93c5fd;
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

body.cygniax-premium-portal .cygniax-map-copy h3{
  margin: 0;
  font-size: clamp(1.35rem, 2.4vw, 2rem);
  color: #f8fbff;
}

body.cygniax-premium-portal .cygniax-map-copy p{
  margin: 0.45rem 0 0;
  max-width: 54rem;
  color: #9db0c7;
  line-height: 1.65;
}

body.cygniax-premium-portal .cygniax-map-stage{
  position: relative;
  isolation: isolate;
  aspect-ratio: 2 / 1;
  min-height: 420px;
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid rgba(59, 130, 246, 0.16);
  background:
    radial-gradient(circle at center, rgba(13, 27, 46, 0.7), rgba(5, 10, 18, 0.98) 72%),
    linear-gradient(180deg, rgba(6, 10, 18, 0.92), rgba(3, 7, 15, 0.96));
}

body.cygniax-premium-portal .cygniax-map-stage::after{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,0.02), transparent 18%, transparent 82%, rgba(255,255,255,0.03));
  pointer-events: none;
}

body.cygniax-premium-portal .cygniax-map-svg,
body.cygniax-premium-portal .cygniax-map-pins{
  position: absolute;
  inset: 0;
}

body.cygniax-premium-portal .cygniax-map-svg{
  width: 100%;
  height: 100%;
}

body.cygniax-premium-portal .cygniax-map-mass path{
  fill: rgba(71, 85, 105, 0.42);
  stroke: rgba(96, 165, 250, 0.14);
  stroke-width: 2;
  filter: drop-shadow(0 16px 32px rgba(2, 8, 23, 0.4));
}

body.cygniax-premium-portal .cygniax-map-grid path{
  fill: none;
  stroke: rgba(148, 163, 184, 0.08);
  stroke-width: 1;
}

body.cygniax-premium-portal .cygniax-map-pin{
  position: absolute;
  transform: translate(-50%, -50%);
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  min-height: 2.4rem;
  padding: 0.45rem 0.82rem 0.45rem 0.45rem;
  border: 1px solid rgba(59, 130, 246, 0.24);
  border-radius: 999px;
  background: rgba(8, 16, 28, 0.92);
  color: #e5edf7;
  box-shadow: 0 14px 30px rgba(2, 6, 23, 0.42);
  cursor: pointer;
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease, background 0.22s ease;
  z-index: 3;
}

body.cygniax-premium-portal .cygniax-map-pin:hover,
body.cygniax-premium-portal .cygniax-map-pin:focus-visible{
  transform: translate(-50%, calc(-50% - 3px));
  border-color: rgba(59, 130, 246, 0.82);
  background: rgba(11, 21, 36, 0.98);
  box-shadow: 0 0 0 1px rgba(59,130,246,0.45), 0 0 18px rgba(59,130,246,0.22), 0 16px 34px rgba(2, 6, 23, 0.5);
  outline: none;
}

body.cygniax-premium-portal .cygniax-map-pin-core{
  width: 0.82rem;
  height: 0.82rem;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(191,219,254,1) 0%, rgba(59,130,246,1) 62%, rgba(29,78,216,1) 100%);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.16), 0 0 18px rgba(59, 130, 246, 0.44);
  flex: 0 0 auto;
}

body.cygniax-premium-portal .cygniax-map-flag{
  font-size: 1rem;
  line-height: 1;
}

body.cygniax-premium-portal .cygniax-map-label{
  font-size: 0.73rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  white-space: nowrap;
}

body.cygniax-premium-portal .cygniax-map-tooltip{
  position: absolute;
  left: 50%;
  bottom: calc(100% + 0.75rem);
  transform: translateX(-50%);
  width: clamp(180px, 24vw, 280px);
  padding: 0.8rem 0.9rem;
  border-radius: 16px;
  border: 1px solid rgba(96, 165, 250, 0.24);
  background: rgba(5, 10, 20, 0.96);
  box-shadow: 0 18px 42px rgba(2, 6, 23, 0.55);
  color: #d7e3f2;
  text-align: left;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.18s ease, transform 0.18s ease;
}

body.cygniax-premium-portal .cygniax-map-tooltip strong{
  display: block;
  margin-bottom: 0.34rem;
  font-size: 0.78rem;
  color: #f8fbff;
}

body.cygniax-premium-portal .cygniax-map-tooltip small{
  display: block;
  font-size: 0.7rem;
  line-height: 1.5;
  color: #9db0c7;
}

body.cygniax-premium-portal .cygniax-map-pin:hover .cygniax-map-tooltip,
body.cygniax-premium-portal .cygniax-map-pin:focus-visible .cygniax-map-tooltip,
body.cygniax-premium-portal .cygniax-map-pin.is-open .cygniax-map-tooltip{
  opacity: 1;
  transform: translateX(-50%) translateY(-4px);
}

body.cygniax-premium-portal .cygniax-premium-xl-banner{
  display: grid;
  gap: 0.35rem;
  margin-bottom: 1rem;
  padding: 0.95rem 1rem;
  border-radius: 18px;
  border: 1px solid rgba(59, 130, 246, 0.2);
  background: linear-gradient(180deg, rgba(12, 21, 38, 0.88), rgba(8, 15, 26, 0.92));
  color: #d9e7f5;
}

body.cygniax-premium-portal .cygniax-premium-xl-banner strong{
  color: #f8fbff;
  font-size: 0.84rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

body.cygniax-premium-portal .cygniax-premium-xl-banner span{
  color: #9db0c7;
  font-size: 0.76rem;
  line-height: 1.55;
}

@media (max-width: 980px){
body.cygniax-premium-portal .cygniax-map-stage{
    min-height: 520px;
  }

body.cygniax-premium-portal .cygniax-map-pin{
    padding-right: 0.68rem;
  }

body.cygniax-premium-portal .cygniax-map-label{
    max-width: 6.4rem;
    white-space: normal;
    line-height: 1.2;
  }

}

@media (max-width: 720px){
body.cygniax-premium-portal .cygniax-map-card{
    padding: 1rem;
  }

body.cygniax-premium-portal .cygniax-map-stage{
    min-height: 600px;
  }

body.cygniax-premium-portal .cygniax-map-pin{
    min-height: 2.25rem;
    padding: 0.38rem 0.6rem 0.38rem 0.38rem;
    gap: 0.32rem;
  }

body.cygniax-premium-portal .cygniax-map-label{
    display: none;
  }

body.cygniax-premium-portal .cygniax-map-tooltip{
    width: min(240px, 70vw);
  }

}

body.cygniax-premium-portal .cygniax-map-card{
  padding: 1.05rem;
  border-radius: 28px;
  border: 1px solid rgba(96, 165, 250, 0.12);
  background: linear-gradient(180deg, rgba(8, 14, 24, 0.94), rgba(6, 10, 18, 0.96));
}

body.cygniax-premium-portal .cygniax-map-copy{
  margin-bottom: 0.85rem;
}

body.cygniax-premium-portal .cygniax-map-stage{
  min-height: 430px;
  border-radius: 22px;
  background: radial-gradient(circle at center, rgba(11, 21, 36, 0.42), rgba(4, 8, 15, 0.98) 76%);
}

body.cygniax-premium-portal .cygniax-map-stage::after{
  background: linear-gradient(180deg, rgba(255,255,255,0.015), transparent 20%, transparent 84%, rgba(255,255,255,0.02));
}

body.cygniax-premium-portal .cygniax-map-mass path{
  fill: none !important;
  stroke: rgba(125, 211, 252, 0.46) !important;
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
  filter: none;
}

body.cygniax-premium-portal .cygniax-map-grid path{
  stroke: rgba(148, 163, 184, 0.045);
}

body.cygniax-premium-portal .cygniax-map-pin{
  min-height: 0;
  padding: 0;
  gap: 0.26rem;
  flex-direction: column;
  align-items: center;
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
}

body.cygniax-premium-portal .cygniax-map-pin:hover,
body.cygniax-premium-portal .cygniax-map-pin:focus-visible{
  background: transparent !important;
  box-shadow: none !important;
}

body.cygniax-premium-portal .cygniax-map-pin-core{
  width: 0.78rem;
  height: 0.78rem;
  box-shadow: 0 0 0 3px rgba(56, 189, 248, 0.12), 0 0 14px rgba(59, 130, 246, 0.3);
}

body.cygniax-premium-portal .cygniax-map-flag{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.8rem;
  min-height: 1.5rem;
  padding: 0.14rem 0.3rem;
  border-radius: 999px;
  border: 1px solid rgba(96, 165, 250, 0.18);
  background: rgba(7, 13, 23, 0.95);
  box-shadow: 0 10px 22px rgba(2, 6, 23, 0.32);
}

body.cygniax-premium-portal .cygniax-map-label{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.14rem 0.42rem;
  border-radius: 999px;
  background: rgba(7, 13, 23, 0.9);
  border: 1px solid rgba(96, 165, 250, 0.12);
  color: #dbeafe;
  font-size: 0.64rem;
  font-weight: 500;
  line-height: 1.15;
  text-align: center;
  white-space: nowrap;
}

body.cygniax-premium-portal .cygniax-map-tooltip{
  width: clamp(180px, 22vw, 260px);
}

@media (max-width: 980px){
body.cygniax-premium-portal .cygniax-map-stage{
    min-height: 500px;
  }

body.cygniax-premium-portal .cygniax-map-label{
    max-width: 7rem;
    white-space: normal;
  }

}

@media (max-width: 720px){
body.cygniax-premium-portal .cygniax-map-stage{
    min-height: 560px;
  }

body.cygniax-premium-portal .cygniax-map-label{
    display: inline-flex;
    max-width: 5.5rem;
    font-size: 0.58rem;
    padding: 0.12rem 0.34rem;
  }

}

.cx-lab-anchor{
  position: relative;
  top: -132px;
  height: 0;
}

.cx-lab-shell{
  margin: 0 0 2.2rem;
  padding: clamp(1.35rem, 2vw, 1.7rem);
  border-radius: 28px;
  border: 1px solid rgba(96, 165, 250, 0.16);
  background:
    linear-gradient(180deg, rgba(13, 21, 36, 0.92) 0%, rgba(9, 16, 28, 0.84) 100%),
    radial-gradient(circle at 0% 0%, rgba(56, 189, 248, 0.12) 0%, transparent 28%),
    radial-gradient(circle at 100% 0%, rgba(249, 115, 22, 0.1) 0%, transparent 28%);
  box-shadow: 0 26px 60px rgba(2, 6, 23, 0.34);
}

.cx-lab-head{
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.2rem;
  margin-bottom: 1.45rem;
}

.cx-lab-kicker{
  margin: 0 0 0.55rem;
  color: #7dd3fc;
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.cx-lab-head h2{
  margin: 0;
  font-size: clamp(1.55rem, 2.3vw, 2.4rem);
  letter-spacing: -0.04em;
  line-height: 1.02;
  color: #f8fbff;
}

.cx-lab-intro{
  margin: 0.8rem 0 0;
  max-width: 72ch;
  color: rgba(226, 232, 240, 0.86);
  line-height: 1.7;
  font-size: 0.98rem;
}

.cx-lab-jump{
  appearance: none;
  border: 1px solid rgba(96, 165, 250, 0.25);
  background: rgba(10, 17, 30, 0.86);
  color: #e2e8f0;
  border-radius: 999px;
  padding: 0.88rem 1.08rem;
  cursor: pointer;
  white-space: nowrap;
  font-size: 0.85rem;
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease, background 0.24s ease;
}

.cx-lab-jump:hover,
.cx-lab-jump:focus-visible{
  outline: none;
  transform: translateY(-1px);
  border-color: rgba(59, 130, 246, 0.86);
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.22), rgba(96, 165, 250, 0.14));
  box-shadow: 0 0 0 1px rgba(59, 130, 246, 0.4), 0 0 16px rgba(59, 130, 246, 0.22);
}

.cx-lab-stats-grid{
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0.9rem;
  margin-bottom: 1.25rem;
}

.cx-lab-stats-grid-compact{
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.cx-lab-stat{
  padding: 1rem 1rem 1.05rem;
  border-radius: 22px;
  border: 1px solid rgba(148, 163, 184, 0.12);
  background: linear-gradient(180deg, rgba(14, 24, 40, 0.86) 0%, rgba(9, 17, 30, 0.9) 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}

.cx-lab-stat strong{
  display: block;
  font-size: clamp(1.42rem, 2vw, 2rem);
  letter-spacing: -0.05em;
  color: #f8fafc;
}

.cx-lab-stat span{
  display: block;
  margin-top: 0.35rem;
  color: rgba(203, 213, 225, 0.74);
  font-size: 0.78rem;
  line-height: 1.45;
}

.cx-lab-feature-grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  margin-bottom: 1rem;
}

.cx-lab-panel{
  --cx-panel-accent: rgba(59, 130, 246, 0.48);
  --cx-panel-accent-soft: rgba(59, 130, 246, 0.18);
  position: relative;
  display: grid;
  grid-template-columns: minmax(250px, 320px) minmax(0, 1fr);
  gap: 1.4rem;
  align-items: start;
  overflow: hidden;
  padding: 1.38rem 1.42rem 1.45rem;
  border-radius: 30px;
  border: 1px solid color-mix(in srgb, var(--cx-panel-accent) 18%, rgba(148, 163, 184, 0.12));
  background:
    radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--cx-panel-accent) 18%, transparent) 0%, transparent 30%),
    radial-gradient(circle at 0% 100%, color-mix(in srgb, var(--cx-panel-accent) 11%, transparent) 0%, transparent 34%),
    linear-gradient(180deg, rgba(16, 26, 42, 0.96) 0%, rgba(8, 13, 24, 0.94) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.05),
    0 28px 70px rgba(2, 6, 23, 0.32),
    0 0 0 1px rgba(255,255,255,0.02);
  backdrop-filter: blur(18px);
}

.cx-lab-panel::before{
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 5px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--cx-panel-accent) 92%, #fff 8%) 0%, transparent 100%);
  opacity: 0.96;
}

.cx-lab-panel::after{
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(118deg, rgba(255,255,255,0.055) 0%, rgba(255,255,255,0) 28%),
    radial-gradient(circle at 92% 8%, color-mix(in srgb, var(--cx-panel-accent) 18%, transparent) 0%, transparent 22%);
}

.cx-lab-panel-primary{
  --cx-panel-accent: rgba(249, 115, 22, 0.75);
  --cx-panel-accent-soft: rgba(249, 115, 22, 0.16);
}

.cx-lab-panel-secondary{
  --cx-panel-accent: rgba(56, 189, 248, 0.74);
  --cx-panel-accent-soft: rgba(56, 189, 248, 0.16);
}

.cx-lab-panel-tertiary{
  --cx-panel-accent: rgba(34, 197, 94, 0.68);
  --cx-panel-accent-soft: rgba(34, 197, 94, 0.14);
}

.cx-lab-panel-head{
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 0.9rem;
  min-height: 100%;
  margin: 0;
  padding: 0.15rem 1.45rem 0.15rem 0.1rem;
  border-right: 1px solid rgba(255,255,255,0.07);
}

.cx-lab-panel-head::after{
  content: "";
  width: 96px;
  height: 1px;
  margin-top: 0.15rem;
  background: linear-gradient(90deg, color-mix(in srgb, var(--cx-panel-accent) 86%, #fff 10%) 0%, transparent 100%);
  box-shadow: 0 0 18px color-mix(in srgb, var(--cx-panel-accent) 24%, transparent);
}

.cx-lab-panel-head > div{
  display: grid;
  gap: 0.45rem;
}

.cx-lab-panel-head > span{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 4.15rem;
  height: 4.15rem;
  border-radius: 22px;
  border: 1px solid color-mix(in srgb, var(--cx-panel-accent) 62%, rgba(255,255,255,0.09));
  background:
    radial-gradient(circle at 50% 0%, color-mix(in srgb, var(--cx-panel-accent) 26%, transparent) 0%, transparent 58%),
    linear-gradient(180deg, color-mix(in srgb, var(--cx-panel-accent) 28%, rgba(15, 23, 42, 0.94)) 0%, rgba(9, 15, 26, 0.96) 100%);
  color: #f8fafc;
  font-size: 0.94rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.05) inset,
    0 14px 30px color-mix(in srgb, var(--cx-panel-accent) 16%, transparent),
    0 0 26px color-mix(in srgb, var(--cx-panel-accent) 18%, transparent);
  flex-shrink: 0;
}

.cx-lab-panel-head h3{
  margin: 0;
  font-size: clamp(1.08rem, 1.55vw, 1.34rem);
  letter-spacing: -0.035em;
  line-height: 1.06;
  color: #f8fafc;
}

.cx-lab-panel-head p{
  margin: 0;
  color: rgba(218, 226, 240, 0.8);
  line-height: 1.72;
  font-size: 0.9rem;
  max-width: 30ch;
}

.cx-lab-subsidiary-grid,
.cx-lab-domain-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.95rem;
}

.cx-lab-panel > .cx-lab-subsidiary-grid,
.cx-lab-panel > .cx-lab-domain-grid,
.cx-lab-panel > .cx-lab-role-grid,
.cx-lab-panel > .cx-lab-phase-grid,
.cx-lab-panel > .cx-lab-node-rail,
.cx-lab-panel > .cx-lab-resilience-grid{
  position: relative;
  align-self: stretch;
}

.cx-lab-subsidiary,
.cx-lab-domain,
.cx-lab-role,
.cx-lab-phase,
.cx-lab-node,
.cx-lab-resilience{
  border-radius: 22px;
  border: 1px solid rgba(148, 163, 184, 0.13);
  background: linear-gradient(180deg, rgba(12, 20, 34, 0.94) 0%, rgba(8, 14, 24, 0.95) 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.035), 0 16px 32px rgba(2, 6, 23, 0.18);
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.cx-lab-subsidiary,
.cx-lab-domain{
  position: relative;
  overflow: hidden;
  padding: 1.05rem 1.05rem 1.08rem;
  border-color: color-mix(in srgb, var(--cx-accent) 30%, rgba(148, 163, 184, 0.12));
  background:
    radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--cx-accent) 17%, transparent) 0%, transparent 34%),
    linear-gradient(180deg, rgba(14, 24, 40, 0.95) 0%, rgba(9, 16, 28, 0.96) 100%);
}

.cx-lab-subsidiary::before,
.cx-lab-domain::before,
.cx-lab-role::before,
.cx-lab-phase::before,
.cx-lab-node::before,
.cx-lab-resilience::before{
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(135deg, rgba(255,255,255,0.035) 0%, rgba(255,255,255,0) 28%);
}

.cx-lab-subsidiary-top,
.cx-lab-domain-top{
  display: flex;
  align-items: center;
  gap: 0.7rem;
  margin-bottom: 0.55rem;
}

.cx-lab-badge{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 3.1rem;
  height: 1.7rem;
  padding: 0 0.7rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--cx-accent) 22%, rgba(15, 23, 42, 0.92));
  color: #f8fafc;
  border: 1px solid color-mix(in srgb, var(--cx-accent) 45%, rgba(255,255,255,0.06));
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  font-weight: 700;
}

.cx-lab-subsidiary-top strong,
.cx-lab-domain-top strong,
.cx-lab-role strong,
.cx-lab-node strong,
.cx-lab-resilience strong{
  color: #f8fafc;
}

.cx-lab-subsidiary-top strong,
.cx-lab-domain-top strong{
  flex: 1;
  font-size: 0.94rem;
  line-height: 1.3;
}

.cx-lab-subsidiary-top em,
.cx-lab-domain-top span{
  font-style: normal;
  font-size: 0.84rem;
  color: #bfdbfe;
}

.cx-lab-subsidiary p,
.cx-lab-domain p,
.cx-lab-role p,
.cx-lab-phase p,
.cx-lab-node p,
.cx-lab-resilience span{
  margin: 0;
  color: rgba(203, 213, 225, 0.76);
  line-height: 1.55;
  font-size: 0.82rem;
}

.cx-lab-role-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.95rem;
}

.cx-lab-role{
  position: relative;
  overflow: hidden;
  padding: 1rem 1.05rem;
  border-left: 3px solid color-mix(in srgb, var(--cx-panel-accent) 58%, transparent);
  border-color: color-mix(in srgb, var(--cx-panel-accent) 20%, rgba(148, 163, 184, 0.12));
  background:
    radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--cx-panel-accent) 14%, transparent) 0%, transparent 36%),
    linear-gradient(180deg, rgba(12, 20, 34, 0.96) 0%, rgba(8, 14, 24, 0.96) 100%);
}

.cx-lab-role strong{
  display: block;
  margin-bottom: 0.25rem;
  font-size: 0.92rem;
}

.cx-lab-phase-grid,
.cx-lab-resilience-grid{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.8rem;
}

.cx-lab-phase,
.cx-lab-resilience{
  position: relative;
  overflow: hidden;
  padding: 1rem;
  border-color: color-mix(in srgb, var(--cx-panel-accent) 18%, rgba(148, 163, 184, 0.12));
  background:
    radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--cx-panel-accent) 13%, transparent) 0%, transparent 38%),
    linear-gradient(180deg, rgba(12, 20, 34, 0.96) 0%, rgba(8, 14, 24, 0.96) 100%);
}

.cx-lab-phase{
  border-top: 1px solid color-mix(in srgb, var(--cx-panel-accent) 34%, transparent);
}

.cx-lab-resilience{
  border-top: 1px solid color-mix(in srgb, var(--cx-panel-accent) 34%, transparent);
}

.cx-lab-phase span,
.cx-lab-node span{
  display: inline-flex;
  margin-bottom: 0.55rem;
  padding: 0.3rem 0.62rem;
  border-radius: 999px;
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #93c5fd;
  background: rgba(59, 130, 246, 0.12);
  border: 1px solid rgba(59, 130, 246, 0.2);
}

.cx-lab-phase strong,
.cx-lab-resilience strong{
  display: block;
  font-size: 1.45rem;
  letter-spacing: -0.04em;
  margin-bottom: 0.35rem;
}

.cx-lab-phase h4{
  margin: 0 0 0.4rem;
  font-size: 0.94rem;
  color: #f8fafc;
}

.cx-lab-node-rail{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.cx-lab-node{
  position: relative;
  overflow: hidden;
  padding: 1rem;
  border-left: 3px solid color-mix(in srgb, var(--cx-panel-accent) 58%, transparent);
  border-color: color-mix(in srgb, var(--cx-panel-accent) 20%, rgba(148, 163, 184, 0.12));
  background:
    radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--cx-panel-accent) 14%, transparent) 0%, transparent 36%),
    linear-gradient(180deg, rgba(12, 20, 34, 0.96) 0%, rgba(8, 14, 24, 0.96) 100%);
}

.cx-lab-node strong{
  display: block;
  margin-bottom: 0.22rem;
  font-size: 0.96rem;
}

.cx-lab-subsidiary:hover,
.cx-lab-domain:hover,
.cx-lab-role:hover,
.cx-lab-phase:hover,
.cx-lab-node:hover,
.cx-lab-resilience:hover{
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--cx-panel-accent) 34%, rgba(148, 163, 184, 0.12));
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04), 0 22px 34px rgba(2, 6, 23, 0.24), 0 0 24px color-mix(in srgb, var(--cx-panel-accent) 10%, transparent);
}

.cx-lab-subsidiary-top em,
.cx-lab-domain-top span{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.8rem;
  padding: 0.18rem 0.6rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--cx-accent) 14%, rgba(15, 23, 42, 0.92));
  border: 1px solid color-mix(in srgb, var(--cx-accent) 32%, rgba(255,255,255,0.06));
  color: color-mix(in srgb, var(--cx-accent) 52%, #dbeafe 48%);
  box-shadow: 0 0 0 1px rgba(255,255,255,0.03) inset;
}

.cx-lab-panel-primary .cx-lab-badge,
.cx-lab-panel-primary .cx-lab-subsidiary-top em,
.cx-lab-panel-primary .cx-lab-domain-top span{
  box-shadow: 0 0 0 1px rgba(255,255,255,0.04) inset, 0 12px 24px rgba(249, 115, 22, 0.14);
}

.cx-lab-panel-secondary .cx-lab-badge,
.cx-lab-panel-secondary .cx-lab-subsidiary-top em,
.cx-lab-panel-secondary .cx-lab-domain-top span{
  box-shadow: 0 0 0 1px rgba(255,255,255,0.04) inset, 0 12px 24px rgba(56, 189, 248, 0.14);
}

.cx-lab-panel-tertiary .cx-lab-badge,
.cx-lab-panel-tertiary .cx-lab-subsidiary-top em,
.cx-lab-panel-tertiary .cx-lab-domain-top span{
  box-shadow: 0 0 0 1px rgba(255,255,255,0.04) inset, 0 12px 24px rgba(34, 197, 94, 0.14);
}

#tc2 .chart-section,
#tc3 .chart-section{
  position: relative;
  padding: 1.15rem 1.15rem 1.2rem;
  border-radius: 24px;
  border: 1px solid rgba(148, 163, 184, 0.12);
  background: linear-gradient(180deg, rgba(13, 21, 35, 0.86) 0%, rgba(8, 14, 24, 0.9) 100%);
  box-shadow: 0 18px 42px rgba(2, 6, 23, 0.24);
}

#tc2 .chart-section h3,
#tc3 .chart-section h3{
  margin-bottom: 0.9rem;
  font-size: 1.02rem;
  letter-spacing: -0.02em;
}

#tc2 .data-table,
#tc3 .data-table{
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(96, 165, 250, 0.12);
  background: rgba(7, 12, 22, 0.92);
}

#tc2 .data-table thead th,
#tc3 .data-table thead th{
  background: linear-gradient(180deg, rgba(19, 31, 52, 0.96) 0%, rgba(11, 19, 31, 0.98) 100%);
}

#tc2 .data-table tbody tr:nth-child(2n),
#tc3 .data-table tbody tr:nth-child(2n){
  background: rgba(255,255,255,0.015);
}

#tc2 .data-table tbody tr:hover,
#tc3 .data-table tbody tr:hover{
  background: rgba(59, 130, 246, 0.08);
}

@media (max-width: 1180px){
.cx-lab-stats-grid,
.cx-lab-stats-grid-compact,
.cx-lab-phase-grid,
.cx-lab-resilience-grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

.cx-lab-panel{
    grid-template-columns: 1fr;
    gap: 1.1rem;
  }

.cx-lab-panel-head{
    padding-right: 0;
    border-right: 0;
    border-bottom: 1px solid rgba(255,255,255,0.07);
    padding-bottom: 1rem;
  }

.cx-lab-role-grid{
    grid-template-columns: 1fr;
  }

}

@media (max-width: 860px){
.cx-lab-head{
    flex-direction: column;
  }

.cx-lab-stats-grid,
.cx-lab-stats-grid-compact,
.cx-lab-subsidiary-grid,
.cx-lab-domain-grid,
.cx-lab-phase-grid,
.cx-lab-resilience-grid,
.cx-lab-node-rail{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

.cx-lab-panel{
    padding: 1.15rem 1.12rem 1.18rem;
    border-radius: 26px;
  }

.cx-lab-panel-head > span{
    min-width: 3.5rem;
    height: 3.5rem;
    border-radius: 19px;
    font-size: 0.86rem;
  }

}

@media (max-width: 560px){
.cx-lab-shell{
    padding: 1rem;
    border-radius: 22px;
  }

.cx-lab-stats-grid,
.cx-lab-stats-grid-compact,
.cx-lab-subsidiary-grid,
.cx-lab-domain-grid,
.cx-lab-phase-grid,
.cx-lab-resilience-grid,
.cx-lab-node-rail{
    grid-template-columns: 1fr;
  }

.cx-lab-jump{
    width: 100%;
    text-align: center;
  }

}




/* === REAL PREMIUM STAGE SHELL FIX START === */
body.cygniax-premium-portal .cx-stage-shell{
  --cx-accent-rgb: 59, 130, 246;
  position: relative;
  max-width: min(1480px, calc(100% - 40px));
  margin: 0 auto 1.15rem;
  padding: 1.35rem;
  border-radius: 30px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(145deg, rgba(11, 18, 33, 0.88) 0%, rgba(8, 14, 27, 0.95) 100%);
  box-shadow: 0 24px 54px rgba(2, 6, 23, 0.28);
  overflow: hidden;
}

body.cygniax-premium-portal .cx-stage-shell::before{
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 0% 0%, rgba(var(--cx-accent-rgb), 0.18) 0%, transparent 34%),
    radial-gradient(circle at 100% 100%, rgba(255, 255, 255, 0.04) 0%, transparent 28%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0));
}

body.cygniax-premium-portal .cx-stage-head,
body.cygniax-premium-portal .cx-stage-metrics,
body.cygniax-premium-portal .cx-stage-grid{
  position: relative;
  z-index: 1;
}

body.cygniax-premium-portal .cx-stage-head{
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
  gap: 1rem;
  align-items: end;
  margin-bottom: 1.2rem;
}

body.cygniax-premium-portal .cx-stage-kicker{
  display: block;
  margin: 0 0 0.8rem;
  color: rgba(var(--cx-accent-rgb), 0.96);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.66rem;
}

body.cygniax-premium-portal .cx-stage-head h2{
  margin: 0;
  color: #f8fafc;
  font-size: clamp(1.8rem, 3vw, 2.8rem);
  letter-spacing: -0.04em;
  line-height: 1.02;
  text-wrap: balance;
}

body.cygniax-premium-portal .cx-stage-intro{
  display: block;
  margin-top: 0.95rem;
  color: rgba(218, 226, 240, 0.84);
  line-height: 1.68;
  font-size: 1rem;
  max-width: 64ch;
}

body.cygniax-premium-portal .cx-stage-metrics{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.7rem;
  margin-bottom: 0.95rem;
}

body.cygniax-premium-portal .cx-stage-metric,
body.cygniax-premium-portal .cx-stage-card{
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.72rem;
  border-radius: 24px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: linear-gradient(180deg, rgba(16, 26, 45, 0.82), rgba(8, 14, 27, 0.94));
  box-shadow: 0 18px 40px rgba(2, 6, 23, 0.24);
  transition: transform 220ms ease, border-color 220ms ease, box-shadow 220ms ease;
  overflow: hidden;
}

body.cygniax-premium-portal .cx-stage-metric{
  padding: 0.95rem 0.9rem 0.85rem;
}

body.cygniax-premium-portal .cx-stage-card{
  padding: 1.15rem;
}

body.cygniax-premium-portal .cx-stage-metric::before,
body.cygniax-premium-portal .cx-stage-card::before{
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(var(--cx-accent-rgb), 0.16) 0%, rgba(var(--cx-accent-rgb), 0) 42%);
}

body.cygniax-premium-portal .cx-stage-metric:hover,
body.cygniax-premium-portal .cx-stage-card:hover{
  transform: translateY(-4px);
  border-color: rgba(var(--cx-accent-rgb), 0.3);
  box-shadow: 0 24px 52px rgba(2, 6, 23, 0.34), 0 0 0 1px rgba(var(--cx-accent-rgb), 0.12);
}

body.cygniax-premium-portal .cx-stage-metric strong,
body.cygniax-premium-portal .cx-stage-metric span,
body.cygniax-premium-portal .cx-stage-card h3,
body.cygniax-premium-portal .cx-stage-card p,
body.cygniax-premium-portal .cx-stage-card-label,
body.cygniax-premium-portal .cx-stage-chip-row,
body.cygniax-premium-portal .cx-stage-chip{
  position: relative;
  z-index: 1;
}

body.cygniax-premium-portal .cx-stage-metric strong{
  display: block;
  color: #f8fafc;
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  letter-spacing: -0.05em;
  line-height: 1;
}

body.cygniax-premium-portal .cx-stage-metric span{
  display: block;
  margin-top: 0.05rem;
  color: rgba(226, 232, 240, 0.72);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.65rem;
  line-height: 1.45;
}

body.cygniax-premium-portal .cx-stage-grid{
  display: grid;
  gap: 0.95rem;
}

body.cygniax-premium-portal .cx-stage-grid-3{
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body.cygniax-premium-portal .cx-stage-grid-4{
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

body.cygniax-premium-portal .cx-stage-card h3{
  margin: 0;
  color: #f8fafc;
  font-size: clamp(1rem, 1.6vw, 1.22rem);
  letter-spacing: -0.03em;
  line-height: 1.15;
}

body.cygniax-premium-portal .cx-stage-card p{
  margin: 0;
  color: rgba(218, 226, 240, 0.82);
  line-height: 1.62;
}

body.cygniax-premium-portal .cx-stage-card-label{
  display: inline-flex;
  margin-bottom: 0.1rem;
  color: rgba(var(--cx-accent-rgb), 0.95);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 0.7rem;
}

body.cygniax-premium-portal .cx-stage-chip-row{
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 0.2rem;
}

body.cygniax-premium-portal .cx-stage-chip{
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.48rem 0.78rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.045);
  color: rgba(226, 232, 240, 0.88);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  line-height: 1.25;
}

body.cygniax-premium-portal .tone-hr{ --cx-accent-rgb: 52, 211, 153; }
body.cygniax-premium-portal .tone-infra{ --cx-accent-rgb: 251, 191, 36; }
body.cygniax-premium-portal .tone-finance{ --cx-accent-rgb: 249, 115, 22; }
body.cygniax-premium-portal .tone-cashflow{ --cx-accent-rgb: 59, 130, 246; }
body.cygniax-premium-portal .tone-scenarios{ --cx-accent-rgb: 168, 85, 247; }
body.cygniax-premium-portal .tone-subs{ --cx-accent-rgb: 14, 165, 233; }
body.cygniax-premium-portal .tone-global{ --cx-accent-rgb: 234, 179, 8; }
body.cygniax-premium-portal .tone-deployment{ --cx-accent-rgb: 244, 114, 182; }

body.cygniax-premium-portal .cx-stage-shell *,
body.cygniax-premium-portal .cx-stage-metric *,
body.cygniax-premium-portal .cx-stage-card *{
  overflow-wrap: anywhere;
  word-break: break-word;
  hyphens: auto;
}

@media (max-width: 1220px){
  body.cygniax-premium-portal .cx-stage-metrics,
  body.cygniax-premium-portal .cx-stage-grid-4{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.cygniax-premium-portal .cx-stage-head{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px){
  body.cygniax-premium-portal .cx-stage-shell{
    max-width: calc(100% - 24px);
  }

  body.cygniax-premium-portal .cx-stage-grid-3{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px){
  body.cygniax-premium-portal .cx-stage-shell{
    border-radius: 22px;
    padding: 1rem;
  }

  body.cygniax-premium-portal .cx-stage-metrics{
    grid-template-columns: 1fr;
  }
}
/* === REAL PREMIUM STAGE SHELL FIX END === */

