/* ==========================================================================
   Cyber CH — brand.css
   Applies on top of Divi's stylesheet. Uses CSS custom properties
   injected by functions.php so values update when the Customizer changes.
   ========================================================================== */

/* ── Fallback custom property values ──────────────────────────────────────
   These are overridden by the inline block generated in cyberch_css_vars().   */
:root {
  --cyberch-gold:              #C7A564;
  --cyberch-gold-dim:          #A88440;
  --cyberch-gold-pale:         #F5EDD8;
  --cyberch-dark:              #1C2329;
  --cyberch-mid:               #242B30;
  --cyberch-surface:           #FAFAF8;
  --cyberch-surface-low:       #F1EFE8;
  --cyberch-muted:             #6B7280;
  --cyberch-outline:           #D1C5B5;
  --cyberch-watermark-opacity: 0.055;
}

/* ── Base typography ───────────────────────────────────────────────────── */
body,
.et_pb_text,
.et_pb_blurb_description,
p {
  font-family: "DM Sans", sans-serif;
  color: var(--cyberch-dark);
}

h1, h2, h3, h4, h5, h6,
.et_pb_slide_title,
.et_pb_module_header,
.et_pb_title_container h1 {
  font-family: "Manrope", sans-serif;
  font-weight: 800;
}

code, pre, .et_pb_code_inner {
  font-family: "DM Mono", monospace;
}

/* ── Page background ───────────────────────────────────────────────────── */
body {
  background-color: var(--cyberch-surface);
}

/* ── Fixed logo watermark (sits behind all Divi sections) ─────────────── */
body::before {
  content: "";
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(72vw, 900px);
  aspect-ratio: 1290.7 / 1513.2;
  background-image: url("../img/cyberch-logo-watermark.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  pointer-events: none;
  z-index: 0;
  opacity: var(--cyberch-watermark-opacity);
}

/* All Divi wrappers must sit above the watermark */
#page-container,
#main-header,
#main-footer,
.et_pb_section {
  position: relative;
  z-index: 1;
}

/* ── Material Symbols icon font setup ─────────────────────────────────── */
.material-symbols-outlined {
  font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
  display: inline-block;
  line-height: 1;
  text-transform: none;
  letter-spacing: normal;
  word-wrap: normal;
  white-space: nowrap;
  direction: ltr;
  vertical-align: middle;
}

/* ── Divi header / nav overrides ──────────────────────────────────────── */
#main-header,
#main-header.et-fixed-header {
  background: rgba(250, 250, 248, 0.88) !important;
  backdrop-filter: blur(18px) saturate(1.6);
  -webkit-backdrop-filter: blur(18px) saturate(1.6);
  border-bottom: 1px solid rgba(199, 165, 100, 0.14) !important;
  box-shadow: none !important;
}

/* Logo in header */
#main-header .logo_container img,
#main-header #logo {
  max-height: 52px !important;
}

/* Primary nav links */
#main-header #et-top-navigation nav > ul > li > a {
  font-family: "Manrope", sans-serif;
  font-weight: 600;
  font-size: 0.875rem;
  letter-spacing: 0.01em;
  color: var(--cyberch-mid) !important;
  transition: color 0.2s;
}
#main-header #et-top-navigation nav > ul > li > a:hover,
#main-header #et-top-navigation nav > ul > li.current-menu-item > a {
  color: var(--cyberch-gold) !important;
}

/* Mobile nav */
#main-header .mobile_menu_bar:before {
  color: var(--cyberch-dark);
}

/* ── Global CTA button class (use in Divi Button module → CSS class) ──── */
.cyberch-btn-gold,
.et_pb_button.cyberch-btn-gold {
  background: var(--cyberch-gold) !important;
  color: #fff !important;
  border-color: var(--cyberch-gold) !important;
  font-family: "Manrope", sans-serif !important;
  font-weight: 700 !important;
  border-radius: 0.5rem !important;
  box-shadow: 0 2px 16px rgba(199, 165, 100, 0.25);
  transition: background 0.22s, transform 0.18s, box-shadow 0.22s !important;
}
.cyberch-btn-gold:hover,
.et_pb_button.cyberch-btn-gold:hover {
  background: var(--cyberch-gold-dim) !important;
  border-color: var(--cyberch-gold-dim) !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(199, 165, 100, 0.38) !important;
  color: #fff !important;
}

.cyberch-btn-outline,
.et_pb_button.cyberch-btn-outline {
  background: transparent !important;
  color: #fff !important;
  border: 1.5px solid rgba(255, 255, 255, 0.35) !important;
  font-family: "Manrope", sans-serif !important;
  font-weight: 700 !important;
  border-radius: 0.5rem !important;
  transition: border-color 0.2s, background 0.2s, transform 0.18s !important;
}
.cyberch-btn-outline:hover,
.et_pb_button.cyberch-btn-outline:hover {
  border-color: rgba(255, 255, 255, 0.7) !important;
  background: rgba(255, 255, 255, 0.08) !important;
  transform: translateY(-2px);
}

/* ── Dark section (brand-dark background) ─────────────────────────────── */
.cyberch-section-dark {
  background-color: var(--cyberch-dark) !important;
}
.cyberch-section-dark .et_pb_text_inner,
.cyberch-section-dark p,
.cyberch-section-dark h2,
.cyberch-section-dark h3 {
  color: #ffffff !important;
}

/* ── Gold ticker strip ────────────────────────────────────────────────── */
.cyberch-ticker-section {
  background: var(--cyberch-gold) !important;
  padding: 0.75rem 0 !important;
  overflow: hidden;
}
.cyberch-ticker-wrap { overflow: hidden; }
.cyberch-ticker-inner {
  display: flex;
  width: max-content;
  animation: cyberch-ticker 28s linear infinite;
}
.cyberch-ticker-inner:hover { animation-play-state: paused; }
.cyberch-ticker-item {
  display: inline-flex;
  align-items: center;
  gap: 1rem;
  padding: 0 2rem;
  font-family: "Manrope", sans-serif;
  font-weight: 700;
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--cyberch-dark);
  white-space: nowrap;
}

/* ── Hero diagonal clip ───────────────────────────────────────────────── */
.cyberch-hero-section {
  position: relative;
  overflow: hidden;
}
.cyberch-hero-section::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  right: 0;
  height: 80px;
  background: var(--cyberch-surface);
  clip-path: polygon(0 100%, 100% 0, 100% 100%);
  z-index: 2;
}

/* ── Pulse badge (hero) ───────────────────────────────────────────────── */
.cyberch-pulse-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.375rem 0.875rem;
  border-radius: 9999px;
  background: rgba(199, 165, 100, 0.15);
  color: var(--cyberch-gold);
  font-family: "DM Mono", monospace;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  border: 1px solid rgba(199, 165, 100, 0.25);
}
.cyberch-pulse-dot {
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background: var(--cyberch-gold);
  position: relative;
  flex-shrink: 0;
}
.cyberch-pulse-dot::before {
  content: "";
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  background: rgba(199, 165, 100, 0.35);
  animation: cyberch-pulse-ring 2.4s ease-in-out infinite;
}

/* ── Service cards ────────────────────────────────────────────────────── */
.cyberch-service-card,
.et_pb_blurb.cyberch-service-card {
  border: 1px solid rgba(199, 165, 100, 0.2) !important;
  border-radius: 1rem !important;
  background: rgba(255, 255, 255, 0.75) !important;
  backdrop-filter: blur(8px);
  transition: border-color 0.3s, transform 0.3s, box-shadow 0.3s !important;
}
.cyberch-service-card:hover,
.et_pb_blurb.cyberch-service-card:hover {
  border-color: var(--cyberch-gold) !important;
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(199, 165, 100, 0.15) !important;
}
.cyberch-service-card .et_pb_main_blurb_image .et-pb-icon {
  color: var(--cyberch-gold) !important;
  background: rgba(199, 165, 100, 0.12);
  border-radius: 0.75rem;
  padding: 0.75rem;
  transition: background 0.3s, color 0.3s;
}
.cyberch-service-card:hover .et_pb_main_blurb_image .et-pb-icon {
  background: var(--cyberch-gold) !important;
  color: #fff !important;
}

/* ── Stat / metrics card ──────────────────────────────────────────────── */
.cyberch-stat-card {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(199, 165, 100, 0.28);
  border-radius: 0.875rem;
  padding: 2rem;
  text-align: center;
}
.cyberch-stat-number {
  font-family: "Manrope", sans-serif;
  font-weight: 900;
  font-size: 3rem;
  color: var(--cyberch-gold);
  line-height: 1.1;
  display: block;
}
.cyberch-stat-label {
  font-family: "DM Mono", monospace;
  font-size: 0.8rem;
  color: #8C9BA8;
  margin-top: 0.25rem;
}

/* ── Progress bars ────────────────────────────────────────────────────── */
.cyberch-progress-wrap {
  background: rgba(199, 165, 100, 0.15);
  border-radius: 9999px;
  height: 0.5rem;
  overflow: hidden;
}
.cyberch-progress-fill {
  height: 100%;
  background: var(--cyberch-gold);
  border-radius: 9999px;
  width: 0;
  transition: width 1.4s cubic-bezier(.16, 1, .3, 1);
}

/* ── Framework step connector ─────────────────────────────────────────── */
.cyberch-step-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  border: 2px solid var(--cyberch-gold);
  color: var(--cyberch-gold);
  font-family: "Manrope", sans-serif;
  font-weight: 700;
  font-size: 0.875rem;
  flex-shrink: 0;
}
.cyberch-step-number.active {
  background: var(--cyberch-gold);
  color: #fff;
  border-color: var(--cyberch-gold);
}

/* ── Testimonial cards ────────────────────────────────────────────────── */
.cyberch-testimonial,
.et_pb_testimonial.cyberch-testimonial {
  border: 1px solid rgba(199, 165, 100, 0.2) !important;
  border-radius: 1rem !important;
  background: rgba(255, 255, 255, 0.85) !important;
  transition: transform 0.3s, box-shadow 0.3s !important;
}
.cyberch-testimonial:hover,
.et_pb_testimonial.cyberch-testimonial:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 36px rgba(199, 165, 100, 0.13) !important;
}

/* ── FAQ / Toggle module ──────────────────────────────────────────────── */
.et_pb_toggle.cyberch-faq {
  border: 1px solid rgba(199, 165, 100, 0.2) !important;
  border-radius: 0.75rem !important;
  background: rgba(255, 255, 255, 0.75) !important;
  margin-bottom: 0.75rem !important;
  transition: border-color 0.2s;
}
.et_pb_toggle.cyberch-faq:hover {
  border-color: rgba(199, 165, 100, 0.5) !important;
}
.et_pb_toggle.cyberch-faq h5.et_pb_toggle_title {
  font-family: "Manrope", sans-serif !important;
  font-weight: 700 !important;
  color: var(--cyberch-dark) !important;
  font-size: 1rem !important;
}
.et_pb_toggle.cyberch-faq .et_pb_toggle_icon {
  color: var(--cyberch-gold) !important;
}
.et_pb_toggle.cyberch-faq .et_pb_toggle_content {
  color: var(--cyberch-muted) !important;
  font-family: "DM Sans", sans-serif !important;
  font-size: 0.9375rem !important;
  line-height: 1.7 !important;
}

/* ── WPForms overrides (matches our form-field style) ─────────────────── */
.wpforms-container .wpforms-field input,
.wpforms-container .wpforms-field select,
.wpforms-container .wpforms-field textarea {
  font-family: "DM Sans", sans-serif !important;
  background: #FAFAF8 !important;
  border: 1px solid #E2DDD5 !important;
  border-radius: 0.5rem !important;
  color: var(--cyberch-dark) !important;
  padding: 0.75rem 1rem !important;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.wpforms-container .wpforms-field input:focus,
.wpforms-container .wpforms-field select:focus,
.wpforms-container .wpforms-field textarea:focus {
  border-color: var(--cyberch-gold) !important;
  box-shadow: 0 0 0 3px rgba(199, 165, 100, 0.15) !important;
  outline: none !important;
}
.wpforms-container .wpforms-field label {
  font-family: "Manrope", sans-serif !important;
  font-weight: 700 !important;
  font-size: 0.6875rem !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--cyberch-muted) !important;
}
.wpforms-container .wpforms-submit-container button[type="submit"] {
  background: var(--cyberch-gold) !important;
  border-color: var(--cyberch-gold) !important;
  color: #fff !important;
  font-family: "Manrope", sans-serif !important;
  font-weight: 700 !important;
  border-radius: 0.5rem !important;
  padding: 0.875rem 2rem !important;
  transition: background 0.22s, transform 0.18s, box-shadow 0.22s !important;
  width: 100%;
}
.wpforms-container .wpforms-submit-container button[type="submit"]:hover {
  background: var(--cyberch-gold-dim) !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(199, 165, 100, 0.35) !important;
}

/* ── Scroll reveal ────────────────────────────────────────────────────── */
[data-reveal] {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.65s cubic-bezier(.16, 1, .3, 1),
              transform 0.65s cubic-bezier(.16, 1, .3, 1);
}
[data-reveal].visible {
  opacity: 1;
  transform: translateY(0);
}
[data-reveal][data-delay="1"] { transition-delay: 0.1s; }
[data-reveal][data-delay="2"] { transition-delay: 0.2s; }
[data-reveal][data-delay="3"] { transition-delay: 0.3s; }
[data-reveal][data-delay="4"] { transition-delay: 0.4s; }

/* ── Footer overrides ─────────────────────────────────────────────────── */
#main-footer {
  background: #ffffff !important;
  border-top: 1px solid rgba(209, 197, 181, 0.4);
}
#main-footer .footer-widget h4 {
  font-family: "Manrope", sans-serif !important;
  font-weight: 700 !important;
  font-size: 0.75rem !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--cyberch-dark) !important;
}
#main-footer a {
  color: var(--cyberch-muted) !important;
  transition: color 0.2s;
}
#main-footer a:hover {
  color: var(--cyberch-gold) !important;
  text-decoration: none;
}
#et-footer-nav {
  border-top: 1px solid rgba(209, 197, 181, 0.3);
}
.et_pb_section.cyberch-footer-bar {
  background: #ffffff !important;
}

/* ── Accessibility: visible focus ring ────────────────────────────────── */
:focus-visible {
  outline: 2px solid var(--cyberch-gold);
  outline-offset: 3px;
}

/* ── Skip link ────────────────────────────────────────────────────────── */
.skip-link {
  position: absolute;
  left: -9999px;
  z-index: 9999;
  padding: 0.5rem 1rem;
  background: var(--cyberch-gold);
  color: #fff;
  font-weight: 700;
}
.skip-link:focus { left: 0; }

/* ── Keyframes ────────────────────────────────────────────────────────── */
@keyframes cyberch-ticker {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
@keyframes cyberch-pulse-ring {
  0%, 100% { transform: scale(1);    opacity: 0.4; }
  50%       { transform: scale(1.15); opacity: 0; }
}
@keyframes cyberch-fade-up {
  0%   { opacity: 0; transform: translateY(24px); }
  100% { opacity: 1; transform: translateY(0); }
}
