/* ==========================================================================
   TrueCraft — Floating glass header (site-wide)
   Floating rounded bar · adaptive dark/light · responsive drawer
   ========================================================================== */

:root {
  --tc-header-font: "Funnel Display", system-ui, sans-serif;
  --tc-header-ease: cubic-bezier(0.22, 1, 0.36, 1);
  --tc-header-soft-ease: cubic-bezier(0.16, 1, 0.3, 1);
  --tc-header-offset: 72px;
  --tc-shell-max: 1180px;
  --tc-shell-height: 56px;
  --tc-shell-radius: 14px;
  --tc-float-pad-x: 24px;
  --tc-float-pad-top: 16px;
  --tc-glass-dark: rgba(8, 8, 10, 0.32);
  --tc-glass-dark-scrolled: rgba(8, 8, 10, 0.52);
  --tc-glass-dark-border: rgba(255, 255, 255, 0.1);
  --tc-glass-light: rgba(255, 255, 255, 0.42);
  --tc-glass-light-scrolled: rgba(255, 255, 255, 0.58);
  --tc-glass-light-border: rgba(255, 255, 255, 0.22);
}

/* ─── Shell ─── */
.tc-header {
  position: fixed;
  inset: 0 0 auto;
  z-index: 400;
  width: 100%;
  padding: var(--tc-float-pad-top) var(--tc-float-pad-x) 0;
  pointer-events: none;
}

.tc-header__shell {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  width: min(var(--tc-shell-max), 100%);
  height: var(--tc-shell-height);
  min-height: var(--tc-shell-height);
  max-height: var(--tc-shell-height);
  margin-inline: auto;
  padding: 0 6px 0 18px;
  border-radius: var(--tc-shell-radius);
  pointer-events: auto;
  box-sizing: border-box;
  backdrop-filter: blur(24px) saturate(1.25);
  -webkit-backdrop-filter: blur(24px) saturate(1.25);
  transition:
    background 0.5s var(--tc-header-soft-ease),
    border-color 0.5s var(--tc-header-soft-ease),
    box-shadow 0.5s var(--tc-header-soft-ease),
    backdrop-filter 0.5s var(--tc-header-soft-ease);
}

/* Light pages / light sections — default for data-header-default="light" */
.tc-header[data-header-default="light"] .tc-header__shell,
.tc-header.is-over-light .tc-header__shell {
  background: var(--tc-glass-light);
  border: 1px solid var(--tc-glass-light-border);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.35) inset,
    0 8px 32px rgba(12, 12, 12, 0.06);
}

.tc-header[data-header-default="light"].is-scrolled .tc-header__shell,
.tc-header.is-over-light.is-scrolled .tc-header__shell {
  background: var(--tc-glass-light-scrolled);
  border-color: rgba(255, 255, 255, 0.32);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.45) inset,
    0 12px 36px rgba(12, 12, 12, 0.08);
}

/* Dark pages / dark sections */
.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-header__shell,
.tc-header.is-over-dark .tc-header__shell {
  background: var(--tc-glass-dark);
  border: 1px solid var(--tc-glass-dark-border);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.06) inset,
    0 8px 32px rgba(0, 0, 0, 0.12);
}

.tc-header[data-header-default="dark"]:not(.is-over-light).is-scrolled .tc-header__shell,
.tc-header.is-over-dark.is-scrolled .tc-header__shell {
  background: var(--tc-glass-dark-scrolled);
  border-color: rgba(255, 255, 255, 0.12);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.08) inset,
    0 12px 40px rgba(0, 0, 0, 0.18);
}

.tc-header[data-header-default="dark"].is-over-light.is-scrolled .tc-header__shell {
  background: var(--tc-glass-light-scrolled);
  border-color: rgba(255, 255, 255, 0.28);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.4) inset,
    0 12px 36px rgba(12, 12, 12, 0.08);
}

/* ─── Logo ─── */
.tc-header__logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  line-height: 0;
}

.tc-header__logo .hr-logo__img {
  display: block;
  height: 26px;
  width: auto;
  max-width: 168px;
  object-fit: contain;
  object-position: left center;
}

.tc-header__logo .hr-logo__img--light {
  display: block;
}

.tc-header__logo .hr-logo__img--dark {
  display: none;
}

.tc-header.is-over-dark .tc-header__logo .hr-logo__img--light {
  display: none;
}

.tc-header.is-over-dark .tc-header__logo .hr-logo__img--dark {
  display: block;
}

/* Text fallback logo (service subpages) */
.tc-header__logo-text {
  font-family: var(--tc-header-font);
  font-size: 1.05rem;
  font-weight: 600;
  letter-spacing: -0.03em;
  color: #0c0c0c;
  transition: color 0.35s var(--tc-header-ease);
}

.tc-header__logo-text em {
  font-style: normal;
  color: #6e6e6e;
}

.tc-header.is-over-dark .tc-header__logo-text {
  color: #fff;
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.4);
}

.tc-header.is-over-dark .tc-header__logo-text em {
  color: rgba(255, 255, 255, 0.55);
}

/* ─── Desktop nav ─── */
.tc-header__nav {
  display: flex;
  align-items: center;
  gap: clamp(1rem, 2vw, 2rem);
  min-width: 0;
  flex: 1 1 auto;
  justify-content: center;
}

.tc-header__nav a {
  position: relative;
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  font-family: var(--tc-header-font);
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: rgba(12, 12, 12, 0.72);
  text-decoration: none;
  white-space: nowrap;
  transition: color 0.25s var(--tc-header-ease);
}

.tc-header__nav > a::after,
.tc-nav-dropdown__toggle::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -5px;
  height: 2px;
  border-radius: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: center;
  transition: transform 0.25s var(--tc-header-ease);
  opacity: 0.9;
}

.tc-header__nav > a:hover::after,
.tc-header__nav > a:focus-visible::after,
.tc-header__nav > a[aria-current="page"]::after,
.tc-nav-dropdown__toggle:hover::after,
.tc-nav-dropdown__toggle:focus-visible::after,
.tc-nav-dropdown.is-active .tc-nav-dropdown__toggle::after,
.tc-nav-dropdown__toggle[aria-current="page"]::after {
  transform: scaleX(1);
}

/* ─── Desktop services dropdown ─── */
.tc-nav-dropdown {
  position: relative;
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
}

.tc-nav-dropdown__toggle {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0;
  border: none;
  background: none;
  font-family: var(--tc-header-font);
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: rgba(12, 12, 12, 0.72);
  cursor: pointer;
  white-space: nowrap;
  transition: color 0.25s var(--tc-header-ease);
}

.tc-nav-dropdown__chevron {
  width: 6px;
  height: 6px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg) translateY(-2px);
  transition: transform 0.25s var(--tc-header-ease);
  opacity: 0.65;
}

.tc-nav-dropdown__toggle[aria-expanded="true"] .tc-nav-dropdown__chevron,
.tc-nav-dropdown.is-open .tc-nav-dropdown__chevron {
  transform: rotate(-135deg) translateY(-1px);
}

.tc-nav-dropdown__menu {
  position: absolute;
  top: calc(100% + 14px);
  left: 50%;
  z-index: 420;
  min-width: 220px;
  padding: 0.4rem;
  border-radius: 12px;
  transform: translateX(-50%);
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(12, 12, 12, 0.08);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.8) inset,
    0 16px 40px rgba(12, 12, 12, 0.12);
  backdrop-filter: blur(20px) saturate(1.2);
  -webkit-backdrop-filter: blur(20px) saturate(1.2);
}

.tc-nav-dropdown__menu[hidden] {
  display: none;
}

.tc-nav-dropdown__item,
.tc-nav-dropdown__all {
  display: block;
  padding: 0.55rem 0.7rem;
  border-radius: 8px;
  font-family: var(--tc-header-font);
  font-size: 0.8125rem;
  font-weight: 500;
  color: rgba(12, 12, 12, 0.72);
  text-decoration: none;
  transition:
    background 0.2s var(--tc-header-ease),
    color 0.2s var(--tc-header-ease);
}

.tc-nav-dropdown__item:hover,
.tc-nav-dropdown__all:hover,
.tc-nav-dropdown__item:focus-visible,
.tc-nav-dropdown__all:focus-visible,
.tc-nav-dropdown__item[aria-current="page"],
.tc-nav-dropdown__all[aria-current="page"] {
  background: rgba(12, 12, 12, 0.05);
  color: #0c0c0c;
}

.tc-nav-dropdown__all {
  margin-top: 0.25rem;
  padding-top: 0.65rem;
  border-top: 1px solid rgba(12, 12, 12, 0.06);
  font-weight: 600;
}

.tc-header[data-header-default="light"] .tc-nav-dropdown__toggle,
.tc-header.is-over-light .tc-nav-dropdown__toggle {
  color: rgba(12, 12, 12, 0.72);
}

.tc-header[data-header-default="light"] .tc-nav-dropdown__toggle:hover,
.tc-header[data-header-default="light"] .tc-nav-dropdown__toggle:focus-visible,
.tc-header[data-header-default="light"] .tc-nav-dropdown.is-active .tc-nav-dropdown__toggle,
.tc-header[data-header-default="light"] .tc-nav-dropdown__toggle[aria-current="page"],
.tc-header.is-over-light .tc-nav-dropdown__toggle:hover,
.tc-header.is-over-light .tc-nav-dropdown__toggle:focus-visible,
.tc-header.is-over-light .tc-nav-dropdown.is-active .tc-nav-dropdown__toggle,
.tc-header.is-over-light .tc-nav-dropdown__toggle[aria-current="page"] {
  color: #0c0c0c;
}

.tc-header.is-over-dark .tc-nav-dropdown__toggle {
  color: rgba(255, 255, 255, 0.82);
  text-shadow: 0 1px 6px rgba(0, 0, 0, 0.4);
}

.tc-header.is-over-dark .tc-nav-dropdown__toggle:hover,
.tc-header.is-over-dark .tc-nav-dropdown__toggle:focus-visible,
.tc-header.is-over-dark .tc-nav-dropdown.is-active .tc-nav-dropdown__toggle,
.tc-header.is-over-dark .tc-nav-dropdown__toggle[aria-current="page"],
.tc-header.is-over-dark .tc-nav-dropdown__toggle[aria-expanded="true"] {
  color: #fff;
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.5);
}

.tc-header.is-over-dark .tc-nav-dropdown__menu {
  background: rgba(12, 10, 18, 0.94);
  border-color: rgba(255, 255, 255, 0.1);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.06) inset,
    0 16px 40px rgba(0, 0, 0, 0.35);
}

.tc-header.is-over-dark .tc-nav-dropdown__item,
.tc-header.is-over-dark .tc-nav-dropdown__all {
  color: rgba(255, 255, 255, 0.78);
}

.tc-header.is-over-dark .tc-nav-dropdown__item:hover,
.tc-header.is-over-dark .tc-nav-dropdown__all:hover,
.tc-header.is-over-dark .tc-nav-dropdown__item:focus-visible,
.tc-header.is-over-dark .tc-nav-dropdown__all:focus-visible,
.tc-header.is-over-dark .tc-nav-dropdown__item[aria-current="page"],
.tc-header.is-over-dark .tc-nav-dropdown__all[aria-current="page"] {
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
}

.tc-header.is-over-dark .tc-nav-dropdown__all {
  border-top-color: rgba(255, 255, 255, 0.08);
}

.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-nav-dropdown__toggle {
  color: rgba(255, 255, 255, 0.82);
  text-shadow: 0 1px 6px rgba(0, 0, 0, 0.35);
}

.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-nav-dropdown__toggle:hover,
.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-nav-dropdown__toggle:focus-visible,
.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-nav-dropdown.is-active .tc-nav-dropdown__toggle,
.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-nav-dropdown__toggle[aria-current="page"],
.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-nav-dropdown__toggle[aria-expanded="true"] {
  color: #fff;
}

.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-nav-dropdown__menu {
  background: rgba(12, 10, 18, 0.94);
  border-color: rgba(255, 255, 255, 0.1);
}

.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-nav-dropdown__item,
.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-nav-dropdown__all {
  color: rgba(255, 255, 255, 0.78);
}

.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-nav-dropdown__item:hover,
.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-nav-dropdown__all:hover,
.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-nav-dropdown__item[aria-current="page"],
.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-nav-dropdown__all[aria-current="page"] {
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
}

.tc-header[data-header-default="light"] .tc-header__nav a,
.tc-header.is-over-light .tc-header__nav a {
  color: rgba(12, 12, 12, 0.72);
}

.tc-header[data-header-default="light"] .tc-header__nav a:hover,
.tc-header[data-header-default="light"] .tc-header__nav a:focus-visible,
.tc-header[data-header-default="light"] .tc-header__nav a[aria-current="page"],
.tc-header.is-over-light .tc-header__nav a:hover,
.tc-header.is-over-light .tc-header__nav a:focus-visible,
.tc-header.is-over-light .tc-header__nav a[aria-current="page"] {
  color: #0c0c0c;
}

.tc-header__nav a:hover,
.tc-header__nav a:focus-visible {
  color: #0c0c0c;
}

.tc-header.is-over-dark .tc-header__nav a {
  color: rgba(255, 255, 255, 0.82);
  text-shadow: 0 1px 6px rgba(0, 0, 0, 0.4);
}

.tc-header.is-over-dark .tc-header__nav a:hover,
.tc-header.is-over-dark .tc-header__nav a:focus-visible,
.tc-header.is-over-dark .tc-header__nav a[aria-current="page"] {
  color: #fff;
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.5);
}

/* ─── Actions ─── */
.tc-header__actions {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  flex-shrink: 0;
}

.tc-header__icon-link {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 10px;
  color: rgba(12, 12, 12, 0.55);
  border: 1px solid rgba(12, 12, 12, 0.08);
  transition:
    color 0.25s var(--tc-header-ease),
    background 0.25s var(--tc-header-ease),
    border-color 0.25s var(--tc-header-ease);
}

.tc-header__icon-link svg {
  width: 16px;
  height: 16px;
}

.tc-header__icon-link:hover,
.tc-header__icon-link:focus-visible {
  color: #0c0c0c;
  background: rgba(12, 12, 12, 0.04);
  border-color: rgba(12, 12, 12, 0.12);
}

.tc-header[data-header-default="light"] .tc-header__icon-link,
.tc-header.is-over-light .tc-header__icon-link {
  color: rgba(12, 12, 12, 0.62);
  border-color: rgba(12, 12, 12, 0.08);
  background: rgba(255, 255, 255, 0.22);
}

.tc-header[data-header-default="light"] .tc-header__icon-link:hover,
.tc-header[data-header-default="light"] .tc-header__icon-link:focus-visible,
.tc-header.is-over-light .tc-header__icon-link:hover,
.tc-header.is-over-light .tc-header__icon-link:focus-visible {
  color: #0c0c0c;
  background: rgba(12, 12, 12, 0.05);
  border-color: rgba(12, 12, 12, 0.16);
}

.tc-header[data-header-default="light"] .tc-header__toggle,
.tc-header[data-header-default="light"] .hamburger,
.tc-header.is-over-light .tc-header__toggle,
.tc-header.is-over-light .hamburger {
  border-color: rgba(12, 12, 12, 0.12);
}

.tc-header[data-header-default="light"] .tc-header__toggle span,
.tc-header[data-header-default="light"] .hamburger span,
.tc-header.is-over-light .tc-header__toggle span,
.tc-header.is-over-light .hamburger span {
  background: #0c0c0c;
}

.tc-header[data-header-default="light"] .tc-header__cta,
.tc-header.is-over-light .tc-header__cta {
  color: #fff;
  background: rgba(12, 12, 12, 0.82);
  border-color: rgba(12, 12, 12, 0.5);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.tc-header.is-over-dark .tc-header__icon-link {
  color: rgba(255, 255, 255, 0.78);
  border-color: rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.04);
}

.tc-header.is-over-dark .tc-header__icon-link:hover,
.tc-header.is-over-dark .tc-header__icon-link:focus-visible {
  color: #fff;
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.2);
}

.tc-header__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  min-height: 38px;
  padding: 0 1rem;
  border-radius: 10px;
  font-family: var(--tc-header-font);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-decoration: none;
  color: #fff;
  background: #0c0c0c;
  border: 1px solid #0c0c0c;
  transition:
    background 0.25s var(--tc-header-ease),
    color 0.25s var(--tc-header-ease),
    border-color 0.25s var(--tc-header-ease),
    transform 0.25s var(--tc-header-ease);
}

.tc-header__cta:hover,
.tc-header__cta:focus-visible {
  background: #2a2a2a;
  border-color: #2a2a2a;
  transform: translateY(-1px);
}

.tc-header.is-over-dark .tc-header__cta {
  color: #0c0c0c;
  background: rgba(255, 255, 255, 0.92);
  border-color: rgba(255, 255, 255, 0.55);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.tc-header.is-over-dark .tc-header__cta:hover,
.tc-header.is-over-dark .tc-header__cta:focus-visible {
  background: rgba(255, 255, 255, 0.98);
}

.tc-header__cta-arrow {
  font-size: 0.9em;
  transition: transform 0.25s var(--tc-header-ease);
}

.tc-header__cta:hover .tc-header__cta-arrow,
.tc-header__cta:focus-visible .tc-header__cta-arrow {
  transform: translateX(2px);
}

/* ─── Hamburger ─── */
.tc-header__toggle,
.tc-header .hamburger {
  display: none;
  width: 38px;
  height: 38px;
  padding: 0;
  border: 1px solid rgba(12, 12, 12, 0.08);
  border-radius: 10px;
  background: transparent;
  cursor: pointer;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
  transition: border-color 0.3s, background 0.3s;
}

.tc-header__toggle span,
.tc-header .hamburger span {
  display: block;
  width: 16px;
  height: 1.5px;
  background: #0c0c0c;
  transition: transform 0.3s var(--tc-header-ease), background 0.3s;
}

.tc-header.is-over-dark .tc-header__toggle,
.tc-header.is-over-dark .hamburger {
  border-color: rgba(255, 255, 255, 0.18);
}

.tc-header.is-over-dark .tc-header__toggle span,
.tc-header.is-over-dark .hamburger span {
  background: #fff;
}

.tc-header__toggle.is-open span:first-child,
.tc-header .hamburger.is-open span:first-child {
  transform: translateY(3.25px) rotate(45deg);
}

.tc-header__toggle.is-open span:last-child,
.tc-header .hamburger.is-open span:last-child {
  transform: translateY(-3.25px) rotate(-45deg);
}

/* ─── Mobile drawer — unified clean / light / shiny (same on every page) ─── */
.tc-header__backdrop,
#menuBackdrop.tc-header__backdrop {
  position: fixed;
  inset: 0;
  z-index: 380;
  background: rgba(10, 12, 20, 0.36);
  backdrop-filter: blur(6px) saturate(1.1);
  -webkit-backdrop-filter: blur(6px) saturate(1.1);
  pointer-events: auto;
}

.tc-header__mobile,
.tc-header .mobile-menu {
  position: fixed;
  inset: calc(var(--tc-header-offset, 88px) + 8px) clamp(12px, 3vw, 20px) auto;
  z-index: 390;
  max-height: calc(100dvh - var(--tc-header-offset, 88px) - 24px);
  overflow-y: auto;
  padding: 12px 12px 14px;
  border-radius: 24px;
  background:
    radial-gradient(135% 95% at 50% -20%, rgba(255, 255, 255, 0.96), rgba(255, 255, 255, 0) 62%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.9) 0%, rgba(246, 247, 251, 0.82) 100%);
  backdrop-filter: blur(34px) saturate(1.8);
  -webkit-backdrop-filter: blur(34px) saturate(1.8);
  border: 1px solid rgba(255, 255, 255, 0.75);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.95) inset,
    0 0 0 1px rgba(15, 17, 26, 0.04),
    0 26px 60px -18px rgba(15, 17, 26, 0.32),
    0 8px 24px -12px rgba(15, 17, 26, 0.18);
  transform: translateY(-12px) scale(0.97);
  opacity: 0;
  pointer-events: none;
  transition:
    opacity 0.34s var(--tc-header-soft-ease),
    transform 0.34s var(--tc-header-soft-ease);
}

/* Keep the drawer light and shiny no matter the page tone or theme. */
.tc-header.is-over-light .tc-header__mobile,
.tc-header.is-over-light .mobile-menu,
.tc-header.is-over-dark .tc-header__mobile,
.tc-header.is-over-dark .mobile-menu,
.tc-header[data-header-default="dark"] .tc-header__mobile,
.tc-header[data-header-default="dark"] .mobile-menu,
body.home-redesign .tc-header__mobile.mobile-menu,
body.theme-glow .tc-header__mobile.mobile-menu {
  background:
    radial-gradient(135% 95% at 50% -20%, rgba(255, 255, 255, 0.96), rgba(255, 255, 255, 0) 62%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.9) 0%, rgba(246, 247, 251, 0.82) 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.75) !important;
  backdrop-filter: blur(34px) saturate(1.8) !important;
  -webkit-backdrop-filter: blur(34px) saturate(1.8) !important;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.95) inset,
    0 0 0 1px rgba(15, 17, 26, 0.04),
    0 26px 60px -18px rgba(15, 17, 26, 0.32),
    0 8px 24px -12px rgba(15, 17, 26, 0.18) !important;
}

.tc-header__mobile.is-open,
.tc-header .mobile-menu.is-open {
  transform: none;
  opacity: 1;
  pointer-events: auto;
}

/* Nav rows */
.tc-header__mobile > a,
.tc-header .mobile-menu > a,
body.home-redesign .tc-header__mobile.mobile-menu > a,
body.mn-page .tc-header__mobile.mobile-menu > a {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.72rem 0.8rem;
  border: none !important;
  border-radius: 13px;
  font-family: var(--tc-header-font) !important;
  font-size: 1.0625rem !important;
  font-weight: 500;
  letter-spacing: -0.02em !important;
  color: rgba(15, 17, 26, 0.82) !important;
  text-decoration: none;
  transition:
    background 0.2s var(--tc-header-ease),
    color 0.2s var(--tc-header-ease);
}

.tc-header__mobile > a:hover,
.tc-header__mobile > a:focus-visible,
.tc-header .mobile-menu > a:hover,
body.home-redesign .tc-header__mobile.mobile-menu > a:hover {
  background: rgba(15, 17, 26, 0.05) !important;
  color: #0f111a !important;
}

.tc-header__mobile > a[aria-current="page"],
.tc-header .mobile-menu > a[aria-current="page"],
body.home-redesign .tc-header__mobile.mobile-menu > a[aria-current="page"] {
  color: #0f111a !important;
  font-weight: 600;
  background: rgba(15, 17, 26, 0.06) !important;
}

/* Services group */
.tc-header__mobile .mobile-menu__group {
  border: none;
  margin: 2px 0;
}

.tc-header__mobile .mobile-menu__subtoggle,
body.home-redesign .tc-header__mobile .mobile-menu__subtoggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 0.72rem 0.8rem;
  border: none;
  border-radius: 13px;
  background: none;
  font-family: var(--tc-header-font) !important;
  font-size: 1.0625rem !important;
  font-weight: 500;
  letter-spacing: -0.02em !important;
  color: rgba(15, 17, 26, 0.82) !important;
  cursor: pointer;
  transition: background 0.2s var(--tc-header-ease), color 0.2s var(--tc-header-ease);
}

.tc-header__mobile .mobile-menu__subtoggle:hover {
  background: rgba(15, 17, 26, 0.05) !important;
  color: #0f111a !important;
}

.tc-header__mobile .mobile-menu__group.is-active > .mobile-menu__subtoggle {
  color: #0f111a !important;
  font-weight: 600;
}

.tc-header__mobile .mobile-menu__sub {
  padding: 0.15rem 0 0.4rem 0.6rem;
  margin: 0 0.2rem 0.2rem;
}

.tc-header__mobile .mobile-menu__sub a,
body.home-redesign .tc-header__mobile .mobile-menu__sub a,
body.mn-page .tc-header__mobile .mobile-menu__sub a {
  display: block;
  padding: 0.5rem 0.6rem;
  border: none !important;
  border-radius: 10px;
  font-family: var(--tc-header-font) !important;
  font-size: 0.9375rem !important;
  font-weight: 500;
  letter-spacing: 0 !important;
  color: rgba(15, 17, 26, 0.58) !important;
  text-decoration: none;
  transition: background 0.18s, color 0.18s;
}

.tc-header__mobile .mobile-menu__sub a:hover,
body.home-redesign .tc-header__mobile .mobile-menu__sub a:hover {
  background: rgba(15, 17, 26, 0.05) !important;
  color: #0f111a !important;
}

.tc-header__mobile .mobile-menu__sub a[aria-current="page"] {
  color: #0f111a !important;
  font-weight: 600;
}

/* Actions area — divider + stacked buttons */
.tc-header__mobile .mobile-menu__actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 12px;
  padding-top: 14px;
  border-top: 1px solid rgba(15, 17, 26, 0.08);
}

/* Schedule a call — shiny icon card */
.tc-header__mobile .mobile-menu__schedule,
.tc-header .mobile-menu .mobile-menu__schedule,
body.mn-page .tc-header__mobile .mobile-menu__schedule,
body.home-redesign .tc-header__mobile .mobile-menu__schedule {
  display: flex !important;
  align-items: center;
  gap: 0.8rem;
  padding: 0.7rem 0.85rem !important;
  border: 1px solid rgba(15, 17, 26, 0.09) !important;
  border-radius: 16px !important;
  font-family: var(--tc-header-font) !important;
  font-size: 1rem !important;
  letter-spacing: -0.01em !important;
  text-decoration: none;
  color: #0f111a !important;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(248, 249, 252, 0.78)) !important;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.9) inset,
    0 6px 18px -8px rgba(15, 17, 26, 0.16);
  transition: transform 0.2s var(--tc-header-ease), box-shadow 0.2s var(--tc-header-ease);
}

.tc-header__mobile .mobile-menu__schedule:hover,
.tc-header__mobile .mobile-menu__schedule:focus-visible {
  transform: translateY(-1px);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.95) inset,
    0 12px 26px -10px rgba(15, 17, 26, 0.24);
}

.tc-header__mobile .mobile-menu__schedule-icon {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  flex-shrink: 0;
  border-radius: 13px;
  color: #fff;
  background: linear-gradient(180deg, #2c2c34, #0f111a);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.2) inset,
    0 6px 14px -6px rgba(15, 17, 26, 0.5);
}

.tc-header__mobile .mobile-menu__schedule-icon svg {
  width: 19px;
  height: 19px;
}

.tc-header__mobile .mobile-menu__schedule-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1 1 auto;
  min-width: 0;
}

.tc-header__mobile .mobile-menu__schedule-title {
  font-family: var(--tc-header-font);
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: #0f111a;
}

.tc-header__mobile .mobile-menu__schedule-sub {
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0;
  color: rgba(15, 17, 26, 0.5);
}

.tc-header__mobile .mobile-menu__schedule-arrow {
  flex-shrink: 0;
  font-size: 1.05rem;
  color: rgba(15, 17, 26, 0.4);
  transition: transform 0.2s var(--tc-header-ease);
}

.tc-header__mobile .mobile-menu__schedule:hover .mobile-menu__schedule-arrow {
  transform: translateX(3px);
  color: rgba(15, 17, 26, 0.7);
}

/* Primary CTA — consistent charcoal + gloss (overrides legacy theme colors) */
.tc-header__mobile .mobile-menu__cta,
.tc-header .mobile-menu .mobile-menu__cta,
body.home-redesign .tc-header__mobile .mobile-menu__cta,
body.theme-glow .tc-header__mobile .mobile-menu__cta,
body.theme-enterprise .tc-header__mobile .mobile-menu__cta {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  width: 100%;
  margin: 0 !important;
  padding: 0.95rem 1.25rem !important;
  border-radius: 16px !important;
  font-family: var(--tc-header-font) !important;
  font-size: 0.95rem !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  color: #fff !important;
  background: linear-gradient(180deg, #2c2c34 0%, #0f111a 100%) !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.16) inset,
    0 12px 26px -10px rgba(15, 17, 26, 0.4) !important;
  transition: transform 0.2s var(--tc-header-ease), box-shadow 0.2s var(--tc-header-ease) !important;
}

.tc-header__mobile .mobile-menu__cta:hover,
.tc-header__mobile .mobile-menu__cta:focus-visible {
  transform: translateY(-1px);
}

/* ─── Page offset ─── */
body:has(.tc-header) main#main,
body:has(.tc-header) #main {
  scroll-margin-top: var(--tc-header-offset, 88px);
}

body.mn-page:has(.tc-header) main#main {
  padding-top: var(--tc-header-offset, 88px);
}

body.site-menu-open {
  overflow: hidden;
}

/* ─── Responsive ─── */
@media (max-width: 960px) {
  :root {
    --tc-float-pad-x: 16px;
  }

  .tc-header__nav {
    display: none;
  }

  .tc-header__icon-link {
    display: none;
  }

  .tc-header__toggle,
  .tc-header .hamburger {
    display: flex;
  }

  .tc-header__cta span:not(.tc-header__cta-arrow) {
    display: none;
  }

  .tc-header__cta {
    width: 38px;
    height: 38px;
    min-height: 38px;
    padding: 0;
    justify-content: center;
  }

  .tc-header__cta-arrow {
    margin: 0;
  }
}

@media (max-width: 480px) {
  :root {
    --tc-float-pad-x: 12px;
    --tc-shell-height: 52px;
    --tc-shell-radius: 12px;
  }

  .tc-header__shell {
    padding-left: 14px;
  }

  .tc-header__cta {
    display: none;
  }
}

/* ─── Lock dimensions — block leaks from minimal.css / homepage-redesign.css ─── */
/* Default tone before JS runs (matches data-header-default on each page) */
.tc-header[data-header-default="light"] .hr-logo__img--light {
  display: block !important;
}

.tc-header[data-header-default="light"] .hr-logo__img--dark {
  display: none !important;
}

.tc-header[data-header-default="dark"]:not(.is-over-light) .hr-logo__img--light {
  display: none !important;
}

.tc-header[data-header-default="dark"]:not(.is-over-light) .hr-logo__img--dark {
  display: block !important;
}

.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-header__shell {
  background: var(--tc-glass-dark);
  border-color: var(--tc-glass-dark-border);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.06) inset,
    0 8px 32px rgba(0, 0, 0, 0.12);
}

.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-header__nav a,
.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-header__nav a[aria-current="page"] {
  color: rgba(255, 255, 255, 0.82);
  text-shadow: 0 1px 6px rgba(0, 0, 0, 0.35);
}

.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-header__nav a:hover,
.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-header__nav a:focus-visible,
.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-header__nav a[aria-current="page"]:hover {
  color: #fff;
}

.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-header__toggle,
.tc-header[data-header-default="dark"]:not(.is-over-light) .hamburger {
  border-color: rgba(255, 255, 255, 0.16);
}

.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-header__toggle span,
.tc-header[data-header-default="dark"]:not(.is-over-light) .hamburger span {
  background: #fff;
}

.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-header__icon-link {
  color: rgba(255, 255, 255, 0.78);
  border-color: rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.04);
}

.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-header__cta {
  color: #0c0c0c;
  background: rgba(255, 255, 255, 0.92);
  border-color: rgba(255, 255, 255, 0.55);
}

body.mn-page .tc-header .hr-logo__img,
body.home-redesign .tc-header .hr-logo__img,
body.theme-glow .tc-header .hr-logo__img,
.tc-header__logo .hr-logo__img {
  height: 26px !important;
  max-width: 168px !important;
}

body.mn-page .tc-header[data-header-default="light"] .hr-logo__img--light,
body.mn-page .tc-header.is-over-light .hr-logo__img--light,
body.home-redesign .tc-header.is-over-light .hr-logo__img--light,
.tc-header.is-over-light .hr-logo__img--light {
  display: block !important;
}

body.mn-page .tc-header[data-header-default="light"] .hr-logo__img--dark,
body.mn-page .tc-header.is-over-light .hr-logo__img--dark,
body.home-redesign .tc-header.is-over-light .hr-logo__img--dark,
.tc-header.is-over-light .hr-logo__img--dark {
  display: none !important;
}

body.mn-page .tc-header.is-over-dark .hr-logo__img--light,
body.home-redesign .tc-header.is-over-dark .hr-logo__img--light,
.tc-header.is-over-dark .hr-logo__img--light {
  display: none !important;
}

body.mn-page .tc-header.is-over-dark .hr-logo__img--dark,
body.home-redesign .tc-header.is-over-dark .hr-logo__img--dark,
.tc-header.is-over-dark .hr-logo__img--dark {
  display: block !important;
}

body.mn-page .tc-header .hamburger,
body.home-redesign .tc-header .hamburger,
body.theme-glow .tc-header .hamburger,
.tc-header .tc-header__toggle {
  width: 38px !important;
  height: 38px !important;
  min-width: 38px !important;
  min-height: 38px !important;
}

/* Block legacy styles.css / theme .hamburger rules inside the floating header */
.tc-header .tc-header__toggle,
.tc-header .hamburger {
  position: relative !important;
  top: auto !important;
  right: auto !important;
  left: auto !important;
  transform: none !important;
  margin: 0 !important;
  flex: 0 0 auto !important;
  background: transparent !important;
  box-shadow: none !important;
}

.tc-header .tc-header__toggle::before,
.tc-header .tc-header__toggle::after,
.tc-header .hamburger::before,
.tc-header .hamburger::after {
  content: none !important;
  display: none !important;
}

.tc-header .tc-header__toggle span,
.tc-header .hamburger span {
  opacity: 1 !important;
  position: static !important;
  width: 16px !important;
  height: 1.5px !important;
  margin: 0 !important;
  border-radius: 1px !important;
  box-shadow: none !important;
  pointer-events: none;
}

.tc-header.is-over-dark .tc-header__toggle span,
.tc-header.is-over-dark .hamburger span,
.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-header__toggle span,
.tc-header[data-header-default="dark"]:not(.is-over-light) .hamburger span {
  background: #fff !important;
}

.tc-header.is-over-light .tc-header__toggle span,
.tc-header.is-over-light .hamburger span,
.tc-header[data-header-default="light"] .tc-header__toggle span,
.tc-header[data-header-default="light"] .hamburger span {
  background: #0c0c0c !important;
}

.tc-header .tc-header__toggle.is-open span:first-child,
.tc-header .hamburger.is-open span:first-child {
  transform: translateY(3.25px) rotate(45deg) !important;
}

.tc-header .tc-header__toggle.is-open span:last-child,
.tc-header .hamburger.is-open span:last-child {
  transform: translateY(-3.25px) rotate(-45deg) !important;
}

.tc-header__mobile .mobile-menu__sub[hidden] {
  display: none;
}

body.mn-page .tc-header .hr-logo:hover,
body.home-redesign .tc-header .hr-logo:hover {
  transform: none;
}

.tc-header__mobile .mobile-menu__subtoggle-icon {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  flex-shrink: 0;
  border-radius: 8px;
  border: 1px solid rgba(0, 0, 0, 0.08);
  background: rgba(0, 0, 0, 0.03);
  transition: transform 0.25s var(--tc-header-ease);
}

.tc-header__mobile .mobile-menu__subtoggle-icon::before {
  content: "";
  width: 7px;
  height: 7px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg) translate(-1px, -1px);
  transition: transform 0.25s var(--tc-header-ease);
}

.tc-header__mobile .mobile-menu__subtoggle[aria-expanded="true"] .mobile-menu__subtoggle-icon::before {
  transform: rotate(-135deg) translate(-1px, -1px);
}

.tc-header__mobile .mobile-menu__sub a.mobile-menu__sub-all {
  font-weight: 600;
  color: #0c0c0c;
}

/* Service subpages + other non-mn layouts */
body.sp-service main,
body.rk-services-page main {
  padding-top: var(--tc-header-offset, 88px);
}

body.home-redesign .rk-hero {
  padding-top: var(
    --rk-hero-pad-top,
    calc(var(--tc-float-pad-top, 16px) + var(--tc-shell-height, 56px) + clamp(16px, 2.5vh, 28px))
  );
}

@media (prefers-reduced-motion: reduce) {
  .tc-header,
  .tc-header__shell,
  .tc-header__nav a,
  .tc-header__mobile,
  .tc-header .mobile-menu {
    transition: none !important;
  }
}

/* ==========================================================================
   Site-wide responsive — overflow, marquees, shared mobile rhythm
   ========================================================================== */

html {
  overflow-x: clip;
}

body.mn-page,
body.rk-services-page,
body.sp-service {
  overflow-x: clip;
}

main#main > .mn-marquee {
  overflow: hidden !important;
  max-width: 100%;
  width: 100%;
}

@media (max-width: 640px) {
  body.about-page,
  body.portfolio-page,
  body.blog-page,
  body.pricing-page,
  body.rk-services-page {
    --ev-hero-card-margin: 8px;
    --ev-hero-pad-inline: clamp(16px, 4vw, 20px);
    --ev-hero-pad-top: clamp(32px, 6vh, 48px);
    --ev-hero-pad-bottom: clamp(48px, 10vw, 72px);
    --ev-hero-radius: 20px;
  }

  body.about-page {
    --ab-pad-inline: clamp(16px, 4vw, 20px);
    --ab-space-section: clamp(56px, 12vw, 72px);
    --ab-wrap: min(1180px, calc(100% - 16px));
  }

  body.pricing-page {
    --pr-wrap: min(1120px, calc(100% - 16px));
  }

  body.contact-page.contact-simple {
    --dg-max: min(1140px, calc(100% - clamp(20px, 5vw, 32px)));
  }

  .mn-footer__grid {
    grid-template-columns: 1fr;
    gap: clamp(28px, 6vw, 40px);
  }
}

/* ── Schedule (calendar) button — always orange to match the schedule page ── */
.tc-header .tc-header__icon-link,
.tc-header[data-header-default="light"] .tc-header__icon-link,
.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-header__icon-link,
.tc-header.is-over-light .tc-header__icon-link,
.tc-header.is-over-dark .tc-header__icon-link {
  color: #ff7020;
  border-color: rgba(255, 112, 32, 0.45);
  background: rgba(255, 112, 32, 0.1);
}

.tc-header .tc-header__icon-link:hover,
.tc-header .tc-header__icon-link:focus-visible,
.tc-header[data-header-default="light"] .tc-header__icon-link:hover,
.tc-header[data-header-default="light"] .tc-header__icon-link:focus-visible,
.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-header__icon-link:hover,
.tc-header[data-header-default="dark"]:not(.is-over-light) .tc-header__icon-link:focus-visible,
.tc-header.is-over-light .tc-header__icon-link:hover,
.tc-header.is-over-light .tc-header__icon-link:focus-visible,
.tc-header.is-over-dark .tc-header__icon-link:hover,
.tc-header.is-over-dark .tc-header__icon-link:focus-visible {
  color: #fff;
  background: #ff7020;
  border-color: #ff7020;
}
