/* ─── CSS Variables ──────────────────────────────────────────── */
:root {
  --cc-dark-purple: #702963;
  --cc-blue:        #1a6eb5;
  --cc-sky:         #7fffff;
  --cc-ice:         #e8f4fc;
  --cc-white:       #ffffff;
  --cc-gray-light:  #f4f7fa;
  --cc-gray-mid:    #8a9ab0;
  --cc-gray-dark:   #3a4a5c;
  --cc-accent:      #ff6b2b;

  --font-display: 'Bebas Neue', sans-serif;
  --font-body:    'DM Sans', sans-serif;

  --radius-card:  12px;
  --transition:   0.25s ease;
}

/* ─── Base ───────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html {
  scroll-behavior: smooth;
  background-color: #00000a;
}
body {
  font-family: var(--font-body);
  color: var(--cc-white);
  background: transparent;
  margin: 0;
  position: relative;
  overflow-x: hidden;
}
img { max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }

/* ─── Galaxy Background  (blue / magenta / cyan palette) ─────── */
/* Layer 1 — deep nebula clouds */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: -2;
  background:
    /* hot-pink / magenta burst at top-centre */
    radial-gradient(ellipse 50% 55% at 50%  -5%, rgba(220, 0, 140, 0.85)  0%, transparent 65%),
    /* cyan cloud — left-centre */
    radial-gradient(ellipse 55% 45% at  8%  55%, rgba(0, 170, 220, 0.65)  0%, transparent 60%),
    /* cyan cloud — right-centre */
    radial-gradient(ellipse 50% 40% at 92%  48%, rgba(0, 200, 255, 0.60)  0%, transparent 58%),
    /* deep blue mid-left */
    radial-gradient(ellipse 65% 50% at 25%  65%, rgba(10,  50, 200, 0.72) 0%, transparent 65%),
    /* deep blue mid-right */
    radial-gradient(ellipse 60% 45% at 75%  70%, rgba(0,   30, 180, 0.68) 0%, transparent 60%),
    /* teal/green tint — lower centre */
    radial-gradient(ellipse 45% 35% at 52%  85%, rgba(0, 180, 160, 0.40)  0%, transparent 55%),
    /* dark base */
    #00000a;
  pointer-events: none;
}

/* Layer 2 — secondary glow & depth */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  z-index: -1;
  background-image:
    /* ── Large glowing star clusters (with cyan/white bloom) ── */
    radial-gradient(6px 6px at 20%  12%, #fff                    0%, rgba(140,230,255,0.50) 50%, transparent 100%),
    radial-gradient(7px 7px at 50%   8%, rgba(255,255,255,0.95)  0%, rgba(255,180,255,0.40) 50%, transparent 100%),
    radial-gradient(5px 5px at 80%  15%, #fff                    0%, rgba(120,220,255,0.50) 50%, transparent 100%),
    radial-gradient(6px 6px at 35%  55%, rgba(200,240,255,0.90)  0%, rgba(0,200,255,0.35)   50%, transparent 100%),
    radial-gradient(8px 8px at 65%  48%, rgba(255,255,255,0.92)  0%, rgba(200,255,255,0.40) 50%, transparent 100%),
    radial-gradient(5px 5px at 10%  75%, rgba(220,255,255,0.85)  0%, rgba(0,200,220,0.35)   50%, transparent 100%),
    radial-gradient(6px 6px at 90%  68%, rgba(255,255,255,0.88)  0%, rgba(150,220,255,0.40) 50%, transparent 100%),
    radial-gradient(5px 5px at 48%  82%, rgba(200,255,240,0.85)  0%, rgba(0,220,180,0.35)   50%, transparent 100%),
    /* ── Medium stars ── */
    radial-gradient(2px 2px at  5%  20%, rgba(255,255,255,0.80)  0%, transparent 100%),
    radial-gradient(2px 2px at 15%  38%, rgba(180,230,255,0.78)  0%, transparent 100%),
    radial-gradient(2px 2px at 28%   8%, rgba(255,255,255,0.75)  0%, transparent 100%),
    radial-gradient(2px 2px at 42%  28%, rgba(200,240,255,0.80)  0%, transparent 100%),
    radial-gradient(2px 2px at 58%  18%, rgba(255,255,255,0.75)  0%, transparent 100%),
    radial-gradient(2px 2px at 72%  32%, rgba(180,230,255,0.78)  0%, transparent 100%),
    radial-gradient(2px 2px at 85%   8%, rgba(255,255,255,0.72)  0%, transparent 100%),
    radial-gradient(2px 2px at 94%  35%, rgba(200,240,255,0.76)  0%, transparent 100%),
    radial-gradient(2px 2px at  8%  48%, rgba(255,255,255,0.70)  0%, transparent 100%),
    radial-gradient(2px 2px at 22%  62%, rgba(180,230,255,0.72)  0%, transparent 100%),
    radial-gradient(2px 2px at 38%  72%, rgba(255,255,255,0.68)  0%, transparent 100%),
    radial-gradient(2px 2px at 55%  65%, rgba(200,255,240,0.70)  0%, transparent 100%),
    radial-gradient(2px 2px at 70%  78%, rgba(255,255,255,0.72)  0%, transparent 100%),
    radial-gradient(2px 2px at 82%  58%, rgba(180,230,255,0.68)  0%, transparent 100%),
    radial-gradient(2px 2px at 96%  80%, rgba(255,255,255,0.70)  0%, transparent 100%),
    radial-gradient(2px 2px at 12%  88%, rgba(200,240,255,0.65)  0%, transparent 100%),
    radial-gradient(2px 2px at 45%  92%, rgba(255,255,255,0.68)  0%, transparent 100%),
    /* ── Small dim stars ── */
    radial-gradient(1px 1px at  3%  15%, rgba(255,255,255,0.70)  0%, transparent 100%),
    radial-gradient(1px 1px at 11%  28%, rgba(255,255,255,0.60)  0%, transparent 100%),
    radial-gradient(1px 1px at 18%  52%, rgba(200,240,255,0.65)  0%, transparent 100%),
    radial-gradient(1px 1px at 25%  18%, rgba(255,255,255,0.58)  0%, transparent 100%),
    radial-gradient(1px 1px at 33%  42%, rgba(255,255,255,0.62)  0%, transparent 100%),
    radial-gradient(1px 1px at 40%  85%, rgba(200,255,240,0.58)  0%, transparent 100%),
    radial-gradient(1px 1px at 48%  35%, rgba(255,255,255,0.65)  0%, transparent 100%),
    radial-gradient(1px 1px at 53%  78%, rgba(255,255,255,0.60)  0%, transparent 100%),
    radial-gradient(1px 1px at 62%  22%, rgba(200,240,255,0.62)  0%, transparent 100%),
    radial-gradient(1px 1px at 68%  58%, rgba(255,255,255,0.55)  0%, transparent 100%),
    radial-gradient(1px 1px at 75%  42%, rgba(255,255,255,0.62)  0%, transparent 100%),
    radial-gradient(1px 1px at 78%  88%, rgba(200,255,240,0.55)  0%, transparent 100%),
    radial-gradient(1px 1px at 87%  25%, rgba(255,255,255,0.65)  0%, transparent 100%),
    radial-gradient(1px 1px at 93%  52%, rgba(200,240,255,0.60)  0%, transparent 100%),
    radial-gradient(1px 1px at 97%  14%, rgba(255,255,255,0.58)  0%, transparent 100%),
    radial-gradient(1px 1px at  7%  68%, rgba(255,255,255,0.55)  0%, transparent 100%),
    radial-gradient(1px 1px at 17%  78%, rgba(200,240,255,0.52)  0%, transparent 100%),
    radial-gradient(1px 1px at 30%  95%, rgba(255,255,255,0.56)  0%, transparent 100%),
    radial-gradient(1px 1px at 43%  55%, rgba(255,255,255,0.50)  0%, transparent 100%),
    radial-gradient(1px 1px at 57%  45%, rgba(200,255,240,0.55)  0%, transparent 100%),
    radial-gradient(1px 1px at 63%  92%, rgba(255,255,255,0.52)  0%, transparent 100%),
    radial-gradient(1px 1px at 73%  15%, rgba(255,255,255,0.58)  0%, transparent 100%),
    radial-gradient(1px 1px at 83%  72%, rgba(200,240,255,0.52)  0%, transparent 100%),
    radial-gradient(1px 1px at 90%  95%, rgba(255,255,255,0.48)  0%, transparent 100%);
  pointer-events: none;
  animation: twinkle 7s ease-in-out infinite alternate;
}

@keyframes twinkle {
  0%   { opacity: 1; }
  50%  { opacity: 0.75; }
  100% { opacity: 1; }
}

/* ─── Top Bar ────────────────────────────────────────────────── */
.top-bar {
  background: rgba(140, 0, 80, 0.80);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: var(--cc-white);
  font-size: 0.82rem;
  padding: 8px 0;

  position: sticky;
  top: 0;
  z-index: 1031;
}
.top-bar .top-bar__hours {
  font-weight: 500;
  letter-spacing: 0.03em;
}
.top-bar .top-bar__contacts {
  display: flex;
  align-items: center;
  gap: 20px;
  justify-content: flex-end;
  flex-wrap: wrap;
}
.top-bar .top-bar__contacts a {
  color: var(--cc-white);
  display: flex;
  align-items: center;
  gap: 5px;
  transition: color var(--transition);
}
.top-bar .top-bar__contacts a:hover { color: var(--cc-sky); }
.top-bar .btn-schedule {
  background: rgba(0, 160, 220, 0.85);
  color: var(--cc-white);
  border: none;
  border-radius: 4px;
  padding: 4px 14px;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: background var(--transition);
}
.top-bar .btn-schedule:hover { background: rgba(0, 180, 255, 0.95); }

/* ─── Secondary Header / Nav ─────────────────────────────────── */
.main-nav {
  background: rgba(0, 0, 15, 0.78);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(0, 180, 255, 0.30);
  padding: 14px 0;
  /*
  position: sticky;
  top: 41px;
  z-index: 1000;
  */
  box-shadow: 0 2px 24px rgba(0, 0, 0, 0.50);
}
.main-nav .nav-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-display);
  font-size: 1.6rem;
  letter-spacing: 0.06em;
  color: var(--cc-white);
}
.main-nav .nav-logo img { height: 62px; width: auto; }
.nav-logo__placeholder {
  width: 66px;
  height: 62px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.65rem;
  color: var(--cc-blue);
  font-family: var(--font-body);
  font-weight: 600;
}
.main-nav .nav-services {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}
.main-nav .nav-services li { position: relative; }
.main-nav .nav-services .nav-service-link {
  display: flex;
  align-items: center;
  gap: 6px;
  font-weight: 500;
  font-size: 0.9rem;
  color: rgba(255, 255, 255, 0.85);
  padding: 6px 10px;
  border-radius: 6px;
  transition: background var(--transition), color var(--transition);
  cursor: pointer;
}
.main-nav .nav-services .nav-service-link:hover {
  background: rgba(0, 160, 220, 0.25);
  color: var(--cc-sky);
}
.nav-service-link .tooltip-icon {
  color: var(--cc-gray-mid);
  font-size: 0.9rem;
  transition: color var(--transition);
}
.nav-service-link:hover .tooltip-icon { color: var(--cc-blue); }

/* ─── Hero Section ───────────────────────────────────────────── */
.hero {
  background: linear-gradient(
    160deg,
    rgba(180, 0, 120, 0.45) 0%,
    rgba(0, 60, 180, 0.55) 50%,
    rgba(0, 160, 200, 0.30) 100%
  );
  position: relative;
  overflow: hidden;
  min-height: 520px;
  display: flex;
  align-items: center;
  border-bottom: 1px solid rgba(0, 180, 255, 0.20);
}
.hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%234fb3e8' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  pointer-events: none;
}
.hero__content { position: relative; z-index: 2; padding: 60px 0; }
.hero__subheading {
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cc-sky);
  margin-bottom: 12px;
}
.hero__heading {
  font-family: var(--font-display);
  font-size: clamp(2.8rem, 6vw, 5rem);
  line-height: 1;
  color: var(--cc-white);
  margin-bottom: 28px;
  letter-spacing: 0.04em;
}
.hero__heading span { color: var(--cc-sky); }
.hero__buttons { display: flex; gap: 14px; flex-wrap: wrap; }
.btn-primary-cc {
  background: rgba(0, 150, 220, 0.90);
  color: var(--cc-white);
  border: none;
  border-radius: 6px;
  padding: 12px 28px;
  font-weight: 600;
  font-size: 0.95rem;
  cursor: pointer;
  transition: background var(--transition), transform var(--transition);
}
.btn-primary-cc:hover { background: rgba(0, 180, 255, 1); transform: translateY(-1px); }
.btn-outline-cc {
  background: transparent;
  color: var(--cc-white);
  border: 2px solid rgba(0, 200, 255, 0.55);
  border-radius: 6px;
  padding: 12px 28px;
  font-weight: 600;
  font-size: 0.95rem;
  cursor: pointer;
  transition: border-color var(--transition), background var(--transition), transform var(--transition);
}
.btn-outline-cc:hover {
  border-color: var(--cc-sky);
  background: rgba(0, 200, 255, 0.12);
  transform: translateY(-1px);
}
.hero__image-wrapper {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
}
.hero__img-placeholder {
  width: 100%;
  min-height: 340px;
  background: rgba(0, 100, 180, 0.15);
  border: 2px dashed rgba(0, 200, 255, 0.35);
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 12px;
  color: rgba(200, 240, 255, 0.50);
  font-size: 0.85rem;
}
.hero__img-placeholder i { font-size: 3rem; }

/* ─── Section Common ─────────────────────────────────────────── */
.section { padding: 72px 0; }
.section--alt { background: rgba(0, 10, 30, 0.45); }
.section__title {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  letter-spacing: 0.05em;
  color: var(--cc-white);
  text-align: center;
  margin-bottom: 40px;
}
.section__title span { color: var(--cc-sky); }

/* ─── Services Grid (Section 1) ──────────────────────────────── */
.services-grid .service-card {
  display: block;
  text-decoration: none;
  color: inherit;
  background: rgba(0, 10, 40, 0.72);
  border: 1px solid rgba(0, 170, 220, 0.38);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: var(--radius-card);
  overflow: hidden;
  transition: box-shadow var(--transition), transform var(--transition), border-color var(--transition);
  cursor: pointer;
  height: 100%;
  max-height: 400px;
}
.services-grid .service-card:hover {
  box-shadow: 0 8px 32px rgba(0, 180, 255, 0.35);
  border-color: rgba(0, 220, 255, 0.60);
  transform: translateY(-3px);
}
.service-card__img {
  width: 100%;
  aspect-ratio: 4/3;
  background: rgba(0, 100, 180, 0.28);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cc-sky);
  font-size: 2rem;
  border-bottom: 1px solid rgba(0, 170, 220, 0.28);
  overflow: hidden;
}
.service-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
.service-card__label {
  padding: 12px 14px;
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--cc-white);
  text-align: center;
}

/* ─── Promos Grid (Section 2) ────────────────────────────────── */
.promos-grid .promo-card {
  background: rgba(0, 10, 40, 0.72);
  border: 1px solid rgba(0, 170, 220, 0.38);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: var(--radius-card);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: box-shadow var(--transition), transform var(--transition), border-color var(--transition);
  height: 100%;
  max-height: 700px;
}
.promos-grid .promo-card:hover {
  box-shadow: 0 8px 32px rgba(0, 180, 255, 0.35);
  border-color: rgba(0, 220, 255, 0.60);
  transform: translateY(-3px);
}
.promo-card__img {
  width: 100%;
  aspect-ratio: 4/3;
  background: rgba(0, 100, 180, 0.28);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cc-sky);
  font-size: 2.4rem;
  border-bottom: 1px solid rgba(0, 170, 220, 0.28);
  overflow: hidden;
}
.promo-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
.promo-card__body {
  padding: 20px;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.promo-card__title {
  font-weight: 700;
  font-size: 1rem;
  color: var(--cc-white);
  margin-bottom: 8px;
}
.promo-card__text {
  font-size: 0.88rem;
  line-height: 1.65;
  color: rgba(200, 240, 255, 0.80);
  flex: 1;
}
.promo-card__btn {
  margin-top: 18px;
  background: rgba(0, 150, 220, 0.85);
  color: var(--cc-white);
  border: none;
  border-radius: 6px;
  padding: 10px 20px;
  font-weight: 600;
  font-size: 0.88rem;
  cursor: pointer;
  transition: background var(--transition);
  width: 100%;
}
.promo-card__btn:hover { background: rgba(0, 180, 255, 1); }

/* ─── TikTok Section ─────────────────────────────────────────── */
.tiktok-section {
    background: transparent;
    padding: 72px 0;
  }

  /*
   * The carousel wrapper clips overflow so prev/next
   * arrows sit just outside the track.
   */
  .tiktok-carousel {
    position: relative;
  }

  /* Grid that shows 1–3 columns depending on JS + viewport */
  .tiktok-carousel__track {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }

  /*
   * Each card is a clean white rounded box that
   * lets the TikTok embed determine its own height.
   */
  .tiktok-video-card {
    height: 740px;
    background: rgba(0, 10, 40, 0.85);
    border-radius: var(--radius-card);
    overflow: hidden;
  }

  .tiktok-video-card iframe {
    flex: 1;
    width: 100%;
    height: 100%;
    border: none;
    display: block;
  }

  /* Arrow buttons */
  .carousel-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(180, 0, 120, 0.75);
    border: none;
    color: var(--cc-white);
    width: 44px;
    height: 44px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    cursor: pointer;
    transition: background var(--transition);
    z-index: 10;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.40);
  }
  .carousel-btn:hover { background: rgba(0, 160, 220, 0.90); }
  .carousel-btn--prev { left: -22px; }
  .carousel-btn--next { right: -22px; }

/* ─── Technicians (Section 4) ────────────────────────────────── */
.technicians-section { padding: 72px 0; }
.technician-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: center;
  margin-bottom: 48px;
}
.technician-row:last-child { margin-bottom: 0; }
.technician-row.reverse { direction: rtl; }
.technician-row.reverse > * { direction: ltr; }
.technician__img-placeholder {
  width: 100%;
  aspect-ratio: 4/3;
  background: rgba(0, 10, 40, 0.60);
  border: 2px dashed rgba(0, 170, 220, 0.45);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cc-sky);
  font-size: 2.5rem;
}
.technician__text .tech-name {
  font-family: var(--font-display);
  font-size: 1.7rem;
  letter-spacing: 0.04em;
  color: var(--cc-white);
  margin-bottom: 6px;
}
.technician__text .tech-role {
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--cc-sky);
  margin-bottom: 14px;
}
.technician__text p {
  font-size: 0.92rem;
  line-height: 1.75;
  color: rgba(200, 240, 255, 0.80);
}

/* ─── Footer ─────────────────────────────────────────────────── */
.site-footer {
  background: rgba(0, 0, 10, 0.88);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-top: 1px solid rgba(0, 170, 220, 0.25);
  color: rgba(200, 240, 255, 0.70);
  padding: 52px 0 28px;
}
.footer-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
}
.footer-logo__placeholder {
  width: 64px;
  height: 58px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.65rem;
  color: var(--cc-sky);
  font-family: var(--font-body);
}
.footer-logo__name {
  font-family: var(--font-display);
  font-size: 1.5rem;
  letter-spacing: 0.06em;
  color: var(--cc-white);
}
.footer-tagline { font-size: 0.82rem; line-height: 1.6; }
.footer-menu h3 {
  font-family: var(--font-display);
  font-size: 1.1rem;
  letter-spacing: 0.08em;
  color: var(--cc-white);
  margin-bottom: 14px;
}
.footer-menu ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.footer-menu ul li {
  margin-bottom: 8px;
  font-size: 0.88rem;
  overflow-wrap: break-word;
  word-break: break-word;
}
.footer-menu ul li a {
  color: rgba(200, 240, 255, 0.65);
  transition: color var(--transition);
  display: flex;
  align-items: center;
  gap: 6px;
}
.footer-menu ul li a:hover { color: var(--cc-sky); }
.footer-divider {
  border-color: rgba(0, 180, 255, 0.15);
  margin: 32px 0 20px;
}
.footer-bottom {
  font-size: 0.78rem;
  color: rgba(200, 240, 255, 0.35);
  text-align: center;
}

/* ─── About Us Page ──────────────────────────────────────────── */

/* "Get To Know" intro heading above the page hero */
.page-intro {
  padding: 60px 0 48px;
  text-align: center;
  background: linear-gradient(
    160deg,
    rgba(180, 0, 120, 0.45) 0%,
    rgba(0, 60, 180, 0.55) 50%,
    rgba(0, 160, 200, 0.30) 100%
  );
  border-bottom: 1px solid rgba(0, 180, 255, 0.20);
  position: relative;
  overflow: hidden;
}
.page-intro__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3.2rem);
  letter-spacing: 0.06em;
  color: var(--cc-white);
  margin: 0;
}
.page-intro__title span { color: var(--cc-sky); }

/* Full-bleed page hero image */
.page-hero {
  width: 100%;
  min-height: 380px;
  background: rgba(0, 10, 40, 0.60);
  border-top: 1px solid rgba(0, 170, 220, 0.28);
  border-bottom: 1px solid rgba(0, 170, 220, 0.28);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  position: relative;
}
.page-hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  inset: 0;
}
.page-hero__placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  color: rgba(255,255,255,0.35);
  font-size: 0.85rem;
  z-index: 1;
}
.page-hero__placeholder i { font-size: 3.5rem; }

/* Our Story section — reuses .technician-row layout */
.our-story { padding: 72px 0; }
.our-story .section__title { margin-bottom: 48px; }

/* Why We're Different — 3-col cards */
.diff-card {
  background: rgba(0, 10, 40, 0.72);
  border: 1px solid rgba(0, 170, 220, 0.38);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: var(--radius-card);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  height: 100%;
  transition: box-shadow var(--transition), transform var(--transition), border-color var(--transition);
}
.diff-card:hover {
  box-shadow: 0 8px 32px rgba(0, 180, 255, 0.35);
  border-color: rgba(0, 220, 255, 0.60);
  transform: translateY(-3px);
}
.diff-card__img {
  width: 100%;
  aspect-ratio: 4/3;
  background: rgba(0, 100, 180, 0.28);
  border-bottom: 1px solid rgba(0, 170, 220, 0.28);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cc-sky);
  font-size: 2.2rem;
}
.diff-card__body {
  padding: 20px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.diff-card__title {
  font-family: var(--font-display);
  font-size: 1.15rem;
  letter-spacing: 0.05em;
  color: var(--cc-white);
  margin-bottom: 10px;
}
.diff-card__text {
  font-size: 0.88rem;
  line-height: 1.7;
  color: rgba(200, 240, 255, 0.80);
}

/* ─── Responsive Tweaks ───────────────────────────────────────── */
@media (max-width: 768px) {
  .hero__content { padding: 40px 20px 20px; }
  .technician-row { grid-template-columns: 1fr; }
  .technician-row.reverse { direction: ltr; }
  .carousel-btn--prev { left: 0; }
  .carousel-btn--next { right: 0; }
  .top-bar .top-bar__contacts { justify-content: flex-start; gap: 12px; }
}
@media (max-width: 576px) {
  .hero__heading { font-size: 2.4rem; }
}

/* ─── Contact Page ───────────────────────────────────────────── */
.contact-section { padding: 60px 0 80px; }

/* Form card */
.contact-form-card {
  background: rgba(0, 10, 40, 0.72);
  border: 1px solid rgba(0, 170, 220, 0.38);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: var(--radius-card);
  padding: 32px;
}
.contact-form-card label {
  font-size: 0.88rem;
  font-weight: 600;
  color: rgba(200, 240, 255, 0.85);
  margin-bottom: 6px;
  letter-spacing: 0.02em;
  display: block;
}
.contact-form-card .form-control {
  background: rgba(0, 20, 60, 0.60);
  border: 1px solid rgba(0, 170, 220, 0.35);
  color: var(--cc-white);
  border-radius: 8px;
  padding: 10px 14px;
  font-size: 0.9rem;
  font-family: var(--font-body);
  transition: border-color var(--transition), box-shadow var(--transition);
}
.contact-form-card .form-control:focus {
  background: rgba(0, 20, 60, 0.80);
  border-color: rgba(0, 200, 255, 0.70);
  box-shadow: 0 0 0 3px rgba(0, 200, 255, 0.12);
  color: var(--cc-white);
  outline: none;
}
.contact-form-card .form-control::placeholder { color: rgba(200, 240, 255, 0.28); }
.contact-form-card textarea.form-control { resize: vertical; min-height: 110px; }

/* Section divider labels inside the form */
.form-section-label {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--cc-sky);
  margin-bottom: 14px;
  margin-top: 28px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.form-section-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: rgba(0, 170, 220, 0.25);
}

/* Inquiry type radio buttons */
.inquiry-radio {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  border-radius: 8px;
  cursor: pointer;
  transition: background var(--transition);
  margin-bottom: 4px;
}
.inquiry-radio:hover { background: rgba(0, 160, 220, 0.15); }
.inquiry-radio input[type="radio"] {
  accent-color: var(--cc-sky);
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  cursor: pointer;
}
.inquiry-radio span { font-size: 0.9rem; color: rgba(200, 240, 255, 0.82); }

/* Submit button */
.btn-submit-cc {
  background: rgba(0, 150, 220, 0.90);
  color: var(--cc-white);
  border: none;
  border-radius: 6px;
  padding: 14px 36px;
  font-weight: 600;
  font-size: 1rem;
  cursor: pointer;
  width: 100%;
  margin-top: 10px;
  transition: background var(--transition), transform var(--transition);
  letter-spacing: 0.03em;
}
.btn-submit-cc:hover { background: rgba(0, 180, 255, 1); transform: translateY(-1px); }

/* Form success banner */
.form-success {
  display: none;
  background: rgba(0, 180, 100, 0.18);
  border: 1px solid rgba(0, 220, 130, 0.45);
  border-radius: 10px;
  padding: 18px 20px;
  margin-top: 20px;
  color: rgba(180, 255, 220, 0.90);
  font-size: 0.92rem;
  line-height: 1.6;
  text-align: center;
}
.form-success i { font-size: 1.4rem; display: block; margin-bottom: 6px; color: #5fdc9a; }

/* Calendar column — sticky on desktop */
.calendar-col { position: sticky; top: 110px; align-self: flex-start; }

/* Calendar widget card */
.calendar-widget {
  background: rgba(0, 10, 40, 0.72);
  border: 1px solid rgba(0, 170, 220, 0.38);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: var(--radius-card);
  padding: 28px;
}
.cal-card-title {
  font-family: var(--font-display);
  font-size: 1.1rem;
  letter-spacing: 0.07em;
  color: var(--cc-white);
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.cal-card-title i { color: var(--cc-sky); }

/* Month nav header */
.cal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 18px;
}
.cal-month-label {
  font-family: var(--font-display);
  font-size: 1.35rem;
  letter-spacing: 0.06em;
  color: var(--cc-white);
}
.cal-nav-btn {
  background: rgba(0, 100, 180, 0.30);
  border: 1px solid rgba(0, 200, 255, 0.28);
  color: var(--cc-sky);
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 0.95rem;
  transition: background var(--transition), border-color var(--transition);
  padding: 0;
}
.cal-nav-btn:hover:not(:disabled) {
  background: rgba(0, 180, 255, 0.40);
  border-color: rgba(0, 220, 255, 0.60);
}
.cal-nav-btn:disabled { opacity: 0.28; cursor: default; }

/* Weekday row */
.cal-weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  margin-bottom: 6px;
}
.cal-weekday {
  text-align: center;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: rgba(200, 240, 255, 0.40);
  padding: 3px 0;
}

/* Day grid */
.cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 3px;
}
.cal-day {
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 7px;
  font-size: 0.86rem;
  font-weight: 500;
  user-select: none;
  cursor: default;
  transition: background var(--transition), color var(--transition), transform var(--transition);
}
.cal-day--empty     { background: transparent; }
.cal-day--past      { color: rgba(200, 240, 255, 0.18); }
.cal-day--unavailable { color: rgba(200, 240, 255, 0.22); }
.cal-day--available {
  color: var(--cc-sky);
  cursor: pointer;
  border: 1px solid rgba(0, 200, 255, 0.22);
  background: rgba(0, 100, 180, 0.18);
}
.cal-day--available:hover {
  background: rgba(0, 180, 255, 0.28);
  border-color: rgba(0, 220, 255, 0.55);
  transform: scale(1.1);
}
.cal-day--today { box-shadow: 0 0 0 2px rgba(0, 200, 255, 0.55); }
.cal-day--selected {
  background: rgba(0, 170, 255, 0.88) !important;
  color: var(--cc-white) !important;
  border-color: transparent !important;
  font-weight: 700;
  transform: scale(1.1);
  box-shadow: 0 4px 14px rgba(0, 180, 255, 0.40);
}

/* Legend */
.cal-legend { display: flex; gap: 14px; margin-top: 14px; flex-wrap: wrap; }
.cal-legend-item {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 0.75rem;
  color: rgba(200, 240, 255, 0.50);
}
.cal-legend-dot { width: 10px; height: 10px; border-radius: 3px; flex-shrink: 0; }
.cal-legend-dot--available {
  background: rgba(0, 180, 255, 0.60);
  border: 1px solid rgba(0, 220, 255, 0.45);
}
.cal-legend-dot--unavailable { background: rgba(200, 240, 255, 0.15); }
.cal-legend-dot--selected    { background: rgba(0, 170, 255, 0.90); }

/* Time slot picker */
.time-slots {
  display: none;
  margin-top: 22px;
  padding-top: 20px;
  border-top: 1px solid rgba(0, 170, 220, 0.25);
}
.time-slots__header {
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(200, 240, 255, 0.65);
  margin-bottom: 8px;
}
.time-slots__date {
  font-family: var(--font-display);
  font-size: 1rem;
  letter-spacing: 0.05em;
  color: var(--cc-sky);
  margin-bottom: 14px;
}
.time-slots__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.time-slot-btn {
  background: rgba(0, 20, 60, 0.60);
  border: 1px solid rgba(0, 170, 220, 0.32);
  color: rgba(200, 240, 255, 0.82);
  border-radius: 8px;
  padding: 9px 6px;
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  text-align: center;
  font-family: var(--font-body);
  transition: background var(--transition), border-color var(--transition), color var(--transition);
}
.time-slot-btn:hover:not(:disabled):not(.booked) {
  background: rgba(0, 150, 220, 0.35);
  border-color: rgba(0, 220, 255, 0.55);
  color: var(--cc-sky);
}
.time-slot-btn.booked { opacity: 0.28; cursor: not-allowed; text-decoration: line-through; }
.time-slot-btn.selected {
  background: rgba(0, 170, 255, 0.85);
  border-color: transparent;
  color: var(--cc-white);
  box-shadow: 0 3px 12px rgba(0, 180, 255, 0.35);
}

/* Appointment summary */
.appt-summary {
  display: none;
  margin-top: 16px;
  background: rgba(0, 150, 220, 0.15);
  border: 1px solid rgba(0, 200, 255, 0.30);
  border-radius: 10px;
  padding: 14px 16px;
  font-size: 0.86rem;
  color: rgba(200, 240, 255, 0.85);
  line-height: 1.7;
}
.appt-summary strong { color: var(--cc-sky); }

/* Booking service tabs */
.booking-tabs {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.booking-tab {
  background: rgba(0, 20, 60, 0.60);
  border: 1px solid rgba(0, 170, 220, 0.35);
  color: rgba(200, 240, 255, 0.70);
  border-radius: 8px;
  padding: 8px 14px;
  font-size: 0.82rem;
  font-weight: 600;
  font-family: var(--font-body);
  cursor: pointer;
  transition: background var(--transition), border-color var(--transition), color var(--transition);
  white-space: nowrap;
}
.booking-tab:hover {
  background: rgba(0, 150, 220, 0.25);
  border-color: rgba(0, 220, 255, 0.50);
  color: var(--cc-sky);
}
.booking-tab.active {
  background: rgba(0, 170, 255, 0.85);
  border-color: transparent;
  color: var(--cc-white);
}

/* Booking iframe */
.booking-iframe {
  width: 100%;
  height: 620px;
  border: none;
  border-radius: 10px;
  display: block;
}

/* Contact page responsive */
@media (max-width: 991px) {
  .calendar-col { position: static; }
}

/* ─── Service Areas Page ─────────────────────────────────────── */
.service-area-section { padding: 60px 0 80px; }

/* Map */
.map-container {
  width: 100%;
  border-radius: var(--radius-card);
  overflow: hidden;
  border: 1px solid rgba(0, 170, 220, 0.38);
  margin-bottom: 64px;
  box-shadow: 0 8px 40px rgba(0, 0, 0, 0.45);
}
.map-frame {
  width: 100%;
  height: 420px;
  border: none;
  display: block;
}

/* Cards intro text */
.areas-eyebrow {
  font-size: 0.76rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--cc-sky);
  text-align: center;
  margin-bottom: 8px;
}
.areas-heading {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 3.5vw, 2.2rem);
  letter-spacing: 0.06em;
  color: var(--cc-white);
  text-align: center;
  margin-bottom: 40px;
}

/* Service area card */
.area-card {
  background: rgba(0, 10, 40, 0.72);
  border: 1px solid rgba(0, 170, 220, 0.38);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: var(--radius-card);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  height: 100%;
  text-decoration: none;
  color: inherit;
  transition: box-shadow var(--transition), transform var(--transition), border-color var(--transition);
}
.area-card:hover {
  box-shadow: 0 8px 32px rgba(0, 180, 255, 0.35);
  border-color: rgba(0, 220, 255, 0.60);
  transform: translateY(-4px);
  color: inherit;
  text-decoration: none;
}
.area-card__icon {
  font-size: 1.3rem;
  color: var(--cc-sky);
  margin-bottom: 12px;
}
.area-card__name {
  font-family: var(--font-display);
  font-size: 1.35rem;
  letter-spacing: 0.06em;
  color: var(--cc-white);
  margin-bottom: 10px;
}
.area-card__text {
  font-size: 0.86rem;
  line-height: 1.65;
  color: rgba(200, 240, 255, 0.72);
  flex: 1;
  margin-bottom: 18px;
}
.area-card__cta {
  font-size: 0.80rem;
  font-weight: 600;
  color: var(--cc-sky);
  letter-spacing: 0.05em;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: gap var(--transition);
}
.area-card:hover .area-card__cta { gap: 10px; }
@media (max-width: 576px) {
  .contact-form-card { padding: 20px; }
  .calendar-widget   { padding: 18px; }
  .time-slots__grid  { grid-template-columns: repeat(2, 1fr); }
}

/* ─── Promotions Page ────────────────────────────────────────── */
.promotions-section { padding: 60px 0 80px; }

.promo-page-card {
  background: rgba(0, 10, 40, 0.72);
  border: 1px solid rgba(0, 170, 220, 0.38);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: var(--radius-card);
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  text-align: center;
  height: 100%;
  overflow: hidden;
  transition: box-shadow var(--transition), transform var(--transition), border-color var(--transition);
}
.promo-page-card:hover {
  box-shadow: 0 8px 32px rgba(0, 180, 255, 0.35);
  border-color: rgba(0, 220, 255, 0.60);
  transform: translateY(-4px);
}
.promo-page-card__img {
  width: 100%;
  aspect-ratio: 4/3;
  overflow: hidden;
  flex-shrink: 0;
}
.promo-page-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
.promo-page-card__body {
  padding: 24px 24px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
}
.promo-page-card__title {
  font-family: var(--font-display);
  font-size: 1.25rem;
  letter-spacing: 0.06em;
  color: var(--cc-white);
  margin-bottom: 12px;
  line-height: 1.2;
}
.promo-page-card__text {
  font-size: 0.88rem;
  line-height: 1.7;
  color: rgba(200, 240, 255, 0.75);
  flex: 1;
  margin-bottom: 24px;
}
.promo-page-card__btn {
  display: block;
  width: 100%;
  background: rgba(0, 150, 220, 0.90);
  color: var(--cc-white);
  border: none;
  border-radius: 6px;
  padding: 12px 20px;
  font-weight: 700;
  font-size: 0.95rem;
  letter-spacing: 0.04em;
  cursor: pointer;
  text-decoration: none;
  text-align: center;
  transition: background var(--transition), transform var(--transition);
}
.promo-page-card__btn:hover {
  background: rgba(0, 180, 255, 1);
  color: var(--cc-white);
  text-decoration: none;
  transform: translateY(-1px);
}

/* ═══════════════════════════════════════════════
   MOBILE & RESPONSIVE — all pages
═══════════════════════════════════════════════ */

/* ── Nav: hide service links on phones & small tablets ── */
/* The top bar already has phone, email, and Schedule CTA  */
@media (max-width: 767px) {
  .main-nav .nav-services { display: none; }
}

/* ── Top bar mobile: single row, hide Contact Us link ── */
@media (max-width: 767px) {
  .top-bar { padding: 6px 0; }
  .top-bar .row { flex-wrap: nowrap; align-items: center; }
  .top-bar .col-12.col-md-5 { flex: 0 0 auto; width: auto; }
  .top-bar .col-12.col-md-7 { flex: 1; width: auto; }
  .top-bar .top-bar__contacts { flex-wrap: nowrap; justify-content: flex-end; gap: 8px; }
  .top-bar .top-bar__contacts a[href="contact.html"] { display: none; }
}

/* ── Top bar: tighten spacing on very small phones ── */
@media (max-width: 400px) {
  .top-bar .top-bar__contacts { gap: 8px; flex-wrap: wrap; }
  .top-bar .top-bar__contacts a { font-size: 0.76rem; }
  .top-bar .btn-schedule { padding: 4px 10px; }
}

/* ── TikTok carousel: 2-up on tablet, 1-up on mobile ── */
@media (max-width: 991px) {
  .tiktok-carousel__track { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
  .tiktok-carousel__track { grid-template-columns: 1fr; }
  /* Pad bottom to make room for buttons sitting below the video */
  .tiktok-carousel {
    padding-left: 0 !important;
    padding-right: 0 !important;
    padding-bottom: 64px;
  }
  /* Move buttons below the iframe so touches aren't swallowed by it */
  .carousel-btn {
    top: auto;
    transform: none;
    bottom: 0;
  }
  .carousel-btn--prev { left: calc(50% - 56px); }
  .carousel-btn--next { right: calc(50% - 56px); left: auto; }
}

/* ── Map: shorter on mobile ── */
@media (max-width: 767px) {
  .map-frame { height: 260px; }
  .map-container { margin-bottom: 40px; }
}

/* ── Hero image placeholder: don't waste too much vertical space ── */
@media (max-width: 991px) {
  .hero__img-placeholder { min-height: 220px; }
}

/* ── Section padding: reduce on mobile ── */
@media (max-width: 767px) {
  .section { padding: 48px 0; }
  .technicians-section { padding: 48px 0; }
  .tiktok-section { padding: 48px 0; }
  .service-area-section { padding: 40px 0 60px; }
  .promotions-section { padding: 40px 0 60px; }
  .contact-section { padding: 40px 0 60px; }
}

/* ── Promo page cards: reduce padding on small phones ── */
@media (max-width: 576px) {
  .promo-page-card__body { padding: 18px 16px 18px; }
}

/* ── Area cards: reduce padding on small phones ── */
@media (max-width: 576px) {
  .area-card { padding: 22px 18px; }
}

/* ── Footer: stack address block cleanly on mobile ── */
@media (max-width: 767px) {
  .site-footer { padding: 40px 0 24px; }
  .footer-logo { margin-bottom: 10px; }
}
