:root {
      --bg: #f4f1eb;
      --surface: rgba(255,255,255,.92);
      --surface-strong: rgba(255,255,255,.97);
      --text: #10151b;
      --muted: #64707c;
      --line: rgba(16,21,27,.08);
      --accent: #18354f;
      --accent-soft: rgba(24,53,79,.08);
      --shadow: 0 18px 50px rgba(10,24,38,.10);
      --radius: 24px;
      --radius-sm: 18px;
    }

    html { scroll-behavior: smooth; }
    body {
      font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
      background:
        radial-gradient(circle at top left, rgba(24,53,79,.08), transparent 24%),
        radial-gradient(circle at 90% 8%, rgba(127,154,177,.14), transparent 18%),
        var(--bg);
      color: var(--text);
      letter-spacing: -0.01em;
    }

    .navbar {
      backdrop-filter: blur(16px);
      background: rgba(244,241,235,.78);
      border-bottom: 1px solid rgba(16,21,27,.06);
      padding-top: .3rem;
      padding-bottom: .3rem;
    }

    .navbar-brand {
      font-weight: 800;
      letter-spacing: .12em;
      text-transform: uppercase;
      font-size: .88rem;
    }

    .nav-link {
      color: rgba(16,21,27,.72);
      font-weight: 500;
    }

    .nav-link:hover,
    .nav-link:focus {
      color: var(--accent) !important;
    }

    .nav-shell {
      position: relative;
      min-height: 56px;
    }

    .nav-center-slot {
      position: absolute;
      left: 50%;
      top: 50%;
      transform: translate(-50%, -50%);
      z-index: 2;
      pointer-events: none;
    }

    .utc-clock {
      display: inline-flex;
      align-items: center;
      gap: .55rem;
      padding: .42rem .78rem;
      border-radius: 999px;
      background: rgba(255,255,255,.44);
      border: 1px solid rgba(16,21,27,.08);
      box-shadow: 0 10px 24px rgba(10,24,38,.06);
      backdrop-filter: blur(10px);
      white-space: nowrap;
      pointer-events: none;
    }

    .utc-clock__label {
      font-size: .68rem;
      font-weight: 700;
      letter-spacing: .18em;
      text-transform: uppercase;
      color: var(--muted);
    }

    .utc-clock__time {
      font-size: .82rem;
      font-weight: 800;
      letter-spacing: .18em;
      text-transform: uppercase;
      color: var(--accent);
      font-variant-numeric: tabular-nums;
    }

    .hero {
      position: relative;
      padding: 7rem 0 6rem;
      overflow: hidden;
      min-height: 76vh;
      display: flex;
      align-items: end;
    }

    .hero::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        linear-gradient(115deg, rgba(8,14,22,.82), rgba(24,53,79,.38)),
        url('../../images/halo.jpeg') center center / cover no-repeat;
      opacity: .98;
    }

    .hero > .container,
    .services-overlap,
    .section-card,
    .service-card,
    .about-card,
    .contact-card,
    .stat-card {
      position: relative;
      z-index: 1;
    }

    .eyebrow {
      display: inline-flex;
      align-items: center;
      gap: .65rem;
      padding: .5rem .9rem;
      border-radius: 999px;
      background: rgba(255,255,255,.10);
      border: 1px solid rgba(255,255,255,.14);
      color: #fff;
      font-size: .8rem;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: .08em;
      backdrop-filter: blur(8px);
    }

    .dot {
      width: 8px;
      height: 8px;
      border-radius: 50%;
      background: #dbe8f5;
      display: inline-block;
    }

    .hero-title {
      color: #fff;
      font-weight: 800;
      font-size: clamp(2.2rem, 4vw, 4rem);
      line-height: .95;
      letter-spacing: -0.05em;
      max-width: 11ch;
      margin: 1rem 0 1rem;
    }

    .hero-copy {
      color: rgba(255,255,255,.86);
      font-size: 1.04rem;
      line-height: 1.8;
      max-width: 42rem;
      margin-bottom: 0;
    }

    .hero-panel {
      background: rgba(255,255,255,.12);
      border: 1px solid rgba(255,255,255,.16);
      border-radius: var(--radius);
      padding: 1.3rem;
      box-shadow: 0 18px 50px rgba(0,0,0,.16);
      backdrop-filter: blur(10px);
      color: #fff;
      max-width: 28rem;
      margin-left: auto;
    }

    .hero-panel h3 {
      font-size: 1rem;
      font-weight: 700;
      margin-bottom: .8rem;
    }

    .hero-panel p {
      color: rgba(255,255,255,.82);
      line-height: 1.7;
      margin-bottom: 0;
    }

    .services-overlap {
      margin-top: -88px;
      padding-bottom: 1rem;
    }

    .service-card,
    .section-card,
    .about-card,
    .contact-card {
      background: var(--surface);
      border: 1px solid rgba(255,255,255,.76);
      border-radius: var(--radius);
      box-shadow: var(--shadow);
      backdrop-filter: blur(12px);
      height: 100%;
    }

    .service-card,
    .section-card,
    .about-card,
    .contact-card {
      padding: 1.65rem;
    }

    .service-card {
      transition: transform .2s ease, box-shadow .2s ease;
    }

    .service-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 24px 60px rgba(10,24,38,.14);
    }

    .service-icon {
      width: 52px;
      height: 52px;
      border-radius: 16px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: var(--accent-soft);
      color: var(--accent);
      margin-bottom: 1rem;
    }

    .service-card h3,
    .about-card h2,
    .section-card h2,
    .contact-card h2 {
      font-weight: 750;
      letter-spacing: -0.03em;
    }

    .service-card h3 {
      font-size: 1.16rem;
      margin-bottom: .8rem;
    }

    .service-card p,
    .section-card p,
    .about-card p,
    .contact-card p,
    .service-card li {
      color: var(--muted);
      line-height: 1.78;
      margin-bottom: 0;
    }

    section {
      padding: 2rem 0 4.2rem;
    }

    .section-label {
      color: var(--accent);
      font-size: .8rem;
      letter-spacing: .14em;
      text-transform: uppercase;
      font-weight: 700;
      margin-bottom: .75rem;
    }

    .section-title {
      font-size: clamp(1.9rem, 3vw, 2.8rem);
      line-height: 1.03;
      letter-spacing: -0.04em;
      margin-bottom: 1rem;
    }

    .portrait-wrap {
      position: relative;
      border-radius: 20px;
      overflow: hidden;
      width: 170px;
      margin: 0 auto;
      box-shadow: 0 18px 44px rgba(11,22,34,.12);
      background: rgba(255,255,255,.55);
      border: 1px solid rgba(16,21,27,.06);
    }

    .portrait-wrap img {
      width: 100%;
      display: block;
      aspect-ratio: 4 / 5;
      object-fit: cover;
      object-position: center top;
    }

    .about-grid {
      display: grid;
      grid-template-columns: 170px 1fr;
      gap: 1.5rem;
      align-items: start;
    }

    .about-intro {
      font-size: 1.04rem;
      color: var(--text) !important;
      line-height: 1.82;
      margin-bottom: .9rem !important;
    }

    .about-note {
      margin-bottom: 0;
    }

    .about-sections {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: .9rem;
      margin-top: 1.25rem;
    }

    .about-block {
      padding: 1rem 1rem .95rem;
      border-radius: 18px;
      background: var(--surface-strong);
      border: 1px solid var(--line);
    }

    .about-block h3 {
      font-size: .82rem;
      letter-spacing: .12em;
      text-transform: uppercase;
      color: var(--accent);
      margin-bottom: .65rem;
      font-weight: 800;
    }

    .about-block p {
      margin-bottom: 0;
      color: var(--muted);
      line-height: 1.72;
    }

    .about-block ul {
      list-style: none;
      padding: 0;
      margin: 0;
    }

    .about-block li {
      position: relative;
      padding-left: 1rem;
      margin-bottom: .55rem;
      color: var(--muted);
      line-height: 1.7;
    }

    .about-block li:last-child {
      margin-bottom: 0;
    }

    .about-block li::before {
      content: "";
      position: absolute;
      left: 0;
      top: .72rem;
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: var(--accent);
      opacity: .7;
    }

    @media (max-width: 767.98px) {
      .about-grid {
        grid-template-columns: 1fr;
      }

      .portrait-wrap {
        width: 150px;
        margin: 0 0 1rem;
      }

      .about-sections {
        grid-template-columns: 1fr;
      }
    }

    .stat-card {
      background: var(--surface-strong);
      border: 1px solid var(--line);
      border-radius: 18px;
      padding: 1rem 1rem .95rem;
      height: 100%;
    }

    .stat-card strong {
      display: block;
      color: var(--accent);
      font-size: 1.35rem;
      font-weight: 800;
      line-height: 1;
      margin-bottom: .35rem;
    }

    .bullet-list {
      list-style: none;
      padding: 0;
      margin: 1rem 0 0;
    }

    .bullet-list li {
      position: relative;
      padding-left: 1.15rem;
      margin-bottom: .65rem;
    }

    .bullet-list li::before {
      content: "";
      position: absolute;
      left: 0;
      top: .72rem;
      width: 7px;
      height: 7px;
      border-radius: 50%;
      background: var(--accent);
      opacity: .7;
    }

    .contact-strip {
      display: flex;
      flex-wrap: wrap;
      gap: .8rem;
      margin-top: 1.25rem;
    }

    .contact-pill {
      display: inline-flex;
      align-items: center;
      gap: .5rem;
      border-radius: 999px;
      padding: .72rem 1rem;
      text-decoration: none;
      font-weight: 600;
      color: var(--text);
      background: rgba(24,53,79,.05);
      border: 1px solid rgba(24,53,79,.08);
    }

    .contact-pill:hover {
      color: var(--accent);
      background: rgba(24,53,79,.08);
    }

    .btn-premium {
      background: var(--accent);
      color: #fff;
      border: 0;
      border-radius: 999px;
      padding: .92rem 1.2rem;
      font-weight: 650;
    }

    .btn-premium:hover {
      background: #10283d;
      color: #fff;
    }

    footer {
      padding: 0 0 2.5rem;
      color: rgba(16,21,27,.56);
      font-size: .94rem;
    }
.hero-panel {
        margin: 1.5rem 0 0;
        max-width: none;
      }

      .services-overlap {
        margin-top: -52px;
      }
    }

    @media (max-width: 767.98px) {
      .services-overlap {
        margin-top: -38px;
      }

      .service-card,
      .section-card,
      .about-card,
      .contact-card {
        padding: 1.35rem;
      }
    }
.contact-grid {
      display: grid;
      grid-template-columns: 1.1fr .9fr;
      gap: 1.5rem;
      align-items: stretch;
    }

    .contact-left {
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      min-height: 100%;
    }
.contact-detail-card {
      background: var(--surface-strong);
      border: 1px solid var(--line);
      border-radius: 18px;
      padding: 1rem 1rem .95rem;
      height: 100%;
    }

    .contact-detail-label {
      font-size: .76rem;
      letter-spacing: .12em;
      text-transform: uppercase;
      color: var(--accent);
      font-weight: 800;
      margin-bottom: .4rem;
    }

    .contact-detail-value {
      color: var(--text);
      font-weight: 600;
      line-height: 1.65;
      word-break: break-word;
    }

    .contact-detail-value a {
      color: inherit;
      text-decoration: none;
    }

    .contact-detail-value a:hover {
      color: var(--accent);
    }

    .contact-action {
      margin-top: 1.5rem;
    }

    .contact-note {
      margin-top: 1rem;
      color: var(--muted);
      font-size: .95rem;
    }
}


    .contact-full {
      padding: 0;
      overflow: hidden;
    }

    .contact-grid {
      display: grid;
      grid-template-columns: 1.05fr .95fr;
      align-items: stretch;
      min-height: 100%;
    }

    .contact-pane {
      padding: 2rem 2rem 2rem 2.05rem;
      display: flex;
      flex-direction: column;
      justify-content: center;
    }

    .contact-kicker {
      color: var(--accent);
      font-size: .78rem;
      letter-spacing: .14em;
      text-transform: uppercase;
      font-weight: 700;
      margin-bottom: .8rem;
    }

    .contact-title-compact {
      font-size: clamp(1.7rem, 2.7vw, 2.3rem);
      line-height: 1.04;
      letter-spacing: -0.04em;
      margin-bottom: .9rem;
      font-weight: 760;
      max-width: 12ch;
    }

    .contact-copy-main {
      color: var(--muted);
      line-height: 1.75;
      margin-bottom: 1.2rem;
      max-width: 34rem;
    }

    .contact-email-card {
      display: inline-flex;
      align-items: center;
      gap: .75rem;
      padding: .85rem 1rem;
      border-radius: 16px;
      background: var(--surface-strong);
      border: 1px solid var(--line);
      margin-bottom: 1.2rem;
      width: fit-content;
      max-width: 100%;
    }

    .contact-email-card strong {
      font-size: .76rem;
      letter-spacing: .12em;
      text-transform: uppercase;
      color: var(--accent);
      font-weight: 800;
      white-space: nowrap;
    }

    .contact-email-card a {
      color: var(--text);
      text-decoration: none;
      font-weight: 600;
      word-break: break-word;
    }

    .contact-email-card a:hover {
      color: var(--accent);
    }

    .contact-image {
      position: relative;
      min-height: 360px;
      background: #d7dbe0;
      border-radius: 24px;
      overflow: hidden;
    }

    .contact-image img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center center;
      display: block;
    }

    .contact-image::after {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(90deg, rgba(244,241,235,.08) 0%, rgba(244,241,235,0) 18%, rgba(10,16,24,.06) 100%);
      pointer-events: none;
    }

    @media (max-width: 991.98px) {
      .contact-grid {
        grid-template-columns: 1fr;
      }

      .contact-pane {
        padding: 1.6rem;
      }

      .contact-image {
        min-height: 260px;
        order: -1;
      }
    }

.page-hero { padding: 10rem 0 4rem; }
.page-hero .section-card { max-width: 900px; }
.active-nav { color: var(--accent) !important; }
.hero-list { margin: 0; padding-left: 1.15rem; color: rgba(255,255,255,.82); line-height: 1.7; }
.hero-list li { margin-bottom: .35rem; }


.dropdown-menu {
  border: 1px solid rgba(16,21,27,.08);
  border-radius: 18px;
  padding: .6rem;
  background: rgba(255,255,255,.96);
  box-shadow: 0 20px 50px rgba(10,24,38,.12);
  backdrop-filter: blur(12px);
  min-width: 290px;
}

.dropdown-item-text {
  display: block;
  padding: .72rem .9rem;
  border-radius: 12px;
  color: rgba(16,21,27,.82);
  font-weight: 500;
  white-space: normal;
}

.dropdown-item-text + .dropdown-item-text {
  margin-top: .2rem;
}

.services-toggle::after {
  margin-left: .45rem;
}

.dropdown-item-text:hover,
.dropdown-item-text:focus {
  background: rgba(24,53,79,.06);
}

@media (max-width: 991.98px) {
  .dropdown-menu {
    border: 0;
    box-shadow: none;
    background: transparent;
    padding: .2rem 0 0;
    min-width: 100%;
  }

  .dropdown-item-text {
    padding: .5rem 0 .5rem 1rem;
  }
}


    @media (max-width: 991.98px) {
      .nav-shell {
        align-items: center;
      }

      .utc-clock--mobile {
        position: static;
        transform: none;
        translate: 0 0;
        display: inline-flex;
        margin: .35rem 0 .25rem;
        pointer-events: auto;
      }

      .navbar-collapse {
        padding-top: .6rem;
      }
    }
