/* ============================================
   financials.css — Financials Page Styles
   Behaviour Simulator - Living Behavioral Intelligence
   ============================================ */

/* --- Hero --- */
.fin-hero {
  padding: calc(var(--header-height) + var(--space-16)) 0 var(--space-16);
  text-align: center;
  position: relative;
  overflow: hidden;
}

.fin-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--gradient-hero);
  z-index: 0;
}

.fin-hero .container {
  position: relative;
  z-index: 1;
}

.fin-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: 'Cabinet Grotesk', sans-serif;
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-primary);
  margin-bottom: var(--space-4);
  padding: var(--space-1) var(--space-3);
  background: var(--color-primary-light);
  border-radius: var(--radius-2xl);
}

.fin-hero__title {
  font-size: var(--text-hero);
  line-height: 1.08;
  margin-bottom: var(--space-5);
}

.fin-hero__subtitle {
  font-size: var(--text-xl);
  color: var(--color-text-muted);
  max-width: 700px;
  margin-inline: auto;
  line-height: 1.6;
}

/* --- Headline KPI Strip --- */
.kpi-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
  margin-top: calc(-1 * var(--space-10));
  position: relative;
  z-index: 2;
}

.kpi-card {
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-8) var(--space-6);
  text-align: center;
  box-shadow: var(--shadow-md);
  transition: all var(--transition-base);
}

.kpi-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: var(--color-primary-light);
}

.kpi-card__value {
  font-family: 'Cabinet Grotesk', sans-serif;
  font-size: var(--text-3xl);
  font-weight: 900;
  background: var(--gradient-accent-number);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: var(--space-2);
}

.kpi-card__label {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  font-weight: 500;
}

/* --- TAM Section --- */
.tam-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}

.tam-card {
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  box-shadow: var(--shadow-sm);
  transition: all var(--transition-base);
  position: relative;
  overflow: hidden;
}

.tam-card::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--gradient-primary);
  opacity: 0;
  transition: opacity var(--transition-base);
}

.tam-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.tam-card:hover::after {
  opacity: 1;
}

.tam-card--tier1 {
  border-left: 3px solid var(--color-primary);
}

.tam-card--tier2 {
  border-left: 3px solid var(--color-accent);
}

.tam-card--tier3 {
  border-left: 3px solid var(--color-purple);
}

.tam-card__tier {
  font-family: 'Cabinet Grotesk', sans-serif;
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: var(--space-2);
}

.tam-card--tier1 .tam-card__tier { color: var(--color-primary); }
.tam-card--tier2 .tam-card__tier { color: var(--color-accent); }
.tam-card--tier3 .tam-card__tier { color: var(--color-purple); }

.tam-card__name {
  font-size: var(--text-lg);
  font-weight: 700;
  margin-bottom: var(--space-3);
}

.tam-card__tam {
  font-family: 'Cabinet Grotesk', sans-serif;
  font-size: var(--text-2xl);
  font-weight: 900;
  background: var(--gradient-accent-number);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: var(--space-2);
}

.tam-card__wtp {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-3);
}

.tam-card__usecase {
  font-size: var(--text-sm);
  color: var(--color-text-faint);
  line-height: 1.6;
  border-top: 1px solid var(--color-border-subtle);
  padding-top: var(--space-3);
}

/* --- Aggregate TAM Bar --- */
.tam-aggregate {
  background: var(--gradient-primary);
  color: #fff;
  border-radius: var(--radius-xl);
  padding: var(--space-10);
  text-align: center;
  margin-top: var(--space-8);
  box-shadow: var(--shadow-lg);
}

.tam-aggregate__value {
  font-family: 'Cabinet Grotesk', sans-serif;
  font-size: var(--text-hero);
  font-weight: 900;
  margin-bottom: var(--space-2);
}

.tam-aggregate__label {
  font-size: var(--text-lg);
  opacity: 0.9;
}

/* --- Revenue Projections Table --- */
.revenue-table-wrap {
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-md);
}

.revenue-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}

.revenue-table thead th {
  background: var(--color-surface-2);
  padding: var(--space-4) var(--space-5);
  text-align: left;
  font-family: 'Cabinet Grotesk', sans-serif;
  font-weight: 700;
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-muted);
  border-bottom: 2px solid var(--color-border);
}

.revenue-table tbody td {
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-border-subtle);
  color: var(--color-text);
}

.revenue-table tbody tr {
  transition: background var(--transition-fast);
}

.revenue-table tbody tr:hover {
  background: var(--color-primary-subtle);
}

.revenue-table .revenue-highlight {
  font-weight: 700;
  background: var(--gradient-accent-number);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.revenue-table .tier-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.tier-badge--1 {
  background: var(--color-primary-light);
  color: var(--color-primary);
}

.tier-badge--2 {
  background: var(--color-accent-light);
  color: var(--color-accent);
}

.tier-badge--3 {
  background: var(--color-purple-light);
  color: var(--color-purple);
}

/* --- Revenue Summary Cards --- */
.rev-summary-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  margin-top: var(--space-8);
}

.rev-summary-card {
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  text-align: center;
  box-shadow: var(--shadow-sm);
  transition: all var(--transition-base);
}

.rev-summary-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: var(--color-primary-light);
}

.rev-summary-card__label {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text-muted);
  margin-bottom: var(--space-3);
}

.rev-summary-card__value {
  font-family: 'Cabinet Grotesk', sans-serif;
  font-size: var(--text-2xl);
  font-weight: 900;
  background: var(--gradient-accent-number);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: var(--space-2);
}

.rev-summary-card__note {
  font-size: var(--text-xs);
  color: var(--color-text-faint);
}

/* --- Roadmap Timeline --- */
.roadmap-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
}

.roadmap-phase {
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  box-shadow: var(--shadow-sm);
  transition: all var(--transition-base);
  position: relative;
}

.roadmap-phase:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.roadmap-phase__number {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--gradient-primary);
  color: #fff;
  font-family: 'Cabinet Grotesk', sans-serif;
  font-weight: 900;
  font-size: var(--text-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-4);
  box-shadow: 0 4px 15px rgba(10, 123, 131, 0.3);
}

.roadmap-phase__timeline {
  font-family: 'Cabinet Grotesk', sans-serif;
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--color-primary);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: var(--space-2);
}

.roadmap-phase__title {
  font-size: var(--text-lg);
  font-weight: 700;
  margin-bottom: var(--space-3);
}

.roadmap-phase__items {
  list-style: none;
  padding: 0;
}

.roadmap-phase__items li {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.7;
  padding-left: var(--space-5);
  position: relative;
  margin-bottom: var(--space-2);
}

.roadmap-phase__items li::before {
  content: '→';
  position: absolute;
  left: 0;
  color: var(--color-primary);
  font-weight: 700;
}

/* --- ROI Section --- */
.roi-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-8);
}

.roi-card {
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  box-shadow: var(--shadow-sm);
  transition: all var(--transition-base);
}

.roi-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.roi-card__icon {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-md);
  background: var(--gradient-primary);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-4);
  box-shadow: 0 4px 15px rgba(10, 123, 131, 0.3);
}

.roi-card__icon svg {
  width: 24px;
  height: 24px;
}

.roi-card__title {
  font-size: var(--text-lg);
  font-weight: 700;
  margin-bottom: var(--space-3);
}

.roi-card__text {
  font-size: var(--text-base);
  color: var(--color-text-muted);
  line-height: 1.7;
}

/* --- Budget Section --- */
.budget-table-wrap {
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-md);
}

.budget-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}

.budget-table thead th {
  background: var(--color-surface-2);
  padding: var(--space-4) var(--space-5);
  text-align: left;
  font-family: 'Cabinet Grotesk', sans-serif;
  font-weight: 700;
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-muted);
  border-bottom: 2px solid var(--color-border);
}

.budget-table tbody td {
  padding: var(--space-3) var(--space-5);
  border-bottom: 1px solid var(--color-border-subtle);
}

.budget-table tbody tr:hover {
  background: var(--color-primary-subtle);
}

.budget-table tfoot td {
  padding: var(--space-4) var(--space-5);
  font-weight: 700;
  background: var(--color-surface-2);
  border-top: 2px solid var(--color-border);
}

/* --- Flywheel Visual --- */
.flywheel-steps {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-4);
  text-align: center;
}

.flywheel-step {
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-6) var(--space-4);
  box-shadow: var(--shadow-sm);
  transition: all var(--transition-base);
  position: relative;
}

.flywheel-step:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: var(--color-primary-light);
}

.flywheel-step__num {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--gradient-primary);
  color: #fff;
  font-family: 'Cabinet Grotesk', sans-serif;
  font-weight: 900;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--space-3);
  font-size: var(--text-sm);
}

.flywheel-step__title {
  font-size: var(--text-sm);
  font-weight: 700;
  margin-bottom: var(--space-2);
}

.flywheel-step__desc {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: 1.5;
}

/* Arrow connector between steps */
.flywheel-step:not(:last-child)::after {
  content: '→';
  position: absolute;
  right: -16px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-primary);
  font-size: 1.2rem;
  font-weight: 700;
  z-index: 1;
}

/* --- Responsive --- */
@media (max-width: 1024px) {
  .kpi-strip { grid-template-columns: repeat(2, 1fr); }
  .tam-grid { grid-template-columns: repeat(2, 1fr); }
  .roadmap-grid { grid-template-columns: repeat(2, 1fr); }
  .flywheel-steps { grid-template-columns: repeat(3, 1fr); }
  .flywheel-step::after { display: none; }
}

@media (max-width: 768px) {
  .kpi-strip { grid-template-columns: 1fr; }
  .tam-grid { grid-template-columns: 1fr; }
  .roi-grid { grid-template-columns: 1fr; }
  .rev-summary-grid { grid-template-columns: 1fr; }
  .roadmap-grid { grid-template-columns: 1fr; }
  .flywheel-steps { grid-template-columns: 1fr; }
  .revenue-table-wrap { overflow-x: auto; }
  .budget-table-wrap { overflow-x: auto; }
}



/* ============================================
   Financials — Light Mode Colored Cards
   ============================================ */

[data-theme="light"] .kpi-card {
  background: linear-gradient(135deg, rgba(10, 123, 131, 0.09) 0%, rgba(6, 182, 212, 0.06) 100%);
}

[data-theme="light"] .kpi-card:nth-child(2) {
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.09) 0%, rgba(99, 102, 241, 0.06) 100%);
}

[data-theme="light"] .kpi-card:nth-child(3) {
  background: linear-gradient(135deg, rgba(124, 58, 237, 0.08) 0%, rgba(139, 92, 246, 0.05) 100%);
}

[data-theme="light"] .kpi-card:nth-child(4) {
  background: linear-gradient(135deg, rgba(6, 182, 212, 0.09) 0%, rgba(10, 123, 131, 0.06) 100%);
}

[data-theme="light"] .tam-card {
  background: linear-gradient(135deg, rgba(224, 242, 245, 0.8) 0%, rgba(225, 230, 248, 0.65) 100%);
}

[data-theme="light"] .tam-card--tier1 {
  background: linear-gradient(135deg, rgba(10, 123, 131, 0.10) 0%, rgba(6, 182, 212, 0.06) 100%);
}

[data-theme="light"] .tam-card--tier2 {
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.09) 0%, rgba(99, 102, 241, 0.06) 100%);
}

[data-theme="light"] .tam-card--tier3 {
  background: linear-gradient(135deg, rgba(124, 58, 237, 0.08) 0%, rgba(139, 92, 246, 0.05) 100%);
}

[data-theme="light"] .rev-summary-card:nth-child(odd) {
  background: linear-gradient(135deg, rgba(10, 123, 131, 0.10) 0%, rgba(8, 145, 178, 0.07) 100%);
}

[data-theme="light"] .rev-summary-card:nth-child(even) {
  background: linear-gradient(135deg, rgba(99, 102, 241, 0.09) 0%, rgba(124, 58, 237, 0.06) 100%);
}

[data-theme="light"] .roadmap-phase {
  background: linear-gradient(135deg, rgba(224, 242, 245, 0.75) 0%, rgba(225, 230, 248, 0.6) 100%);
}

[data-theme="light"] .roadmap-phase:nth-child(2) {
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.08) 0%, rgba(99, 102, 241, 0.06) 100%);
}

[data-theme="light"] .roadmap-phase:nth-child(3) {
  background: linear-gradient(135deg, rgba(124, 58, 237, 0.07) 0%, rgba(139, 92, 246, 0.05) 100%);
}

[data-theme="light"] .roadmap-phase:nth-child(4) {
  background: linear-gradient(135deg, rgba(6, 182, 212, 0.09) 0%, rgba(10, 123, 131, 0.06) 100%);
}

[data-theme="light"] .flywheel-step {
  background: linear-gradient(135deg, rgba(224, 242, 245, 0.8) 0%, rgba(225, 230, 248, 0.65) 100%);
}

[data-theme="light"] .flywheel-step:nth-child(2n) {
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.08) 0%, rgba(99, 102, 241, 0.06) 100%);
}

[data-theme="light"] .roi-card {
  background: linear-gradient(135deg, rgba(10, 123, 131, 0.09) 0%, rgba(6, 182, 212, 0.06) 100%);
}

[data-theme="light"] .roi-card:nth-child(2) {
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.09) 0%, rgba(99, 102, 241, 0.06) 100%);
}

[data-theme="light"] .roi-card:nth-child(3) {
  background: linear-gradient(135deg, rgba(124, 58, 237, 0.08) 0%, rgba(139, 92, 246, 0.05) 100%);
}

[data-theme="light"] .revenue-table-wrap {
  background: rgba(224, 239, 243, 0.85);
}

[data-theme="light"] .revenue-table thead th {
  background: rgba(180, 215, 225, 0.6);
}

[data-theme="light"] .budget-table-wrap {
  background: rgba(224, 239, 243, 0.85);
}

[data-theme="light"] .budget-table thead th {
  background: rgba(180, 215, 225, 0.6);
}

[data-theme="light"] .budget-table tfoot td {
  background: rgba(180, 215, 225, 0.5);
}

[data-theme="light"] .tam-aggregate {
  background: linear-gradient(135deg, rgba(10, 123, 131, 0.12) 0%, rgba(99, 102, 241, 0.08) 50%, rgba(124, 58, 237, 0.06) 100%);
}
