/*
Theme Name: Chat Genius
Description: Custom Theme for chatgenius.net
Version: 1.0.0
Author: Chat Genius
Author URI:
Theme URI: https://chatgenius.net/
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Template: Divi
*/

/* ========== DESIGN SYSTEM: The Kinetic Concierge ========== */

/* --- CSS Custom Properties --- */
:root {
  /* Surface Hierarchy */
  --cg-background: #051329;
  --cg-surface: #051329;
  --cg-surface-dim: #051329;
  --cg-surface-container-lowest: #010e24;
  --cg-surface-container-low: #0d1c32;
  --cg-surface-container: #122036;
  --cg-surface-container-high: #1d2a41;
  --cg-surface-container-highest: #28354c;
  --cg-surface-bright: #2c3951;
  --cg-surface-variant: #28354c;

  /* Primary (Teal) */
  --cg-primary: #4adcc2;
  --cg-primary-bright: #73ffe3;
  --cg-primary-container: #00120e;
  --cg-on-primary: #00382f;
  --cg-on-primary-container: #008b78;
  --cg-primary-fixed: #6df9dd;

  /* Secondary (Blue-Lavender) */
  --cg-secondary: #b9c7e4;
  --cg-secondary-container: #3c4962;
  --cg-on-secondary: #233148;

  /* Tertiary (Lime Pulse) */
  --cg-tertiary: #d4ddb6;
  --cg-tertiary-container: #0a1000;
  --cg-on-tertiary: #2b3410;

  /* Text */
  --cg-on-surface: #d6e3ff;
  --cg-on-surface-variant: #c5c6ce;
  --cg-on-background: #d6e3ff;

  /* Outline */
  --cg-outline: #8f9097;
  --cg-outline-variant: #44474d;

  /* Error */
  --cg-error: #ffb4ab;
  --cg-error-container: #93000a;

  /* Inverse */
  --cg-inverse-surface: #d6e3ff;
  --cg-inverse-on-surface: #233148;
  --cg-inverse-primary: #006b5c;

  /* Surface Tint */
  --cg-surface-tint: #4adcc2;
}

/* --- Global Resets for Divi --- */
body,
#page-container,
.et-l,
.et_builder_inner_content,
.et_pb_section,
.et_pb_section_0,
.et_d4_element,
.et_pb_with_background {
  background-color: var(--cg-background) !important;
  color: var(--cg-on-surface) !important;
}

/* Divi section backgrounds */
.et_pb_section {
  background-color: #051329 !important;
}

body {
  font-family: 'Manrope', sans-serif !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

#main-content {
  background-color: var(--cg-background) !important;
}

/* --- Typography --- */
.cg-headline,
.cg-display {
  font-family: 'Space Grotesk', sans-serif !important;
  letter-spacing: -0.02em;
  color: #ffffff;
}

/* Force all headings in Divi sections to use the peach accent */
.et_pb_section h1,
.et_pb_section h2,
.et_pb_section h3,
.et_pb_section h4,
.et_pb_section h5,
.et_pb_section h6,
.et_pb_fullwidth_code h1,
.et_pb_fullwidth_code h2,
.et_pb_fullwidth_code h3,
.et_pb_fullwidth_code h4,
.et_pb_fullwidth_code h5,
.et_pb_fullwidth_code h6,
.et_pb_code h1,
.et_pb_code h2,
.et_pb_code h3,
.et_pb_code h4,
.et_pb_code h5,
.et_pb_code h6 {
  color: #d4ddb6 !important;
  padding: 0 !important;
}

/* Reset default browser margins on headings in cards */
.et_pb_fullwidth_code h1,
.et_pb_fullwidth_code h2,
.et_pb_fullwidth_code h3,
.et_pb_fullwidth_code h4,
.et_pb_fullwidth_code h5,
.et_pb_fullwidth_code h6,
.cg-card h1,
.cg-card h2,
.cg-card h3,
.cg-card h4,
.cg-card h5,
.cg-card h6 {
  margin-top: 0;
  margin-bottom: 0;
  line-height: 1.2;
}

/* Allow specific color overrides for gradient text and accent colors */
.cg-gradient-text,
.et_pb_section .cg-gradient-text {
  background: linear-gradient(135deg, #4adcc2 0%, #008b78 100%) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  color: transparent !important;
}

.et_pb_section .cg-text-primary,
.et_pb_section h1.cg-text-primary,
.et_pb_section h2.cg-text-primary,
.et_pb_section h3.cg-text-primary,
.et_pb_section h4.cg-text-primary,
.et_pb_section .cg-text-primary-bright,
.et_pb_section h1.cg-text-primary-bright,
.et_pb_section h2.cg-text-primary-bright,
.et_pb_section h3.cg-text-primary-bright {
  color: var(--cg-primary-bright) !important;
}

.et_pb_section .cg-text-tertiary,
.et_pb_section h3.cg-text-tertiary {
  color: var(--cg-tertiary) !important;
}

.cg-body {
  font-family: 'Manrope', sans-serif !important;
}

.cg-label {
  font-family: 'Space Grotesk', sans-serif !important;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: #d6e3ff;
}

/* Display sizes */
.cg-display-lg { font-size: clamp(3rem, 6.5vw, 5rem); line-height: 0.95; font-weight: 700; letter-spacing: -0.03em; }
.cg-display-md { font-size: clamp(2.25rem, 4.5vw, 3.5rem); line-height: 1; font-weight: 700; letter-spacing: -0.025em; }
.cg-display-sm { font-size: clamp(1.875rem, 3.5vw, 2.75rem); line-height: 1.05; font-weight: 700; letter-spacing: -0.02em; }
.cg-title-lg { font-size: 1.625rem; line-height: 1.25; font-weight: 700; letter-spacing: -0.01em; }
.cg-title-md { font-size: 1.25rem; line-height: 1.3; font-weight: 700; letter-spacing: -0.005em; }
.cg-body-lg { font-size: 1.1875rem; line-height: 1.7; }
.cg-body-md { font-size: 1rem; line-height: 1.7; }
.cg-body-sm { font-size: 0.9375rem; line-height: 1.7; color: #92989F; }
.cg-label-lg { font-size: 0.75rem; }
.cg-label-sm { font-size: 0.6875rem; }

/* --- Color Utilities --- */
.cg-text-primary { color: var(--cg-primary) !important; }
.cg-text-primary-bright { color: var(--cg-primary-bright) !important; }
.cg-text-tertiary { color: var(--cg-tertiary) !important; }
.cg-text-on-surface { color: var(--cg-on-surface) !important; }
.cg-text-on-surface-variant { color: #ADB3B9 !important; }
.cg-text-muted { color: rgba(207, 210, 219, 0.75) !important; }
.cg-text-error { color: #ffb4ab !important; }

/* Ensure platform icon text is readable */
.cg-platform-item .cg-label {
  color: #cfd2db;
}

.cg-bg-background { background-color: var(--cg-background) !important; }
.cg-bg-surface { background-color: var(--cg-surface) !important; }
.cg-bg-surface-lowest { background-color: var(--cg-surface-container-lowest) !important; }
.cg-bg-surface-low { background-color: var(--cg-surface-container-low) !important; }
.cg-bg-surface-container { background-color: var(--cg-surface-container) !important; }
.cg-bg-surface-high { background-color: var(--cg-surface-container-high) !important; }
.cg-bg-surface-highest { background-color: var(--cg-surface-container-highest) !important; }
.cg-bg-surface-bright { background-color: var(--cg-surface-bright) !important; }
.cg-bg-primary { background-color: var(--cg-primary) !important; }
.cg-bg-on-primary { color: var(--cg-on-primary) !important; }

/* --- Glass Panel (sharper, more opaque for readability) --- */
.cg-glass {
  background: rgba(40, 53, 76, 0.85) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.cg-glass-nav {
  background: rgba(5, 19, 41, 0.85) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

/* --- Liquid Gradient (Primary CTA) --- */
.cg-gradient-primary {
  background: linear-gradient(135deg, #4adcc2 0%, #008b78 100%) !important;
}

.cg-gradient-text {
  background: linear-gradient(135deg, #4adcc2 0%, #008b78 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* --- Buttons --- */
.cg-btn-primary {
  background: linear-gradient(135deg, #4adcc2 0%, #008b78 100%) !important;
  color: var(--cg-on-primary) !important;
  font-family: 'Space Grotesk', sans-serif !important;
  font-weight: 700;
  font-size: 0.9375rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 18px 36px;
  border-radius: 0.625rem;
  border: none !important;
  cursor: pointer;
  transition: all 0.3s ease;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none !important;
}
.cg-btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 30px rgba(74, 220, 194, 0.35);
}

.cg-btn-secondary {
  background: rgba(40, 53, 76, 0.5) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  color: var(--cg-on-surface) !important;
  font-family: 'Space Grotesk', sans-serif !important;
  font-weight: 700;
  font-size: 0.9375rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 18px 36px;
  border-radius: 0.625rem;
  border: 1px solid rgba(214, 227, 255, 0.12) !important;
  cursor: pointer;
  transition: all 0.3s ease;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none !important;
}
.cg-btn-secondary:hover {
  background: var(--cg-surface-variant) !important;
}

.cg-btn-dark {
  background: var(--cg-on-primary) !important;
  color: #fff !important;
  font-family: 'Space Grotesk', sans-serif !important;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 20px 40px;
  border-radius: 0.75rem;
  border: none !important;
  cursor: pointer;
  transition: all 0.3s ease;
  text-decoration: none !important;
}
.cg-btn-dark:hover {
  transform: scale(1.03);
}

/* --- Cards --- */
.cg-card {
  border-radius: 1rem;
  padding: 2.25rem;
  transition: background-color 0.3s ease;
  display: flex;
  flex-direction: column;
}
.cg-card > *:last-child {
  margin-bottom: 0;
}
@media (max-width: 768px) {
  .cg-card {
    padding: 1.75rem;
  }
}

.cg-card-glass {
  background: rgba(40, 53, 76, 0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: 1rem;
  padding: 2.25rem;
  color: #d6e3ff;
}

/* Outlined card - subtle teal border (matches status pill style) */
.cg-card-outline {
  border: 1px solid rgba(74, 220, 194, 0.18);
}

/* Outlined card - taupe border for teal-background cards */
.cg-card-outline-taupe {
  border: 1px solid rgba(176, 160, 144, 0.4);
}

/* Ensure all text in cards is readable */
.cg-card p,
.cg-card-glass p,
.cg-card li {
  color: #92989F;
}

/* --- Sections --- */
.cg-section {
  padding: 70px 0;
}

/* Venue type cards (USE CASES BY VENUE TYPE on /for-locations/): 4-col grid + subtle teal top accent */
.cg-venue-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
}
.cg-venue-grid > .cg-card {
  background-color: #152339 !important;
}
@media (max-width: 900px) {
  .cg-venue-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .cg-venue-grid { grid-template-columns: 1fr; }
}

.cg-section-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 2.5rem;
}

/* THE OPPORTUNITY cards: tighter padding + asymmetric columns
   Left column (cards 1 & 3): narrower → squarer
   Right column (cards 2 & 4): wider → more rectangular for longer copy */
/* THE OPPORTUNITY / Friction Paradox: 2-column shell — narrative left, cards right.
   1 : 1 keeps the title/subtitle column visually balanced with the right cards column */
.cg-opp-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: start;
}
.cg-opp-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
  align-items: start;
}
.cg-opp-cards > .cg-card {
  padding: 1.5rem;
}
.cg-opp-cards > .cg-card .material-symbols-outlined {
  font-size: 2rem !important;
  margin-bottom: 1rem !important;
}
.cg-opp-cards > .cg-card h4 {
  margin-bottom: 0.5rem !important;
}
/* Friction Paradox — right column override: space-between layout + rows stacked with dividers */
.cg-opp-grid:has(.cg-fp-row) {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 2rem;
}
.cg-opp-grid:has(.cg-fp-row) > .cg-opp-sticky {
  align-self: flex-start;
}
.cg-opp-sticky {
  max-width: 38rem;
  margin-left: auto;
  margin-right: auto;
}
.cg-fp-row {
  max-width: 38rem;
  margin-left: auto;
  margin-right: 0;
  align-self: flex-end;
  position: relative;
  padding: 1rem 1.25rem !important;
}
.cg-fp-row p {
  text-align: justify;
}
.cg-fp-row > div {
  flex: 1;
  min-width: 0;
}
.cg-fp-row + .cg-fp-row::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 95%;
  height: 1px;
  background: rgba(176, 160, 144, 0.35);
}
@media (max-width: 900px) {
  .cg-opp-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .cg-opp-cards { grid-template-columns: 1fr !important; }
}
@media (max-width: 768px) {
  .cg-section {
    padding: 30px 0;
  }
  .cg-section-inner {
    padding: 0 1.5rem;
  }
}

/* --- Admin Bar Fix --- */
body.admin-bar .cg-header {
  top: 32px;
}
body.admin-bar.cg-has-header {
  padding-top: 110px;
}
body.cg-has-header {
  padding-top: 78px;
}
@media (max-width: 782px) {
  body.admin-bar .cg-header {
    top: 46px;
  }
  body.admin-bar.cg-has-header {
    padding-top: 118px;
  }
  /* Mobile admin bar is position:absolute — it scrolls away. Pin the header
     to top:0 once scrolled past the bar so no empty strip shows above it. */
  body.admin-bar .cg-header.cg-header-scrolled {
    top: 0 !important;
  }
}

/* --- Stats Strip --- */
.cg-stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-radius: 1rem;
  overflow: hidden;
  gap: 1px;
  background: rgba(68, 71, 77, 0.08);
}
@media (max-width: 768px) {
  .cg-stats-grid {
    grid-template-columns: 1fr;
  }
}

.cg-stat-item {
  padding: 2rem 2.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.cg-stat-number {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 3.25rem;
  font-weight: 700;
  color: var(--cg-primary);
  line-height: 1;
  letter-spacing: -0.02em;
}

.cg-stat-label {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: rgba(207, 210, 219, 0.8);
}

/* --- Bento Grid --- */
.cg-bento {
  display: grid;
  gap: 1.25rem;
  grid-auto-rows: 1fr;
}
/* Bento with natural (auto) row heights - content-sized cards */
.cg-bento-auto {
  grid-auto-rows: auto !important;
}
.cg-bento-auto > .cg-card {
  height: auto !important;
}
/* Bento where each row sizes to its tallest card, but rows are independent */
.cg-bento-row-auto {
  grid-auto-rows: min-content !important;
}
.cg-bento-row-auto > .cg-card {
  height: 100%;
  max-width: calc(100% - 5px);
}

.cg-bento-4 {
  grid-template-columns: repeat(4, 1fr);
}
.cg-bento-12 {
  grid-template-columns: repeat(12, 1fr);
}
@media (max-width: 768px) {
  .cg-bento-4, .cg-bento-12 {
    grid-template-columns: 1fr;
  }
}

.cg-col-span-4 { grid-column: span 4; }
.cg-col-span-5 { grid-column: span 5; }
.cg-col-span-6 { grid-column: span 6; }
.cg-col-span-7 { grid-column: span 7; }
.cg-col-span-8 { grid-column: span 8; }
.cg-col-span-12 { grid-column: span 12; }
@media (max-width: 768px) {
  [class*="cg-col-span-"] { grid-column: span 1; }
}

/* --- Pulse Indicator --- */
.cg-pulse {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--cg-tertiary);
  display: inline-block;
  box-shadow: 0 0 10px rgba(192, 204, 154, 0.5);
  animation: cg-pulse-anim 2s infinite;
}

@keyframes cg-pulse-anim {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

/* Quick fade, long dim — used for the "chase" effect on Choose Your Control Level list */
@keyframes cg-chase-anim {
  0%, 100% { opacity: 0.25; }
  8% { opacity: 1; }
  30% { opacity: 1; }
  40% { opacity: 0.25; }
}

.cg-pulse-primary {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--cg-primary);
  display: inline-block;
  box-shadow: 0 0 10px rgba(74, 220, 194, 0.5);
  animation: cg-pulse-anim 2s infinite;
}

/* --- Step Numbers --- */
.cg-step-number {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.125rem;
  font-weight: 700;
  color: rgba(74, 220, 194, 0.95);
  line-height: 1;
}

/* --- Feature Tags/Chips --- */
.cg-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.375rem 1rem;
  border-radius: 9999px;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
}

.cg-chip-primary {
  background: rgba(74, 220, 194, 0.1);
  color: var(--cg-primary);
}

.cg-chip-tertiary {
  background: rgba(192, 204, 154, 0.1);
  color: var(--cg-tertiary);
}

/* --- Border Accents (No-Line Rule compliant) --- */
.cg-border-l-primary {
  border-left: 4px solid var(--cg-primary) !important;
}
.cg-border-t-primary {
  border-top: 3px solid var(--cg-primary) !important;
}

/* --- Grid Helpers --- */
.cg-grid-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.25rem;
  grid-auto-rows: 1fr;
}
.cg-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
  grid-auto-rows: 1fr;
}
/* Flex version that centers incomplete last rows - 3 cards per row */
.cg-flex-3 {
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem;
  justify-content: center;
  align-items: stretch;
}
.cg-flex-3 > .cg-card {
  flex: 0 0 calc((100% - 2.5rem) / 3);
  max-width: calc((100% - 2.5rem) / 3);
  padding: 2rem !important;
  gap: 1.25rem !important;
}
.cg-flex-3 > .cg-card p {
  margin-bottom: 0;
  line-height: 1.65;
}
.cg-flex-3 > .cg-card .cg-bg-surface-low {
  padding: 0.875rem 1.125rem !important;
}
.cg-flex-3 > .cg-card .cg-bg-surface-low p {
  font-size: 0.8125rem;
  line-height: 1.6;
}
@media (max-width: 1024px) {
  .cg-flex-3 > .cg-card {
    flex: 0 0 calc((100% - 1.25rem) / 2);
    max-width: calc((100% - 1.25rem) / 2);
  }
}
@media (max-width: 768px) {
  .cg-flex-3 > .cg-card {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
@media (max-width: 768px) {
  .cg-flex-3 > .cg-card {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
.cg-grid-4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
  grid-auto-rows: 1fr;
}
/* All cards stretch to equal heights in grids */
.cg-grid-2 > .cg-card,
.cg-grid-3 > .cg-card,
.cg-grid-4 > .cg-card,
.cg-bento > .cg-card {
  height: 100%;
}
/* Inline surface box (e.g. Before/After) pushed to bottom */
.cg-card > .cg-bg-surface-low:last-child,
.cg-card > .cg-bg-surface-lowest:last-child {
  margin-top: auto;
}
@media (max-width: 768px) {
  .cg-grid-2, .cg-grid-3, .cg-grid-4 {
    grid-template-columns: 1fr;
  }
}
@media (min-width: 769px) and (max-width: 1024px) {
  .cg-grid-3, .cg-grid-4 {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* --- Image Treatment --- */
.cg-img-cover {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.cg-img-grayscale {
  filter: grayscale(100%);
  transition: filter 0.5s ease;
}
.cg-img-grayscale:hover {
  filter: grayscale(0%);
}

/* --- Spacing Utilities --- */
.cg-mb-sm { margin-bottom: 0.5rem; }
.cg-mb-md { margin-bottom: 1rem; }
.cg-mb-lg { margin-bottom: 2rem; }
.cg-mb-xl { margin-bottom: 3rem; }
.cg-mb-2xl { margin-bottom: 3rem; }
.cg-mt-xl { margin-top: 2rem; }
.cg-mt-2xl { margin-top: 3rem; }
.cg-py-section { padding-top: 60px; padding-bottom: 60px; }

/* --- Material Symbols --- */
.material-symbols-outlined {
  font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
  vertical-align: middle;
}

/* --- Divi Overrides --- */
/* Remove default Divi section padding */
.et_pb_section.cg-section-reset {
  padding: 0 !important;
}

/* Remove Divi row width constraints for full-bleed sections */
.et_pb_row.cg-row-full {
  max-width: 100% !important;
  width: 100% !important;
  padding: 0 !important;
}

/* Divi code module cleanup */
.et_pb_code_inner {
  line-height: normal;
}

/* Override Divi link colors */
.et_pb_section a:not(.cg-btn-primary):not(.cg-btn-secondary):not(.cg-btn-dark) {
  color: var(--cg-primary);
  text-decoration: none;
}
.et_pb_section a:hover {
  color: var(--cg-primary-bright);
}

/* Remove Divi default bottom margin on modules */
.et_pb_module.cg-no-margin {
  margin-bottom: 0 !important;
}

/* --- CTA Section --- */
.cg-cta-banner {
  background: linear-gradient(135deg, #4adcc2 0%, #008b78 100%);
  border-radius: 1.5rem;
  padding: 5rem 4rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cg-cta-banner h1,
.cg-cta-banner h2,
.cg-cta-banner h3 {
  color: #00382f !important;
}
.cg-cta-banner p {
  color: rgba(0, 56, 47, 0.85) !important;
}

/* Olive cards - icons and titles */
.et_pb_section .cg-olive-cards .cg-card h4,
.cg-olive-cards .cg-card h4 {
  color: #ffffff !important;
}
.et_pb_section .cg-flex-3 .cg-card h4,
.cg-flex-3 .cg-card h4 {
  color: #ffffff !important;
}
.et_pb_section .cg-flex-3 .cg-card .material-symbols-outlined,
.cg-flex-3 .cg-card .material-symbols-outlined {
  color: #ffffff !important;
}
.et_pb_section .cg-olive-cards .cg-card .material-symbols-outlined,
.cg-olive-cards .cg-card .material-symbols-outlined {
  color: #4adcc2 !important;
}

/* Section title accent (legacy class name kept for compatibility) */
.et_pb_section h1.cg-white-title,
.et_pb_section h2.cg-white-title,
.et_pb_section h3.cg-white-title,
.cg-white-title {
  color: #d4ddb6 !important;
}
/* Card titles (inside .cg-card) use white so they read clearly against card surfaces */
.et_pb_section .cg-card h3,
.et_pb_section .cg-card h4,
.et_pb_section .cg-card h5,
.et_pb_section .cg-card h6,
.cg-card h3,
.cg-card h4,
.cg-card h5,
.cg-card h6 {
  color: #ffffff !important;
}

/* Allow inline style colors to override global heading rules */
.et_pb_section h1[style*="color:"],
.et_pb_section h2[style*="color:"],
.et_pb_section h3[style*="color:"],
.et_pb_section h4[style*="color:"],
.et_pb_section h5[style*="color:"],
.et_pb_section h6[style*="color:"] {
  /* Inline styles win due to style attribute specificity */
}

/* Connect Your Channels title and label override */
.et_pb_section h4.cg-connect-title,
.et_pb_section span.cg-connect-title,
h4.cg-connect-title,
span.cg-connect-title,
.cg-connect-title {
  color: #00382f !important;
}

/* Teal accent cards - dark text override */
.et_pb_section .cg-teal-card h1,
.et_pb_section .cg-teal-card h2,
.et_pb_section .cg-teal-card h3,
.et_pb_section .cg-teal-card h4,
.et_pb_section .cg-teal-card .cg-headline,
.cg-teal-card h1,
.cg-teal-card h2,
.cg-teal-card h3,
.cg-teal-card h4,
.cg-teal-card .cg-headline {
  color: #00382f !important;
}
.et_pb_section .cg-teal-card p,
.et_pb_section .cg-teal-card .cg-body-sm,
.et_pb_section .cg-teal-card .cg-text-on-surface-variant,
.cg-teal-card p,
.cg-teal-card .cg-body-sm {
  color: rgba(0, 56, 47, 0.85) !important;
}

.cg-cta-banner::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.1);
  mix-blend-mode: overlay;
}
.cg-cta-banner > * {
  position: relative;
  z-index: 1;
}

/* --- Footer --- */
.cg-footer {
  background: var(--cg-surface-container-lowest) !important;
  padding: 5rem 2.5rem 3rem;
}
.cg-footer a {
  color: rgba(214, 227, 255, 0.5);
  text-decoration: none;
  transition: color 0.3s;
}
.cg-footer a:hover {
  color: var(--cg-primary);
}

/* --- Form Styling (Gravity Forms) --- */
.cg-form .gfield_label,
.cg-form label {
  font-family: 'Space Grotesk', sans-serif !important;
  font-size: 0.625rem !important;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--cg-on-surface-variant) !important;
  font-weight: 700 !important;
}

.cg-form input[type="text"],
.cg-form input[type="email"],
.cg-form input[type="tel"],
.cg-form textarea,
.cg-form select {
  background: var(--cg-surface-container-low) !important;
  border: none !important;
  border-bottom: 2px solid var(--cg-outline-variant) !important;
  color: var(--cg-on-surface) !important;
  font-family: 'Manrope', sans-serif !important;
  font-size: 0.8rem !important;
  padding: 0.75rem !important;
  border-radius: 5px !important;
  transition: border-color 0.3s !important;
}

.cg-form textarea {
  min-height: 0 !important;
  height: 5.25em !important;
  resize: vertical;
}

/* Tighten vertical spacing between form fields */
.cg-form .gform_fields {
  row-gap: 0.95rem !important;
  column-gap: 1rem !important;
}
.cg-form .gfield {
  margin-bottom: 0 !important;
}
.cg-form .gfield_label {
  margin-bottom: 0.25rem !important;
}

/* 2-row multi-column layout: Full Name + Business Email split 50/50,
   Business Type + Inquiry Volume split 37.5/62.5. */
.cg-form .gform_fields {
  display: grid !important;
  grid-template-columns: repeat(8, 1fr) !important;
}
.cg-form .gfield {
  grid-column: span 8;
}
.cg-form #field_1_1 {
  grid-column: 1 / span 4 !important;
  order: 1;
}
.cg-form #field_1_2 {
  grid-column: 5 / span 4 !important;
  order: 2;
}
.cg-form #field_1_3 {
  grid-column: 1 / span 4 !important;
  order: 3;
}
.cg-form #field_1_8 {
  grid-column: 5 / span 4 !important;
  order: 4;
}
.cg-form #field_1_4 { order: 5; }
.cg-form #field_1_5 { order: 6; }
.cg-form #field_1_6 { order: 7; }
.cg-form #field_1_7 { order: 8; }
.cg-form #field_1_9 { order: 9; }
@media (max-width: 540px) {
  .cg-form #field_1_1,
  .cg-form #field_1_2,
  .cg-form #field_1_3,
  .cg-form #field_1_8 {
    grid-column: 1 / span 8 !important;
  }
}

.cg-form input:focus,
.cg-form textarea:focus,
.cg-form select:focus {
  border-bottom-color: var(--cg-primary) !important;
  outline: none !important;
  box-shadow: none !important;
}

.cg-form select {
  appearance: auto !important;
  -webkit-appearance: menulist !important;
  cursor: pointer;
  line-height: 1.4 !important;
  min-height: 2.75rem !important;
  padding: 0.625rem 0.75rem !important;
}
.cg-form select option {
  background: var(--cg-surface-container-low) !important;
  color: var(--cg-on-surface) !important;
  font-size: 0.8rem !important;
}

.cg-form .gform_button,
.cg-form input[type="submit"] {
  background: linear-gradient(135deg, #4adcc2 0%, #008b78 100%) !important;
  color: var(--cg-on-primary) !important;
  font-family: 'Space Grotesk', sans-serif !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
  padding: 12px 24px !important;
  border-radius: 0.5rem !important;
  border: none !important;
  cursor: pointer !important;
  width: 100% !important;
  font-size: 0.9375rem !important;
  transition: all 0.3s ease !important;
}

.cg-form .gform_button:hover,
.cg-form input[type="submit"]:hover {
  transform: scale(1.02);
  box-shadow: 0 20px 40px rgba(74, 220, 194, 0.15);
}

.cg-form .ginput_container_checkbox label,
.cg-form .gchoice label {
  font-family: 'Manrope', sans-serif !important;
  font-size: 0.8125rem !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  color: var(--cg-on-surface-variant) !important;
}

.cg-form .gfield_checkbox input[type="checkbox"] {
  accent-color: var(--cg-primary);
}

.cg-form .gfield_consent_label {
  font-size: 0.5625rem !important;
  line-height: 1.5 !important;
  color: var(--cg-on-surface-variant) !important;
}

/* --- Use Case / Venue Cards with Image --- */
.cg-venue-card {
  cursor: pointer;
}
.cg-venue-card .cg-venue-img {
  aspect-ratio: 3/4;
  border-radius: 1rem;
  overflow: hidden;
  margin-bottom: 1.5rem;
  position: relative;
}
.cg-venue-card .cg-venue-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(100%);
  transition: all 0.5s ease;
  transform: scale(1.05);
}
.cg-venue-card:hover .cg-venue-img img {
  filter: grayscale(0%);
  transform: scale(1);
}

/* --- Responsive Navigation Override --- */
#main-header,
#top-header {
  background-color: rgba(5, 19, 41, 0.6) !important;
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
}

.et_header_style_left #et-top-navigation nav > ul > li > a,
#top-menu li a {
  color: rgba(214, 227, 255, 0.7) !important;
  font-family: 'Space Grotesk', sans-serif !important;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 13px !important;
  letter-spacing: 0.05em;
}

#top-menu li.current-menu-item a,
#top-menu li a:hover {
  color: var(--cg-primary-bright) !important;
}

/* Logo text override */
#logo {
  max-height: 40px !important;
}

/* --- Privacy / Terms Page --- */
.cg-legal-page {
  max-width: 800px;
  margin: 0 auto;
  padding: 2rem;
}
.cg-legal-page h2 {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--cg-on-surface);
  margin-top: 2.5rem;
  margin-bottom: 1rem;
  text-transform: uppercase;
}
.cg-legal-page h3 {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--cg-primary);
  margin-top: 2rem;
  margin-bottom: 0.75rem;
}
.cg-legal-page p,
.cg-legal-page li {
  font-family: 'Manrope', sans-serif;
  font-size: 0.9375rem;
  line-height: 1.7;
  color: #cfd2db;
  margin-bottom: 0.75rem;
}
.cg-legal-page ul {
  list-style: disc;
  padding-left: 1.5rem;
}
.cg-legal-page strong {
  color: var(--cg-on-surface);
}
.cg-legal-page a {
  color: var(--cg-primary);
}
.cg-legal-page hr {
  border: none;
  border-top: 1px solid rgba(68, 71, 77, 0.15);
  margin: 2rem 0;
}

/* --- Selection --- */
::selection {
  background: rgba(74, 220, 194, 0.3);
  color: var(--cg-on-surface);
}
