/* Dark glass contact page — shared across Office 168/52, FrontOffice247, Ask Bob */

.contact-page.contact-page--dark {
  margin: 0;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  line-height: 1.6;
  color: #f7f8ff;
  background: #02040d;
  min-height: 100vh;
}

.contact-page.contact-page--dark *,
.contact-page.contact-page--dark *::before,
.contact-page.contact-page--dark *::after {
  box-sizing: border-box;
}

.contact-main {
  position: relative;
}

.contact-hero {
  position: relative;
  overflow: hidden;
  min-height: calc(100vh - 82px);
  padding: 24px 0 54px;
  color: #f7f8ff;
}

.contact-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 82% 12%, rgba(54, 102, 255, .22), transparent 34%),
    radial-gradient(circle at 55% 8%, rgba(189, 52, 255, .18), transparent 30%),
    linear-gradient(180deg, #040819 0%, #020511 62%, #02040d 100%);
  z-index: -2;
}

.contact-aurora {
  position: absolute;
  top: 70px;
  left: 50%;
  width: min(1800px, 118vw);
  height: 390px;
  transform: translateX(-38%);
  background-image: url("/assets/brand/contact-aurora-streak.svg");
  background-repeat: no-repeat;
  background-position: center top;
  background-size: contain;
  opacity: 0.95;
  pointer-events: none;
  z-index: 0;
}

.contact-container {
  width: min(100% - 48px, 1460px);
  margin-inline: auto;
  position: relative;
  z-index: 2;
}

.contact-hero-copy {
  padding-top: 14px;
  max-width: 780px;
}

.contact-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  height: 34px;
  padding: 0 15px;
  border-radius: 999px;
  background: rgba(137, 68, 255, 0.12);
  border: 1px solid rgba(203, 112, 255, 0.52);
  color: #d99cff;
  font-weight: 800;
  font-size: 0.86rem;
  letter-spacing: 0.055em;
  text-transform: uppercase;
  box-shadow: 0 0 24px rgba(158, 73, 255, .16);
}

.contact-eyebrow__icon {
  display: inline-flex;
  width: 18px;
  height: 18px;
  color: #c77dff;
}

.contact-title {
  margin: 14px 0 12px;
  font-size: clamp(4rem, 7vw, 6.8rem);
  line-height: 0.92;
  letter-spacing: -0.07em;
  font-weight: 950;
}

.contact-title__accent {
  background: linear-gradient(90deg, #b976ff 0%, #d34fff 44%, #5f8cff 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.contact-lede {
  max-width: 760px;
  font-size: clamp(1.15rem, 1.35vw, 1.42rem);
  line-height: 1.42;
  color: rgba(245, 247, 255, 0.88);
}

.contact-trust-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 34px;
  max-width: 900px;
  margin-top: 30px;
  margin-bottom: 18px;
}

.contact-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(360px, .85fr);
  gap: 30px;
  align-items: start;
  margin-top: 18px;
}

.contact-main-col {
  display: grid;
  gap: 14px;
  min-width: 0;
}

/* ── Premium glowing icon badges ─────────────────────────────────────────── */

.contact-icon-badge {
  position: relative;
  flex-shrink: 0;
  display: grid;
  place-items: center;
  color: #f4f6ff;
}

.contact-icon-badge::before {
  content: "";
  position: absolute;
  inset: -4px;
  border-radius: inherit;
  background: radial-gradient(circle at 50% 42%, var(--badge-glow, rgba(138, 99, 255, .55)), transparent 68%);
  opacity: 0.9;
  filter: blur(6px);
  z-index: 0;
}

.contact-icon-badge svg {
  position: relative;
  z-index: 1;
  filter:
    drop-shadow(0 0 6px var(--badge-accent, rgba(170, 120, 255, .75)))
    drop-shadow(0 0 14px var(--badge-accent-soft, rgba(100, 140, 255, .45)));
}

.contact-icon-badge--trust {
  width: 64px;
  height: 64px;
  border-radius: 999px;
  background:
    radial-gradient(circle at 32% 22%, rgba(255, 255, 255, .18), transparent 38%),
    radial-gradient(circle at 50% 115%, rgba(88, 120, 255, .28), transparent 52%),
    linear-gradient(155deg, rgba(98, 62, 210, .82) 0%, rgba(42, 58, 150, .88) 48%, rgba(24, 34, 96, .92) 100%);
  border: 1px solid rgba(188, 132, 255, .42);
  box-shadow:
    0 0 0 1px rgba(120, 160, 255, .12),
    0 0 28px rgba(138, 72, 255, .38),
    0 0 52px rgba(72, 110, 255, .22),
    inset 0 1px 0 rgba(255, 255, 255, .14);
}

.contact-icon-badge--trust svg {
  width: 28px;
  height: 28px;
}

.contact-icon-badge--violet {
  --badge-glow: rgba(168, 92, 255, .62);
  --badge-accent: rgba(210, 150, 255, .9);
  --badge-accent-soft: rgba(110, 150, 255, .55);
}

.contact-icon-badge--card {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  background:
    radial-gradient(circle at 30% 20%, rgba(255, 255, 255, .16), transparent 42%),
    linear-gradient(145deg, rgba(120, 70, 220, .78), rgba(48, 72, 170, .85));
  border: 1px solid rgba(196, 130, 255, .45);
  box-shadow:
    0 0 24px rgba(150, 90, 255, .42),
    0 0 44px rgba(90, 130, 255, .2),
    inset 0 1px 0 rgba(255, 255, 255, .12);
  --badge-glow: rgba(176, 108, 255, .58);
  --badge-accent: rgba(220, 170, 255, .95);
}

.contact-icon-badge--card svg {
  width: 24px;
  height: 24px;
}

.contact-icon-badge--method {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background:
    radial-gradient(circle at 30% 22%, rgba(255, 255, 255, .2), transparent 40%),
    linear-gradient(155deg, var(--badge-bg-top, rgba(56, 92, 200, .82)), var(--badge-bg-bottom, rgba(28, 38, 98, .9)));
  border: 1px solid var(--badge-border, rgba(120, 170, 255, .42));
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, .04),
    0 0 26px var(--badge-shadow, rgba(72, 130, 255, .36)),
    0 0 48px var(--badge-shadow-soft, rgba(90, 80, 255, .18)),
    inset 0 1px 0 rgba(255, 255, 255, .12);
}

.contact-icon-badge--method svg {
  width: 23px;
  height: 23px;
}

.contact-icon-badge--blue {
  --badge-glow: rgba(72, 150, 255, .62);
  --badge-accent: rgba(150, 210, 255, .95);
  --badge-accent-soft: rgba(72, 150, 255, .55);
  --badge-bg-top: rgba(48, 98, 220, .88);
  --badge-bg-bottom: rgba(20, 42, 110, .92);
  --badge-border: rgba(110, 175, 255, .48);
  --badge-shadow: rgba(64, 140, 255, .42);
  --badge-shadow-soft: rgba(64, 120, 255, .22);
}

.contact-icon-badge--purple {
  --badge-glow: rgba(168, 92, 255, .62);
  --badge-accent: rgba(220, 170, 255, .95);
  --badge-accent-soft: rgba(140, 90, 255, .5);
  --badge-bg-top: rgba(118, 62, 210, .88);
  --badge-bg-bottom: rgba(48, 28, 98, .92);
  --badge-border: rgba(188, 132, 255, .48);
  --badge-shadow: rgba(150, 80, 255, .42);
  --badge-shadow-soft: rgba(120, 70, 255, .22);
}

.contact-icon-badge--cyan {
  --badge-glow: rgba(64, 210, 255, .58);
  --badge-accent: rgba(170, 245, 255, .95);
  --badge-accent-soft: rgba(64, 200, 255, .5);
  --badge-bg-top: rgba(36, 140, 210, .88);
  --badge-bg-bottom: rgba(18, 58, 108, .92);
  --badge-border: rgba(100, 210, 255, .46);
  --badge-shadow: rgba(48, 180, 255, .4);
  --badge-shadow-soft: rgba(48, 160, 255, .2);
}

.contact-icon-badge--alert {
  --badge-glow: rgba(255, 108, 180, .58);
  --badge-accent: rgba(255, 200, 230, .95);
  --badge-accent-soft: rgba(255, 100, 160, .5);
  --badge-bg-top: rgba(180, 58, 150, .86);
  --badge-bg-bottom: rgba(72, 24, 88, .92);
  --badge-border: rgba(255, 130, 200, .46);
  --badge-shadow: rgba(220, 80, 180, .4);
  --badge-shadow-soft: rgba(180, 60, 220, .22);
}

.contact-icon-badge--help {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background:
    radial-gradient(circle at 30% 22%, rgba(255, 255, 255, .16), transparent 42%),
    linear-gradient(145deg, rgba(42, 98, 220, .82), rgba(22, 48, 118, .9));
  border: 1px solid rgba(110, 170, 255, .42);
  box-shadow: 0 0 22px rgba(72, 140, 255, .34);
  --badge-glow: rgba(72, 150, 255, .55);
  --badge-accent: rgba(160, 210, 255, .95);
}

.contact-icon-badge--help svg {
  width: 22px;
  height: 22px;
}

.contact-icon-badge--inline {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: inline-grid;
  vertical-align: middle;
}

.contact-icon-badge--inline svg {
  width: 18px;
  height: 18px;
}

.contact-trust-item {
  display: grid;
  grid-template-columns: 64px 1fr;
  align-items: center;
  gap: 16px;
}

.contact-trust-item h2 {
  margin: 0 0 4px;
  font-size: 1.22rem;
  line-height: 1.05;
  font-weight: 900;
}

.contact-trust-item p {
  margin: 0;
  color: rgba(242, 244, 255, .84);
  font-size: 1.02rem;
  line-height: 1.18;
}

.contact-card {
  background:
    linear-gradient(180deg, rgba(12, 23, 62, 0.72), rgba(5, 10, 29, 0.78)),
    rgba(8, 14, 35, .72);
  border: 1px solid rgba(103, 132, 255, .28);
  border-radius: 16px;
  box-shadow:
    0 22px 70px rgba(0, 0, 0, .35),
    inset 0 1px 0 rgba(255, 255, 255, .05);
  backdrop-filter: blur(18px);
}

.contact-form-card {
  padding: 28px 30px 24px;
}

.contact-card-heading {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 18px;
}

.contact-card-heading h2 {
  margin: 0;
  font-size: clamp(1.8rem, 2.2vw, 2.25rem);
  line-height: 1.05;
  font-weight: 950;
}

.contact-card-heading p {
  margin: 8px 0 0;
  font-size: 1.08rem;
  color: rgba(239, 242, 255, .82);
}

.contact-form {
  display: grid;
  gap: 14px;
}

.contact-form-row {
  display: grid;
  gap: 14px;
}

.contact-form-row--two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.contact-field {
  display: grid;
  gap: 7px;
}

.contact-field span {
  color: #ffffff;
  font-size: 1rem;
  line-height: 1;
  font-weight: 850;
}

.contact-field input,
.contact-field select,
.contact-field textarea {
  width: 100%;
  min-height: 54px;
  border-radius: 10px;
  border: 1px solid rgba(168, 108, 255, .88);
  background:
    linear-gradient(180deg, rgba(19, 31, 72, .88), rgba(11, 19, 46, .9));
  color: #f8f9ff;
  font-size: 1.08rem;
  padding: 0 16px;
  outline: none;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 0 0 1px rgba(88, 140, 255, .28),
    0 0 18px rgba(130, 88, 255, .32),
    0 0 38px rgba(72, 120, 255, .2);
  font-family: inherit;
  transition: border-color .18s ease, box-shadow .18s ease;
}

.contact-field select {
  appearance: none;
  background-image:
    linear-gradient(180deg, rgba(19, 31, 72, .82), rgba(11, 19, 46, .82)),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23b87aff' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat: no-repeat, no-repeat;
  background-position: 0 0, calc(100% - 16px) center;
  padding-right: 40px;
}

.contact-field textarea {
  min-height: 92px;
  padding-top: 14px;
  resize: vertical;
}

.contact-field input::placeholder,
.contact-field textarea::placeholder {
  color: rgba(226, 232, 255, .68);
}

.contact-field input:focus,
.contact-field select:focus,
.contact-field textarea:focus {
  border-color: rgba(130, 190, 255, .98);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 0 0 2px rgba(100, 160, 255, .32),
    0 0 22px rgba(140, 100, 255, .48),
    0 0 48px rgba(80, 140, 255, .36),
    0 0 72px rgba(120, 80, 255, .22);
}

.contact-field--honeypot {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.contact-submit {
  margin-top: 2px;
  height: 58px;
  border: none;
  border-radius: 10px;
  background: linear-gradient(90deg, #a83cff 0%, #6f55ff 48%, #3487ff 100%);
  color: white;
  font-size: 1.08rem;
  font-weight: 950;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  cursor: pointer;
  box-shadow:
    0 18px 42px rgba(72, 95, 255, .28),
    inset 0 1px 0 rgba(255,255,255,.22);
  font-family: inherit;
  transition: transform .16s ease, filter .16s ease;
}

.contact-submit:hover:not(:disabled) {
  transform: translateY(-1px);
  filter: brightness(1.06);
}

.contact-submit:disabled {
  opacity: 0.72;
  cursor: wait;
}

.contact-submit__icon svg {
  width: 20px;
  height: 20px;
}

.contact-privacy-note {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 7px;
  margin: 14px 0 0;
  font-size: 1rem;
  color: rgba(235, 238, 255, .76);
  text-align: center;
  flex-wrap: wrap;
}

.contact-privacy-note a {
  color: #5fa2ff;
  text-decoration: none;
}

.contact-privacy-note a:hover {
  text-decoration: underline;
}

.contact-form-status {
  display: none;
  padding: 14px 16px;
  border-radius: 10px;
  font-size: 1rem;
  line-height: 1.4;
}

.contact-form-status.is-visible {
  display: block;
}

.contact-form-status--success {
  background: rgba(16, 185, 129, 0.14);
  border: 1px solid rgba(16, 185, 129, 0.45);
  color: #a7f3d0;
}

.contact-form-status--error {
  background: rgba(239, 68, 68, 0.12);
  border: 1px solid rgba(239, 68, 68, 0.42);
  color: #fecaca;
}

.contact-side {
  display: grid;
  gap: 14px;
}

.contact-reach-card {
  padding: 18px;
}

.contact-reach-card h2,
.contact-hours-card h2 {
  margin: 0 0 14px;
  font-size: 1.42rem;
  font-weight: 950;
}

.contact-method-list {
  display: grid;
  gap: 9px;
}

.contact-method {
  display: grid;
  grid-template-columns: 52px 1fr 28px;
  align-items: center;
  gap: 12px;
  min-height: 78px;
  padding: 10px 13px;
  border-radius: 13px;
  background: linear-gradient(180deg, rgba(24, 36, 82, .62), rgba(11, 19, 48, .68));
  border: 1px solid rgba(100, 129, 255, .18);
  color: inherit;
  text-decoration: none;
  transition: transform .16s ease, border-color .16s ease, background .16s ease;
}

.contact-method:hover {
  transform: translateY(-1px);
  border-color: rgba(142, 99, 255, .46);
  background: linear-gradient(180deg, rgba(33, 48, 102, .78), rgba(13, 23, 58, .76));
}

.contact-method:hover .contact-icon-badge--method {
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, .06),
    0 0 32px var(--badge-shadow, rgba(72, 130, 255, .46)),
    0 0 58px var(--badge-shadow-soft, rgba(90, 80, 255, .24)),
    inset 0 1px 0 rgba(255, 255, 255, .14);
}

.contact-method__body {
  display: grid;
  gap: 1px;
  min-width: 0;
}

.contact-method__body strong {
  color: #b87aff;
  font-size: 1.06rem;
  line-height: 1.05;
  font-weight: 950;
}

.contact-method__body span {
  color: rgba(250, 251, 255, .88);
  font-size: .98rem;
  overflow-wrap: anywhere;
}

.contact-method__body small {
  color: rgba(227, 232, 255, .78);
  font-size: .94rem;
}

.contact-method__arrow {
  justify-self: end;
  font-size: 2rem;
  color: rgba(255,255,255,.9);
  line-height: 1;
}

.contact-hours-card {
  padding: 18px 20px 20px;
}

.contact-hours-card h2 {
  display: flex;
  align-items: center;
  gap: 11px;
}

.support-hours-list {
  margin: 0;
  display: grid;
}

.support-hours-list div {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 16px;
  padding: 11px 0;
  border-bottom: 1px solid rgba(130, 151, 255, .12);
}

.support-hours-list dt,
.support-hours-list dd {
  margin: 0;
  color: rgba(240, 244, 255, .84);
  font-size: 1rem;
}

.support-hours-list dd {
  text-align: right;
}

.support-hours-note {
  margin: 15px 0 0;
  font-size: .96rem;
  line-height: 1.42;
  color: rgba(235, 239, 255, .82);
}

.support-hours-note strong {
  color: #ffffff;
}

.support-hours-tagline {
  margin: 14px 0 0;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.4;
  color: rgba(196, 181, 253, .95);
}

.contact-help-strip {
  margin-top: 0;
  padding: 20px 24px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 24px;
  align-items: center;
}

.contact-help-heading {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.contact-help-heading h2 {
  margin: 0 0 4px;
  font-size: 1.45rem;
  font-weight: 950;
}

.contact-help-heading p {
  margin: 0;
  color: rgba(235, 240, 255, .8);
  font-size: 1rem;
}

.contact-help-actions {
  display: flex;
  gap: 12px;
  margin-top: 14px;
  flex-wrap: wrap;
}

.contact-help-actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  min-height: 40px;
  padding: 0 18px;
  border-radius: 9px;
  background: linear-gradient(180deg, rgba(32, 52, 116, .78), rgba(17, 28, 72, .82));
  border: 1px solid rgba(99, 128, 255, .2);
  color: #6ea0ff;
  font-weight: 850;
  text-decoration: none;
  transition: border-color .16s ease, background .16s ease;
}

.contact-help-actions a:hover {
  border-color: rgba(142, 99, 255, .46);
  background: linear-gradient(180deg, rgba(40, 62, 130, .85), rgba(20, 32, 82, .88));
}

.contact-help-stats {
  display: grid;
  grid-template-columns: repeat(3, 138px);
  gap: 12px;
}

.contact-help-stats article {
  min-height: 94px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 6px;
  padding: 8px;
  background: rgba(14, 25, 61, .7);
  border: 1px solid rgba(109, 132, 255, .28);
  text-align: center;
}

.contact-help-stats strong {
  font-size: clamp(1.1rem, 2vw, 1.85rem);
  line-height: 1.1;
  font-weight: 950;
  background: linear-gradient(90deg, #4288ff, #c35cff);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.contact-help-stats span {
  color: rgba(244, 246, 255, .88);
  font-size: .94rem;
  font-weight: 750;
}

/* Unified nav on dark contact page */
.contact-page--dark [data-unified-nav] .unified-nav {
  background: rgba(2, 6, 20, 0.88);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid rgba(105, 126, 255, 0.16);
}

@media (max-width: 1040px) {
  .contact-grid {
    grid-template-columns: 1fr;
  }

  .contact-main-col {
    order: 1;
  }

  .contact-side {
    order: 2;
  }
}

@media (max-width: 900px) {
  .contact-help-strip {
    grid-template-columns: 1fr;
  }

  .contact-help-stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 850px) {
  .contact-trust-strip {
    grid-template-columns: 1fr;
    gap: 18px;
  }
}

@media (max-width: 720px) {
  .contact-container {
    width: min(100% - 28px, 100%);
  }

  .contact-form-row--two {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .contact-title {
    font-size: clamp(3.2rem, 16vw, 4.7rem);
    letter-spacing: -0.06em;
  }

  .contact-lede {
    font-size: 1.08rem;
  }
}

@media (max-width: 620px) {
  .contact-help-actions,
  .contact-help-stats {
    grid-template-columns: 1fr;
    display: grid;
  }
}
