:root {
  --bg: #f6f8fb;
  --bg-elev: #ffffff;
  --text: #0f172a;
  --text-secondary: #334155;
  --text-dim: #64748b;
  --glass-blur: 24px;
  --bg-glass: rgba(255, 255, 255, 0.36);
  --bg-glass-strong: rgba(255, 255, 255, 0.5);
  --glass-border: rgba(255, 255, 255, 0.52);
  --glass-highlight: rgba(255, 255, 255, 0.82);
  --glass-shadow-soft: 0 18px 48px rgba(15, 23, 42, 0.12);
  --glass-shadow-strong: 0 24px 60px rgba(15, 23, 42, 0.18);
  --agent-primary: #4f86d9;
  --agent-secondary: #7db4ff;
  --agent-accent: #d93058;
  --agent-line: rgba(79, 134, 217, 0.22);
}

[data-theme="dark"] {
  --bg: #020305;
  --bg-elev: #11151e;
  --text: #f8fafc;
  --text-secondary: #d7e0ee;
  --text-dim: #a6b1c2;
  --bg-glass: rgba(20, 32, 52, 0.28);
  --bg-glass-strong: rgba(18, 30, 48, 0.4);
  --glass-border: rgba(171, 197, 236, 0.26);
  --glass-highlight: rgba(255, 255, 255, 0.2);
  --glass-shadow-soft: 0 20px 56px rgba(2, 6, 23, 0.45);
  --glass-shadow-strong: 0 26px 70px rgba(2, 6, 23, 0.58);
  --agent-primary: #6fa8ff;
  --agent-secondary: #8cc0ff;
  --agent-accent: #ff5c7d;
  --agent-line: rgba(118, 168, 255, 0.25);
}

body {
  background:
    radial-gradient(circle at 22% 12%, rgba(232, 51, 90, 0.08), transparent 30%),
    radial-gradient(circle at 78% 16%, rgba(15, 23, 42, 0.08), transparent 34%),
    linear-gradient(180deg, #fbfcfe 0%, var(--bg) 100%);
}

[data-theme="dark"] body {
  background:
    radial-gradient(circle at 24% 12%, rgba(232, 51, 90, 0.08), transparent 28%),
    radial-gradient(circle at 76% 18%, rgba(255, 122, 148, 0.06), transparent 32%),
    linear-gradient(180deg, rgba(6, 7, 10, 0.98), rgba(2, 3, 5, 1));
}

.glass,
.glass-strong {
  backdrop-filter: blur(var(--glass-blur)) saturate(165%);
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(165%);
}

.glass {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.03)),
    var(--bg-glass);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.82),
    inset 0 -1px 0 rgba(255, 255, 255, 0.08),
    var(--glass-shadow-soft);
}

.glass::before {
  padding: 1.2px;
  background: linear-gradient(135deg,
    var(--glass-highlight) 0%,
    rgba(255, 255, 255, 0.22) 24%,
    rgba(255, 255, 255, 0.03) 52%,
    rgba(255, 255, 255, 0.12) 76%,
    rgba(255, 255, 255, 0.45) 100%);
}

.glass::after {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  pointer-events: none;
  background:
    radial-gradient(circle at top left, rgba(255, 255, 255, 0.28), transparent 42%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 55%);
  opacity: 0.72;
  z-index: 0;
}

.glass > *,
.glass-strong > * {
  position: relative;
  z-index: 2;
}

main > section.container {
  padding-left: 28px;
  padding-right: 28px;
}

main > section.container:not(.page-hero) {
  padding-top: clamp(40px, 4vw, 64px);
  padding-bottom: clamp(40px, 4vw, 64px);
}

main > section.container + section.container {
  margin-top: 0;
}

.card-grid {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr)) !important;
  gap: clamp(24px, 2.2vw, 36px) !important;
  align-items: stretch;
}

.card,
.glass,
.glass-strong {
  min-width: 0;
}

main > section.container > .card.glass-strong:only-child,
main > section.container > .card.glass:only-child {
  margin-top: 0 !important;
}

.glass-strong {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0.04)),
    var(--bg-glass-strong);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.84),
    inset 0 -1px 0 rgba(255, 255, 255, 0.08),
    var(--glass-shadow-strong);
}

.navbar {
  position: fixed;
  top: 16px;
  z-index: 2100;
  overflow: visible;
  transform-style: preserve-3d;
  transition: transform 120ms ease, box-shadow 180ms ease, background 180ms ease;
}

.navbar::after {
  content: "";
  position: absolute;
  inset: -10px;
  border-radius: inherit;
  pointer-events: none;
  background:
    radial-gradient(220px circle at var(--nav-glow-x, 50%) var(--nav-glow-y, 50%), rgba(232, 51, 90, 0.22), transparent 42%),
    radial-gradient(180px circle at var(--nav-glow-x, 50%) var(--nav-glow-y, 50%), rgba(255, 255, 255, 0.1), transparent 55%);
  opacity: 0;
  filter: blur(16px);
  transition: opacity 140ms ease;
  z-index: 0;
}

.navbar.is-reactive-hover {
  box-shadow:
    0 16px 36px rgba(15, 23, 42, 0.18),
    0 0 0 1px rgba(255, 255, 255, 0.08);
}

.navbar.is-reactive-hover::after {
  opacity: 1;
}

.navbar.glass,
.lang-dropdown.glass,
.lang-switcher {
  overflow: visible;
}

[data-theme="dark"] .navbar,
[data-theme="dark"] .logo,
[data-theme="dark"] .nav-links a,
[data-theme="dark"] .lang-btn,
[data-theme="dark"] .icon-btn {
  color: rgba(248, 250, 252, 0.9);
}

[data-theme="dark"] .nav-links a.active {
  color: var(--accent);
}

[data-theme="dark"] .page-hero h1,
[data-theme="dark"] .section-title,
[data-theme="dark"] .hero-title,
[data-theme="dark"] h1,
[data-theme="dark"] h2 {
  color: #f8fafc;
}

[data-theme="dark"] p,
[data-theme="dark"] .page-hero p,
[data-theme="dark"] .hero-subtitle {
  color: rgba(215, 224, 238, 0.9);
}

[data-theme="light"] .navbar,
[data-theme="light"] .logo,
[data-theme="light"] .nav-links a,
[data-theme="light"] .lang-btn,
[data-theme="light"] .icon-btn,
[data-theme="light"] .btn-secondary {
  color: #101827;
}

[data-theme="light"] .nav-links a.active {
  color: var(--accent);
}

[data-theme="light"] .page-hero h1,
[data-theme="light"] .section-title,
[data-theme="light"] .hero-title,
[data-theme="light"] h1,
[data-theme="light"] h2 {
  color: #101827;
}

[data-theme="light"] p,
[data-theme="light"] .page-hero p,
[data-theme="light"] .hero-subtitle {
  color: rgba(31, 41, 55, 0.82);
}

.nav-right,
.lang-switcher {
  position: relative;
}

.lang-switcher {
  z-index: 90;
}

.lang-btn {
  position: relative;
  z-index: 91;
}

.lang-btn:focus-visible,
.lang-option:focus-visible {
  outline: 2px solid rgba(232, 51, 90, 0.7);
  outline-offset: 2px;
}

.lang-dropdown {
  z-index: 2200;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.05)),
    var(--bg-glass-strong);
  border: 1px solid var(--glass-border);
  box-shadow: 0 22px 48px rgba(15, 23, 42, 0.18);
}

.lang-dropdown.open {
  display: block;
}

.lang-option {
  position: relative;
  z-index: 2;
}

.logo {
  position: relative;
  align-items: center;
}

.logo-mark-svg {
  overflow: hidden;
  border-radius: 999px;
  filter: drop-shadow(0 0 10px rgba(232, 51, 90, 0.2));
  transition: filter 180ms ease, transform 180ms ease;
}

.logo-mark-circle {
  transform-box: fill-box;
  transform-origin: center;
}

.logo:hover .logo-mark-svg,
.navbar:hover .logo-mark-svg {
  filter:
    drop-shadow(0 0 12px rgba(232, 51, 90, 0.35))
    drop-shadow(0 0 22px rgba(232, 51, 90, 0.26));
  transform: translateY(-0.5px);
}

.logo-waves-shell {
  clip-path: inset(0 round 999px);
}

.lm-waves {
  transform-box: fill-box;
  transform-origin: center;
  will-change: transform;
}

.agent-bg {
  z-index: -1;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 16%, rgba(232, 51, 90, 0.08), transparent 34%),
    radial-gradient(circle at 50% 56%, rgba(15, 23, 42, 0.08), transparent 46%),
    radial-gradient(circle at 78% 18%, rgba(255, 255, 255, 0.82), transparent 36%),
    linear-gradient(180deg, rgba(250, 252, 255, 0.98), rgba(233, 239, 248, 1));
}

[data-theme="dark"] .agent-bg {
  background:
    radial-gradient(circle at 50% 18%, rgba(232, 51, 90, 0.1), transparent 30%),
    radial-gradient(circle at 50% 58%, rgba(255, 255, 255, 0.03), transparent 40%),
    linear-gradient(180deg, rgba(5, 6, 9, 0.995), rgba(1, 2, 4, 1));
}

.wave-grid-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  pointer-events: none;
  opacity: 0.9;
  z-index: 0;
}

body.index-agent-muted .agent-canvas {
  clip-path: inset(0 0 34% 0);
}

body.index-agent-muted .agent-bg.is-local-agent-ready .agent-scene,
body.index-agent-muted .agent-scene {
  clip-path: inset(0 0 34% 0);
}

.agent-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  opacity: 0.46;
  z-index: 2;
}

.agent-bg.is-local-agent-ready .agent-scene {
  opacity: 0.025;
  filter: blur(18px) saturate(104%);
}

.agent-bg.is-local-agent-failed .agent-scene,
.agent-scene {
  position: absolute;
  inset: -4%;
  width: 108%;
  height: 108%;
  z-index: 1;
  opacity: 0.1;
  filter: blur(22px) saturate(108%);
}

[data-theme="dark"] .agent-bg.is-local-agent-ready .agent-scene {
  opacity: 0.035;
  filter: blur(20px) saturate(106%);
}

[data-theme="dark"] .agent-bg.is-local-agent-failed .agent-scene,
[data-theme="dark"] .agent-scene {
  opacity: 0.12;
  filter: blur(24px) saturate(110%);
}

@media (max-width: 960px) {
  .lang-dropdown {
    right: 0;
    left: auto;
  }

  main > section.container {
    padding-left: 20px;
    padding-right: 20px;
  }

  main > section.container:not(.page-hero) {
    padding-top: 40px;
    padding-bottom: 40px;
  }

  .agent-canvas {
    opacity: 0.4;
  }
}

@media (max-width: 540px) {
  main > section.container {
    padding-left: 16px;
    padding-right: 16px;
  }

  main > section.container:not(.page-hero) {
    padding-top: 34px;
    padding-bottom: 34px;
  }

  .card-grid {
    gap: 18px !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  .logo-mark-svg,
  .lm-waves,
  .agent-canvas {
    transition: none !important;
    animation: none !important;
  }
}

/* ================================================================
   v6 additions — honest globe tagline, HubSpot form integration,
   social bar adjustments after removing icons.
   ================================================================ */

/* Globe-area honest tagline that replaced the fake city pills */
.globe-honest-line {
  position: relative;
  z-index: 2;
  text-align: center;
  margin: 28px auto 0;
  max-width: 520px;
  padding: 14px 22px;
  font-size: 14.5px;
  color: var(--text-secondary);
  background: rgba(255, 255, 255, 0.35);
  border: 1px solid var(--border);
  border-radius: 100px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
[data-theme="dark"] .globe-honest-line {
  background: rgba(30, 41, 59, 0.4);
}

/* HubSpot form lives inside .contact-form-card.glass — make it inherit cleanly */
.hs-form-wrap {
  position: relative;
  z-index: 1;
}
.hs-form-frame {
  min-height: 320px;
}
/* HubSpot generates its own DOM; nudge field spacing + colors to match site */
.hs-form-wrap form,
.hs-form-wrap iframe {
  width: 100% !important;
  max-width: 100% !important;
  background: transparent !important;
}
.hs-form-wrap .hs-form-field,
.hs-form-wrap .hs-form-field label,
.hs-form-wrap .form-columns-1,
.hs-form-wrap .form-columns-2 {
  color: var(--text) !important;
  font-family: 'Inter', sans-serif !important;
}
.hs-form-wrap input[type="text"],
.hs-form-wrap input[type="email"],
.hs-form-wrap input[type="tel"],
.hs-form-wrap textarea,
.hs-form-wrap select {
  background: var(--bg-elev) !important;
  color: var(--text) !important;
  border: 1px solid var(--border-strong) !important;
  border-radius: 12px !important;
  padding: 12px 14px !important;
  font-family: inherit !important;
  font-size: 14.5px !important;
  width: 100% !important;
  margin-top: 6px !important;
}
.hs-form-wrap input:focus,
.hs-form-wrap textarea:focus,
.hs-form-wrap select:focus {
  outline: none !important;
  border-color: var(--accent) !important;
}
.hs-form-wrap .hs-button,
.hs-form-wrap input[type="submit"],
.hs-form-wrap button[type="submit"] {
  background: var(--accent) !important;
  color: white !important;
  border: none !important;
  border-radius: 12px !important;
  padding: 13px 22px !important;
  font-weight: 600 !important;
  font-size: 14.5px !important;
  cursor: pointer !important;
  transition: background 0.2s !important;
  margin-top: 6px !important;
}
.hs-form-wrap .hs-button:hover,
.hs-form-wrap input[type="submit"]:hover,
.hs-form-wrap button[type="submit"]:hover {
  background: var(--accent-hover, #d11d44) !important;
}
.hs-form-wrap .hs-error-msgs,
.hs-form-wrap .hs-error-msg {
  color: var(--accent) !important;
  font-size: 12.5px !important;
  list-style: none !important;
  padding-left: 0 !important;
  margin-top: 4px !important;
}

/* Social bar layout — after removing icons there are only 3 left,
   make them slightly larger and well-spaced */
.social-bar {
  gap: 10px;
}
.social-link {
  width: 40px;
  height: 40px;
}

/* HubSpot form loading placeholder — shown until the form populates */
.hs-form-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 280px;
}
.hs-form-loading-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent, #E8335A);
  animation: hsLoadingDot 1.4s ease-in-out infinite;
  opacity: 0.4;
}
.hs-form-loading-dot:nth-child(2) { animation-delay: 0.2s; }
.hs-form-loading-dot:nth-child(3) { animation-delay: 0.4s; }
@keyframes hsLoadingDot {
  0%, 60%, 100% { transform: translateY(0); opacity: 0.4; }
  30% { transform: translateY(-8px); opacity: 1; }
}
/* HubSpot replaces the inner contents once loaded, so the dots vanish naturally */

/* ================================================================
   v7 — Team function cards (Engineering / Growth & Comms / Operations)
   Three smaller cards sit below the founder card in a responsive row.
   ================================================================ */
.team-functions {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 2vw, 28px);
  max-width: 1100px;
  margin: 8px auto 0;
  align-items: stretch;
}

.team-fn-card {
  padding: 30px 28px;
  border-radius: var(--radius-lg, 24px);
  text-align: left;
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.team-fn-icon {
  width: 46px;
  height: 46px;
  border-radius: 12px;
  background: var(--accent-soft);
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 18px;
  position: relative;
  z-index: 2;
}

.team-fn-icon svg {
  width: 22px;
  height: 22px;
}

.team-fn-title {
  font-size: 18px;
  font-weight: 700;
  margin: 0 0 10px 0;
  color: var(--text);
  letter-spacing: -0.01em;
  position: relative;
  z-index: 2;
}

.team-fn-desc {
  font-size: 14px;
  color: var(--text-secondary);
  line-height: 1.65;
  margin: 0;
  position: relative;
  z-index: 2;
}

@media (max-width: 900px) {
  .team-functions {
    grid-template-columns: 1fr;
    gap: 16px;
    max-width: 480px;
  }
}


/* ================================================================
   v8 — Dark-mode fixes for the HubSpot embedded form,
   stronger glass opacity on contact cards in dark mode,
   dual-QR layout on the right info card.
   ================================================================ */

/* Aggressive readability for ALL HubSpot form text — adapts to theme */
.hs-form-wrap h1,
.hs-form-wrap h2,
.hs-form-wrap h3,
.hs-form-wrap h4,
.hs-form-wrap h5,
.hs-form-wrap h6,
.hs-form-wrap p,
.hs-form-wrap span,
.hs-form-wrap label,
.hs-form-wrap legend,
.hs-form-wrap .hs-richtext,
.hs-form-wrap .hs-richtext *,
.hs-form-wrap .hs-form-field > label,
.hs-form-wrap .hs-form-field label,
.hs-form-wrap .hs-form-field legend {
  color: var(--text) !important;
}

/* The required asterisk stays brand pink */
.hs-form-wrap .hs-form-required,
.hs-form-wrap label .hs-form-required {
  color: var(--accent) !important;
}

/* Inputs/textareas/selects — readable in both themes */
.hs-form-wrap input[type="text"],
.hs-form-wrap input[type="email"],
.hs-form-wrap input[type="tel"],
.hs-form-wrap input[type="number"],
.hs-form-wrap input[type="url"],
.hs-form-wrap textarea,
.hs-form-wrap select {
  color: var(--text) !important;
  background: var(--bg-elev) !important;
  border: 1px solid var(--border-strong) !important;
  border-radius: 12px !important;
  padding: 12px 14px !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 14.5px !important;
  width: 100% !important;
  margin-top: 6px !important;
}

.hs-form-wrap input:focus,
.hs-form-wrap textarea:focus,
.hs-form-wrap select:focus {
  outline: none !important;
  border-color: var(--accent) !important;
}

/* Placeholder readability in dark mode */
.hs-form-wrap input::placeholder,
.hs-form-wrap textarea::placeholder {
  color: var(--text-dim) !important;
  opacity: 1 !important;
}

/* Submit button — definitive brand-pink override
   covers all common HubSpot submit-button class permutations */
.hs-form-wrap .hs-button,
.hs-form-wrap input[type="submit"],
.hs-form-wrap button[type="submit"],
.hs-form-wrap .actions input,
.hs-form-wrap .hs_submit input {
  background: var(--accent) !important;
  background-image: none !important;
  background-color: var(--accent) !important;
  color: white !important;
  border: none !important;
  border-radius: 12px !important;
  padding: 13px 26px !important;
  font-weight: 600 !important;
  font-size: 14.5px !important;
  cursor: pointer !important;
  margin-top: 12px !important;
  transition: background 0.2s !important;
}

.hs-form-wrap .hs-button:hover,
.hs-form-wrap input[type="submit"]:hover,
.hs-form-wrap button[type="submit"]:hover {
  background: var(--accent-hover, #d11d44) !important;
  background-color: var(--accent-hover, #d11d44) !important;
}

/* Error messages — stay readable, brand pink */
.hs-form-wrap .hs-error-msg,
.hs-form-wrap .hs-error-msgs,
.hs-form-wrap .hs-error-msgs label,
.hs-form-wrap .hs-error-msgs li,
.hs-form-wrap .hs-main-font-element {
  color: var(--accent) !important;
  font-size: 12.5px !important;
}

/* Country/phone selector readability */
.hs-form-wrap select option,
.hs-form-wrap .iti__country-list {
  color: #0f172a !important;
  background: white !important;
}

/* Stronger glass opacity for contact cards in dark mode —
   prevents the animated agent background from bleeding through and hurting legibility */
[data-theme="dark"] .contact-info-card.glass {
  background: rgba(15, 25, 42, 0.82) !important;
  backdrop-filter: blur(18px) saturate(140%) !important;
  -webkit-backdrop-filter: blur(18px) saturate(140%) !important;
}

[data-theme="dark"] .contact-info-card.glass::after {
  opacity: 0.4 !important;
}

/* ============================================================
   v8 — Two-QR row layout in the info card
   ============================================================ */
.contact-qr-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-top: 8px;
}

.contact-qr-card {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.contact-qr-card img {
  width: 100%;
  max-width: 140px;
  aspect-ratio: 1 / 1;
  border-radius: 12px;
  padding: 6px;
  background: white;
  display: block;
}

.contact-qr-card .contact-qr-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--text-dim);
  margin-top: 10px;
  font-family: 'JetBrains Mono', monospace;
}

.contact-qr-card .contact-qr-handle {
  font-size: 12.5px;
  color: var(--text);
  margin-top: 3px;
  font-family: 'JetBrains Mono', monospace;
  word-break: break-all;
}

/* Hide the old single-QR block style (we replaced it with .contact-qr-row) */
.contact-qr {
  display: none !important;
}

@media (max-width: 540px) {
  .contact-qr-row {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .contact-qr-card img {
    max-width: 160px;
  }
}

/* ================================================================
   v15 contact fixes — direct card alignment + brighter form card.
   ================================================================ */

.contact-grid {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: clamp(18px, 2.4vw, 28px) !important;
  max-width: 760px !important;
  margin: 36px auto 0 !important;
  grid-template-columns: none !important;
}

.contact-form-card,
.contact-info-card {
  width: min(100%, 760px) !important;
  align-self: center !important;
  min-height: 0 !important;
}

.contact-info-card {
  order: 2 !important;
  align-items: center !important;
  justify-content: center !important;
  gap: clamp(14px, 1.6vw, 20px) !important;
  min-width: 0 !important;
  padding: clamp(26px, 3vw, 34px) !important;
  text-align: center !important;
}

.contact-form-card {
  order: 1 !important;
}

.contact-info-card > * {
  position: relative;
  z-index: 2;
}

.contact-info-item {
  width: min(100%, 520px) !important;
  min-width: 0 !important;
  display: grid !important;
  grid-template-columns: 38px minmax(0, 1fr) !important;
  align-items: center !important;
  justify-content: stretch !important;
  gap: 14px !important;
  text-align: left !important;
  margin: 0 auto !important;
}

.contact-info-item > div:last-child {
  min-width: 0 !important;
}

.contact-info-item h5 {
  margin: 0 0 4px !important;
}

.contact-info-item a,
.contact-info-item p {
  overflow-wrap: anywhere !important;
  margin: 0 !important;
}

.contact-line-group {
  display: grid !important;
  gap: 3px !important;
  min-width: 0 !important;
}

.contact-info-icon {
  align-self: center !important;
}

.contact-info-card .contact-qr-row {
  margin-top: clamp(6px, 1vw, 12px) !important;
  width: min(100%, 430px) !important;
  gap: clamp(12px, 2vw, 18px) !important;
}

@media (max-width: 900px) {
  .contact-grid {
    max-width: 680px !important;
  }
}

@media (max-width: 540px) {
  .contact-grid {
    gap: 18px !important;
    margin-top: 28px !important;
  }

  .contact-info-item {
    width: 100% !important;
  }
}

[data-theme="dark"] .contact-form-card.glass {
  background: rgba(238, 242, 255, 0.92) !important;
  color: #0f172a !important;
  box-shadow:
    inset 0 1px 1px rgba(255, 255, 255, 0.58),
    0 26px 70px rgba(0, 0, 0, 0.34) !important;
}

[data-theme="dark"] .contact-form-card.glass::before {
  background: linear-gradient(135deg,
    rgba(255, 255, 255, 0.78) 0%,
    rgba(255, 255, 255, 0.24) 34%,
    rgba(232, 51, 90, 0.10) 70%,
    rgba(255, 255, 255, 0.46) 100%) !important;
}

[data-theme="dark"] .contact-form-card.glass::after {
  opacity: 0.18 !important;
}

[data-theme="dark"] .contact-form-card iframe,
[data-theme="dark"] .contact-form-card .hs-form-frame {
  background: rgba(255, 255, 255, 0.98) !important;
  border-radius: 16px !important;
}

[data-theme="dark"] .contact-form-card,
[data-theme="dark"] .contact-form-card .hs-form-wrap,
[data-theme="dark"] .contact-form-card .hs-form-frame,
[data-theme="dark"] .contact-form-card #phasefloHubspotForm {
  --hsf-global__font-family: 'Inter', sans-serif;
  --hsf-global__color: #0f172a;
  --hsf-heading__color: #0f172a;
  --hsf-richtext__color: rgba(15, 23, 42, 0.82);
  --hsf-label__color: #0f172a;
  --hsf-field-label__color: #0f172a;
  --hsf-field-label__font-weight: 800;
  --hsf-field-description__color: rgba(15, 23, 42, 0.74);
  --hsf-field-footer__color: rgba(15, 23, 42, 0.70);
  --hsf-input__background-color: #ffffff;
  --hsf-input__color: #0f172a;
  --hsf-input__border-color: rgba(15, 23, 42, 0.18);
  --hsf-input__border-radius: 10px;
  --hsf-button__background-color: var(--accent, #E8335A);
  --hsf-button__border-color: var(--accent, #E8335A);
  --hsf-button__color: #ffffff;
  --hsf-button__font-weight: 800;
  --hsf-button__border-radius: 10px;
  --hsf-error__color: #ff6f91;
  color: #0f172a !important;
}

[data-theme="dark"] .contact-form-card h1,
[data-theme="dark"] .contact-form-card h2,
[data-theme="dark"] .contact-form-card h3,
[data-theme="dark"] .contact-form-card h4,
[data-theme="dark"] .contact-form-card h5,
[data-theme="dark"] .contact-form-card h6,
[data-theme="dark"] .contact-form-card p,
[data-theme="dark"] .contact-form-card span,
[data-theme="dark"] .contact-form-card label,
[data-theme="dark"] .contact-form-card legend,
[data-theme="dark"] .contact-form-card .hs-form-wrap,
[data-theme="dark"] .contact-form-card .hs-form-wrap *,
[data-theme="dark"] .contact-form-card .hs-richtext,
[data-theme="dark"] .contact-form-card .hs-richtext *,
[data-theme="dark"] .contact-form-card .hs-form-field,
[data-theme="dark"] .contact-form-card .hs-form-field > label,
[data-theme="dark"] .contact-form-card .hs-form-field label,
[data-theme="dark"] .contact-form-card .hs-main-font-element {
  color: #0f172a !important;
  font-weight: 800 !important;
}

[data-theme="dark"] .contact-form-card .hs-richtext p,
[data-theme="dark"] .contact-form-card .hs-form-field > label span:not(.hs-form-required) {
  color: rgba(15, 23, 42, 0.82) !important;
}

[data-theme="dark"] .contact-form-card .hs-form-required,
[data-theme="dark"] .contact-form-card label .hs-form-required {
  color: var(--accent, #E8335A) !important;
  font-weight: 900 !important;
}

[data-theme="dark"] .contact-form-card input[type="text"],
[data-theme="dark"] .contact-form-card input[type="email"],
[data-theme="dark"] .contact-form-card input[type="tel"],
[data-theme="dark"] .contact-form-card input[type="number"],
[data-theme="dark"] .contact-form-card input[type="url"],
[data-theme="dark"] .contact-form-card textarea,
[data-theme="dark"] .contact-form-card select {
  background: #ffffff !important;
  color: #0f172a !important;
  border-color: rgba(15, 23, 42, 0.18) !important;
}

[data-theme="dark"] .contact-form-card input::placeholder,
[data-theme="dark"] .contact-form-card textarea::placeholder {
  color: rgba(15, 23, 42, 0.58) !important;
  opacity: 1 !important;
}

[data-theme="dark"] .contact-form-card .hs-button,
[data-theme="dark"] .contact-form-card input[type="submit"],
[data-theme="dark"] .contact-form-card button[type="submit"],
[data-theme="dark"] .contact-form-card .actions input,
[data-theme="dark"] .contact-form-card .hs_submit input {
  background: var(--accent, #E8335A) !important;
  background-color: var(--accent, #E8335A) !important;
  background-image: none !important;
  border-color: var(--accent, #E8335A) !important;
  color: #ffffff !important;
  font-weight: 800 !important;
}

[data-theme="dark"] .contact-form-card .hs-button:hover,
[data-theme="dark"] .contact-form-card input[type="submit"]:hover,
[data-theme="dark"] .contact-form-card button[type="submit"]:hover {
  background: var(--accent-hover, #D11D44) !important;
  background-color: var(--accent-hover, #D11D44) !important;
}

[data-theme="dark"] .contact-info-card,
[data-theme="dark"] .contact-info-card *,
[data-theme="dark"] .contact-info-card h5,
[data-theme="dark"] .contact-info-card p,
[data-theme="dark"] .contact-info-card a,
[data-theme="dark"] .contact-info-card span,
[data-theme="dark"] .contact-info-card div,
[data-theme="dark"] .contact-info-card .contact-qr-label,
[data-theme="dark"] .contact-info-card .contact-qr-handle {
  color: #ffffff !important;
  opacity: 1 !important;
}

[data-theme="dark"] .contact-info-card h5,
[data-theme="dark"] .contact-info-card .contact-qr-label {
  font-weight: 800 !important;
}

[data-theme="dark"] .contact-info-card .contact-info-icon {
  color: var(--accent, #E8335A) !important;
}

[data-theme="dark"] .contact-info-card .contact-info-icon svg {
  color: var(--accent, #E8335A) !important;
  stroke: currentColor !important;
}
