
/* Overrides: footer smaller + smoother flow spacing */
.pc-footer, .site-footer { font-size: 12px; line-height: 1.5; }
.pc-footer .pc-footer__legal, .pc-footer small, .site-footer small { font-size: 11px; }

/* Breathing room before footer */
main { padding-bottom: 72px; }

/* Section helpers */
.pcx-section{ padding: clamp(48px, 6vw, 96px) 0; position: relative; }
.pcx-divider{ height: 48px; background: linear-gradient(180deg, rgba(0,0,0,0.06), rgba(0,0,0,0)); }
@media (min-width:980px){ .pcx-divider{ height: 64px; } }
.pcx-image-section{ position: relative; min-height: 60vh; display: grid; place-items: center; color: #fff; text-align: center; overflow: hidden; }
.pcx-image-section::before{ content:""; position:absolute; inset:0; background: radial-gradient(60% 60% at 50% 40%, rgba(0,0,0,.25), rgba(0,0,0,.55)); }
.pcx-image-section .bg{ position:absolute; inset:0; background-size: cover; background-position: center; filter: saturate(1.05) contrast(1.02); transform: scale(1.02); }
.pcx-split{ display:grid; gap: clamp(24px, 4vw, 56px); align-items: center; }
@media (min-width:980px){ .pcx-split{ grid-template-columns: 1.2fr 1fr; } }
.pcx-split__img{ width:100%; min-height:320px; background-size:cover; background-position:center; border-radius:12px; overflow:hidden; }
.pcx-split__content{ padding: 0 4vw; }
.pcx-chips{ display:flex; flex-wrap:wrap; gap:12px; justify-content:center; }
.pcx-chip{ padding:8px 14px; border-radius:999px; border:1px solid rgba(0,0,0,0.08); background:#fff; box-shadow:0 2px 12px rgba(0,0,0,0.04); }


/* Login chooser + form */
.login-wrap{ max-width: 880px; margin: 40px auto; padding: 10px; }
.login-chooser{ display:grid; grid-template-columns: 1fr; gap:16px; margin-top: 16px; }
@media(min-width:880px){ .login-chooser{ grid-template-columns: 1fr 1fr; } }
.bigbtn{ display:flex; align-items:center; justify-content:center; min-height:160px; border:1px solid #e5e7eb; border-radius:16px; background:#fff; text-align:center; cursor:pointer; text-decoration:none; }
.bigbtn:hover{ box-shadow:0 8px 24px rgba(0,0,0,0.08); transform: translateY(-1px); }
.bigbtn .title{ font-size: 22px; font-weight: 700; }
.bigbtn .sub{ margin-top:6px; color:#555; font-size:14px; }
.login-form{ background:#fff; border:1px solid #e5e7eb; border-radius:16px; padding: 18px; margin-top: 18px; }
.login-form h2{ margin:0 0 6px; }
.login-form .form-row{ display:flex; flex-direction:column; gap:8px; margin-top:10px; }
.login-form input{ padding:10px 12px; border:1px solid #ddd; border-radius:10px; }
.login-form .actions{ display:flex; gap:10px; margin-top: 12px; }
.btn-xl{ display:inline-block; padding:14px 18px; border-radius:12px; border:0; background:#111827; color:#fff; font-weight:700; cursor:pointer; }
.btn-ghost{ display:inline-block; padding:14px 18px; border-radius:12px; border:1px solid #ddd; background:#fff; color:#111; font-weight:600; cursor:pointer; text-decoration:none; }

nav li.open > ul { display: block !important; visibility: visible; opacity: 1; }


/* Hero helpers */
.pcx-image-section{ position:relative; display:flex; align-items:center; color:#fff; text-align:center; overflow:hidden; }
.pcx-image-section.tall{ min-height:80vh; }
.pcx-image-section .bg{ position:absolute; inset:0; background-size:cover; background-position:center; }
.pcx-image-section .bg::after{ content:""; position:absolute; inset:0; background:
  radial-gradient(60% 60% at 50% 40%, rgba(0,0,0,.25), rgba(0,0,0,.55)),
  linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.6)); opacity:.6; }
.pcx-image--mfg .bg::after{ opacity:.62; } .pcx-image--about .bg::after{ opacity:.64; }
.pcx-image-section .container{ position:relative; z-index:2; padding-bottom:140px; }
.pcx-pills{ display:flex; gap:10px; flex-wrap:wrap; justify-content:center; margin:18px 0 10px; }
.pcx-pills .pill{ padding:8px 12px; border-radius:999px; border:1px solid rgba(255,255,255,.22); background: rgba(0,0,0,.25); color:#fff; text-decoration:none; }
.pcx-thumbstrip{ position:absolute; left:50%; transform:translateX(-50%); bottom:24px; display:flex; gap:10px; z-index:1; }
.pcx-thumbstrip img{ width:160px; height:100px; object-fit:cover; border-radius:10px; border:1px solid rgba(255,255,255,.25); opacity:.95; }

/* PCQ styles (scoped) */
.pcq{ min-height:80vh; padding: clamp(48px,6vw,96px) 0; background:#f7f7f8; color:#0b0f16; }
.pcq .container{ max-width:1200px; margin:0 auto; }
.pcq h2{ margin:0 0 8px; font-size: clamp(26px,3vw,36px); letter-spacing:-0.01em; }
.pcq .lead{ font-weight:650; margin:0 0 10px; font-size: clamp(16px,1.6vw,19px); color:#111827; }
.pcq__grid{ display:grid; gap: clamp(20px,4vw,48px); align-items:start; } @media (min-width:980px){ .pcq__grid{ grid-template-columns:1.1fr 1fr; } }
.pcq__checklist{ list-style:none; padding:0; margin:12px 0 0; } .pcq__checklist li{ margin:8px 0; }
.pcq__checklist .check{ display:inline-block; width:1.25em; height:1.25em; border-radius:999px; background:#16a34a; color:#fff; line-height:1.25em; text-align:center; margin-right:.5em; font-weight:700; }
.pcq__standards{ display:flex; flex-wrap:wrap; gap:10px; margin-top:14px; } .pcq__standards .std{ display:inline-flex; align-items:center; padding:8px 10px; border:1px solid #e5e7eb; border-radius:12px; background:#fff; }
.pcq__cards{ display:grid; gap:16px; grid-template-columns: repeat(3, 1fr); } @media (max-width:980px){ .pcq__cards{ grid-template-columns:1fr; } }
.pcq-card{ background:#fff; border:1px solid #e5e7eb; border-radius:14px; box-shadow:0 4px 16px rgba(0,0,0,.04); overflow:hidden; }
.pcq-card img{ width:100%; height:180px; object-fit:cover; display:block; }
.pcq-card h3{ font-size:18px; margin:12px 12px 6px; color:#0b0f16; } .pcq-card p{ margin:0 12px 14px; color:#374151; }
.pcq__flow{ display:flex; flex-wrap:wrap; gap:10px; margin:16px 0 0; padding:0; list-style:none; color:#374151; font-weight:600; }
.pcq__flow li::after{ content:"→"; margin:0 8px; color:#9ca3af; } .pcq__flow li:last-child::after{ content:""; }
.pcq__actions{ display:flex; gap:10px; margin-top:14px; flex-wrap:wrap; }

/* Outcomes showcase */
.pcx-showcase{ padding: clamp(40px,6vw,96px) 0; background:#0b0f16; color:#fff; }
.pcx-showcase .showcase-grid{ display:grid; gap:16px; grid-template-columns: repeat(3,1fr); text-align:center; }
@media (max-width:900px){ .pcx-showcase .showcase-grid{ grid-template-columns:1fr; } }
.pcx-showcase .num{ font-size: clamp(28px,5vw,44px); font-weight:800; }
.pcx-showcase .lbl{ opacity:.9; margin-top:6px; }
.pcx-showcase .logo-rail.mini{ display:flex; gap:12px; align-items:center; justify-content:center; margin-top:18px; flex-wrap:wrap; }
.pcx-showcase .logo-item img{ width:120px; height:48px; object-fit:cover; opacity:.9; border-radius:8px; border:1px solid rgba(255,255,255,.15); }

/* Who We Are heading emphasis */
.pcx-who .pcx-drop summary h3, .pcx-who .grid .card h3{ color:#0b0f16; font-weight:700; }

/* CTA near footer spacing */
.cta-near-footer{ margin-top: clamp(64px,9vw,120px) !important; margin-bottom:0 !important; border-top:1px solid rgba(0,0,0,0.06); padding-top: clamp(12px,2.5vw,20px) !important; }



/* Secure Login v2 (scoped) */
.login-v2 { max-width:880px; }
.login-v2 .h2, .login-v2 h1, .login-v2 h2 { color:#0b0f16; }
.login-v2 .login-chooser{ display:grid; gap:16px; grid-template-columns:1fr; margin-top:12px; }
@media(min-width:880px){ .login-v2 .login-chooser{ grid-template-columns:1fr 1fr; } }
.login-v2 .bigbtn{ border:1px solid #e5e7eb; border-radius:14px; padding:16px; background:#fff; box-shadow:0 8px 24px rgba(0,0,0,.05); }
.login-v2 .login-form{ background:#fff; border:1px solid #e5e7eb; border-radius:16px; padding: 18px; margin-top: 18px; box-shadow:0 10px 30px rgba(0,0,0,.06); }
.login-v2 .btn-primary{ background:#111827; color:#fff; border-radius:12px; }
.login-v2 .btn-secondary{ border-radius:12px; }
.login-v2 input{ border-radius:10px; }


/* Home > Who we are: force white titles on the three intro cards */
.pcx-who .grid .card h3{ color:#fff !important; }


/* Home > Quality step flow: responsive numbered pill grid */
.pcq__flow{
  display:grid !important;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)) !important;
  gap:12px !important;
  margin:22px 0 !important;
  padding:0 !important;
  list-style:none !important;
  counter-reset: step;
}
.pcq__flow li{
  list-style:none !important;
  position:relative !important;
  counter-increment: step;
  border:1px solid #e5e7eb !important;
  border-radius:999px !important;
  padding:10px 14px 10px 40px !important;
  background:#fff !important;
  color:#0b0f16 !important;
  font-weight:700 !important;
  box-shadow:0 2px 12px rgba(0,0,0,.04) !important;
}
.pcq__flow li::before{
  content: counter(step);
  position:absolute; left:10px; top:50%;
  transform: translateY(-50%);
  width:24px; height:24px; line-height:24px; text-align:center;
  border-radius:12px;
  background:#0b0f16; color:#fff; font-size:12px; font-weight:800;
}
.pcq__flow li::after{ content: none !important; }

.pcq__actions{ justify-content:center !important; gap:12px !important; margin-top:16px !important; }



/* === About page enhancements (first pass) === */
.abt-hero .container h1{ color:#fff; }
.abt-hero .container .lead{ color:#f0f3f8; }

.abt-timeline .tl-rail{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns: minmax(120px, 1fr);
  gap: 14px;
  overflow-x:auto;
  padding: 12px 2px 6px;
  scrollbar-width: thin;
}
.abt-timeline .tl-item{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:14px 10px;
  border:1px solid #e5e7eb;
  border-radius:12px;
  background:#fff;
  box-shadow: 0 1px 2px rgba(0,0,0,.05);
  cursor:pointer;
  transition: transform .15s ease, box-shadow .15s ease;
}
.abt-timeline .tl-item:hover{ transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,.08); }
.abt-timeline .tl-year{ font-weight:800; font-size:18px; color:#0b0f16; letter-spacing:.2px; }
.abt-timeline .tl-label{ color:#374151; font-weight:600; font-size:14px; text-align:center; }

.tl-hovercard{
  position: sticky;
  left: 0;
  bottom: 0;
  margin-top: 16px;
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 14px;
  align-items:center;
  background: #0b0f16;
  color: #fff;
  border-radius: 12px;
  padding: 10px;
}
.tl-hovercard[hidden]{ display:none; }
.tl-hovercard .tl-photo{ width:120px; height:120px; background-size:cover; background-position:center; border-radius:10px; border:1px solid rgba(255,255,255,.15); }
.tl-hovercard .tl-name{ font-weight:800; font-size:18px; }
.tl-hovercard .tl-desc{ opacity:.9; margin-top:4px; }

.visually-hidden{ position:absolute !important; width:1px; height:1px; margin:-1px; padding:0; overflow:hidden; clip:rect(0 0 0 0); border:0; }

#team .grid .details-card summary .pc-summary__title{ font-weight:700; color:#0b0f16; }


/* === CONTACT v7 — stable structure + original compliance & AI, no side capability image === */

/* Hero chips */
.hero-chips{ display:flex; gap:8px; justify-content:center; flex-wrap:wrap; margin-top:14px; }
.hero-chips .chip{ background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12); padding:6px 10px; border-radius:999px; font-weight:600; color:#d8e1f0; }

/* Team card (scoped visuals; keep native card spacing) */
.team-card__heading{ letter-spacing:.6px; text-transform:uppercase; margin:.2rem 0 .6rem; }
.team-card__wrap{ display:grid; grid-template-columns:110px 1fr; gap:14px; align-items:center; }
.team-card__avatar{ position:relative; width:110px; height:110px; border-radius:14px; overflow:hidden; background:#0f1624; display:grid; place-items:center; border:1px solid rgba(255,255,255,.08); }
.team-card__avatar img{ width:100%; height:100%; object-fit:cover; filter:saturate(1.05) contrast(1.05); }
.team-card__ring{ position:absolute; inset:0; pointer-events:none; }
.team-card__meta{ display:grid; gap:6px; }
.team-card__name{ font-weight:900; font-size:clamp(1.1rem, 2.4vw, 1.4rem); letter-spacing:.2px; }
.team-card__role{ color:var(--muted); font-weight:700; text-transform:uppercase; font-size:.82rem; letter-spacing:.26px; }
.team-card__actions{ display:flex; gap:8px; flex-wrap:wrap; margin-top:4px; }
.action-chip{ display:inline-flex; align-items:center; gap:8px; padding:8px 12px; border-radius:999px; background: linear-gradient(180deg, rgba(225,6,0,.18), rgba(225,6,0,.12)); color:#fff; border:1px solid rgba(225,6,0,.35); font-weight:800; text-decoration:none; }
.action-chip.ghost{ background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.18); color:#e9eef7; }
.action-chip .icon{ display:inline-grid; place-items:center; width:20px; height:20px; }

/* Map wrap */
.map-card .map-frame-wrap{ border-radius:12px; overflow:hidden; border:1px solid rgba(255,255,255,.08); background:#0f1624; }
.map-frame{ display:block; width:100%; aspect-ratio:16/10; border:0; }

/* Cinematic image strip polish */
.pcx-image-section{
  position:relative; min-height:46vh; display:grid; place-items:center; text-align:center;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
  overflow:hidden;
}
.pcx-image-section .bg{ position:absolute; inset:0; background-size:cover; background-position:center; filter: saturate(1.05) brightness(.9); }
.pcx-image-section::after{ content:""; position:absolute; inset:0; background: radial-gradient(40% 35% at 50% 15%, rgba(0,0,0,.35), transparent 55%), linear-gradient(180deg, rgba(10,15,22,.2), rgba(10,15,22,.75)); pointer-events:none; }
.pcx-image-section > div{ position:relative; z-index:1; }
.pcx-image-section h2{ font-size: clamp(1.6rem, 3.2vw, 2.2rem); margin:.2rem 0 .2rem; }
.pcx-image-section p{ color: var(--muted); margin:0; }

/* Compliance ribbon (original look) */
.compliance-ribbon{ padding:22px 0 34px; border-top:1px solid rgba(255,255,255,.06); background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02)); }
.compliance-ribbon h3{ margin:0 0 10px; text-align:center; }
.comp-badges{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; padding:0; margin:0; list-style:none; }
.comp-badges li{ display:inline-flex; align-items:center; gap:8px; padding:8px 12px; border-radius:999px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); box-shadow: inset 0 0 0 1px rgba(0,0,0,.12); font-weight:800; color:#e5ecfb; }
.comp-icon{ display:inline-flex; width:20px; height:20px; align-items:center; justify-content:center; background: radial-gradient(120% 120% at -10% -10%, rgba(91,137,255,.35), transparent 60%), radial-gradient(120% 120% at 110% 110%, rgba(225,6,0,.35), transparent 60%); border-radius:50%; border:1px solid rgba(255,255,255,.22); }

/* AI CTA (original styling) */
.ai-cta{ position:relative; padding: 64px 0; border-top: 1px solid rgba(255,255,255,.06); background: radial-gradient(40% 60% at 10% 10%, rgba(85,146,255,.14), transparent 60%), radial-gradient(40% 60% at 90% 20%, rgba(225,6,0,.18), transparent 60%), linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02)); overflow:hidden; }
.ai-cta::before{ content:""; position:absolute; width:900px; height:900px; right:-300px; bottom:-420px; border-radius:50%; background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.12), transparent 60%); filter: blur(24px); opacity:.4; animation: orbit 26s linear infinite; }
@keyframes orbit{ from{ transform: rotate(0deg)} to{ transform: rotate(360deg)} }
.ai-cta__grid{ display:grid; grid-template-columns: 1.1fr 1fr; gap: 24px; align-items: center; }
.ai-pill{ display:inline-flex; align-items:center; gap:8px; padding:4px 10px; border-radius:999px; background: linear-gradient(180deg, rgba(255,255,255,.22), rgba(255,255,255,.06)); border:1px solid rgba(255,255,255,.22); color:#0b0f16; font-weight:900; letter-spacing:.3px; box-shadow: 0 4px 18px rgba(0,0,0,.25); }
.ai-cta__copy h2{ margin:.4rem 0 .3rem; font-size: clamp(1.6rem, 3.2vw, 2.2rem) }
.ai-cta__copy .lead{ color:#cfe0ff; }
.ai-cta__actions{ display:flex; gap:10px; flex-wrap:wrap; margin-top:10px; }
.ai-btn{ background: linear-gradient(180deg, #e10600, #b30500); border:1px solid rgba(255,255,255,.14); font-weight:900; box-shadow: 0 16px 40px rgba(225,6,0,.28); }
.ai-btn-ghost{ border:1px solid rgba(255,255,255,.20); background: rgba(255,255,255,.06); font-weight:800; }
.ai-cta__features{ margin:0; padding:0; list-style:none; display:grid; gap:12px; }
.ai-cta__features li{ display:grid; grid-template-columns: 38px 1fr; gap:10px; align-items:flex-start; background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03)); border:1px solid rgba(255,255,255,.08); border-radius: 14px; padding:12px; }
.ai-cta__features strong{ display:block; }
.ai-icon{ display:grid; place-items:center; width:38px; height:38px; border-radius:12px; background: radial-gradient(120% 120% at -10% -10%, rgba(91,137,255,.35), transparent 60%), radial-gradient(120% 120% at 110% 110%, rgba(225,6,0,.35), transparent 60%); color:#fff; border:1px solid rgba(255,255,255,.22); box-shadow: inset 0 0 0 1px rgba(0,0,0,.18), 0 6px 16px rgba(0,0,0,.25); }

/* Accessibility helper */
.sr-only{ position:absolute !important; width:1px !important; height:1px !important; padding:0 !important; margin:-1px !important; overflow:hidden !important; clip:rect(0,0,0,0) !important; white-space:nowrap !important; border:0 !important; }

/* Responsive safety */
@media (max-width: 980px){
  .ai-cta__grid{ grid-template-columns: 1fr; }
  .team-card__wrap{ grid-template-columns: 80px 1fr; }
}


/* === Full-width map hero under the contact hero === */
.contact-map-hero{
  position:relative;
  min-height:60vh;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
  overflow:hidden;
}
.map-hero__frame{
  position:absolute; inset:0;
  width:100%; height:100%; border:0;
  filter: saturate(1.05) contrast(1.05) brightness(.95);
}
.contact-map-hero::after{
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.18));
  pointer-events:none;
}

/* Team card avatar now shows a PC icon SVG */
.team-card__avatar{ display:grid; place-items:center; }
.team-card__pc{ width:70%; height:auto; display:block; }
.team-card__wrap{ grid-template-columns: 100px 1fr; } /* tighten so text never overlaps */


/* === CONTACT v9 — hero map background + logo ring avatar + iconified info === */

/* Hero map as background */
.contact-hero{ position:relative; overflow:hidden; }
.contact-hero__bg{ position:absolute; inset:0; z-index:0; }
.hero-map{ position:absolute; inset:0; }
.hero-map__iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; filter: saturate(1.05) contrast(1.05) brightness(.9); }
.contact-hero::after{
  content:""; position:absolute; inset:0; z-index:1;
  background: radial-gradient(40% 35% at 50% 15%, rgba(0,0,0,.35), transparent 55%),
              linear-gradient(180deg, rgba(10,15,22,.15), rgba(10,15,22,.65));
}
.contact-hero__inner{ position:relative; z-index:2; }
.contact-hero h1{ color:#fff; text-shadow: 0 2px 14px rgba(0,0,0,.45); }
.contact-hero .lead{ color:#e5edff; text-shadow: 0 1px 10px rgba(0,0,0,.35); }

/* Team card logo avatar with ring */
.team-card__avatar{ position:relative; width:110px; height:110px; border-radius:14px; overflow:hidden; background:#0f1624; display:grid; place-items:center; border:1px solid rgba(255,255,255,.08); }
.team-card__avatar img{ display:block; width:100%; height:100%; object-fit:cover; filter:contrast(1.03) saturate(1.02); }
.team-card__ring{ position:absolute; inset:0; pointer-events:none; display:block; }

/* Iconified info lists */
.ci-list{ list-style:none; padding:0; margin:0; display:grid; gap:10px; }
.ci-list li{ display:grid; grid-template-columns: 28px 1fr; gap:10px; align-items:flex-start; }
.ci-icon{ display:grid; place-items:center; width:28px; height:28px; border-radius:10px; background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04)); border:1px solid rgba(255,255,255,.12); color:#fff; }
.ci-list a{ color:#fff; text-decoration:none; border-bottom:1px dashed rgba(255,255,255,.28); }
.ci-list a:hover{ border-bottom-color: transparent; }

/* Ensure action chips remain prominent */
.action-chip{ box-shadow: 0 10px 24px rgba(225,6,0,.22); }
