    /* ============================================================
       DESIGN TOKENS
       Simple corporate palette inspired by TÜV-style B2B sites:
       deep blue primary, white surfaces, soft grey backgrounds,
       red accent reserved for emphasis only.
       ============================================================ */
    :root {
      --color-primary:        #1a4d8c;
      --color-primary-dark:   #133b6c;
      --color-primary-soft:   #e8f0fa;
      --color-accent:         #d52b1e;

      --color-text:           #1a1a1a;
      --color-text-soft:      #595959;
      --color-text-muted:     #8a8a8a;

      --color-bg:             #ffffff;
      --color-bg-soft:        #f7f8fa;
      --color-bg-deep:        #0f2a4d;

      --color-border:         #e6e6e6;
      --color-border-strong:  #cccccc;

      --container:            1240px;
      --gap:                  24px;
      --radius:               4px;

      --transition:           180ms ease;
    }

    /* ============================================================
       RESET & BASELINE
       ============================================================ */
    *, *::before, *::after { box-sizing: border-box; }
    html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
    body {
      margin: 0;
      font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
      font-size: 16px;
      line-height: 1.55;
      color: var(--color-text);
      background: var(--color-bg);
      -webkit-font-smoothing: antialiased;
    }
    img { max-width: 100%; display: block; }
    a { color: var(--color-primary); text-decoration: none; transition: color var(--transition); }
    a:hover { color: var(--color-primary-dark); }
    button { font-family: inherit; cursor: pointer; }

    .container {
      max-width: var(--container);
      margin: 0 auto;
      padding: 0 24px;
    }

    /* ============================================================
       BUTTONS
       ============================================================ */
    .btn {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      padding: 12px 22px;
      font-size: 15px;
      font-weight: 600;
      line-height: 1.2;
      border: 1px solid transparent;
      border-radius: var(--radius);
      transition: background var(--transition), color var(--transition), border-color var(--transition);
      cursor: pointer;
      text-decoration: none;
    }
    .btn--primary {
      background: var(--color-primary);
      color: #fff;
      border-color: var(--color-primary);
    }
    .btn--primary:hover {
      background: var(--color-primary-dark);
      border-color: var(--color-primary-dark);
      color: #fff;
    }
    .btn--ghost {
      background: transparent;
      color: var(--color-primary);
      border-color: var(--color-primary);
    }
    .btn--ghost:hover {
      background: var(--color-primary-soft);
      color: var(--color-primary-dark);
    }
    .btn--white {
      background: #fff;
      color: var(--color-primary);
      border-color: #fff;
    }
    .btn--white:hover {
      background: var(--color-primary-soft);
      color: var(--color-primary-dark);
    }
    .btn__arrow { width: 14px; height: 14px; }

    /* ============================================================
       BRAND RIBBON (3px red signature line on top of page)
       ============================================================ */
    .brand-bar {
      height: 3px;
      background: var(--color-accent);
    }

    /* ============================================================
       UTILITY BAR (top thin strip)
       ============================================================ */
    .utility {
      background: #fff;
      border-bottom: 1px solid var(--color-border);
      font-size: 13px;
      color: var(--color-text-soft);
    }
    .utility__row {
      display: flex;
      align-items: center;
      justify-content: flex-end;
      gap: 24px;
      height: 38px;
    }
    .utility a {
      color: var(--color-text-soft);
      text-decoration: none;
    }
    .utility a:hover { color: var(--color-primary); }
    .utility__sep {
      width: 1px;
      height: 14px;
      background: var(--color-border-strong);
    }
    .utility__lang {
      display: inline-flex;
      align-items: center;
      gap: 6px;
    }

    /* Language dropdown */
    .lang {
      position: relative;
      display: inline-flex;
      align-items: center;
    }
    .lang__trigger {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 0;
      background: transparent;
      border: none;
      font: inherit;
      font-size: 13px;
      color: var(--color-text-soft);
      cursor: pointer;
    }
    .lang__trigger:hover { color: var(--color-primary); }
    .lang__caret {
      width: 10px;
      height: 10px;
      transition: transform var(--transition);
    }
    .lang.is-open .lang__caret { transform: rotate(180deg); }
    .lang__menu {
      position: absolute;
      top: calc(100% + 8px);
      right: 0;
      min-width: 160px;
      background: #fff;
      border: 1px solid var(--color-border);
      border-radius: var(--radius);
      box-shadow: 0 12px 32px rgba(15, 42, 77, 0.12);
      list-style: none;
      margin: 0;
      padding: 4px;
      display: none;
      z-index: 110;
    }
    .lang.is-open .lang__menu { display: block; }
    .lang__opt {
      display: block;
      width: 100%;
      text-align: left;
      padding: 9px 12px;
      background: transparent;
      border: none;
      font: inherit;
      font-size: 14px;
      color: var(--color-text);
      cursor: pointer;
      border-radius: calc(var(--radius));
    }
    .lang__opt:hover {
      background: var(--color-bg-soft);
      color: var(--color-primary);
    }
    .lang__opt.is-active {
      color: var(--color-primary);
      font-weight: 600;
    }

    /* ============================================================
       HEADER & NAVIGATION
       ============================================================ */
    .header {
      background: #fff;
      border-bottom: 1px solid var(--color-border);
      position: sticky;
      top: 0;
      z-index: 100;
    }
    .header__row {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 32px;
      height: 76px;
    }
    .logo {
      display: inline-flex;
      align-items: center;
      height: 38px;
      text-decoration: none;
    }
    .logo img {
      height: 100%;
      width: auto;
      display: block;
    }
    .footer .logo { height: 42px; }
    @media (max-width: 720px) {
      .logo { height: 32px; }
    }
    .nav {
      display: flex;
      align-items: center;
      gap: 4px;
    }
    .nav__link {
      position: relative;
      padding: 10px 4px;
      margin: 0 12px;
      font-size: 15px;
      font-weight: 500;
      color: var(--color-text);
      text-decoration: none;
      transition: color var(--transition);
    }
    .nav__link::after {
      content: '';
      position: absolute;
      left: 4px;
      right: 4px;
      bottom: 4px;
      height: 2px;
      background: var(--color-primary);
      transform: scaleX(0);
      transform-origin: left center;
      transition: transform 320ms cubic-bezier(0.4, 0, 0.2, 1);
    }
    .nav__link:hover {
      color: var(--color-primary);
    }
    .nav__link:hover::after {
      transform: scaleX(1);
    }
    .header__cta {
      display: flex;
      align-items: center;
      gap: 16px;
    }
    .header__search {
      width: 38px;
      height: 38px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border: 1px solid var(--color-border);
      border-radius: var(--radius);
      background: #fff;
      color: var(--color-text-soft);
      transition: border-color var(--transition), color var(--transition);
    }
    .header__search:hover {
      border-color: var(--color-primary);
      color: var(--color-primary);
    }

    /* Mobile burger (hidden on desktop) */
    .header__burger {
      display: none;
      width: 40px;
      height: 40px;
      align-items: center;
      justify-content: center;
      background: transparent;
      border: 1px solid var(--color-border);
      border-radius: var(--radius);
    }
    .header__burger span {
      display: block;
      width: 18px;
      height: 2px;
      background: var(--color-text);
      position: relative;
    }
    .header__burger span::before,
    .header__burger span::after {
      content: '';
      position: absolute;
      left: 0;
      width: 18px;
      height: 2px;
      background: var(--color-text);
    }
    .header__burger span::before { top: -6px; }
    .header__burger span::after  { top:  6px; }

    /* ============================================================
       HERO
       ============================================================ */
    .hero {
      background: var(--color-bg);
      padding: 72px 0 88px;
      border-bottom: 1px solid var(--color-border);
    }
    .hero__grid {
      display: grid;
      grid-template-columns: 1.05fr 1fr;
      gap: 64px;
      align-items: center;
    }
    .hero__eyebrow {
      display: inline-block;
      font-size: 13px;
      font-weight: 600;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: var(--color-primary);
      margin-bottom: 20px;
    }
    .hero__title {
      font-size: clamp(34px, 4.4vw, 56px);
      line-height: 1.08;
      font-weight: 700;
      letter-spacing: -0.02em;
      color: var(--color-text);
      margin: 0 0 24px;
    }
    .hero__lede {
      font-size: 18px;
      line-height: 1.6;
      color: var(--color-text-soft);
      max-width: 540px;
      margin: 0 0 32px;
    }
    .hero__actions {
      display: flex;
      gap: 12px;
      flex-wrap: wrap;
    }
    .hero__media {
      position: relative;
      aspect-ratio: 4 / 3;
      border-radius: var(--radius);
      overflow: hidden;
      background-image: url('../assets/hero.jpg');
      background-size: cover;
      background-position: center;
      background-color: var(--color-primary); /* fallback while loading */
    }
    .hero__media::after {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, rgba(0,0,0,0) 60%, rgba(15,30,58,0.45) 100%);
    }
    .hero__media-caption {
      position: absolute;
      left: 24px;
      bottom: 22px;
      color: #fff;
      font-size: 13px;
      font-weight: 500;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      opacity: 0.85;
      z-index: 1;
    }

    /* ============================================================
       SECTION COMMONS
       ============================================================ */
    section { padding: 80px 0; }
    .section__head {
      max-width: 720px;
      margin: 0 0 48px;
    }
    .section__eyebrow {
      display: inline-block;
      font-size: 13px;
      font-weight: 600;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: var(--color-primary);
      margin-bottom: 14px;
    }
    .section__title {
      font-size: clamp(28px, 3.2vw, 40px);
      line-height: 1.15;
      font-weight: 700;
      letter-spacing: -0.015em;
      color: var(--color-text);
      margin: 0 0 16px;
    }
    .section__lede {
      font-size: 17px;
      line-height: 1.6;
      color: var(--color-text-soft);
      margin: 0;
    }

    /* ============================================================
       SERVICES TILES (3×2)
       ============================================================ */
    .services {
      background: var(--color-bg-soft);
    }
    .services__grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 1px;
      background: var(--color-border);
      border: 1px solid var(--color-border);
    }
    .service {
      background: #fff;
      padding: 32px 28px 28px;
      display: flex;
      flex-direction: column;
      gap: 16px;
      text-decoration: none;
      color: var(--color-text);
      transition: background var(--transition);
    }
    .service:hover {
      background: var(--color-primary-soft);
      color: var(--color-text);
    }
    .service__icon {
      width: 40px;
      height: 40px;
      color: var(--color-primary);
      display: inline-flex;
      align-items: center;
      justify-content: center;
    }
    .service__icon svg {
      width: 100%;
      height: 100%;
      stroke: currentColor;
      stroke-width: 1.5;
      fill: none;
      stroke-linecap: round;
      stroke-linejoin: round;
    }
    .service__title {
      font-size: 18px;
      font-weight: 600;
      line-height: 1.3;
      margin: 0;
    }
    .service__desc {
      font-size: 14px;
      line-height: 1.55;
      color: var(--color-text-soft);
      margin: 0;
      flex: 1;
    }
    .service__more {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      font-size: 14px;
      font-weight: 600;
      color: var(--color-primary);
    }
    .service__more svg {
      width: 14px; height: 14px;
      transition: transform var(--transition);
    }
    .service:hover .service__more svg { transform: translateX(3px); }

    /* ============================================================
       INDUSTRIES (3×2 grid with gradient covers)
       ============================================================ */
    .industries__grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;
    }
    .industry {
      display: flex;
      flex-direction: column;
      text-decoration: none;
      color: var(--color-text);
      background: #fff;
      border: 1px solid var(--color-border);
      border-radius: var(--radius);
      overflow: hidden;
      transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
    }
    .industry:hover {
      border-color: var(--color-primary);
      box-shadow: 0 12px 32px rgba(15, 42, 77, 0.10);
      transform: translateY(-2px);
    }
    .industry__cover {
      aspect-ratio: 16 / 9;
      position: relative;
      overflow: hidden;
      background-image: linear-gradient(135deg, var(--c1, #1a4d8c), var(--c2, #0f2a4d));
      background-size: cover;
      background-position: center;
      background-color: var(--c1, #1a4d8c);
    }
    .industry__cover::after {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(135deg, rgba(0,0,0,0.40) 0%, rgba(0,0,0,0) 35%, rgba(0,0,0,0) 65%, rgba(0,0,0,0.50) 100%);
      pointer-events: none;
    }
    .industry__cover-mark {
      position: absolute;
      top: 16px;
      left: 16px;
      font-size: 12px;
      font-weight: 600;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.85);
      z-index: 1;
    }
    .industry__cover-icon {
      position: absolute;
      right: 16px;
      bottom: 16px;
      width: 44px;
      height: 44px;
      color: rgba(255, 255, 255, 0.85);
      z-index: 1;
    }
    .industry__cover-icon svg { width: 100%; height: 100%; stroke: currentColor; stroke-width: 1.4; fill: none; stroke-linecap: round; stroke-linejoin: round; }
    .industry__body {
      padding: 22px 22px 24px;
      display: flex;
      flex-direction: column;
      gap: 8px;
      flex: 1;
    }
    .industry__title {
      font-size: 18px;
      font-weight: 600;
      line-height: 1.3;
      margin: 0;
      color: var(--color-text);
    }
    .industry__desc {
      font-size: 14px;
      color: var(--color-text-soft);
      line-height: 1.55;
      margin: 0 0 6px;
      flex: 1;
    }
    .industry__more {
      font-size: 14px;
      font-weight: 600;
      color: var(--color-primary);
      display: inline-flex;
      align-items: center;
      gap: 6px;
    }
    .industry__more svg {
      width: 14px; height: 14px;
      transition: transform var(--transition);
    }
    .industry:hover .industry__more svg { transform: translateX(3px); }

    /* ============================================================
       LOCATIONS (offices grid)
       ============================================================ */
    .locations {
      background: var(--color-bg-soft);
    }
    .locations__grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 1px;
      background: var(--color-border);
      border: 1px solid var(--color-border);
    }
    .office {
      background: #fff;
      padding: 22px 22px 24px;
      display: flex;
      flex-direction: column;
      gap: 4px;
      text-decoration: none;
      color: var(--color-text);
      transition: background var(--transition);
      position: relative;
    }
    .office:hover { background: var(--color-primary-soft); }
    .office__country {
      font-size: 12px;
      font-weight: 600;
      letter-spacing: 0.06em;
      color: var(--color-text-soft);
      text-transform: uppercase;
      display: inline-flex;
      align-items: center;
      gap: 6px;
    }
    .office__hq {
      display: inline-block;
      padding: 2px 6px;
      background: var(--color-accent);
      color: #fff;
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 0.08em;
      border-radius: 2px;
      margin-left: 4px;
    }
    .office__city {
      font-size: 22px;
      font-weight: 600;
      color: var(--color-text);
      letter-spacing: -0.01em;
      margin: 4px 0 6px;
    }
    .office__addr {
      font-size: 13px;
      line-height: 1.5;
      color: var(--color-text-soft);
      flex: 1;
    }
    .office__phone {
      font-family: 'JetBrains Mono', ui-monospace, Menlo, monospace;
      font-size: 12px;
      color: var(--color-primary);
      margin-top: 8px;
      letter-spacing: 0.02em;
    }
    @media (max-width: 1024px) {
      .locations__grid { grid-template-columns: repeat(3, 1fr); }
    }
    @media (max-width: 720px) {
      .locations__grid { grid-template-columns: repeat(2, 1fr); }
    }
    @media (max-width: 460px) {
      .locations__grid { grid-template-columns: 1fr; }
    }

    /* ============================================================
       INSIGHTS (3-card row)
       ============================================================ */
    .insights__grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 32px;
    }
    .article {
      display: flex;
      flex-direction: column;
      text-decoration: none;
      color: var(--color-text);
    }
    .article__cover {
      aspect-ratio: 16 / 10;
      background-image: linear-gradient(135deg, #cfdcec, #1a4d8c);
      background-size: cover;
      background-position: center;
      background-color: var(--color-primary-soft);
      border-radius: var(--radius);
      margin-bottom: 18px;
      position: relative;
      overflow: hidden;
      transition: transform 480ms ease;
    }
    .article:hover .article__cover { transform: scale(1.02); }
    .article__meta {
      font-size: 13px;
      color: var(--color-text-muted);
      margin-bottom: 8px;
      letter-spacing: 0.02em;
    }
    .article__title {
      font-size: 19px;
      font-weight: 600;
      line-height: 1.35;
      margin: 0 0 10px;
      color: var(--color-text);
    }
    .article__excerpt {
      font-size: 14px;
      line-height: 1.6;
      color: var(--color-text-soft);
      margin: 0 0 14px;
      flex: 1;
    }
    .article__read {
      font-size: 14px;
      font-weight: 600;
      color: var(--color-primary);
      display: inline-flex;
      align-items: center;
      gap: 6px;
    }
    .article:hover .article__title { color: var(--color-primary); }
    .insights__footer {
      margin-top: 48px;
      text-align: center;
    }

    /* ============================================================
       CTA BANNER
       ============================================================ */
    .cta {
      background: var(--color-bg-deep);
      padding: 72px 0;
    }
    .cta__inner {
      display: grid;
      grid-template-columns: 1.4fr 1fr;
      gap: 48px;
      align-items: center;
      color: #fff;
    }
    .cta__title {
      font-size: clamp(26px, 3vw, 36px);
      font-weight: 700;
      line-height: 1.2;
      letter-spacing: -0.01em;
      margin: 0 0 12px;
    }
    .cta__text {
      font-size: 17px;
      line-height: 1.55;
      margin: 0;
      color: rgba(255,255,255,0.78);
    }
    .cta__actions {
      display: flex;
      gap: 12px;
      justify-content: flex-end;
      flex-wrap: wrap;
    }

    /* ============================================================
       FOOTER
       ============================================================ */
    .footer {
      background: #fff;
      border-top: 1px solid var(--color-border);
      padding: 64px 0 32px;
      font-size: 14px;
    }
    .footer__grid {
      display: grid;
      grid-template-columns: 1.4fr repeat(4, 1fr);
      gap: 40px;
      margin-bottom: 48px;
    }
    .footer__brand .logo { margin-bottom: 16px; }
    .footer__tagline {
      color: var(--color-text-soft);
      margin: 0 0 16px;
      max-width: 280px;
      line-height: 1.55;
    }
    .footer__email {
      display: inline-block;
      font-family: 'JetBrains Mono', ui-monospace, Menlo, monospace;
      font-size: 14px;
      font-weight: 500;
      color: var(--color-primary);
      text-decoration: none;
      letter-spacing: 0.01em;
    }
    .footer__email:hover {
      color: var(--color-primary-dark);
      text-decoration: underline;
    }
    .footer__col-title {
      font-size: 13px;
      font-weight: 700;
      letter-spacing: 0.04em;
      text-transform: uppercase;
      color: var(--color-text);
      margin: 0 0 16px;
    }
    .footer__list {
      list-style: none;
      padding: 0;
      margin: 0;
      display: flex;
      flex-direction: column;
      gap: 10px;
    }
    .footer__list a {
      color: var(--color-text-soft);
      text-decoration: none;
    }
    .footer__list a:hover { color: var(--color-primary); }
    .footer__bottom {
      border-top: 1px solid var(--color-border);
      padding-top: 24px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      color: var(--color-text-muted);
      font-size: 13px;
      gap: 24px;
      flex-wrap: wrap;
    }
    .footer__legal {
      display: flex;
      gap: 20px;
    }
    .footer__legal a { color: var(--color-text-muted); text-decoration: none; }
    .footer__legal a:hover { color: var(--color-primary); }

    /* ============================================================
       SCROLL REVEAL (very subtle)
       ============================================================ */
    .reveal {
      opacity: 0;
      transform: translateY(16px);
      transition: opacity 600ms ease, transform 600ms ease;
    }
    .reveal.is-visible {
      opacity: 1;
      transform: none;
    }

    /* ============================================================
       FLATPICKR — brand color overrides
       ============================================================ */
    .flatpickr-day.selected,
    .flatpickr-day.startRange,
    .flatpickr-day.endRange,
    .flatpickr-day.selected.inRange,
    .flatpickr-day.selected:focus,
    .flatpickr-day.selected:hover,
    .flatpickr-day.startRange:focus,
    .flatpickr-day.startRange:hover,
    .flatpickr-day.endRange:focus,
    .flatpickr-day.endRange:hover {
      background: var(--color-primary);
      border-color: var(--color-primary);
      color: #fff;
    }
    .flatpickr-day.today {
      border-color: var(--color-primary);
      color: var(--color-primary);
    }
    .flatpickr-day.today:hover { background: var(--color-primary-soft); color: var(--color-primary); }
    .flatpickr-day:hover { background: var(--color-bg-soft); }
    .flatpickr-months .flatpickr-prev-month:hover svg,
    .flatpickr-months .flatpickr-next-month:hover svg { fill: var(--color-primary); }
    .flatpickr-current-month .numInputWrapper:hover { background: var(--color-bg-soft); }
    .flatpickr-calendar { font-family: 'Inter', system-ui, sans-serif; }
    .flatpickr-calendar.arrowTop:before,
    .flatpickr-calendar.arrowTop:after { display: none; }

    /* ============================================================
       MODAL + CONTACT FORM
       ============================================================ */
    .modal-backdrop {
      position: fixed;
      inset: 0;
      background: rgba(15, 42, 77, 0.55);
      z-index: 200;
      display: none;
      align-items: flex-start;
      justify-content: center;
      padding: 5vh 16px;
      overflow-y: auto;
      opacity: 0;
      transition: opacity 220ms ease;
    }
    .modal-backdrop.is-open {
      display: flex;
      opacity: 1;
    }
    body.is-modal-open { overflow: hidden; }
    .modal {
      background: #fff;
      border-radius: var(--radius);
      max-width: 640px;
      width: 100%;
      box-shadow: 0 30px 80px rgba(15, 42, 77, 0.25);
      transform: translateY(12px);
      opacity: 0;
      transition: transform 260ms ease, opacity 260ms ease;
      margin: auto;
    }
    .modal-backdrop.is-open .modal {
      transform: translateY(0);
      opacity: 1;
    }
    .modal__header {
      padding: 28px 32px 0;
      position: relative;
    }
    .modal__close {
      position: absolute;
      top: 16px;
      right: 16px;
      width: 36px;
      height: 36px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: transparent;
      border: 1px solid var(--color-border);
      border-radius: var(--radius);
      color: var(--color-text-soft);
      transition: background var(--transition), border-color var(--transition), color var(--transition);
    }
    .modal__close:hover {
      background: var(--color-bg-soft);
      border-color: var(--color-border-strong);
      color: var(--color-text);
    }
    .modal__title {
      font-size: 22px;
      font-weight: 700;
      letter-spacing: -0.01em;
      margin: 0 0 6px;
      color: var(--color-text);
    }
    .modal__sub {
      font-size: 14px;
      color: var(--color-text-soft);
      margin: 0;
    }
    .modal__email-block {
      display: flex;
      gap: 8px;
      align-items: center;
      flex-wrap: wrap;
      margin-top: 14px;
    }
    .modal__email-btn {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 10px 14px;
      background: var(--color-primary-soft);
      border-radius: var(--radius);
      font-size: 14px;
      font-weight: 600;
      color: var(--color-primary);
      text-decoration: none;
      transition: background var(--transition), color var(--transition);
    }
    .modal__email-btn:hover {
      background: rgba(26, 77, 140, 0.15);
      color: var(--color-primary-dark);
    }
    .modal__email-btn svg {
      width: 16px;
      height: 16px;
      flex-shrink: 0;
    }
    .modal__email-copy {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 10px 12px;
      background: transparent;
      border: 1px solid var(--color-border);
      border-radius: var(--radius);
      font-family: 'JetBrains Mono', ui-monospace, Menlo, monospace;
      font-size: 13px;
      font-weight: 500;
      color: var(--color-text);
      cursor: pointer;
      transition: background var(--transition), border-color var(--transition), color var(--transition);
    }
    .modal__email-copy:hover {
      border-color: var(--color-primary);
      color: var(--color-primary);
    }
    .modal__email-copy svg {
      width: 14px;
      height: 14px;
      flex-shrink: 0;
      opacity: 0.7;
    }
    .modal__email-copy .modal__email-copy-check { display: none; color: #2f8557; opacity: 1; }
    .modal__email-copy.is-copied {
      background: rgba(47, 133, 87, 0.08);
      border-color: #2f8557;
      color: #2f8557;
    }
    .modal__email-copy.is-copied .modal__email-copy-icon { display: none; }
    .modal__email-copy.is-copied .modal__email-copy-check { display: inline-block; }
    .modal__tabs {
      display: flex;
      gap: 0;
      padding: 0 32px;
      margin-top: 24px;
      border-bottom: 1px solid var(--color-border);
    }
    .modal__tab {
      padding: 12px 0;
      margin-right: 24px;
      background: transparent;
      border: none;
      font-size: 14px;
      font-weight: 600;
      color: var(--color-text-soft);
      cursor: pointer;
      position: relative;
      transition: color var(--transition);
    }
    .modal__tab:hover { color: var(--color-text); }
    .modal__tab.is-active {
      color: var(--color-primary);
    }
    .modal__tab.is-active::after {
      content: '';
      position: absolute;
      left: 0;
      right: 0;
      bottom: -1px;
      height: 2px;
      background: var(--color-primary);
    }
    .modal__body {
      padding: 28px 32px 32px;
    }
    .modal__form-pane { display: none; }
    .modal__form-pane.is-active { display: block; }

    /* Form elements */
    .form-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px;
    }
    .form-field {
      display: flex;
      flex-direction: column;
      gap: 6px;
    }
    .form-field--full { grid-column: 1 / -1; }
    .form-label {
      font-size: 13px;
      font-weight: 600;
      color: var(--color-text);
    }
    .form-label .req { color: var(--color-accent); margin-left: 2px; }
    .form-input,
    .form-select,
    .form-textarea {
      width: 100%;
      padding: 11px 12px;
      font-family: inherit;
      font-size: 14px;
      line-height: 1.4;
      color: var(--color-text);
      background: #fff;
      border: 1px solid var(--color-border-strong);
      border-radius: var(--radius);
      transition: border-color var(--transition), box-shadow var(--transition);
    }
    .form-input:focus,
    .form-select:focus,
    .form-textarea:focus {
      outline: none;
      border-color: var(--color-primary);
      box-shadow: 0 0 0 3px rgba(26, 77, 140, 0.12);
    }
    .form-input.is-error,
    .form-select.is-error,
    .form-textarea.is-error {
      border-color: var(--color-accent);
      box-shadow: 0 0 0 3px rgba(213, 43, 30, 0.10);
    }
    .form-textarea {
      min-height: 96px;
      resize: vertical;
    }
    .form-select {
      appearance: none;
      background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23595959' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
      background-repeat: no-repeat;
      background-position: right 12px center;
      padding-right: 36px;
    }
    .form-error-msg {
      font-size: 12px;
      color: var(--color-accent);
      margin-top: 4px;
      display: none;
    }
    .form-input.is-error + .form-error-msg,
    .form-select.is-error + .form-error-msg,
    .form-textarea.is-error + .form-error-msg {
      display: block;
    }
    .form-actions {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      margin-top: 22px;
    }
    .form-note {
      font-size: 12px;
      color: var(--color-text-muted);
    }

    /* Success state */
    .modal__success {
      padding: 48px 32px 40px;
      text-align: center;
      display: none;
    }
    .modal__success.is-visible { display: block; }
    .modal__success-icon {
      width: 56px;
      height: 56px;
      margin: 0 auto 18px;
      border-radius: 50%;
      background: var(--color-primary-soft);
      color: var(--color-primary);
      display: inline-flex;
      align-items: center;
      justify-content: center;
    }
    .modal__success-icon svg { width: 28px; height: 28px; }
    .modal__success-title {
      font-size: 22px;
      font-weight: 700;
      margin: 0 0 8px;
    }
    .modal__success-text {
      font-size: 15px;
      color: var(--color-text-soft);
      max-width: 380px;
      margin: 0 auto 24px;
      line-height: 1.55;
    }

    /* Hide content body when success is shown */
    .modal.is-success .modal__tabs,
    .modal.is-success .modal__body { display: none; }
    .modal.is-success .modal__success { display: block; }

    @media (max-width: 560px) {
      .modal__header { padding: 24px 22px 0; }
      .modal__tabs { padding: 0 22px; gap: 0; overflow-x: auto; }
      .modal__tab { font-size: 13px; margin-right: 18px; white-space: nowrap; }
      .modal__body { padding: 22px 22px 26px; }
      .form-grid { grid-template-columns: 1fr; }
      .form-actions { flex-direction: column-reverse; align-items: stretch; }
      .modal__success { padding: 36px 22px 28px; }
    }

    /* ============================================================
       MOBILE NAV DRAWER
       ============================================================ */
    .mobile-drawer {
      position: fixed;
      inset: 0;
      z-index: 150;
      background: rgba(15, 42, 77, 0.6);
      display: none;
      opacity: 0;
      transition: opacity 200ms ease;
    }
    .mobile-drawer.is-open { display: block; opacity: 1; }
    .mobile-drawer__panel {
      position: absolute;
      top: 0;
      right: 0;
      width: min(320px, 86vw);
      height: 100%;
      background: #fff;
      padding: 24px 24px 32px;
      transform: translateX(100%);
      transition: transform 240ms ease;
      display: flex;
      flex-direction: column;
      gap: 24px;
    }
    .mobile-drawer.is-open .mobile-drawer__panel { transform: translateX(0); }
    .mobile-drawer__top {
      display: flex;
      align-items: center;
      justify-content: space-between;
    }
    .mobile-drawer__close {
      width: 40px; height: 40px;
      display: inline-flex; align-items: center; justify-content: center;
      background: transparent;
      border: 1px solid var(--color-border);
      border-radius: var(--radius);
      color: var(--color-text-soft);
    }
    .mobile-drawer__nav {
      display: flex;
      flex-direction: column;
      gap: 4px;
    }
    .mobile-drawer__nav a {
      padding: 12px 4px;
      font-size: 16px;
      font-weight: 500;
      color: var(--color-text);
      text-decoration: none;
      border-bottom: 1px solid var(--color-border);
    }
    .mobile-drawer__nav a:hover { color: var(--color-primary); }

    /* Lang switcher inside mobile drawer */
    .mobile-drawer__lang {
      margin-top: auto;
      padding-top: 24px;
      border-top: 1px solid var(--color-border);
    }
    .mobile-drawer__lang-label {
      font-size: 12px;
      font-weight: 600;
      letter-spacing: 0.04em;
      text-transform: uppercase;
      color: var(--color-text-muted);
      margin-bottom: 12px;
      display: block;
    }
    .mobile-drawer__lang .lang__trigger {
      width: 100%;
      justify-content: flex-start;
      padding: 12px 14px;
      border: 1px solid var(--color-border);
      border-radius: var(--radius);
      font-size: 15px;
      color: var(--color-text);
    }
    .mobile-drawer__lang .lang__caret { margin-left: auto; }
    .mobile-drawer__lang .lang__menu {
      bottom: calc(100% + 6px);
      top: auto;
      width: 100%;
      min-width: 0;
    }

    /* ============================================================
       BACK TO TOP BUTTON
       ============================================================ */
    .to-top {
      position: fixed;
      right: 24px;
      bottom: 24px;
      width: 44px;
      height: 44px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: var(--color-primary);
      color: #fff;
      border: none;
      border-radius: 50%;
      box-shadow: 0 8px 24px rgba(15, 42, 77, 0.25);
      cursor: pointer;
      opacity: 0;
      transform: translateY(8px);
      pointer-events: none;
      transition: opacity 220ms ease, transform 220ms ease, background var(--transition);
      z-index: 90;
    }
    .to-top.is-visible {
      opacity: 1;
      transform: translateY(0);
      pointer-events: auto;
    }
    .to-top:hover { background: var(--color-primary-dark); }

    /* ============================================================
       ACTIVE NAV STATE (when section in viewport)
       ============================================================ */
    .nav__link.is-active {
      color: var(--color-primary);
    }
    .nav__link.is-active::after {
      transform: scaleX(1);
    }

    /* ============================================================
       RESPONSIVE
       ============================================================ */
    @media (max-width: 1024px) {
      .hero__grid,
      .cta__inner { grid-template-columns: 1fr; gap: 32px; }
      .cta__actions { justify-content: flex-start; }
      .services__grid { grid-template-columns: repeat(2, 1fr); }
      .industries__grid { grid-template-columns: repeat(2, 1fr); }
      .insights__grid { grid-template-columns: repeat(2, 1fr); }
      .footer__grid { grid-template-columns: 1fr 1fr 1fr; }
      .footer__brand { grid-column: 1 / -1; }
    }
    @media (max-width: 720px) {
      section { padding: 56px 0; }
      .hero { padding: 48px 0 56px; }
      .nav, .header__search, .utility { display: none; }
      .header__burger { display: inline-flex; }
      .services__grid,
      .industries__grid,
      .insights__grid,
      .footer__grid { grid-template-columns: 1fr; }
      .footer__bottom { flex-direction: column; align-items: flex-start; }
    }

    /* ============================================================
       SERVICE DETAIL PAGES
       ============================================================ */

    /* Breadcrumb */
    .breadcrumb {
      font-size: 13px;
      color: var(--color-text-muted);
      margin-bottom: 24px;
      display: flex;
      flex-wrap: wrap;
      gap: 6px;
      align-items: center;
    }
    .breadcrumb a {
      color: var(--color-text-soft);
      text-decoration: none;
    }
    .breadcrumb a:hover { color: var(--color-primary); }
    .breadcrumb__sep { color: var(--color-text-muted); }
    .breadcrumb__current { color: var(--color-text); font-weight: 500; }

    /* Page hero (service / industry / about) */
    .page-hero {
      padding: 56px 0 64px;
      background: var(--color-bg);
      border-bottom: 1px solid var(--color-border);
    }
    .page-hero__title {
      font-size: clamp(34px, 4.4vw, 52px);
      line-height: 1.1;
      font-weight: 700;
      letter-spacing: -0.02em;
      margin: 0 0 20px;
      max-width: 880px;
    }
    .page-hero__lede {
      font-size: 18px;
      line-height: 1.6;
      color: var(--color-text-soft);
      max-width: 720px;
      margin: 0 0 32px;
    }
    .page-hero__actions {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
    }

    /* Quick KPI strip below page hero */
    .kpi-strip {
      background: var(--color-bg-soft);
      border-bottom: 1px solid var(--color-border);
      padding: 28px 0;
    }
    .kpi-strip__grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 32px;
    }
    .kpi {
      display: flex;
      flex-direction: column;
      gap: 4px;
    }
    .kpi__value {
      font-size: 22px;
      font-weight: 700;
      color: var(--color-primary);
      letter-spacing: -0.01em;
    }
    .kpi__label {
      font-size: 13px;
      color: var(--color-text-soft);
    }

    /* "What we do" — sub-services list (cards on grey bg) */
    .subservices {
      background: var(--color-bg-soft);
    }
    .subservices__grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 1px;
      background: var(--color-border);
      border: 1px solid var(--color-border);
    }
    .subservice {
      background: #fff;
      padding: 28px 26px;
      display: flex;
      flex-direction: column;
      gap: 10px;
    }
    .subservice__num {
      font-size: 13px;
      font-weight: 700;
      color: var(--color-primary);
      letter-spacing: 0.04em;
      margin-bottom: 4px;
    }
    .subservice__title {
      font-size: 18px;
      font-weight: 600;
      margin: 0;
      color: var(--color-text);
    }
    .subservice__desc {
      font-size: 14px;
      line-height: 1.6;
      color: var(--color-text-soft);
      margin: 0;
    }

    /* Standards list — monospaced codes */
    .standards__list {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 1px;
      background: var(--color-border);
      border: 1px solid var(--color-border);
      list-style: none;
      padding: 0;
      margin: 0;
    }
    .standards__item {
      background: #fff;
      padding: 18px 22px;
      display: flex;
      flex-direction: column;
      gap: 4px;
    }
    .standards__code {
      font-family: 'JetBrains Mono', ui-monospace, Menlo, monospace;
      font-size: 13px;
      font-weight: 600;
      color: var(--color-primary);
      letter-spacing: 0.01em;
    }
    .standards__name {
      font-size: 14px;
      color: var(--color-text);
    }

    /* Process steps */
    .process {
      background: var(--color-bg-soft);
    }
    .process__list {
      list-style: none;
      counter-reset: step;
      padding: 0;
      margin: 0;
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 24px;
    }
    .process__step {
      counter-increment: step;
      background: #fff;
      padding: 28px 24px;
      border: 1px solid var(--color-border);
      border-radius: var(--radius);
      position: relative;
    }
    .process__step::before {
      content: counter(step, decimal-leading-zero);
      position: absolute;
      top: 18px;
      right: 22px;
      font-family: 'JetBrains Mono', ui-monospace, Menlo, monospace;
      font-size: 28px;
      font-weight: 600;
      color: var(--color-border-strong);
      letter-spacing: -0.02em;
    }
    .process__title {
      font-size: 16px;
      font-weight: 600;
      margin: 0 0 8px;
      padding-right: 40px;
      color: var(--color-text);
    }
    .process__text {
      font-size: 14px;
      line-height: 1.55;
      color: var(--color-text-soft);
      margin: 0;
    }

    /* FAQ accordion */
    .faq {
      max-width: 880px;
    }
    .faq__item {
      border-top: 1px solid var(--color-border);
    }
    .faq__item:last-child {
      border-bottom: 1px solid var(--color-border);
    }
    .faq__item[open] .faq__icon { transform: rotate(45deg); }
    .faq__summary {
      list-style: none;
      cursor: pointer;
      padding: 22px 0;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 24px;
      font-size: 17px;
      font-weight: 600;
      color: var(--color-text);
    }
    .faq__summary::-webkit-details-marker { display: none; }
    .faq__summary:hover { color: var(--color-primary); }
    .faq__icon {
      flex-shrink: 0;
      width: 20px;
      height: 20px;
      color: var(--color-primary);
      transition: transform 240ms ease;
    }
    .faq__answer {
      padding: 0 0 22px;
      font-size: 15px;
      line-height: 1.65;
      color: var(--color-text-soft);
      max-width: 720px;
    }

    /* Related industries chips */
    .chips {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      margin-top: 8px;
    }
    .chip {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 8px 14px;
      background: var(--color-bg-soft);
      border: 1px solid var(--color-border);
      border-radius: 999px;
      font-size: 13px;
      font-weight: 500;
      color: var(--color-text);
      text-decoration: none;
      transition: background var(--transition), border-color var(--transition), color var(--transition);
    }
    .chip:hover {
      background: var(--color-primary-soft);
      border-color: var(--color-primary);
      color: var(--color-primary);
    }

    /* Responsive tweaks for service pages */
    @media (max-width: 1024px) {
      .process__list { grid-template-columns: repeat(2, 1fr); }
      .kpi-strip__grid { grid-template-columns: 1fr 1fr; }
      .kpi-strip__grid .kpi:last-child { grid-column: 1 / -1; }
    }
    @media (max-width: 720px) {
      .subservices__grid,
      .standards__list,
      .process__list { grid-template-columns: 1fr; }
      .kpi-strip__grid { grid-template-columns: 1fr; }
      .page-hero { padding: 40px 0 48px; }
    }

    /* JetBrains Mono fallback for codes/numbers */
    @import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@500;600&display=swap');

    /* ============================================================
       CONTACT SECTION (full inline form on home page)
       ============================================================ */
    .contact-section {
      background: #fff;
      padding: 80px 0;
      border-top: 1px solid var(--color-border);
    }
    .contact-section__grid {
      display: grid;
      grid-template-columns: 1.4fr 1fr;
      gap: 56px;
      align-items: start;
    }
    .contact-section__title {
      font-size: clamp(28px, 3.2vw, 40px);
      line-height: 1.15;
      font-weight: 700;
      letter-spacing: -0.015em;
      margin: 14px 0 8px;
      color: var(--color-text);
    }
    .contact-section__hint {
      font-size: 13px;
      color: var(--color-text-muted);
      margin: 0 0 28px;
    }

    /* Floating-label fields */
    .contact-form__row {
      margin-bottom: 16px;
    }
    .contact-form__row--two {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px;
    }
    .float-field {
      position: relative;
    }
    .float-field__input {
      width: 100%;
      padding: 22px 14px 8px;
      border: 1px solid var(--color-border-strong);
      border-radius: var(--radius);
      background: #fff;
      font-family: inherit;
      font-size: 15px;
      line-height: 1.4;
      color: var(--color-text);
      transition: border-color var(--transition), box-shadow var(--transition);
      appearance: none;
    }
    .float-field__input:focus {
      outline: none;
      border-color: var(--color-primary);
      box-shadow: 0 0 0 3px rgba(26, 77, 140, 0.10);
    }
    .float-field__input.is-error {
      border-color: var(--color-accent);
      box-shadow: 0 0 0 3px rgba(213, 43, 30, 0.10);
    }
    .float-field__label {
      position: absolute;
      left: 12px;
      top: 8px;
      font-size: 11px;
      font-weight: 500;
      color: var(--color-primary);
      letter-spacing: 0.02em;
      pointer-events: none;
      background: #fff;
      padding: 0 4px;
      transition: top var(--transition), font-size var(--transition), color var(--transition);
    }
    /* Empty (placeholder shown) → label centered inside, larger, soft grey */
    .float-field__input:placeholder-shown:not(:focus) + .float-field__label {
      top: 18px;
      font-size: 15px;
      color: var(--color-text-soft);
      font-weight: 400;
      background: transparent;
    }
    /* Textarea taller; label sits at top when empty */
    .float-field__input--textarea {
      min-height: 120px;
      resize: vertical;
      padding-top: 26px;
    }
    .float-field__input--textarea:placeholder-shown:not(:focus) + .float-field__label {
      top: 18px;
    }
    /* Select — invalid (empty value) shows big label inside */
    .float-field__input--select {
      padding-right: 36px;
      background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23595959' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
      background-repeat: no-repeat;
      background-position: right 12px center;
    }
    .float-field__input--select:invalid:not(:focus) + .float-field__label {
      top: 18px;
      font-size: 15px;
      color: var(--color-text-soft);
      font-weight: 400;
      background: transparent;
    }
    .float-field__error {
      display: none;
      font-size: 12px;
      color: var(--color-accent);
      margin-top: 4px;
      padding: 0 4px;
    }
    .float-field__input.is-error ~ .float-field__error { display: block; }

    /* Consent paragraph */
    .contact-form__consent {
      font-size: 13px;
      line-height: 1.55;
      color: var(--color-text-soft);
      margin: 16px 0 22px;
    }
    .contact-form__consent a { color: var(--color-primary); }

    /* Send-request submit button */
    .contact-form__submit {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      padding: 14px 28px;
      background: var(--color-primary);
      color: #fff;
      border: none;
      border-radius: var(--radius);
      font-family: inherit;
      font-size: 15px;
      font-weight: 600;
      cursor: pointer;
      transition: background var(--transition), transform var(--transition);
    }
    .contact-form__submit:hover {
      background: var(--color-primary-dark);
      transform: translateY(-1px);
    }
    .contact-form__submit svg { width: 14px; height: 14px; }

    /* Success state for inline form */
    .contact-form__success[hidden] { display: none !important; }
    .contact-form__success {
      margin-top: 22px;
      padding: 22px 24px;
      background: rgba(47, 133, 87, 0.08);
      border: 1px solid #2f8557;
      border-radius: var(--radius);
      display: flex;
      flex-direction: column;
      gap: 6px;
    }
    .contact-form__success strong {
      color: #1f6643;
      font-size: 16px;
      font-weight: 600;
    }
    .contact-form__success span {
      color: var(--color-text-soft);
      font-size: 14px;
      line-height: 1.55;
    }

    /* Right-side aside cards */
    .contact-section__aside {
      display: flex;
      flex-direction: column;
      gap: 16px;
      position: sticky;
      top: 100px;
    }
    .contact-card {
      padding: 28px 28px 30px;
      background: #fff;
      border: 1px solid var(--color-border);
      border-radius: var(--radius);
    }
    .contact-card--dark {
      background: var(--color-bg-deep);
      color: #fff;
      border-color: var(--color-bg-deep);
    }
    .contact-card__title {
      font-size: 18px;
      font-weight: 600;
      margin: 0 0 8px;
      letter-spacing: -0.01em;
    }
    .contact-card__text {
      font-size: 14px;
      line-height: 1.55;
      color: var(--color-text-soft);
      margin: 0 0 16px;
    }
    .contact-card--dark .contact-card__text { color: rgba(255,255,255,0.78); }
    .contact-card__btn {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 11px 18px;
      border-radius: var(--radius);
      font-family: inherit;
      font-size: 14px;
      font-weight: 600;
      text-decoration: none;
      cursor: pointer;
      transition: background var(--transition), color var(--transition), border-color var(--transition);
    }
    .contact-card__btn--primary {
      background: var(--color-primary-soft);
      color: var(--color-primary);
      border: 1px solid transparent;
    }
    .contact-card__btn--primary:hover {
      background: rgba(26, 77, 140, 0.14);
      color: var(--color-primary-dark);
    }
    .contact-card__btn--white {
      background: #fff;
      color: var(--color-primary);
      border: 1px solid #fff;
    }
    .contact-card__btn--white:hover {
      background: var(--color-primary-soft);
    }
    .contact-card__btn svg { width: 14px; height: 14px; flex-shrink: 0; }

    @media (max-width: 1024px) {
      .contact-section__grid { grid-template-columns: 1fr; gap: 32px; }
      .contact-section__aside { position: static; }
    }
    @media (max-width: 720px) {
      .contact-section { padding: 56px 0; }
      .contact-form__row--two { grid-template-columns: 1fr; }
    }

    /* ============================================================
       INDUSTRY DETAIL PAGES
       ============================================================ */
    .industry-banner {
      width: 100%;
      aspect-ratio: 21 / 9;
      background-size: cover;
      background-position: center;
      position: relative;
      overflow: hidden;
    }
    .industry-banner::after {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, rgba(15,30,58,0) 50%, rgba(15,30,58,0.35) 100%);
      pointer-events: none;
    }

    /* Long-form body text */
    .prose {
      max-width: 720px;
      margin: 0 auto;
    }
    .prose p {
      font-size: 17px;
      line-height: 1.7;
      color: var(--color-text);
      margin: 0 0 22px;
    }
    .prose p:last-child { margin-bottom: 0; }
    .prose strong { font-weight: 600; }

    /* Related services — compact 2-col grid */
    .related {
      background: var(--color-bg-soft);
    }
    .related__grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 1px;
      background: var(--color-border);
      border: 1px solid var(--color-border);
    }
    .related__card {
      background: #fff;
      padding: 24px 26px;
      display: flex;
      flex-direction: column;
      gap: 8px;
      text-decoration: none;
      color: var(--color-text);
      transition: background var(--transition);
    }
    .related__card:hover {
      background: var(--color-primary-soft);
    }
    .related__card-num {
      font-size: 13px;
      font-weight: 700;
      color: var(--color-primary);
      letter-spacing: 0.04em;
    }
    .related__card-title {
      font-size: 17px;
      font-weight: 600;
      margin: 0;
      color: var(--color-text);
    }
    .related__card-desc {
      font-size: 14px;
      line-height: 1.55;
      color: var(--color-text-soft);
      margin: 0;
      flex: 1;
    }
    .related__card-more {
      font-size: 13px;
      font-weight: 600;
      color: var(--color-primary);
      display: inline-flex;
      align-items: center;
      gap: 6px;
      margin-top: 4px;
    }
    @media (max-width: 720px) {
      .related__grid { grid-template-columns: 1fr; }
    }
