/*
Theme Name: DiviChild
Theme URI: http://www.elegantthemes.com/gallery/divi/
Description: A child theme for Divi — dark glassmorphism Aurora design
Author: Elegant Themes
Author URI: http://www.elegantthemes.com
Template: Divi
Version: 1.0.0
License: GNU General Public License v2
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: divichild
*/

/* ==========================================================================
   DESIGN SYSTEM — CSS Custom Properties
   ========================================================================== */

:root {
  --dc-ink: #0F1115;
  --dc-surface: #14171D;
  --dc-panel: #1A1E26;
  --dc-border: #262B36;
  --dc-mute: #B8BFCC;
  --dc-muted: #B8BFCC;
  --dc-text: #E2E6EF;
  --dc-primary: #3B82F6;
  --dc-accent: #60A5FA;
  --dc-accent-alt: #3B82F6;
  --dc-ice: #BFDBFE;
  --dc-deep: #1D4ED8;
  --dc-radius: 1.25rem;
  --dc-radius-lg: 1.5rem;
}

/* ==========================================================================
   GLOBAL RESETS & BASE
   ========================================================================== */

* {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

html,
body,
#page-container {
  background: var(--dc-ink) !important;
  color: var(--dc-text);
}

/* Prevent dark theme from leaking into Divi 5 Visual Builder UI */
.et-vb-top-window-portal,
.et-vb-top-window-portal h1,
.et-vb-top-window-portal h2,
.et-vb-top-window-portal h3,
.et-vb-top-window-portal h4,
.et-vb-top-window-portal h5,
.et-vb-top-window-portal h6,
.et-vb-top-window-portal p,
.et-vb-top-window-portal span,
.et-vb-top-window-portal label {
  color: revert;
}
.et-vb-top-window-portal a {
  color: revert;
}

/* ==========================================================================
   DIVI 5 D4-COMPAT & LAYOUT LIGHT OVERRIDE
   Force all text to light in our dark theme, regardless of Divi bg_layout.
   ========================================================================== */

body.divichild-dark .et_pb_bg_layout_light,
body.divichild-dark .et_pb_bg_layout_light p,
body.divichild-dark .et_pb_bg_layout_light span,
body.divichild-dark .et_pb_bg_layout_light li,
body.divichild-dark .et_pb_bg_layout_light .et_pb_blurb_description,
body.divichild-dark .et_pb_bg_layout_light .et_pb_toggle_content,
body.divichild-dark .et_pb_bg_layout_light .et_pb_pricing_content li,
body.divichild-dark .et_pb_bg_layout_light .et_pb_contact_form label,
body.divichild-dark .et_pb_bg_layout_light .post-content,
body.divichild-dark .et_pb_bg_layout_light .post-content p,
body.divichild-dark .et_pb_bg_layout_light .post-meta {
  color: var(--dc-text) !important;
}

body.divichild-dark .et_pb_bg_layout_light h1,
body.divichild-dark .et_pb_bg_layout_light h2,
body.divichild-dark .et_pb_bg_layout_light h3,
body.divichild-dark .et_pb_bg_layout_light h4,
body.divichild-dark .et_pb_bg_layout_light h5,
body.divichild-dark .et_pb_bg_layout_light h6,
body.divichild-dark .et_pb_bg_layout_light .et_pb_module_header,
body.divichild-dark .et_pb_bg_layout_light .et_pb_module_header a,
body.divichild-dark .et_pb_bg_layout_light .et_pb_toggle_title,
body.divichild-dark .et_pb_bg_layout_light .et_pb_pricing_heading h2,
body.divichild-dark .et_pb_bg_layout_light .entry-title,
body.divichild-dark .et_pb_bg_layout_light .entry-title a {
  color: #fff !important;
}

/* D5 block module text overrides */
body.divichild-dark .et_block_module,
body.divichild-dark .et_block_module p,
body.divichild-dark .et_block_module span,
body.divichild-dark .et_block_module li {
  color: var(--dc-text);
}

body.divichild-dark .et_block_module h1,
body.divichild-dark .et_block_module h2,
body.divichild-dark .et_block_module h3,
body.divichild-dark .et_block_module h4 {
  color: #fff;
}

/* Override Divi's default white/light section & row backgrounds */
body.divichild-dark .et_pb_section,
body.divichild-dark .et_d4_element.et_pb_section,
body.divichild-dark .et_pb_row,
body.divichild-dark .et_d4_element.et_pb_row {
  background-color: transparent !important;
}

/* Override Divi default content area background */
body.divichild-dark #main-content .container,
body.divichild-dark .et_builder_inner_content {
  background: transparent !important;
}

/* Override Divi default module backgrounds */
body.divichild-dark .et_pb_module,
body.divichild-dark .et_d4_element.et_pb_module {
  background-color: transparent;
}

/* Fix Divi number counter styling in dark mode */
body.divichild-dark .et_pb_number_counter .percent p,
body.divichild-dark .et_pb_number_counter .percent .percent-value {
  color: #fff !important;
}

/* Fix Divi blurb default styling */
body.divichild-dark .et_pb_blurb_content .et_pb_blurb_container p,
body.divichild-dark .et_pb_blurb_description {
  color: var(--dc-mute) !important;
}
/* Fix button arrow/icon default color */
body.divichild-dark .et_pb_button::after,
body.divichild-dark .et_pb_more_button::after {
  color: #fff !important;
}

/* Fix default link colors */
body.divichild-dark #page-container a {
  color: var(--dc-accent);
}

body.divichild-dark #page-container a:hover {
  color: #fff;
}

/* Fix Divi default footer background */
body.divichild-dark #main-footer,
body.divichild-dark .footer-widget {
  background: var(--dc-ink) !important;
}

/* Hide Divi's default footer — replaced by custom .dc-footer in functions.php */
#main-footer {
  display: none !important;
}

::selection {
  background: rgba(59, 130, 246, 0.35);
  color: #fff;
}

/* Scrollbar */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--dc-ink); }
::-webkit-scrollbar-thumb { background: var(--dc-border); border-radius: 6px; }
::-webkit-scrollbar-thumb:hover { background: #3a4252; }

/* ==========================================================================
   AURORA ANIMATED BACKGROUND (injected via functions.php)
   ========================================================================== */

.dc-aurora {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}

.dc-aurora::before,
.dc-aurora::after {
  content: '';
  position: absolute;
  width: 60vw;
  height: 60vw;
  border-radius: 50%;
  filter: blur(120px);
  opacity: 0.5;
  mix-blend-mode: screen;
}

.dc-aurora::before {
  background: radial-gradient(circle, var(--dc-primary) 0%, transparent 60%);
  top: -20%;
  left: -20%;
  animation: dc-drift1 22s ease-in-out infinite;
}

.dc-aurora::after {
  background: radial-gradient(circle, var(--dc-deep) 0%, transparent 60%);
  bottom: -30%;
  right: -20%;
  animation: dc-drift2 28s ease-in-out infinite;
}

@keyframes dc-drift1 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50%      { transform: translate(20vw, 15vh) scale(1.15); }
}

@keyframes dc-drift2 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50%      { transform: translate(-15vw, -10vh) scale(1.1); }
}

/* Noise / grain overlay */
.dc-grain {
  position: fixed;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  opacity: 0.05;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* Scroll progress bar */
.dc-scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  z-index: 99999;
  background: linear-gradient(90deg, var(--dc-primary), var(--dc-accent), var(--dc-ice));
  transform-origin: left center;
  transform: scaleX(0);
  transition: transform 0.12s linear;
  box-shadow: 0 0 12px rgba(96, 165, 250, 0.6);
}

/* ==========================================================================
   TYPOGRAPHY
   ========================================================================== */

.dc-display,
.dc-display h1,
.dc-display h2,
.dc-display h3,
.dc-display h4 {
  font-family: 'Space Grotesk', 'Inter', sans-serif !important;
  letter-spacing: -0.04em !important;
  line-height: 0.95 !important;
}

.dc-gradient-text,
.dc-gradient-text h1,
.dc-gradient-text h2,
.dc-gradient-text h3,
.dc-gradient-text span {
  background: linear-gradient(110deg, #FFFFFF 0%, var(--dc-ice) 40%, var(--dc-primary) 100%) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  color: transparent !important;
}

.dc-eyebrow,
.dc-eyebrow .et_pb_text_inner,
.dc-eyebrow .et_pb_text_inner p {
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 11px !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  color: var(--dc-accent) !important;
}

.dc-mono {
  font-family: 'JetBrains Mono', monospace !important;
}

/* ==========================================================================
   DOT GRID BACKGROUND (use as CSS class on Divi sections)
   ========================================================================== */

.dc-dot-grid::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(96, 165, 250, 0.18) 1px, transparent 1px);
  background-size: 22px 22px;
  mask-image: radial-gradient(ellipse 60% 50% at 50% 50%, black 30%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse 60% 50% at 50% 50%, black 30%, transparent 80%);
  pointer-events: none;
  z-index: 0;
}

/* ==========================================================================
   DIVI SECTION OVERRIDES
   ========================================================================== */

body.divichild-dark #page-container,
body.divichild-dark #main-content,
body.divichild-dark .et_pb_section,
body.divichild-dark .et_d4_element.et_pb_section {
  position: relative;
  z-index: 2;
  background-color: transparent !important;
}

/* Section backgrounds handled by D4-compat override above */

/* Dark surface section */
.dc-section-surface {
  background: rgba(20, 23, 29, 0.4) !important;
  border-top: 1px solid var(--dc-border) !important;
  border-bottom: 1px solid var(--dc-border) !important;
}

/* Gradient horizontal divider */
.dc-h-divider .et_pb_module_inner,
.dc-h-divider hr {
  height: 1px !important;
  background: linear-gradient(90deg, transparent, rgba(96, 165, 250, 0.4), transparent) !important;
  border: none !important;
}

/* ==========================================================================
   DIVI ROW / COLUMN OVERRIDES
   ========================================================================== */

body.divichild-dark .et_pb_row {
  position: relative;
  z-index: 2;
}

/* ==========================================================================
   HEADER / NAV
   ========================================================================== */

body.divichild-dark #main-header {
  background: linear-gradient(180deg, rgba(15, 17, 21, 0.85), rgba(15, 17, 21, 0.55)) !important;
  backdrop-filter: blur(24px) saturate(160%);
  -webkit-backdrop-filter: blur(24px) saturate(160%);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.04) inset, 0 20px 40px -30px rgba(0, 0, 0, 0.7) !important;
}

body.divichild-dark #main-header.et-fixed-header {
  background: rgba(15, 17, 21, 0.92) !important;
}

body.divichild-dark #main-header,
body.divichild-dark #main-header .et_pb_menu__menu a,
body.divichild-dark #et-top-navigation .et-cart-info span,
body.divichild-dark .et_menu_container a {
  color: #cfd6e4 !important;
}

body.divichild-dark #main-header .et_pb_menu__menu a:hover,
body.divichild-dark .et_menu_container a:hover,
body.divichild-dark #main-header .et_pb_menu__menu a.current-menu-item-active {
  color: #fff !important;
}

/* Nav link underline animation */
body.divichild-dark #main-header .et_pb_menu__menu a {
  position: relative;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: -0.005em;
}

body.divichild-dark #main-header .et_pb_menu__menu a::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -8px;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--dc-accent), var(--dc-primary));
  border-radius: 2px;
  transform: translateX(-50%);
  transition: width 0.3s cubic-bezier(0.2, 0.8, 0.2, 1);
  box-shadow: 0 0 12px rgba(96, 165, 250, 0.6);
}

body.divichild-dark #main-header .et_pb_menu__menu a:hover::after,
body.divichild-dark #main-header .et_pb_menu__menu .current-menu-item > a::after,
body.divichild-dark #main-header .et_pb_menu__menu a.current-menu-item-active::after {
  width: 100%;
}

/* Top header bar (Divi secondary nav) */
body.divichild-dark #top-header {
  background: rgba(0, 0, 0, 0.35) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04) !important;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  color: var(--dc-mute) !important;
}

body.divichild-dark #top-header a {
  color: var(--dc-mute) !important;
}

body.divichild-dark #top-header a:hover {
  color: #fff !important;
}

/* Logo */
body.divichild-dark #logo {
  filter: brightness(0) invert(1);
}

/* ==========================================================================
   GLASSMORPHISM CARD — apply .dc-glass-card to any Divi module/row/section
   ========================================================================== */

.dc-glass-card {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.06) 0%, rgba(255, 255, 255, 0.015) 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  backdrop-filter: blur(22px) saturate(140%);
  -webkit-backdrop-filter: blur(22px) saturate(140%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    inset 0 -1px 0 rgba(0, 0, 0, 0.25),
    0 30px 60px -30px rgba(0, 0, 0, 0.6) !important;
  border-radius: var(--dc-radius-lg) !important;
  transition: all 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
  position: relative;
  overflow: hidden;
  padding: 30px;
}

.dc-glass-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 35%);
  pointer-events: none;
  opacity: 0.6;
  border-radius: inherit;
}

.dc-glass-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(600px circle at var(--mx, 50%) var(--my, 0%), rgba(96, 165, 250, 0.18), transparent 40%);
  opacity: 0;
  transition: opacity 0.4s;
  pointer-events: none;
  z-index: 1;
  border-radius: inherit;
}

.dc-glass-card > * {
  position: relative;
  z-index: 2;
}

/* Glass card children in Code modules (nested deeper) */
.dc-glass-card h3,
.dc-glass-card p,
.dc-glass-card span,
.dc-glass-card a,
.dc-glass-card .dc-card-icon,
.dc-glass-card .dc-case-metrics {
  position: relative;
  z-index: 2;
}

.dc-glass-card:hover {
  border-color: rgba(96, 165, 250, 0.4) !important;
  transform: translateY(-4px);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    inset 0 -1px 0 rgba(0, 0, 0, 0.25),
    0 40px 80px -30px rgba(59, 130, 246, 0.35) !important;
}

.dc-glass-card:hover::before {
  opacity: 1;
}

/* Gradient-border variant */
.dc-gradient-border {
  position: relative;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.01)) !important;
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border-radius: var(--dc-radius) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 20px 50px -25px rgba(0, 0, 0, 0.5) !important;
  border: none !important;
}

.dc-gradient-border::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, rgba(96, 165, 250, 0.55), rgba(255, 255, 255, 0.06) 40%, rgba(29, 78, 216, 0.45));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}

/* Gradient-border blurb cards — padding & hover */
.dc-gradient-border.et_pb_blurb {
  padding: 1.75rem !important;
  margin-bottom: 1rem !important;
  transition: transform 0.35s cubic-bezier(0.2, 0.8, 0.2, 1),
              box-shadow 0.35s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.dc-gradient-border.et_pb_blurb:hover {
  transform: translateY(-4px);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 30px 60px -20px rgba(59, 130, 246, 0.25) !important;
}

.dc-gradient-border .et_pb_module_header {
  font-family: 'Space Grotesk', sans-serif !important;
  font-weight: 600 !important;
  font-size: 1.25rem !important;
  letter-spacing: -0.02em !important;
  margin-bottom: 0.5rem !important;
}

.dc-gradient-border .et_pb_blurb_description,
.dc-gradient-border .et_pb_blurb_description p {
  color: var(--dc-mute) !important;
  font-size: 0.875rem !important;
  line-height: 1.65 !important;
}

/* ==========================================================================
   STUDIO SECTION (#about) — 2-col staggered grid for blurb cards
   ========================================================================== */

@media (min-width: 981px) {
  /* Left column: sticky + vertically centered */
  #about .et_pb_row > .et_pb_column:first-child {
    position: sticky;
    top: 8rem;
    align-self: start;
  }

  /* Right column: 2-col grid for blurbs */
  #about .et_pb_row > .et_pb_column:last-child {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    align-items: start;
  }

  /* Stagger even blurbs down */
  #about .et_pb_row > .et_pb_column:last-child > .et_pb_blurb:nth-child(even) {
    margin-top: 2.5rem !important;
  }

  #about .et_pb_row > .et_pb_column:last-child > .et_pb_blurb {
    margin-bottom: 0 !important;
  }
}

/* ==========================================================================
   GLASS STYLE — simpler glass
   ========================================================================== */

.dc-glass {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.01)) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-radius: var(--dc-radius) !important;
}

/* ==========================================================================
   CHIP / PILL
   ========================================================================== */

.dc-chip,
.dc-chip .et_pb_text_inner {
  display: inline-flex !important;
  align-items: center;
  gap: 0.5rem;
  padding: 0.35rem 0.85rem;
  border-radius: 999px;
  background: rgba(59, 130, 246, 0.08);
  border: 1px solid rgba(59, 130, 246, 0.2);
  color: var(--dc-ice) !important;
  font-size: 12px;
  font-family: 'JetBrains Mono', monospace;
}

.dc-chip .dc-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--dc-accent);
  box-shadow: 0 0 12px var(--dc-accent);
  display: inline-block;
}

/* ==========================================================================
   BUTTONS — Divi et_pb_button overrides
   ========================================================================== */

/* Primary button */
body.divichild-dark .et_pb_button,
.dc-btn-primary .et_pb_button {
  background: linear-gradient(180deg, #5B9BFF 0%, #3B82F6 100%) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 0.75rem !important;
  padding: 0.875rem 1.5rem !important;
  font-weight: 500 !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.25),
    0 1px 0 rgba(0, 0, 0, 0.4),
    0 10px 30px -10px rgba(59, 130, 246, 0.55) !important;
  transition: all 0.25s ease !important;
}

body.divichild-dark .et_pb_button:hover,
.dc-btn-primary .et_pb_button:hover {
  transform: translateY(-2px);
  filter: brightness(1.15) saturate(1.1);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.4),
    0 1px 0 rgba(0, 0, 0, 0.4),
    0 22px 50px -8px rgba(96, 165, 250, 0.85),
    0 0 0 1px rgba(191, 219, 254, 0.4) !important;
}

body.divichild-dark .et_pb_button::after {
  color: #fff !important;
}

/* Ghost button variant */
.dc-btn-ghost .et_pb_button {
  background: rgba(255, 255, 255, 0.03) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  color: #fff !important;
  box-shadow: none !important;
}

.dc-btn-ghost .et_pb_button:hover {
  background: rgba(96, 165, 250, 0.08) !important;
  border-color: rgba(96, 165, 250, 0.4) !important;
  transform: translateY(-2px);
}

/* Rounded pill button */
.dc-btn-pill .et_pb_button {
  border-radius: 999px !important;
}

/* ==========================================================================
   TEXT MODULES
   ========================================================================== */

body.divichild-dark .et_pb_text,
body.divichild-dark .et_pb_text p {
  color: var(--dc-text);
}

.dc-text-mute .et_pb_text_inner,
.dc-text-mute .et_pb_text_inner p,
.dc-text-mute p {
  color: var(--dc-mute) !important;
}

.dc-text-white .et_pb_text_inner,
.dc-text-white .et_pb_text_inner p,
.dc-text-white h1,
.dc-text-white h2,
.dc-text-white h3,
.dc-text-white h4 {
  color: #fff !important;
}

.dc-text-accent {
  color: var(--dc-accent) !important;
}

/* ==========================================================================
   HEADING MODULES
   ========================================================================== */

body.divichild-dark #page-container h1,
body.divichild-dark #page-container h2,
body.divichild-dark #page-container h3,
body.divichild-dark #page-container h4,
body.divichild-dark #page-container .et_pb_module_header {
  color: #fff;
}

/* ==========================================================================
   BLURB MODULES — used for service cards, process steps, etc.
   ========================================================================== */

body.divichild-dark .et_pb_blurb {
  color: var(--dc-text);
}

body.divichild-dark .et_pb_blurb .et_pb_module_header,
body.divichild-dark .et_pb_blurb .et_pb_module_header a {
  color: #fff !important;
}

body.divichild-dark .et_pb_blurb .et-pb-icon {
  color: var(--dc-primary) !important;
}

body.divichild-dark .et_pb_blurb .et_pb_main_blurb_image {
  margin-bottom: 1.5rem;
}

/* Service card blurb */
.dc-service-card .et_pb_blurb_container {
  padding: 0 !important;
}

.dc-service-card .et_pb_main_blurb_image .et-pb-icon {
  width: 44px;
  height: 44px;
  border-radius: 0.75rem;
  background: rgba(59, 130, 246, 0.15);
  border: 1px solid rgba(59, 130, 246, 0.25);
  display: grid;
  place-items: center;
  color: var(--dc-primary) !important;
  font-size: 20px !important;
}

/* ==========================================================================
   NUMBER COUNTER MODULES — Stats
   ========================================================================== */

body.divichild-dark .et_pb_number_counter {
  color: var(--dc-text);
}

body.divichild-dark .et_pb_number_counter .percent p {
  font-family: 'Space Grotesk', sans-serif !important;
  font-weight: 700 !important;
  letter-spacing: -0.04em !important;
  color: #fff !important;
}

body.divichild-dark .et_pb_number_counter h3 {
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 10px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.25em !important;
  color: var(--dc-mute) !important;
}

/* Accent-colored suffix (+, %, /7) */
.dc-counter-accent .percent .percent-sign {
  color: var(--dc-accent) !important;
}

/* ==========================================================================
   TESTIMONIAL MODULES
   ========================================================================== */

body.divichild-dark .et_pb_testimonial {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.06) 0%, rgba(255, 255, 255, 0.015) 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-radius: var(--dc-radius-lg) !important;
  backdrop-filter: blur(22px) saturate(140%);
  -webkit-backdrop-filter: blur(22px) saturate(140%);
  padding: 2rem !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 30px 60px -30px rgba(0, 0, 0, 0.6) !important;
}

body.divichild-dark .et_pb_testimonial p {
  color: var(--dc-text) !important;
}

body.divichild-dark .et_pb_testimonial .et_pb_testimonial_author {
  color: #fff !important;
  font-weight: 500 !important;
}

body.divichild-dark .et_pb_testimonial .et_pb_testimonial_meta {
  color: var(--dc-mute) !important;
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 12px !important;
}

body.divichild-dark .et_pb_testimonial_portrait {
  border: none !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, var(--dc-primary), var(--dc-deep)) !important;
}

/* Star rating for testimonials */
.dc-stars::before {
  content: '★★★★★';
  display: block;
  color: var(--dc-accent);
  font-size: 14px;
  letter-spacing: 2px;
  margin-bottom: 1rem;
}

/* ==========================================================================
   ACCORDION / TOGGLE — FAQ
   ========================================================================== */

body.divichild-dark .et_pb_accordion .et_pb_toggle,
body.divichild-dark .et_pb_toggle {
  background: transparent !important;
  border: none !important;
  border-bottom: 1px solid var(--dc-border) !important;
  border-radius: 0 !important;
  padding: 1.25rem 0 !important;
  margin: 0 !important;
}

body.divichild-dark .et_pb_toggle .et_pb_toggle_title {
  font-family: 'Space Grotesk', sans-serif !important;
  font-size: 1.1rem !important;
  font-weight: 500 !important;
  color: #fff !important;
  padding: 0 !important;
  transition: color 0.25s ease;
}

body.divichild-dark .et_pb_toggle .et_pb_toggle_title:hover {
  color: var(--dc-accent) !important;
}

body.divichild-dark .et_pb_toggle .et_pb_toggle_content {
  color: var(--dc-mute) !important;
  font-size: 0.95rem !important;
  line-height: 1.6 !important;
  max-width: 65ch;
  padding: 1rem 0 0 0 !important;
}

body.divichild-dark .et_pb_toggle .et_pb_toggle_title::before {
  color: var(--dc-mute) !important;
  font-size: 18px !important;
  transition: transform 0.35s ease, color 0.25s ease !important;
}

body.divichild-dark .et_pb_toggle.et_pb_toggle_open .et_pb_toggle_title::before {
  color: var(--dc-accent) !important;
}

/* ==========================================================================
   PRICING TABLES
   ========================================================================== */

body.divichild-dark .et_pb_pricing_table {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.06) 0%, rgba(255, 255, 255, 0.015) 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-radius: var(--dc-radius-lg) !important;
  backdrop-filter: blur(22px) saturate(140%);
  margin: 0 !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 30px 60px -30px rgba(0, 0, 0, 0.6) !important;
}

body.divichild-dark .et_pb_pricing_table .et_pb_pricing_heading {
  background: transparent !important;
  border: none !important;
  padding: 2rem 2rem 0 2rem !important;
}

body.divichild-dark .et_pb_pricing_table .et_pb_pricing_heading h2 {
  font-family: 'Space Grotesk', sans-serif !important;
  font-weight: 700 !important;
  color: #fff !important;
}

body.divichild-dark .et_pb_pricing_table .et_pb_best_value {
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 10px !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  color: var(--dc-mute) !important;
  background: transparent !important;
}

body.divichild-dark .et_pb_pricing_table .et_pb_dollar_sign,
body.divichild-dark .et_pb_pricing_table .et_pb_sum {
  font-family: 'Space Grotesk', sans-serif !important;
  font-weight: 700 !important;
  color: #fff !important;
}

body.divichild-dark .et_pb_pricing_table .et_pb_per {
  color: var(--dc-mute) !important;
}

body.divichild-dark .et_pb_pricing_table .et_pb_pricing_content {
  border: none !important;
}

body.divichild-dark .et_pb_pricing_table .et_pb_pricing_content li {
  color: var(--dc-text) !important;
  border-bottom: none !important;
  padding: 0.5rem 0 0.5rem 1.25rem !important;
  position: relative;
}

/* Hide Divi's default dot so only the checkmark shows */
body.divichild-dark .et_pb_pricing li > span::before {
  display: none !important;
}

body.divichild-dark .et_pb_pricing_table .et_pb_pricing_content li::before {
  content: '✓';
  color: var(--dc-accent);
  position: absolute;
  left: 0;
  top: 0.5rem;
}

body.divichild-dark .et_pb_pricing_table .et_pb_button_wrapper {
  padding: 0 2rem 2rem !important;
}

/* Popular / featured pricing card */
body.divichild-dark .et_pb_featured_table {
  border-color: rgba(96, 165, 250, 0.4) !important;
  background: linear-gradient(180deg, rgba(96, 165, 250, 0.08) 0%, rgba(255, 255, 255, 0.015) 100%) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 40px 80px -30px rgba(59, 130, 246, 0.5) !important;
}

/* ==========================================================================
   CONTACT FORM
   ========================================================================== */

body.divichild-dark .et_pb_contact_form .et_pb_contact_form_label {
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 10px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.15em !important;
  color: var(--dc-mute) !important;
}

body.divichild-dark .et_pb_contact_form input[type="text"],
body.divichild-dark .et_pb_contact_form input[type="email"],
body.divichild-dark .et_pb_contact_form input[type="tel"],
body.divichild-dark .et_pb_contact_form textarea,
body.divichild-dark .et_pb_contact_form select {
  background: transparent !important;
  border: none !important;
  border-bottom: 1px solid var(--dc-border) !important;
  border-radius: 0 !important;
  color: #fff !important;
  padding: 0.75rem 0 !important;
  font-size: 1rem !important;
  transition: border-color 0.25s ease !important;
}

body.divichild-dark .et_pb_contact_form input:focus,
body.divichild-dark .et_pb_contact_form textarea:focus {
  border-bottom-color: var(--dc-accent) !important;
  outline: none !important;
}

body.divichild-dark .et_pb_contact_form input::placeholder,
body.divichild-dark .et_pb_contact_form textarea::placeholder {
  color: var(--dc-mute) !important;
}

/* ==========================================================================
   BLOG MODULE
   ========================================================================== */

body.divichild-dark .et_pb_blog .et_pb_post,
body.divichild-dark .et_pb_blog_grid .et_pb_post {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.06) 0%, rgba(255, 255, 255, 0.015) 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-radius: var(--dc-radius-lg) !important;
  overflow: hidden !important;
  backdrop-filter: blur(22px) saturate(140%);
  -webkit-backdrop-filter: blur(22px) saturate(140%);
  transition: all 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
  padding: 2rem !important;
}

body.divichild-dark .et_pb_blog .et_pb_post:hover,
body.divichild-dark .et_pb_blog_grid .et_pb_post:hover {
  border-color: rgba(96, 165, 250, 0.4) !important;
  transform: translateY(-4px);
  box-shadow: 0 30px 60px -20px rgba(59, 130, 246, 0.2);
}

body.divichild-dark .et_pb_post .post-meta,
body.divichild-dark .et_pb_post .post-meta span,
body.divichild-dark .et_pb_post .published {
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 11px !important;
  color: var(--dc-mute) !important;
  text-transform: uppercase;
  letter-spacing: 2px;
}

body.divichild-dark .et_pb_post h2.entry-title,
body.divichild-dark .et_pb_post h2.entry-title a {
  font-family: 'Space Grotesk', sans-serif !important;
  font-weight: 600 !important;
  font-size: 1.35rem !important;
  letter-spacing: -0.02em !important;
  color: #fff !important;
  transition: color 0.25s ease !important;
  margin-bottom: 0.75rem !important;
}

body.divichild-dark .et_pb_post:hover h2.entry-title a {
  color: var(--dc-accent) !important;
}

body.divichild-dark .et_pb_post .post-content,
body.divichild-dark .et_pb_post .post-content p,
body.divichild-dark .et_pb_post .post-content-inner,
body.divichild-dark .et_pb_post .post-content-inner p {
  color: var(--dc-mute) !important;
  font-size: 0.9rem !important;
  line-height: 1.65 !important;
}

/* Blog grid layout */
body.divichild-dark .et_pb_blog .et_pb_posts.et_grid_module {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 1.5rem;
}

body.divichild-dark .et_pb_blog .et_pb_posts.et_grid_module .et_pb_post {
  width: 100% !important;
  margin: 0 !important;
}

/* ==========================================================================
   IMAGE MODULE
   ========================================================================== */

body.divichild-dark .et_pb_image {
  border-radius: var(--dc-radius) !important;
  overflow: hidden;
}

/* ==========================================================================
   DIVIDER
   ========================================================================== */

body.divichild-dark .et_pb_space,
body.divichild-dark .et_pb_divider {
  border-color: var(--dc-border) !important;
}

.dc-glow-divider .et_pb_divider_internal {
  border-top: 1px solid transparent !important;
  background-image: linear-gradient(90deg, transparent, rgba(96, 165, 250, 0.4), transparent) !important;
  height: 1px !important;
}

/* ==========================================================================
   LOGO MARQUEE — use Text module with dc-marquee class
   ========================================================================== */

.dc-marquee {
  overflow: hidden;
  position: relative;
}

.dc-marquee::before,
.dc-marquee::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  width: 10%;
  z-index: 3;
  pointer-events: none;
}

.dc-marquee::before {
  left: 0;
  background: linear-gradient(90deg, var(--dc-ink), transparent);
}

.dc-marquee::after {
  right: 0;
  background: linear-gradient(-90deg, var(--dc-ink), transparent);
}

.dc-marquee .et_pb_text_inner {
  display: flex;
  gap: 4rem;
  animation: dc-scroll 35s linear infinite;
  white-space: nowrap;
  color: var(--dc-mute) !important;
  font-family: 'Space Grotesk', sans-serif !important;
  font-weight: 600 !important;
  font-size: 1.25rem !important;
}

@keyframes dc-scroll {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* ==========================================================================
   FOOTER
   ========================================================================== */

/* ==========================================================================
   CUSTOM FOOTER — .dc-footer
   ========================================================================== */

.dc-footer {
  position: relative;
  z-index: 2;
  background: var(--dc-ink);
  border-top: 1px solid var(--dc-border);
  color: var(--dc-text);
}

.dc-footer-inner {
  max-width: 1280px;
  width: 90%;
  margin: 0 auto;
  padding: 5rem 0;
}

@media (min-width: 1600px) {
  .dc-footer-inner {
    max-width: 1440px;
    width: 88%;
  }
}

/* ── Wordmark ── */
.dc-footer-wordmark {
  margin-bottom: 4rem;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  font-size: clamp(3rem, 15vw, 12rem);
  line-height: 0.85;
  letter-spacing: -0.04em;
}

.dc-footer-wordmark-white {
  color: #fff;
}

.dc-footer-wordmark-gradient {
  background: linear-gradient(110deg, #FFFFFF 0%, var(--dc-ice) 40%, var(--dc-primary) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* ── Grid ── */
.dc-footer-grid {
  display: grid;
  grid-template-columns: 5fr 2fr 2fr 3fr;
  gap: 2.5rem;
  margin-bottom: 4rem;
}

/* ── Description column ── */
.dc-footer-desc {
  color: var(--dc-mute);
  max-width: 22rem;
  line-height: 1.65;
  font-size: 0.9375rem;
}

.dc-footer-social {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 1.5rem;
}

.dc-footer-social-link {
  width: 40px;
  height: 40px;
  border-radius: 0.75rem;
  border: 1px solid var(--dc-border);
  display: grid;
  place-items: center;
  color: var(--dc-mute);
  text-decoration: none;
  transition: all 0.25s ease;
}

.dc-footer-social-link:hover {
  color: #fff;
  border-color: var(--dc-accent);
}

/* ── Link columns ── */
.dc-footer-heading {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.25em;
  color: var(--dc-mute);
  margin-bottom: 1.25rem;
  font-weight: 500;
}

.dc-footer-links {
  list-style: none;
  margin: 0;
  padding: 0;
}

.dc-footer-links li {
  margin-bottom: 0.75rem;
}

.dc-footer-links a {
  color: #cfd6e4;
  text-decoration: none;
  font-size: 0.875rem;
  transition: color 0.25s ease;
}

.dc-footer-links a:hover {
  color: var(--dc-accent);
}

/* ── Newsletter column ── */
.dc-footer-newsletter-desc {
  color: var(--dc-mute);
  font-size: 0.875rem;
  margin-bottom: 1rem;
}

.dc-footer-newsletter-form {
  display: flex;
  gap: 0.5rem;
}

.dc-footer-newsletter-input {
  flex: 1;
  min-width: 0;
  padding: 0.625rem 0.75rem;
  border-radius: 0.5rem;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: #fff;
  font-size: 0.875rem;
  outline: none;
  transition: border-color 0.25s ease;
}

.dc-footer-newsletter-input::placeholder {
  color: var(--dc-mute);
}

.dc-footer-newsletter-input:focus {
  border-color: var(--dc-accent);
}

.dc-footer-newsletter-btn {
  padding: 0.625rem 1rem;
  border-radius: 0.5rem;
  background: #fff;
  color: var(--dc-ink);
  font-size: 0.875rem;
  font-weight: 500;
  border: none;
  cursor: pointer;
  transition: background 0.25s ease;
}

.dc-footer-newsletter-btn:hover {
  background: var(--dc-ice);
}

/* ── Bottom bar ── */
.dc-footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-top: 2rem;
  border-top: 1px solid var(--dc-border);
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  color: var(--dc-mute);
}

.dc-footer-bottom a {
  color: var(--dc-mute);
  text-decoration: none;
  transition: color 0.25s ease;
}

.dc-footer-bottom a:hover {
  color: var(--dc-accent);
}

.dc-footer-bottom-right {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}

.dc-footer-status {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.dc-footer-status-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #34d399;
  animation: dc-pulse-dot 2s ease-in-out infinite;
}

/* ── Footer responsive — Tablet ── */
@media (max-width: 980px) {
  .dc-footer-inner {
    padding: 3.5rem 1.5rem;
  }

  .dc-footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
  }

  .dc-footer-col-desc {
    grid-column: span 2;
  }

  .dc-footer-col-newsletter {
    grid-column: span 2;
  }

  .dc-footer-wordmark {
    margin-bottom: 2.5rem;
  }
}

/* ── Footer responsive — Mobile ── */
@media (max-width: 767px) {
  .dc-footer-inner {
    padding: 2.5rem 1rem;
  }

  .dc-footer-grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .dc-footer-col-desc {
    grid-column: span 1;
  }

  .dc-footer-col-newsletter {
    grid-column: span 1;
  }

  .dc-footer-wordmark {
    margin-bottom: 2rem;
    font-size: clamp(2.5rem, 12vw, 5rem);
  }

  .dc-footer-bottom {
    flex-direction: column;
    text-align: center;
    gap: 1rem;
  }

  .dc-footer-bottom-right {
    flex-wrap: wrap;
    justify-content: center;
  }

  .dc-footer-newsletter-form {
    flex-direction: column;
  }

  .dc-footer-newsletter-btn {
    width: 100%;
  }
}

/* ==========================================================================
   REVEAL ON SCROLL
   ========================================================================== */

.dc-reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.9s cubic-bezier(0.2, 0.8, 0.2, 1),
              transform 0.9s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.dc-reveal.dc-visible {
  opacity: 1;
  transform: none;
}

/* Divi 5 Visual Builder: reveal elements immediately (custom JS runs before React) */
.et-fb .dc-reveal,
body.et_fb_desktop_mode .dc-reveal {
  opacity: 1 !important;
  transform: none !important;
}

/* ==========================================================================
   FOCUS RINGS (a11y)
   ========================================================================== */

a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible {
  outline: 2px solid var(--dc-accent);
  outline-offset: 3px;
  border-radius: 6px;
}

/* ==========================================================================
   FUNNEL BARS (for Code module or Text module with custom HTML)
   ========================================================================== */

.dc-funnel-bar {
  height: 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.05);
  overflow: hidden;
}

.dc-funnel-bar-fill {
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--dc-primary), var(--dc-accent));
  width: 0;
  transition: width 1.4s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.dc-funnel-bar-fill.dc-visible {
  width: var(--dc-width);
}

/* ==========================================================================
   PROCESS CONNECTOR LINE
   ========================================================================== */

.dc-process-line {
  position: absolute;
  top: 24px;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--dc-border), transparent);
}

.dc-process-line-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--dc-primary), var(--dc-accent), var(--dc-ice));
  width: 0;
  transition: width 1.4s cubic-bezier(0.2, 0.8, 0.2, 1);
  box-shadow: 0 0 12px rgba(96, 165, 250, 0.5);
}

.dc-process-line-fill.dc-visible {
  width: 100%;
}

/* Process step circles */
.dc-process-circle {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-family: 'JetBrains Mono', monospace;
  font-size: 14px;
  color: var(--dc-accent);
  flex-shrink: 0;
}

.dc-process-circle-active {
  background: linear-gradient(135deg, var(--dc-primary), var(--dc-accent)) !important;
  color: #fff !important;
  box-shadow: 0 0 30px rgba(56, 139, 253, 0.5);
}

/* ==========================================================================
   LIVE DOT (pulsing green)
   ========================================================================== */

.dc-live-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #34d399;
  box-shadow: 0 0 12px #34d399;
  display: inline-block;
  animation: dc-pulse-dot 2s ease-in-out infinite;
}

@keyframes dc-pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.5; transform: scale(0.85); }
}

/* ==========================================================================
   UTILITY — padding / spacing helpers
   ========================================================================== */

.dc-py-section {
  padding-top: 7rem !important;
  padding-bottom: 7rem !important;
}

@media (min-width: 981px) {
  .dc-py-section {
    padding-top: 10rem !important;
    padding-bottom: 10rem !important;
  }
}

/* ==========================================================================
   HERO SPOTLIGHT — cursor-following radial glow
   ========================================================================== */

.dc-hero-spotlight {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(600px circle at var(--hx, 50%) var(--hy, 30%), rgba(96, 165, 250, 0.18), transparent 55%);
  z-index: 0;
}

/* ==========================================================================
   NUMBER DISPLAY — big stat numbers (hero stats, funnel stats, case stats)
   ========================================================================== */

.dc-num,
.dc-num span {
  font-family: 'Space Grotesk', sans-serif !important;
  font-weight: 700 !important;
  letter-spacing: -0.04em !important;
}

/* Larger counter numbers matching DemoTemplate text-4xl/5xl */
body.divichild-dark .et_pb_number_counter .percent p {
  font-size: clamp(2.25rem, 5vw, 3rem) !important;
}

/* Body large — used on hero subtext and CTA descriptions */
.dc-body-large {
  font-size: 1.125rem !important;
  line-height: 1.65 !important;
  color: var(--dc-mute) !important;
  max-width: 600px;
}

/* Display variant — smaller h2 headings on inner pages */
.dc-display-sm h2,
.dc-display-sm .et_pb_text_inner h2 {
  font-size: clamp(2rem, 5vw, 3.25rem) !important;
}

/* Hero section h1 display size */
#home .dc-display h1,
#home .dc-display .et_pb_text_inner h1 {
  font-size: clamp(2.75rem, 9vw, 7.5rem) !important;
  line-height: 0.95 !important;
}

/* ==========================================================================
   CARD ARROW — "Learn more →" affordance on service cards
   ========================================================================== */

.dc-card-arrow,
.dc-card-arrow a {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin-top: 1.25rem;
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--dc-mute) !important;
  transition: color 0.25s ease, gap 0.25s ease;
}

.dc-glass-card:hover .dc-card-arrow,
.dc-glass-card:hover .dc-card-arrow a {
  color: var(--dc-accent) !important;
  gap: 0.65rem;
}

/* ==========================================================================
   PRICING TABLE — equal-height flex layout
   ========================================================================== */

body.divichild-dark .et_pb_pricing_table_wrap > .et_pb_pricing {
  display: flex !important;
  gap: 1.25rem;
}

/* Prevent flex from leaking into the feature list <ul> */
body.divichild-dark ul.et_pb_pricing {
  display: block !important;
  gap: 0;
}

body.divichild-dark .et_pb_pricing_table {
  display: flex !important;
  flex-direction: column !important;
  flex: 1;
}

body.divichild-dark .et_pb_pricing_table .et_pb_pricing_content {
  flex: 1;
  padding: 0 2rem !important;
}

body.divichild-dark .et_pb_pricing_table .et_pb_pricing_content_top {
  background: transparent !important;
  border: none !important;
  padding: 0 2rem !important;
}

body.divichild-dark .et_pb_pricing_table .et_pb_best_value {
  position: relative;
  margin-bottom: 0.5rem;
}

/* Featured "Most popular" chip badge */
body.divichild-dark .et_pb_featured_table .et_pb_best_value {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.35rem 0.85rem;
  border-radius: 999px;
  background: rgba(59, 130, 246, 0.08) !important;
  border: 1px solid rgba(59, 130, 246, 0.2) !important;
  color: var(--dc-ice) !important;
  font-size: 10px !important;
  letter-spacing: 0.15em !important;
}

body.divichild-dark .et_pb_featured_table .et_pb_best_value::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--dc-accent);
  box-shadow: 0 0 12px var(--dc-accent);
}

/* ==========================================================================
   BLOG POST — gradient header fallback (when no featured image)
   ========================================================================== */

body.divichild-dark .et_pb_post .entry-featured-image-url,
body.divichild-dark .et_pb_post .post-thumbnail {
  border-radius: var(--dc-radius-lg) var(--dc-radius-lg) 0 0 !important;
  overflow: hidden !important;
}

body.divichild-dark .et_pb_post .entry-featured-image-url img {
  border-radius: 0 !important;
}

/* Gradient placeholder for posts without featured images */
body.divichild-dark .et_pb_blog .et_pb_post:not(:has(.entry-featured-image-url))::before {
  content: '';
  display: block;
  height: 13rem;
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.4), rgba(29, 78, 216, 0.3), transparent);
  border-radius: var(--dc-radius-lg) var(--dc-radius-lg) 0 0;
  position: relative;
}

body.divichild-dark .et_pb_blog .et_pb_post:not(:has(.entry-featured-image-url))::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 13rem;
  background-image: radial-gradient(rgba(96, 165, 250, 0.18) 1px, transparent 1px);
  background-size: 22px 22px;
  mask-image: radial-gradient(ellipse 60% 50% at 50% 50%, black 30%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse 60% 50% at 50% 50%, black 30%, transparent 80%);
  opacity: 0.5;
  pointer-events: none;
  border-radius: var(--dc-radius-lg) var(--dc-radius-lg) 0 0;
}

/* ==========================================================================
   CONTACT LINK ROWS — CALL / MAIL / VISIT pattern
   ========================================================================== */

.dc-contact-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.25rem 0;
  border-top: 1px solid var(--dc-border);
  transition: border-color 0.25s ease;
  text-decoration: none !important;
}

.dc-contact-link:hover {
  border-color: rgba(96, 165, 250, 0.5);
}

.dc-contact-link-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--dc-mute);
}

.dc-contact-link-value {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.25rem;
  color: #fff;
  transition: color 0.25s ease;
}

.dc-contact-link:hover .dc-contact-link-value {
  color: var(--dc-accent);
}

.dc-contact-link-arrow {
  color: var(--dc-mute);
  transition: color 0.25s ease, transform 0.25s ease;
}

.dc-contact-link:hover .dc-contact-link-arrow {
  color: var(--dc-accent);
  transform: translateX(4px);
}

/* ==========================================================================
   TESTIMONIAL QUOTE — large hero-style quote block
   ========================================================================== */

.dc-hero-quote .et_pb_testimonial_description p {
  font-family: 'Space Grotesk', sans-serif !important;
  font-size: clamp(1.5rem, 3vw, 2.25rem) !important;
  line-height: 1.35 !important;
  font-weight: 500 !important;
  color: #fff !important;
}

.dc-hero-quote .et_pb_testimonial_description .gradient-text,
.dc-hero-quote .et_pb_testimonial_description span {
  background: linear-gradient(110deg, #FFFFFF 0%, var(--dc-ice) 40%, var(--dc-primary) 100%) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  color: transparent !important;
}

/* Duplicate .dc-py-section removed — already defined in the utility section above */

/* Second definition removed — .dc-h-divider is defined in the global section above */

/* ==========================================================================
   CASE STUDY STATS — before/after stat cards
   ========================================================================== */

/* dc-stat-card base is defined in the inner pages section below */

.dc-stat-card-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.25em;
  color: var(--dc-mute);
  margin-bottom: 0.5rem;
}

.dc-stat-before {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  letter-spacing: -0.04em;
  font-size: 1.5rem;
  color: var(--dc-mute);
  text-decoration: line-through;
}

.dc-stat-after {
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  letter-spacing: -0.04em;
  font-size: 1.875rem;
  color: #fff;
}

.dc-stat-change {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  color: #34d399;
  margin-top: 0.5rem;
}

/* ==========================================================================
   TRUSTED-BY LOGO ROW
   ========================================================================== */

.dc-trusted-by {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  margin-bottom: 1.5rem;
  opacity: 0.8;
}

.dc-trusted-by-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--dc-mute);
  white-space: nowrap;
}

.dc-trusted-by-line {
  flex: 1;
  height: 1px;
  background: var(--dc-border);
}

.dc-trusted-logos {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
  gap: 1.5rem;
  align-items: center;
  text-align: center;
}

.dc-trusted-logos span {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.125rem;
  color: var(--dc-mute);
  transition: color 0.25s ease;
  cursor: default;
}

.dc-trusted-logos span:hover {
  color: #fff;
}

/* ==========================================================================
   WATERMARK TEXT — large background text for contact section
   ========================================================================== */

.dc-watermark {
  position: absolute;
  bottom: -0.75rem;
  right: 0.625rem;
  font-family: 'Space Grotesk', sans-serif;
  font-weight: 700;
  font-size: clamp(8rem, 20vw, 16rem);
  line-height: 1;
  color: rgba(255, 255, 255, 0.03);
  pointer-events: none;
  user-select: none;
}

@media (min-width: 981px) {
  .dc-watermark {
    right: 2.5rem;
  }
}

/* ==========================================================================
   INTEREST PILL CHECKBOXES (contact form)
   ========================================================================== */

.dc-interest-pill {
  display: inline-block;
  padding: 0.5rem 0.75rem;
  border-radius: 0.5rem;
  border: 1px solid var(--dc-border);
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  color: var(--dc-mute);
  text-align: center;
  cursor: pointer;
  transition: all 0.25s ease;
}

.dc-interest-pill:hover,
.dc-interest-pill.active {
  background: rgba(59, 130, 246, 0.15);
  border-color: var(--dc-primary);
  color: var(--dc-ice);
}

/* ==========================================================================
   REDUCED MOTION
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }

  .dc-reveal {
    opacity: 1 !important;
    transform: none !important;
  }

  .dc-funnel-bar-fill {
    width: var(--dc-width) !important;
  }

  .dc-process-line-fill {
    width: 100% !important;
  }

  .dc-aurora::before,
  .dc-aurora::after {
    animation: none !important;
  }
}

/* ==========================================================================
   RESPONSIVE — LARGE SCREENS (min-width: 1200px)
   Widen Divi's default 1080px row cap to fill wider viewports.
   ========================================================================== */

@media (min-width: 1200px) {
  body.divichild-dark .et_pb_row {
    max-width: 1280px !important;
    width: 90% !important;
  }
}

@media (min-width: 1600px) {
  body.divichild-dark .et_pb_row {
    max-width: 1440px !important;
    width: 88% !important;
  }
}

/* ==========================================================================
   RESPONSIVE — TABLET (max-width: 980px)
   ========================================================================== */

@media (max-width: 980px) {

  /* ── Global / Layout ── */
  .dc-glass-card {
    border-radius: 1rem !important;
    padding: 1.5rem !important;
  }

  body.divichild-dark .et_pb_testimonial {
    border-radius: 1rem !important;
  }

  body.divichild-dark .et_pb_pricing_table {
    border-radius: 1rem !important;
  }

  /* ── Section padding: py-20 equiv ── */
  body.divichild-dark .et_pb_section {
    padding-top: 5rem !important;
    padding-bottom: 5rem !important;
  }

  body.divichild-dark .et_pb_section.dc-py-section {
    padding-top: 5rem !important;
    padding-bottom: 5rem !important;
  }

  /* ── Rows ── */
  body.divichild-dark .et_pb_row {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  /* Stack columns vertically on tablet */
  body.divichild-dark .et_pb_row {
    flex-direction: column !important;
  }

  body.divichild-dark .et_pb_row > .et_pb_column {
    width: 100% !important;
    margin-bottom: 2rem;
  }

  /* ── Hero ── */
  #home {
    padding-top: 10rem !important;
    padding-bottom: 6rem !important;
  }

  #home .dc-display h1,
  #home .dc-display .et_pb_text_inner h1 {
    font-size: clamp(2.25rem, 8vw, 4rem) !important;
  }

  /* Stats grid: 2 cols on tablet */
  #home .et_pb_number_counter {
    width: 50% !important;
  }

  /* ── Services — stack bento to 2-col ── */
  #services .dc-glass-card {
    padding: 1.75rem !important;
  }

  /* ── Funnels — stack copy + viz ── */
  #funnels .et_pb_row > .et_pb_column {
    width: 100% !important;
  }

  /* ── Studio / About — unstick + stack ── */
  #about .et_pb_row > .et_pb_column:first-child {
    position: static !important;
  }

  #about .et_pb_row > .et_pb_column:last-child {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
  }

  #about .et_pb_row > .et_pb_column:last-child > .et_pb_blurb:nth-child(even) {
    margin-top: 0 !important;
  }

  /* ── Process — 2-col ── */
  #process .et_pb_row > .et_pb_column {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
  }

  #process .dc-process-line,
  #process .dc-process-line-fill {
    display: none !important;
  }

  /* ── Cases / Testimonials ── */
  #cases .et_pb_testimonial {
    padding: 1.5rem !important;
  }

  /* ── Blog — 2-col ── */
  body.divichild-dark .et_pb_blog .et_pb_posts.et_grid_module {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 1rem;
  }

  /* ── Pricing — stack to 1 col ── */
  body.divichild-dark .et_pb_pricing_table_wrap > .et_pb_pricing {
    flex-direction: column !important;
    gap: 1rem;
  }

  /* ── FAQ — unstick left col ── */
  #faq .et_pb_row > .et_pb_column:first-child {
    position: static !important;
  }

  /* ── Contact — form layout ── */
  #contact .dc-glass-card {
    padding: 2rem !important;
  }

  #contact .et_pb_row > .et_pb_column {
    width: 100% !important;
  }

  /* ── Footer ── */
  body.divichild-dark #main-footer .footer-widget {
    margin-bottom: 2rem;
  }

  /* ── Aurora glow — reduce on tablet for perf ── */
  .dc-aurora::before,
  .dc-aurora::after {
    width: 80vw;
    height: 80vw;
    opacity: 0.35;
  }

  /* ── Watermark ── */
  .dc-watermark {
    font-size: 6rem !important;
  }
}

/* ==========================================================================
   RESPONSIVE — MOBILE (max-width: 767px)
   ========================================================================== */

@media (max-width: 767px) {

  /* ── Global / Layout ── */
  body.divichild-dark .et_pb_section {
    padding-top: 3.5rem !important;
    padding-bottom: 3.5rem !important;
  }

  body.divichild-dark .et_pb_section.dc-py-section {
    padding-top: 3.5rem !important;
    padding-bottom: 3.5rem !important;
  }

  body.divichild-dark .et_pb_row {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }

  .dc-glass-card {
    padding: 1.25rem !important;
    border-radius: 0.875rem !important;
  }

  /* ── Typography scale down ── */
  .dc-display h1,
  .dc-display .et_pb_text_inner h1 {
    font-size: 2rem !important;
    line-height: 1 !important;
  }

  .dc-display h2,
  .dc-display .et_pb_text_inner h2 {
    font-size: 1.75rem !important;
    line-height: 1 !important;
  }

  .dc-display h3,
  .dc-display .et_pb_text_inner h3 {
    font-size: 1.35rem !important;
  }

  .dc-eyebrow,
  .dc-eyebrow .et_pb_text_inner,
  .dc-eyebrow .et_pb_text_inner p {
    font-size: 10px !important;
    letter-spacing: 0.15em !important;
  }

  /* ── Hero ── */
  #home {
    padding-top: 8rem !important;
    padding-bottom: 4rem !important;
  }

  #home .dc-display h1,
  #home .dc-display .et_pb_text_inner h1 {
    font-size: clamp(2rem, 10vw, 3rem) !important;
  }

  /* Chip smaller */
  .dc-chip,
  .dc-chip .et_pb_text_inner {
    font-size: 10px;
    padding: 0.25rem 0.65rem;
  }

  /* Stats grid: 2 cols on mobile */
  body.divichild-dark .et_pb_number_counter .percent p {
    font-size: 2rem !important;
  }

  body.divichild-dark .et_pb_number_counter h3 {
    font-size: 9px !important;
    letter-spacing: 0.15em !important;
  }

  /* ── Marquee ── */
  .dc-marquee .et_pb_text_inner {
    font-size: 1rem !important;
    gap: 2rem;
  }

  /* ── Services ── */
  #services .dc-glass-card {
    padding: 1.25rem !important;
  }

  /* Service card description */
  .dc-service-card .et_pb_blurb_description {
    font-size: 0.8rem !important;
  }

  /* ── Funnels ── */
  #funnels .dc-glass-card {
    padding: 1.25rem !important;
  }

  /* Funnel stat row: stack if needed */
  .dc-num {
    font-size: 1.5rem !important;
  }

  /* ── Studio / About — single col ── */
  #about .et_pb_row > .et_pb_column:last-child {
    grid-template-columns: 1fr !important;
  }

  .dc-gradient-border.et_pb_blurb {
    padding: 1.25rem !important;
  }

  /* ── Process — single col ── */
  #process .et_pb_row > .et_pb_column {
    grid-template-columns: 1fr !important;
  }

  .dc-process-circle {
    width: 40px;
    height: 40px;
    font-size: 12px;
  }

  /* ── Cases / Testimonials ── */
  #cases .et_pb_testimonial {
    padding: 1.25rem !important;
    border-radius: 0.875rem !important;
  }

  body.divichild-dark .et_pb_testimonial_portrait {
    width: 40px !important;
    height: 40px !important;
  }

  .dc-hero-quote .et_pb_testimonial_description p {
    font-size: 1.15rem !important;
  }

  /* Case stat cards */
  .dc-stat-card {
    padding: 1rem;
  }

  .dc-stat-before {
    font-size: 1.15rem;
  }

  .dc-stat-after {
    font-size: 1.5rem;
  }

  /* ── Blog — single col ── */
  body.divichild-dark .et_pb_blog .et_pb_posts.et_grid_module {
    grid-template-columns: 1fr !important;
  }

  body.divichild-dark .et_pb_blog .et_pb_post {
    padding: 1.25rem !important;
  }

  body.divichild-dark .et_pb_post h2.entry-title,
  body.divichild-dark .et_pb_post h2.entry-title a {
    font-size: 1.1rem !important;
  }

  /* ── Pricing — full width stack ── */
  body.divichild-dark .et_pb_pricing_table_wrap > .et_pb_pricing {
    flex-direction: column !important;
  }

  body.divichild-dark .et_pb_pricing_table {
    border-radius: 0.875rem !important;
    padding: 0 !important;
  }

  body.divichild-dark .et_pb_pricing_table .et_pb_pricing_heading {
    padding: 1.5rem 1.5rem 0 1.5rem !important;
  }

  body.divichild-dark .et_pb_pricing_table .et_pb_pricing_content {
    padding: 0 1.5rem !important;
  }

  body.divichild-dark .et_pb_pricing_table .et_pb_button_wrapper {
    padding: 0 1.5rem 1.5rem !important;
  }

  body.divichild-dark .et_pb_pricing_table .et_pb_pricing_content_top {
    padding: 0 1.5rem !important;
  }

  /* ── FAQ ── */
  body.divichild-dark .et_pb_toggle .et_pb_toggle_title {
    font-size: 0.95rem !important;
  }

  body.divichild-dark .et_pb_toggle .et_pb_toggle_content {
    font-size: 0.85rem !important;
  }

  /* ── Contact ── */
  #contact .dc-glass-card {
    padding: 1.5rem !important;
    border-radius: 1rem !important;
  }

  .dc-contact-link-value {
    font-size: 1rem;
  }

  /* Contact form fields */
  body.divichild-dark .et_pb_contact_form input[type="text"],
  body.divichild-dark .et_pb_contact_form input[type="email"],
  body.divichild-dark .et_pb_contact_form input[type="tel"],
  body.divichild-dark .et_pb_contact_form textarea {
    font-size: 0.9rem !important;
  }

  /* Interest pills: 2-col grid */
  .dc-interest-pill {
    font-size: 10px;
    padding: 0.4rem 0.5rem;
  }

  /* ── Watermark ── */
  .dc-watermark {
    font-size: 4rem !important;
    right: 0.5rem !important;
  }

  /* ── Footer ── */
  body.divichild-dark #main-footer {
    text-align: center;
  }

  body.divichild-dark .et-social-icons {
    justify-content: center;
  }

  body.divichild-dark #footer-info {
    font-size: 10px !important;
  }

  /* ── Aurora — further reduce for mobile perf ── */
  .dc-aurora::before,
  .dc-aurora::after {
    width: 100vw;
    height: 100vw;
    opacity: 0.25;
    filter: blur(80px);
  }

  /* ── Nav ── */
  body.divichild-dark #main-header {
    padding: 0 !important;
  }

  body.divichild-dark #top-header {
    font-size: 9px;
    letter-spacing: 0.08em;
  }

  /* ── Gradient divider — reduce spacing on mobile ── */
  .dc-h-divider {
    margin-bottom: 1.5rem;
  }

  /* ── Trusted logos ── */
  .dc-trusted-logos {
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
  }

  .dc-trusted-logos span {
    font-size: 0.9rem;
  }

  /* ── Buttons ── */
  body.divichild-dark .et_pb_button {
    padding: 0.75rem 1.25rem !important;
    font-size: 0.875rem !important;
  }
}

/* ==========================================================================
   RESPONSIVE — SMALL MOBILE (max-width: 479px)
   ========================================================================== */

@media (max-width: 479px) {

  /* Extra tight padding */
  body.divichild-dark .et_pb_row {
    padding-left: 0.75rem !important;
    padding-right: 0.75rem !important;
  }

  /* Hero heading smallest */
  #home .dc-display h1,
  #home .dc-display .et_pb_text_inner h1 {
    font-size: 1.75rem !important;
  }

  .dc-display h2,
  .dc-display .et_pb_text_inner h2 {
    font-size: 1.5rem !important;
  }

  /* Stats: single col if cramped */
  body.divichild-dark .et_pb_number_counter .percent p {
    font-size: 1.75rem !important;
  }

  /* Contact link values */
  .dc-contact-link-value {
    font-size: 0.875rem;
  }

  .dc-contact-link-label {
    font-size: 9px;
  }

  /* Watermark hide on very small */
  .dc-watermark {
    display: none;
  }

  /* Trusted logos: 2-col */
  .dc-trusted-logos {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Blog post placeholder shorter */
  body.divichild-dark .et_pb_blog .et_pb_post:not(:has(.entry-featured-image-url))::before,
  body.divichild-dark .et_pb_blog .et_pb_post:not(:has(.entry-featured-image-url))::after {
    height: 8rem;
  }
}

/* ==========================================================================
   RESPONSIVE — LANDSCAPE PHONE FIX
   ========================================================================== */

@media (max-height: 500px) and (orientation: landscape) {
  #home {
    padding-top: 6rem !important;
    padding-bottom: 3rem !important;
  }

  body.divichild-dark .et_pb_section {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
}

/* ==========================================================================
   RESPONSIVE — DIVI COLUMN WIDTH OVERRIDES
   Divi applies inline widths that break on mobile; override them.
   ========================================================================== */

@media (max-width: 980px) {
  body.divichild-dark .et_pb_column,
  body.divichild-dark .et_pb_column_1_2,
  body.divichild-dark .et_pb_column_1_3,
  body.divichild-dark .et_pb_column_2_3,
  body.divichild-dark .et_pb_column_1_4,
  body.divichild-dark .et_pb_column_3_4 {
    width: 100% !important;
    margin-right: 0 !important;
    margin-left: 0 !important;
  }

  /* Two-column sections that should remain 2-col on tablet */
  #about .et_pb_row > .et_pb_column:last-child {
    width: 100% !important;
  }
}

/* ==========================================================================
   RESPONSIVE — TOUCH TARGETS (a11y)
   ========================================================================== */

@media (pointer: coarse) {
  /* Enlarge tap targets for touch devices */
  body.divichild-dark .et_pb_button {
    min-height: 48px !important;
    min-width: 48px !important;
  }

  body.divichild-dark #main-header .et_pb_menu__menu a {
    padding: 0.75rem 0 !important;
  }

  body.divichild-dark .et_pb_toggle .et_pb_toggle_title {
    padding: 0.5rem 0 !important;
    min-height: 44px;
    display: flex;
    align-items: center;
  }

  .dc-contact-link {
    min-height: 48px;
  }

  .dc-interest-pill {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
}

/* ==========================================================================
   RESPONSIVE — HIGH DPI (Retina) optimizations
   ========================================================================== */

@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
  .dc-aurora::before,
  .dc-aurora::after {
    filter: blur(100px);
  }
}

/* ==========================================================================
   INNER PAGES — Service / About / Cases / Contact
   ========================================================================== */

/* ── Inner Page Layout: constrain content, center sections ── */
body.divichild-dark:not(.home) .et_pb_section .et_pb_row {
  max-width: 1200px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

body.divichild-dark:not(.home) .et_pb_section {
  padding: 80px 5% !important;
}

/* ── Inner Page Hero ── */
body.divichild-dark:not(.home) .et_pb_section:first-child {
  padding-top: 140px !important;
  padding-bottom: 100px !important;
  position: relative;
}

body.divichild-dark:not(.home) .et_pb_section:first-child::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 10%;
  right: 10%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--dc-border), transparent);
}

/* ── dc-hero-text: constrain width for readability ── */
.dc-hero-text {
  max-width: 720px;
}

.dc-hero-text .dc-body-large {
  max-width: 600px;
}

/* ── Inner page section separators ── */
body.divichild-dark:not(.home) .et_pb_section + .et_pb_section {
  border-top: 1px solid rgba(255, 255, 255, 0.04);
}

/* ── Stat Grid ── */
.dc-stat-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  margin-top: 2.5rem;
}

.dc-stat-card {
  text-align: center;
  padding: 2.5rem 1.5rem !important;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.04) 0%, rgba(255, 255, 255, 0.01) 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.06) !important;
  border-radius: var(--dc-radius-lg) !important;
}

.dc-stat-card .dc-counter {
  font-size: 3.5rem;
  font-weight: 700;
  font-family: 'Space Grotesk', sans-serif;
  background: linear-gradient(135deg, var(--dc-accent), var(--dc-accent-alt));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1.1;
}

.dc-stat-suffix {
  font-size: 1.6rem;
  font-weight: 600;
  background: linear-gradient(135deg, var(--dc-accent), var(--dc-accent-alt));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.dc-stat-label {
  display: block;
  margin-top: 0.75rem;
  font-size: 0.8rem;
  color: var(--dc-mute);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 500;
}

/* ── Card Grid (3-col / 2-col) ── */
.dc-card-grid {
  display: grid;
  gap: 1.5rem;
  margin-top: 2.5rem;
}

.dc-card-grid-3 {
  grid-template-columns: repeat(3, 1fr);
}

.dc-card-grid-2 {
  grid-template-columns: repeat(2, 1fr);
}

.dc-card-grid .dc-glass-card {
  padding: 2.25rem !important;
  transition: transform 0.4s cubic-bezier(0.2, 0.8, 0.2, 1),
              box-shadow 0.4s cubic-bezier(0.2, 0.8, 0.2, 1),
              border-color 0.4s ease;
}

.dc-card-grid .dc-glass-card:hover {
  transform: translateY(-6px);
  box-shadow:
    0 20px 60px -15px rgba(59, 130, 246, 0.15),
    0 4px 20px rgba(0, 0, 0, 0.4) !important;
  border-color: rgba(96, 165, 250, 0.3) !important;
}

.dc-card-icon {
  font-size: 2.25rem;
  margin-bottom: 1.25rem;
  display: inline-block;
  width: 3.5rem;
  height: 3.5rem;
  line-height: 3.5rem;
  text-align: center;
  background: rgba(96, 165, 250, 0.08);
  border-radius: 12px;
}

.dc-card-grid h3 {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--dc-text);
  margin-bottom: 0.625rem;
}

.dc-card-grid p {
  color: var(--dc-mute);
  font-size: 0.92rem;
  line-height: 1.65;
  margin: 0;
}

/* ── Card Link (clickable service cards) ── */
.dc-card-link {
  text-decoration: none;
  display: block;
  position: relative;
}

.dc-card-link .dc-card-arrow {
  position: absolute;
  bottom: 1.75rem;
  right: 1.75rem;
  font-size: 1.25rem;
  color: var(--dc-accent);
  opacity: 0;
  transition: opacity 0.3s ease, transform 0.3s ease;
  font-weight: 600;
}

.dc-card-link:hover .dc-card-arrow {
  opacity: 1;
  transform: translateX(4px);
}

.dc-card-link:hover h3 {
  color: var(--dc-accent);
  transition: color 0.3s ease;
}

/* Duplicate .dc-chip removed — already defined in the global CHIP/PILL section above */

.dc-chip-featured {
  background: linear-gradient(135deg, rgba(96, 165, 250, 0.15), rgba(59, 130, 246, 0.08));
  border-color: rgba(96, 165, 250, 0.4);
  box-shadow: 0 0 20px rgba(96, 165, 250, 0.1);
}

/* ── Process Steps ── */
.dc-process-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  margin-top: 2.5rem;
  counter-reset: process;
}

.dc-process-step {
  padding: 2.25rem !important;
  position: relative;
}

/* Connector line between steps */
.dc-process-step:not(:last-child)::after {
  content: '';
  position: absolute;
  top: 2.5rem;
  right: -0.75rem;
  width: 1.5rem;
  height: 2px;
  background: linear-gradient(90deg, var(--dc-accent), transparent);
  opacity: 0.3;
}

.dc-process-num {
  font-size: 2.75rem;
  font-weight: 800;
  font-family: 'Space Grotesk', sans-serif;
  background: linear-gradient(135deg, var(--dc-accent), var(--dc-accent-alt));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  display: block;
  margin-bottom: 1.25rem;
  line-height: 1;
}

.dc-process-step h3 {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--dc-text);
  margin-bottom: 0.625rem;
}

.dc-process-step p {
  color: var(--dc-mute);
  font-size: 0.9rem;
  line-height: 1.65;
}

/* ── Case Cards ── */
.dc-case-card {
  padding: 2.5rem !important;
}

.dc-case-card h3 {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--dc-text);
  margin: 0.75rem 0 0.5rem;
}

.dc-case-result {
  font-size: 1.1rem;
  margin-bottom: 1rem;
  color: var(--dc-mute);
}

.dc-case-number {
  font-size: 1.5rem;
  font-weight: 700;
}

.dc-case-card > p {
  color: var(--dc-mute);
  font-size: 0.92rem;
  line-height: 1.65;
}

.dc-case-metrics {
  display: flex;
  gap: 0.75rem;
  margin-top: 1.25rem;
  flex-wrap: wrap;
}

.dc-case-metrics span {
  display: inline-block;
  padding: 0.35rem 0.75rem;
  font-size: 0.72rem;
  font-weight: 600;
  border-radius: 6px;
  background: rgba(96, 165, 250, 0.08);
  color: var(--dc-accent);
  border: 1px solid rgba(96, 165, 250, 0.18);
  letter-spacing: 0.02em;
}

/* ── Contact Info Stack ── */
.dc-contact-info {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.dc-contact-info .dc-glass-card {
  padding: 1.5rem 1.75rem !important;
}

.dc-contact-info h3 {
  font-family: 'Space Grotesk', sans-serif;
  font-size: 1rem;
  font-weight: 600;
  color: var(--dc-text);
  margin-bottom: 0.35rem;
}

.dc-contact-info p {
  color: var(--dc-mute);
  margin: 0;
  font-size: 0.95rem;
}

.dc-contact-info a {
  color: var(--dc-accent);
  text-decoration: none;
  transition: color 0.2s ease;
}

.dc-contact-info a:hover {
  color: var(--dc-ice);
}

/* ── CTA Section (elevated treatment) ── */
.dc-cta-section {
  text-align: center;
  position: relative;
}

.dc-cta-section .et_pb_row {
  position: relative;
  z-index: 2;
}

.dc-cta-section::before {
  content: '';
  position: absolute;
  top: -60px;
  left: 50%;
  transform: translateX(-50%);
  width: 500px;
  height: 500px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(59, 130, 246, 0.08) 0%, transparent 70%);
  pointer-events: none;
}

.dc-cta-section .dc-display {
  margin-bottom: 0.75rem;
}

.dc-cta-section .dc-body-large {
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 2rem;
}

/* ── Nav CTA button ── */
.dc-nav-cta > a {
  background: linear-gradient(135deg, var(--dc-accent), var(--dc-accent-alt)) !important;
  color: #0a0a0a !important;
  font-weight: 600 !important;
  border-radius: 8px !important;
  padding: 0.6rem 1.2rem !important;
  transition: all 0.3s ease !important;
  box-shadow: 0 2px 12px rgba(96, 165, 250, 0.2) !important;
}

.dc-nav-cta > a:hover {
  box-shadow: 0 4px 20px rgba(96, 165, 250, 0.35) !important;
  transform: translateY(-1px);
}

/* ── Large Button ── */
.dc-btn-lg {
  padding: 1rem 2.5rem !important;
  font-size: 1.05rem !important;
}

/* ── Staggered reveal animation for grids ── */
.dc-card-grid .dc-reveal:nth-child(1) { transition-delay: 0s; }
.dc-card-grid .dc-reveal:nth-child(2) { transition-delay: 0.08s; }
.dc-card-grid .dc-reveal:nth-child(3) { transition-delay: 0.16s; }
.dc-card-grid .dc-reveal:nth-child(4) { transition-delay: 0.24s; }
.dc-card-grid .dc-reveal:nth-child(5) { transition-delay: 0.32s; }
.dc-card-grid .dc-reveal:nth-child(6) { transition-delay: 0.4s; }
.dc-card-grid .dc-reveal:nth-child(7) { transition-delay: 0.48s; }
.dc-card-grid .dc-reveal:nth-child(8) { transition-delay: 0.56s; }
.dc-card-grid .dc-reveal:nth-child(9) { transition-delay: 0.64s; }

.dc-stat-grid .dc-reveal:nth-child(1) { transition-delay: 0s; }
.dc-stat-grid .dc-reveal:nth-child(2) { transition-delay: 0.1s; }
.dc-stat-grid .dc-reveal:nth-child(3) { transition-delay: 0.2s; }
.dc-stat-grid .dc-reveal:nth-child(4) { transition-delay: 0.3s; }

.dc-process-steps .dc-reveal:nth-child(1) { transition-delay: 0s; }
.dc-process-steps .dc-reveal:nth-child(2) { transition-delay: 0.12s; }
.dc-process-steps .dc-reveal:nth-child(3) { transition-delay: 0.24s; }
.dc-process-steps .dc-reveal:nth-child(4) { transition-delay: 0.36s; }

/* ── Hover glow for stat cards ── */
.dc-stat-card {
  transition: all 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.dc-stat-card:hover {
  border-color: rgba(96, 165, 250, 0.2) !important;
  box-shadow: 0 0 40px rgba(59, 130, 246, 0.08) !important;
}

/* ── Inner Pages Responsive ── */
@media (min-width: 1400px) {
  body.divichild-dark:not(.home) .et_pb_section .et_pb_row {
    max-width: 1320px !important;
  }
}

@media (max-width: 980px) {
  body.divichild-dark:not(.home) .et_pb_section {
    padding: 60px 4% !important;
  }
  body.divichild-dark:not(.home) .et_pb_section:first-child {
    padding-top: 100px !important;
  }
  .dc-stat-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .dc-card-grid-3,
  .dc-process-steps {
    grid-template-columns: repeat(2, 1fr);
  }
  .dc-process-step:not(:last-child)::after {
    display: none;
  }
  .dc-hero-text {
    max-width: 100%;
  }
}

@media (max-width: 767px) {
  body.divichild-dark:not(.home) .et_pb_section {
    padding: 50px 5% !important;
  }
  body.divichild-dark:not(.home) .et_pb_section:first-child {
    padding-top: 80px !important;
    padding-bottom: 60px !important;
  }
  .dc-stat-grid,
  .dc-card-grid-3,
  .dc-card-grid-2,
  .dc-process-steps {
    grid-template-columns: 1fr;
  }
  .dc-stat-card .dc-counter {
    font-size: 2.5rem;
  }
  .dc-case-metrics {
    flex-direction: column;
    gap: 0.5rem;
  }
  .dc-cta-section::before {
    width: 300px;
    height: 300px;
  }
}
