/* ============================================================
   APTR GLOBAL — Services v2
   Card grid + service detail modal.
   Loads AFTER styles.css + homepage-v2.css + pages-v2.css.
   Brand-locked: navy #00276A · blue #305FB0 · amber #FFA600.
   ============================================================ */

/* ---------- services intro head ---------- */
.svc-page-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 32px; flex-wrap: wrap; }
.svc-page-head .section-head { max-width: 620px; }
.svc-page-head .shp-note { display: inline-flex; align-items: center; gap: 10px; font-size: 14px; font-weight: 600; color: var(--muted); }
.svc-page-head .shp-note .shp-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--amber); flex: none; }

/* ============================================================
   SERVICE CARD GRID
   ============================================================ */
.svc-cards {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
  margin-top: clamp(36px, 4vw, 56px); position: relative; z-index: 2;
}

.svc-card {
  position: relative; overflow: hidden;
  display: flex; flex-direction: column; align-items: stretch; text-align: left;
  background: #fff; border: 1px solid var(--line); border-radius: var(--radius-xl);
  padding: 30px 30px 28px; min-height: 290px; cursor: pointer;
  font-family: var(--ff-text); color: var(--ink);
  transition: transform .42s var(--ease), box-shadow .42s var(--ease), border-color .42s var(--ease);
}
/* cursor-following spotlight */
.svc-card::before {
  content: ""; position: absolute; inset: 0; z-index: 0; opacity: 0; pointer-events: none;
  background: radial-gradient(420px circle at var(--mx, 50%) var(--my, 0%), rgba(48,95,176,0.10), transparent 60%);
  transition: opacity .4s var(--ease);
}
/* top accent bar */
.svc-card::after {
  content: ""; position: absolute; left: 0; top: 0; height: 4px; width: 0;
  background: var(--amber); transition: width .45s var(--ease); z-index: 3;
}
.svc-card:hover { transform: translateY(-7px); box-shadow: var(--shadow-lg); border-color: transparent; }
.svc-card:hover::before { opacity: 1; }
.svc-card:hover::after { width: 100%; }
.svc-card:focus-visible { outline: none; box-shadow: 0 0 0 4px var(--blue-tint), var(--shadow-md); border-color: var(--blue); }

.svc-card .sc-top { display: flex; align-items: flex-start; justify-content: space-between; position: relative; z-index: 2; }
.svc-card .sc-ic {
  width: 58px; height: 58px; border-radius: 16px; flex: none;
  background: var(--blue-tint); color: var(--blue); display: grid; place-items: center;
  transition: background .42s var(--ease), color .42s var(--ease), transform .42s var(--ease);
}
.svc-card .sc-ic svg { width: 27px; height: 27px; }
.svc-card:hover .sc-ic { background: var(--navy); color: var(--amber); transform: rotate(-6deg); }
.svc-card .sc-num {
  font-family: var(--ff-display); font-weight: 700; font-size: 15px;
  color: var(--paper-2); letter-spacing: 0.04em; transition: color .42s var(--ease);
}
.svc-card:hover .sc-num { color: var(--blue-500); }

.svc-card h3 { font-size: clamp(20px, 1.9vw, 23px); color: var(--navy); margin-top: 22px; position: relative; z-index: 2; }
.svc-card p { font-size: 15px; line-height: 1.6; color: var(--ink-soft); margin-top: 11px; position: relative; z-index: 2; }

.svc-card .sc-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; position: relative; z-index: 2; }
.svc-card .sc-tags span {
  font-size: 12px; font-weight: 700; letter-spacing: 0.01em; color: var(--blue); white-space: nowrap;
  background: var(--blue-tint); padding: 5px 12px; border-radius: 100px;
  transition: background .35s var(--ease), color .35s var(--ease);
}
.svc-card:hover .sc-tags span:nth-child(odd) { background: var(--amber-tint); color: var(--amber-600); }

.svc-card .sc-cta {
  display: inline-flex; align-items: center; gap: 9px; margin-top: auto; padding-top: 24px;
  font-family: var(--ff-display); font-weight: 600; font-size: 14.5px; color: var(--navy);
  position: relative; z-index: 2;
}
.svc-card .sc-cta .sc-arr {
  width: 30px; height: 30px; border-radius: 50%; border: 1.5px solid var(--line);
  display: grid; place-items: center; color: var(--navy);
  transition: background .35s var(--ease), border-color .35s var(--ease), color .35s var(--ease), transform .4s var(--ease);
}
.svc-card .sc-cta .sc-arr svg { width: 15px; height: 15px; }
.svc-card:hover .sc-cta { color: var(--blue); }
.svc-card:hover .sc-cta .sc-arr { background: var(--amber); border-color: var(--amber); color: var(--navy); transform: rotate(-45deg); }

/* ---------- CTA card (fills the 6th cell) ---------- */
.svc-card.cta-card {
  background: linear-gradient(165deg, var(--navy) 0%, #001b4a 100%); border-color: transparent;
  color: #fff; justify-content: space-between;
}
.svc-card.cta-card::after { display: none; }
.svc-card.cta-card::before {
  background: radial-gradient(420px circle at var(--mx, 80%) var(--my, 0%), rgba(255,166,0,0.18), transparent 60%);
}
.svc-card.cta-card .cc-blob {
  position: absolute; right: -70px; bottom: -80px; width: 200px; height: 200px; z-index: 0;
  border-radius: 46% 54% 58% 42% / 52% 44% 56% 48%; background: var(--amber); opacity: .9;
  transition: transform .5s var(--ease);
}
.svc-card.cta-card:hover .cc-blob { transform: scale(1.12) rotate(-8deg); }
.svc-card.cta-card .sc-ic { background: rgba(255,255,255,0.12); color: var(--amber); }
.svc-card.cta-card:hover .sc-ic { background: #fff; color: var(--navy); transform: rotate(-6deg); }
.svc-card.cta-card h3 { color: #fff; max-width: 14ch; }
.svc-card.cta-card p { color: rgba(255,255,255,0.74); }
.svc-card.cta-card .sc-cta { color: var(--amber); }
.svc-card.cta-card .sc-cta .sc-arr { border-color: rgba(255,255,255,0.3); color: #fff; }
.svc-card.cta-card:hover .sc-cta { color: #fff; }
.svc-card.cta-card:hover .sc-cta .sc-arr { background: var(--amber); border-color: var(--amber); color: var(--navy); transform: rotate(-45deg); }

/* ============================================================
   SERVICE DETAIL MODAL
   ============================================================ */
.modal-root {
  position: fixed; inset: 0; z-index: 300;
  display: flex; align-items: flex-start; justify-content: center;
  padding: clamp(16px, 4vw, 56px) clamp(14px, 4vw, 40px);
  overflow-y: auto; overscroll-behavior: contain;
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity .35s var(--ease), visibility .35s;
}
.modal-root.open { opacity: 1; visibility: visible; pointer-events: auto; }

.modal-overlay {
  position: fixed; inset: 0;
  background: radial-gradient(120% 120% at 70% -10%, rgba(10,63,160,0.55), rgba(0,18,48,0.66));
  backdrop-filter: blur(7px); -webkit-backdrop-filter: blur(7px);
}

.modal {
  position: relative; z-index: 2; width: min(900px, 100%); margin: auto;
  background: #fff; border-radius: var(--radius-xl);
  box-shadow: 0 50px 100px -30px rgba(0,18,48,0.6);
  padding: clamp(28px, 3.4vw, 46px);
  transform: translateY(26px) scale(.965); opacity: 0;
  transition: transform .5s var(--ease), opacity .4s var(--ease);
  overflow: hidden;
}
.modal-root.open .modal { transform: translateY(0) scale(1); opacity: 1; }
/* soft amber corner accent */
.modal .modal-glow {
  position: absolute; top: -90px; right: -90px; width: 240px; height: 240px;
  border-radius: 50%; background: var(--amber); opacity: .1; filter: blur(20px); pointer-events: none; z-index: 0;
}

.modal-close {
  position: absolute; top: 20px; right: 20px; z-index: 5;
  width: 44px; height: 44px; border-radius: 50%; border: 1.5px solid var(--line);
  background: #fff; color: var(--navy); cursor: pointer; display: grid; place-items: center;
  transition: background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease), transform .35s var(--ease);
}
.modal-close svg { width: 18px; height: 18px; }
.modal-close:hover { background: var(--navy); color: var(--amber); border-color: var(--navy); transform: rotate(90deg); }
.modal-close:focus-visible { outline: none; box-shadow: 0 0 0 4px var(--blue-tint); }

.modal-head { display: flex; align-items: center; gap: 20px; position: relative; z-index: 2; padding-right: 48px; }
.modal-ic {
  width: 66px; height: 66px; border-radius: 18px; flex: none;
  background: var(--navy); color: var(--amber); display: grid; place-items: center;
  box-shadow: var(--shadow-md);
}
.modal-ic svg { width: 31px; height: 31px; }
.modal-head .mh-kicker { display: flex; align-items: center; gap: 9px; font-size: 12px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--blue); }
.modal-head h2 { font-size: clamp(25px, 2.8vw, 35px); color: var(--navy); margin-top: 7px; line-height: 1.08; }

.modal-lede {
  position: relative; z-index: 2; margin-top: 22px;
  font-size: clamp(16.5px, 1.6vw, 19px); line-height: 1.55; color: var(--ink); font-weight: 500;
  max-width: 60ch;
}

.modal-body {
  position: relative; z-index: 2; margin-top: 26px;
  display: grid; grid-template-columns: 1fr 0.86fr; gap: clamp(24px, 3vw, 40px); align-items: start;
}
.modal-main p { color: var(--ink-soft); font-size: 15.5px; line-height: 1.7; }
.modal-main p + p { margin-top: 14px; }
.modal-ideal { margin-top: 24px; }
.modal-ideal .mi-label,
.modal-side h4 {
  font-family: var(--ff-text); font-weight: 700; font-size: 12px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--muted-2); margin: 0 0 14px;
}
.modal-ideal .mi-chips { display: flex; flex-wrap: wrap; gap: 8px; }
.modal-ideal .mi-chips span {
  font-size: 13px; font-weight: 600; color: var(--navy); background: var(--paper);
  border: 1px solid var(--line); padding: 7px 14px; border-radius: 100px;
}

.modal-side {
  background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-lg);
  padding: 26px 26px 24px;
}
.modal-side h4 { color: var(--navy); }
.modal-side ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 16px; }
.modal-side li {
  display: flex; gap: 12px; align-items: flex-start; font-size: 15px; color: var(--ink); line-height: 1.4;
  opacity: 0; transform: translateY(8px);
  transition: opacity .45s var(--ease), transform .45s var(--ease);
}
.modal-root.open .modal-side li { opacity: 1; transform: none; }
.modal-root.open .modal-side li:nth-child(1) { transition-delay: .16s; }
.modal-root.open .modal-side li:nth-child(2) { transition-delay: .22s; }
.modal-root.open .modal-side li:nth-child(3) { transition-delay: .28s; }
.modal-root.open .modal-side li:nth-child(4) { transition-delay: .34s; }
.modal-root.open .modal-side li:nth-child(5) { transition-delay: .40s; }
.modal-root.open .modal-side li:nth-child(6) { transition-delay: .46s; }
.modal-side .mk {
  flex: none; width: 24px; height: 24px; border-radius: 7px; background: var(--blue-tint);
  display: grid; place-items: center; color: var(--blue); margin-top: 1px;
}
.modal-side .mk svg { width: 14px; height: 14px; }

.modal-foot {
  position: relative; z-index: 2; margin-top: clamp(26px, 3vw, 36px); padding-top: 26px;
  border-top: 1px solid var(--line);
  display: flex; align-items: center; gap: 16px 22px; flex-wrap: wrap;
}
.modal-foot .mf-phone { display: inline-flex; align-items: center; gap: 11px; margin-left: auto; }
.modal-foot .mf-phone .mfp-ic { width: 42px; height: 42px; border-radius: 50%; background: var(--blue-tint); color: var(--blue); display: grid; place-items: center; flex: none; }
.modal-foot .mf-phone .mfp-ic svg { width: 19px; height: 19px; }
.modal-foot .mf-phone .mfp-num { font-family: var(--ff-display); font-weight: 700; font-size: 16px; color: var(--navy); }
.modal-foot .mf-phone .mfp-lbl { font-size: 12px; color: var(--muted); }

/* ---------- engagement process tweak (uses .steps) ---------- */
.svc-process .section-head { max-width: 600px; }
.steps .step::after {
  content: ""; position: absolute; top: 50px; right: -9px; width: 18px; height: 2px;
  background: var(--line); display: none;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 980px) {
  .svc-cards { grid-template-columns: repeat(2, 1fr); }
  .modal-body { grid-template-columns: 1fr; }
  .modal-side { order: -1; }
}
@media (max-width: 620px) {
  .svc-cards { grid-template-columns: 1fr; }
  .svc-card { min-height: 0; }
  .modal-foot .mf-phone { margin-left: 0; }
}

/* ---------- motion safety ---------- */
@media (prefers-reduced-motion: reduce) {
  .modal { transition: opacity .2s; transform: none; }
  .modal-root.open .modal { transform: none; }
  .modal-side li { opacity: 1 !important; transform: none !important; transition: none; }
  .svc-card, .svc-card::before, .svc-card::after { transition: none; }
}
