/* =========================================================================
   NTG Clarity — Managed Software Delivery, DevOps & Cloud
   Shared stylesheet — brand palette derived from ntgclarity.com
   ========================================================================= */

/*
  ---------------------------------------------------------------------
  BRAND FONT — Tahoma
  ---------------------------------------------------------------------
  Tahoma is a Microsoft system font (not on Google Fonts). It's present
  on Windows by default and widely available elsewhere; --font-display
  and --font-body fall back to Verdana, then generic sans-serif, on
  systems that lack Tahoma. IBM Plex Mono (loaded from Google Fonts) is
  kept separately for the small uppercase eyebrow labels and stat
  numbers, where the monospace look is intentional.
  ---------------------------------------------------------------------
*/

:root{
  --bg:#F8F6F3;
  --bg-alt:#F0E8E2;
  --ink:#241A1A;
  --ink-soft:#5E5350;
  --primary:#C82622;        /* NTG Clarity brand red */
  --primary-dark:#9E1D1A;
  --primary-light:#E2554F;
  --primary-tint:#FCEAE9;
  --gold:#F2B134;
  --teal:#2F9E8F;
  --border:#F5DEDC;
  --white:#FFFFFF;
  --max:1180px;
  --radius:14px;
  --shadow-sm:0 2px 10px rgba(36,26,26,0.05);
  --shadow-md:0 12px 28px rgba(36,26,26,0.09);
  --font-display:'Tahoma','Verdana',sans-serif;
  --font-body:'Tahoma','Verdana',sans-serif;
  --font-mono:'IBM Plex Mono',monospace;
}

*{margin:0;padding:0;box-sizing:border-box;}

html{scroll-behavior:smooth;}

[id]{scroll-margin-top:84px;}

body{
  font-family:var(--font-body);
  color:var(--ink-soft);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

img,svg{display:block;max-width:100%;}

a{color:inherit;}

h1,h2,h3,h4{
  font-family:var(--font-display);
  color:var(--ink);
  line-height:1.15;
  font-weight:600;
  letter-spacing:-0.01em;
}

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

.eyebrow{
  font-family:var(--font-mono);
  font-size:0.78rem;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--primary);
  font-weight:500;
  margin-bottom:14px;
  display:inline-flex;
  align-items:center;
  gap:8px;
}

.eyebrow-title{
  font-family:var(--font-mono);
  font-size:0.98rem;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--primary);
  font-weight:500;
  margin-bottom:14px;
  display:inline-flex;
  align-items:center;
  gap:8px;
}

.eyebrow.live::before{
  content:"";
  width:8px;height:8px;border-radius:50%;
  background:var(--white);
  box-shadow:0 0 0 0 rgba(47,158,143,0.5);
}

@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(47,158,143,0.45);}
  70%{box-shadow:0 0 0 8px rgba(47,158,143,0);}
  100%{box-shadow:0 0 0 0 rgba(47,158,143,0);}
}

.nav-links a {
  font-weight: bold;
  text-decoration: none;
}

section{padding:88px 0;}
@media(max-width:768px){section{padding:56px 0;}}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-body);font-weight:600;font-size:0.98rem;
  padding:14px 28px;border-radius:999px;border:1px solid transparent;
  cursor:pointer;text-decoration:none;transition:transform .15s ease, box-shadow .15s ease, background .2s ease, color .2s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--primary);color:var(--white);box-shadow:0 2px 10px rgba(200,38,34,0.18);}
.btn-primary:hover{background:var(--primary-dark);box-shadow:0 8px 22px rgba(200,38,34,0.32);transform:translateY(-1px);}

/* ---------- SERVICE CTA (outlined arrow link) ---------- */
.btn-service{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 26px;border-radius:8px;
  background:transparent;border:1.5px solid var(--primary);
  color:var(--primary);font-family:var(--font-body);font-weight:600;font-size:0.95rem;
  text-decoration:none;cursor:pointer;
  transition:background .2s ease, color .2s ease, transform .15s ease;
}
.btn-service::after{
  content:"→";font-size:1.05rem;line-height:1;transition:transform .2s ease;
}
.btn-service:hover{background:var(--primary);color:var(--white);transform:translateY(-1px);}
.btn-service:hover::after{transform:translateX(4px);}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--border);}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary);}
.btn-gold{background:var(--gold);color:var(--ink);}
.btn-gold:hover{background:#ffc859;}
.btn-light{background:var(--white);color:var(--primary);}
.btn-light:hover{background:var(--bg-alt);}

/* ---------- NAV ---------- */
header.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(247,246,242,0.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 24px;max-width:var(--max);margin:0 auto;gap:24px;
}
.logo{
  display:flex;align-items:center;gap:10px;
  font-family:var(--font-display);font-weight:700;font-size:1.15rem;color:var(--ink);
  text-decoration:none;flex-shrink:0;
}
.logo .mark{
  width:32px;height:32px;border-radius:8px;background:var(--primary);
  display:flex;align-items:center;justify-content:center;gap:3px;flex-shrink:0;
}
.logo .mark span{width:5px;height:5px;border-radius:50%;}
.logo .mark span:nth-child(1){background:var(--teal);}
.logo .mark span:nth-child(2){background:var(--gold);}
.logo .mark span:nth-child(3){background:var(--white);}
.nav-links{
  display:flex;gap:28px;font-size:0.94rem;font-weight:500;color:var(--ink-soft);
  list-style:none;flex:1;justify-content:center;
}
.nav-links a{text-decoration:none;transition:color .15s;}
.nav-links a:hover,.nav-links a.active{color:var(--primary);}
.nav-cta{display:flex;align-items:center;gap:18px;flex-shrink:0;}
.nav-phone{
  font-family:var(--font-mono);font-size:0.88rem;color:var(--ink);
  text-decoration:none;display:none;
}
@media(min-width:1024px){.nav-phone{display:inline;}}

/* ---------- MOBILE NAV ---------- */
.nav-toggle{
  display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;
  width:38px;height:38px;border:1px solid var(--border);border-radius:8px;
  background:var(--white);cursor:pointer;padding:0;flex-shrink:0;
}
.nav-toggle span{display:block;width:18px;height:2px;background:var(--ink);border-radius:2px;transition:transform .2s ease, opacity .2s ease;}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
@media(max-width:860px){
  .nav-toggle{display:flex;order:3;}
  .nav-cta .btn-primary{display:none;}
  .nav-links{
    display:none;flex-direction:column;gap:0;width:100%;
    position:absolute;top:100%;left:0;background:var(--bg);
    border-bottom:1px solid var(--border);box-shadow:var(--shadow-md);
    padding:4px 24px 12px;
  }
  .nav-links.open{display:flex;}
  .nav-links li{width:100%;}
  .nav-links a{display:block;padding:13px 0;border-bottom:1px solid var(--border);}
  .nav-links li:last-child a{border-bottom:none;}
  .nav-links .nav-cta-mobile{
    display:flex;justify-content:center;border:none;margin-top:10px;
    padding:14px 28px;border-radius:999px;background:var(--primary);color:var(--white);font-weight:600;
  }
}

/* ---------- PAGE HERO (secondary pages) ---------- */
.page-hero{
  padding:64px 0 56px;
  background:linear-gradient(180deg,var(--bg-alt) 0%, var(--bg) 100%);
  border-bottom:1px solid var(--border);
}
.page-hero h1{font-size:clamp(2.1rem,4.4vw,3.1rem);margin-bottom:16px;}
.page-hero p.lead{font-size:1.06rem;max-width:640px;}
.page-hero .crumbs{
  font-family:var(--font-mono);font-size:0.78rem;color:var(--ink-soft);
  margin-bottom:18px;text-transform:uppercase;letter-spacing:0.08em;
}
.page-hero .crumbs a{text-decoration:none;color:var(--primary);}

/* ---------- HERO (home) ---------- */
.hero{padding-top:64px;padding-bottom:40px;}
.hero-grid{
  display:grid;grid-template-columns:1.05fr 0.95fr;gap:64px;align-items:center;
}
@media(max-width:960px){.hero-grid{grid-template-columns:1fr;gap:48px;}}

.hero h1{font-size:clamp(2.4rem,5vw,3.6rem);margin-bottom:20px;}
.hero h1 em{
  font-style:normal;color:var(--primary);
  background:linear-gradient(180deg,transparent 62%,rgba(200,38,34,0.14) 62%);
}
.hero p.lead{font-size:1.12rem;max-width:540px;margin-bottom:32px;}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:28px;}
.hero-trust{
  font-size:0.88rem;color:var(--ink-soft);
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
}
.hero-trust strong{color:var(--ink);font-weight:600;}

/* ---------- PIPELINE SIGNATURE ---------- */
.pipeline-card{
  background:linear-gradient(150deg,var(--primary) 0%, var(--primary-dark) 100%);
  border-radius:20px;padding:32px 28px;
  color:var(--bg);position:relative;overflow:hidden;
}
.pipeline-card .label{
  font-family:var(--font-mono);font-size:0.74rem;letter-spacing:0.12em;
  text-transform:uppercase;color:rgba(250,249,252,0.6);margin-bottom:28px;
  display:flex;justify-content:space-between;align-items:center;
}
.pipeline-card .label .dot{
  width:8px;height:8px;border-radius:50%;background:var(--white);
  box-shadow:0 0 0 0 rgba(47,158,143,0.5);
}
.pipeline-track{
  position:relative;display:flex;justify-content:space-between;
  margin:0 4px 36px 4px;padding-top:6px;
}
.pipeline-track::before{
  content:"";position:absolute;top:21px;left:0;right:0;height:2px;
  background:rgba(250,249,252,0.16);
}
.pipeline-track::after{
  content:"";position:absolute;top:21px;left:0;height:2px;width:100%;
  background:linear-gradient(90deg,var(--teal),var(--gold),transparent 70%);
  animation:flow 6s linear infinite;
  transform-origin:left;
}
@keyframes flow{
  0%{clip-path:inset(0 100% 0 0);}
  50%{clip-path:inset(0 0 0 0);}
  100%{clip-path:inset(0 0 0 100%);}
}
.pipeline-step{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  position:relative;z-index:1;flex:1;
}
.pipeline-step .node{
  width:14px;height:14px;border-radius:50%;background:var(--bg);
  border:3px solid var(--primary-dark);box-shadow:0 0 0 4px var(--primary-dark);
}
.pipeline-step span{
  font-family:var(--font-mono);font-size:0.7rem;color:rgba(250,249,252,0.7);
  text-align:center;letter-spacing:0.02em;
}
.pipeline-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
  border-top:1px solid rgba(250,249,252,0.14);padding-top:24px;
}
.pipeline-stats .stat-num{
  font-family:var(--font-mono);font-size:1.6rem;font-weight:500;color:var(--bg);
  display:flex;align-items:baseline;gap:2px;
}
.pipeline-stats .stat-label{
  font-size:0.78rem;color:rgba(250,249,252,0.65);margin-top:4px;
}
@media(max-width:540px){
  .pipeline-track{display:none;}
  .pipeline-stats{grid-template-columns:1fr;gap:14px;}
}

/* ---------- TRUST BAR (stat strip) ---------- */
.trust-bar{
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  background:var(--bg-alt);
}
.trust-bar-inner{
  display:grid;grid-template-columns:repeat(4,1fr);
  padding:30px 24px;
}
.trust-item{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  gap:6px;padding:0 22px;border-left:1px solid var(--border);
}
.trust-item:first-child{border-left:none;}
.trust-num{
  font-family:var(--font-display);font-size:clamp(1.6rem,2.4vw,2.1rem);
  font-weight:700;color:var(--ink);letter-spacing:-0.01em;
}
.trust-label{
  font-size:0.82rem;color:var(--ink-soft);line-height:1.3;max-width:160px;
}
@media(max-width:860px){
  .trust-bar-inner{grid-template-columns:repeat(2,1fr);row-gap:24px;}
  .trust-item:nth-child(2n+1){border-left:none;}
  .trust-item:nth-child(3),.trust-item:nth-child(4){border-top:1px solid var(--border);padding-top:20px;}
}
@media(max-width:520px){
  .trust-bar-inner{grid-template-columns:1fr;}
  .trust-item{border-left:none !important;border-top:1px solid var(--border);padding-top:18px;}
  .trust-item:first-child{border-top:none;padding-top:0;}
}

/* ---------- SECTION HEADERS ---------- */
.section-head{max-width:680px;margin-bottom:48px;}
.section-head h2{font-size:clamp(1.7rem,3.4vw,2.4rem);margin-bottom:14px;}
.section-head p{font-size:1.04rem;}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center;}

/* ---------- PERSONAS ---------- */
.personas-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
@media(max-width:1080px){.personas-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.personas-grid{grid-template-columns:1fr;}}
.persona-card{
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius);
  padding:28px 24px;display:flex;flex-direction:column;
  box-shadow:var(--shadow-sm);transition:transform .15s ease, box-shadow .15s ease;
}
.persona-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);}
.persona-card .tag{
  font-family:var(--font-mono);font-size:0.72rem;text-transform:uppercase;
  letter-spacing:0.1em;color:var(--primary);margin-bottom:14px;display:block;
}
.persona-card h3{font-size:1.22rem;margin-bottom:12px;}
.persona-card ul{list-style:none;display:flex;flex-direction:column;gap:8px;font-size:0.94rem;}
.persona-card ul li{padding-left:18px;position:relative;}
.persona-card ul li::before{
  content:"";position:absolute;left:0;top:0.6em;width:8px;height:1.5px;background:var(--gold);
}

/* ---------- SERVICES ---------- */
.services-list{display:flex;flex-direction:column;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);}
.service-row{
  background:var(--white);display:grid;grid-template-columns:64px 1.1fr 1.4fr;gap:28px;
  padding:32px 30px;align-items:start;
}
@media(max-width:860px){.service-row{grid-template-columns:1fr;gap:14px;}}
.service-row .num{
  font-family:var(--font-mono);font-size:0.9rem;color:var(--primary);font-weight:500;
  border:1px solid var(--border);border-radius:8px;width:40px;height:40px;
  display:flex;align-items:center;justify-content:center;
}
.service-row h3{font-size:1.28rem;margin-bottom:8px;}
.service-row p.tagline{font-size:0.92rem;color:var(--primary);font-weight:600;margin-bottom:10px;}
.service-row .pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px;}
.service-row a.row-link{
  display:inline-flex;align-items:center;gap:6px;margin-top:16px;
  font-weight:600;font-size:0.92rem;color:var(--primary);text-decoration:none;
}
.service-row a.row-link:hover{text-decoration:underline;}
.pill{
  font-family:var(--font-mono);font-size:0.74rem;color:var(--ink-soft);
  background:var(--bg-alt);border:1px solid var(--border);border-radius:999px;
  padding:5px 12px;
}

/* ---------- SERVICE DETAIL CARDS (services.html) ---------- */
.service-detail{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;
  padding:56px 0;border-bottom:1px solid var(--border);
}
.service-detail:last-of-type{border-bottom:none;}
.service-detail.reverse .sd-visual{order:2;}
@media(max-width:900px){
  .service-detail,.service-detail.reverse .sd-visual{grid-template-columns:1fr;order:initial;}
  .service-detail{display:flex;flex-direction:column;}
}
.sd-visual{
  background:var(--bg-alt);border:1px solid var(--border);border-radius:var(--radius);
  padding:32px;min-height:240px;display:flex;flex-direction:column;justify-content:center;gap:14px;
  box-shadow:var(--shadow-sm);
}
.sd-visual .sd-tag{
  font-family:var(--font-mono);font-size:0.74rem;color:var(--primary);
  text-transform:uppercase;letter-spacing:0.1em;
}
.sd-visual .sd-bignum{
  font-family:var(--font-mono);font-size:2.6rem;color:var(--ink);font-weight:600;
}
.sd-visual .sd-list{list-style:none;display:flex;flex-direction:column;gap:10px;margin-top:8px;}
.sd-visual .sd-list li{
  font-size:0.92rem;color:var(--ink-soft);display:flex;align-items:flex-start;gap:10px;
}
.sd-visual .sd-list li::before{
  content:"";width:8px;height:8px;border-radius:50%;background:var(--teal);flex-shrink:0;margin-top:6px;
}
.sd-content .sd-eyebrow{
  font-family:var(--font-mono);font-size:0.76rem;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--primary);margin-bottom:12px;display:block;
}
.sd-content h2{font-size:clamp(1.5rem,3vw,2rem);margin-bottom:14px;}
.sd-content p{margin-bottom:16px;}
.sd-features{list-style:none;display:flex;flex-direction:column;gap:10px;margin:20px 0;}
.sd-features li{display:flex;align-items:flex-start;gap:10px;font-size:0.95rem;}
.sd-features li::before{
  content:"✓";color:var(--white);background:var(--primary);font-size:0.7rem;font-weight:700;
  width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;margin-top:1px;
}

/* ---------- QUICK-JUMP / KEYWORD STRIP ---------- */
.quick-jump{
  display:flex;flex-wrap:wrap;gap:10px;margin-bottom:48px;
}
.quick-jump a{
  font-family:var(--font-mono);font-size:0.82rem;padding:9px 18px;border-radius:999px;
  border:1px solid var(--border);background:var(--white);color:var(--ink-soft);
  text-decoration:none;transition:all .15s ease;
}
.quick-jump a:hover{border-color:var(--primary);color:var(--primary);}

/* ---------- DEVOPS CAPABILITY BLOCK ---------- */
.capability-block{padding:24px 0 8px;}
.capability-head{max-width:680px;margin-bottom:32px;}
.capability-head h3{font-size:clamp(1.3rem,2.6vw,1.7rem);margin-bottom:10px;}
.capability-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:48px;}
@media(max-width:900px){.capability-grid{grid-template-columns:1fr;}}
.capability-card{
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius);
  padding:24px;box-shadow:var(--shadow-sm);transition:transform .15s ease, box-shadow .15s ease;
}
.capability-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);}
.capability-card h4{font-size:1.05rem;margin-bottom:12px;}
.capability-card p{font-size:0.9rem;color:var(--ink-soft);margin:0;}
.capability-card ul{list-style:none;display:flex;flex-direction:column;gap:8px;font-size:0.9rem;color:var(--ink-soft);}
.capability-card ul li{padding-left:16px;position:relative;}
.capability-card ul li::before{
  content:"";position:absolute;left:0;top:0.65em;width:7px;height:1.5px;background:var(--gold);
}

/* ---------- SOLUTIONS / TOOLKIT GRIDS ---------- */
.solutions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:20px;margin-bottom:48px;}
.toolkit-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
@media(max-width:960px){.toolkit-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.toolkit-grid{grid-template-columns:1fr;}}

/* ---------- PROCESS ---------- */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
@media(max-width:900px){.process-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.process-grid{grid-template-columns:1fr;}}
.process-step{position:relative;padding-top:48px;}
.process-step .step-no{
  font-family:var(--font-mono);font-size:2.2rem;font-weight:600;color:var(--border);
  position:absolute;top:-8px;left:0;
}
.process-step h3{font-size:1.08rem;margin-bottom:8px;}
.process-step p{font-size:0.92rem;}

/* ---------- CLIENTS / PROOF ---------- */
.proof{background:var(--primary);color:var(--bg);}
.proof .section-head h2,.proof .section-head p{color:var(--bg);}
.proof .section-head p{color:rgba(250,249,252,0.75);}
.clients-row{
  display:flex;flex-wrap:wrap;gap:16px;margin-bottom:48px;
}
.client-chip{
  font-family:var(--font-display);font-weight:600;font-size:1.05rem;
  border:1px solid rgba(250,249,252,0.22);border-radius:10px;
  padding:18px 26px;flex:1;min-width:140px;text-align:center;
  color:rgba(250,249,252,0.92);
}
.proof-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
@media(max-width:860px){.proof-stats{grid-template-columns:repeat(2,1fr);}}
.proof-stat .num{font-family:var(--font-mono);font-size:2.1rem;color:var(--gold);font-weight:500;}
.proof-stat .label{font-size:0.88rem;color:rgba(250,249,252,0.7);margin-top:6px;}

/* ---------- BENEFITS ---------- */
.benefits-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
@media(max-width:960px){.benefits-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.benefits-grid{grid-template-columns:1fr;}}
.benefit-card{
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius);
  padding:24px;box-shadow:var(--shadow-sm);transition:transform .15s ease, box-shadow .15s ease;
}
.benefit-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);}
.benefit-card .icon{
  width:38px;height:38px;border-radius:10px;background:var(--bg-alt);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px;
  color:var(--primary);font-family:var(--font-mono);font-weight:600;
}
.benefit-card h3{font-size:1.02rem;margin-bottom:6px;}
.benefit-card p{font-size:0.9rem;}

/* ---------- CTA BANNER ---------- */
.cta-banner{
  background:linear-gradient(135deg,var(--primary) 0%, var(--primary-dark) 100%);
  border-radius:24px;padding:56px;color:var(--bg);
  display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap;
}
.cta-banner h2{color:var(--bg);font-size:clamp(1.5rem,3vw,2.1rem);margin-bottom:8px;}
.cta-banner p{color:rgba(250,249,252,0.8);max-width:480px;}
@media(max-width:768px){.cta-banner{padding:36px;}}

/* ---------- LEAD FORM ---------- */
.lead{}
.lead-grid{display:grid;grid-template-columns:0.9fr 1.1fr;gap:56px;align-items:start;}
@media(max-width:900px){.lead-grid{grid-template-columns:1fr;gap:36px;}}
.lead-info h2{font-size:clamp(1.7rem,3.2vw,2.3rem);margin-bottom:16px;}
.lead-info p{margin-bottom:24px;}
.lead-info .lead-points{list-style:none;display:flex;flex-direction:column;gap:12px;font-size:0.95rem;}
.lead-info .lead-points li{display:flex;align-items:flex-start;gap:10px;}
.lead-info .lead-points li::before{
  content:"✓";color:var(--teal);font-weight:700;flex-shrink:0;
  width:22px;height:22px;border-radius:50%;background:rgba(47,158,143,0.12);
  display:flex;align-items:center;justify-content:center;font-size:0.78rem;
}
.lead-info .contact-card{
  margin-top:32px;background:var(--white);border:1px solid var(--border);
  border-radius:var(--radius);padding:22px;display:flex;flex-direction:column;gap:10px;
  font-size:0.92rem;box-shadow:var(--shadow-sm);
}
.lead-info .contact-card strong{color:var(--ink);}
form.lead-form{
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius);
  padding:32px;display:flex;flex-direction:column;gap:18px;box-shadow:var(--shadow-md);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
@media(max-width:560px){.form-row{grid-template-columns:1fr;}}
.field{display:flex;flex-direction:column;gap:6px;}
.field label{font-size:0.84rem;font-weight:600;color:var(--ink);}
.field input,.field select,.field textarea{
  font-family:var(--font-body);font-size:0.96rem;padding:12px 14px;
  border:1px solid var(--border);border-radius:8px;background:var(--bg);
  color:var(--ink);outline:none;transition:border-color .15s;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-tint);}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%235E5350' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;}
.field .checkbox-row{display:flex;align-items:flex-start;gap:10px;font-size:0.86rem;color:var(--ink-soft);}
.field .checkbox-row input{width:16px;height:16px;margin-top:2px;flex-shrink:0;accent-color:var(--primary);}
.field textarea{resize:vertical;min-height:90px;}
.form-note{font-size:0.8rem;color:var(--ink-soft);}
.form-success{
  display:none;background:rgba(47,158,143,0.1);border:1px solid var(--teal);
  border-radius:8px;padding:14px 16px;font-size:0.92rem;color:var(--ink);
}
.form-success.visible{display:block;}

/* ---------- FAQ ---------- */
.faq-list{display:flex;flex-direction:column;gap:1px;max-width:820px;}
.faq-list.wide{max-width:none;}
.faq-item{
  border-bottom:1px solid var(--border);padding:22px 0;cursor:pointer;
}
.faq-item summary{
  font-family:var(--font-display);font-weight:600;font-size:1.05rem;color:var(--ink);
  list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px;
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{
  content:"+";font-family:var(--font-mono);font-size:1.3rem;color:var(--gold);flex-shrink:0;
  transition:transform .2s ease;
}
.faq-item[open] summary::after{content:"–";}
.faq-item p{margin-top:12px;font-size:0.96rem;max-width:680px;}

/* ---------- DEVOPS HUB ---------- */
.hub-filters{
  display:flex;gap:10px;flex-wrap:wrap;margin-bottom:40px;
}
.hub-filter{
  font-family:var(--font-mono);font-size:0.82rem;padding:9px 18px;border-radius:999px;
  border:1px solid var(--border);background:var(--white);color:var(--ink-soft);
  cursor:pointer;transition:all .15s ease;
}
.hub-filter:hover{border-color:var(--primary);color:var(--primary);}
.hub-filter.active{background:var(--primary);color:var(--white);border-color:var(--primary);}

.hub-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
@media(max-width:960px){.hub-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:640px){.hub-grid{grid-template-columns:1fr;}}

.hub-card{
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);
  transition:transform .15s ease, box-shadow .15s ease;
}
.hub-card:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(200,38,34,0.12);}
.hub-card .hub-card-top{
  padding:28px 24px 0;
}
.hub-card .hub-tag{
  font-family:var(--font-mono);font-size:0.7rem;text-transform:uppercase;letter-spacing:0.1em;
  color:var(--primary);background:var(--primary-tint);border-radius:999px;
  padding:5px 12px;display:inline-block;margin-bottom:14px;
}
.hub-card h3{font-size:1.08rem;margin-bottom:10px;}
.hub-card p{font-size:0.92rem;}
.hub-card .hub-card-bottom{
  margin-top:auto;padding:20px 24px 24px;
  display:flex;justify-content:space-between;align-items:center;
  font-size:0.8rem;color:var(--ink-soft);font-family:var(--font-mono);
}
.hub-card .hub-card-bottom a{color:var(--primary);text-decoration:none;font-weight:600;font-family:var(--font-body);}
.hub-card .hub-card-bottom a:hover{text-decoration:underline;}
.hub-card.featured{
  grid-column:span 3;display:grid;grid-template-columns:1.3fr 1fr;gap:0;
}
.hub-card.featured .hub-card-top{padding:36px;display:flex;flex-direction:column;justify-content:center;}
.hub-card.featured .hub-card-visual{
  background:linear-gradient(150deg,var(--primary) 0%, var(--primary-dark) 100%);
  min-height:200px;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-mono);color:rgba(250,249,252,0.85);font-size:0.85rem;letter-spacing:0.08em;
  text-transform:uppercase;padding:24px;text-align:center;
}
@media(max-width:860px){
  .hub-card.featured{grid-column:span 1;grid-template-columns:1fr;}
  .hub-card.featured .hub-card-visual{order:-1;min-height:140px;}
}

.newsletter{
  background:var(--bg-alt);border:1px solid var(--border);border-radius:var(--radius);
  padding:36px;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;
}
.newsletter h3{font-size:1.2rem;margin-bottom:6px;}
.newsletter p{font-size:0.92rem;}
.newsletter form{display:flex;gap:10px;flex-wrap:wrap;}
.newsletter input{
  font-family:var(--font-body);font-size:0.94rem;padding:12px 16px;
  border:1px solid var(--border);border-radius:999px;background:var(--white);min-width:240px;
}

/* ---------- FOOTER ---------- */
footer{background:var(--ink);color:rgba(250,249,252,0.7);}
.footer-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding:64px 0 32px;
}
@media(max-width:860px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr;}}
.footer-grid .logo{color:var(--bg);margin-bottom:14px;}
.footer-grid .logo .mark{background:rgba(250,249,252,0.14);}
.footer-grid .logo .mark span:nth-child(3){background:var(--bg);}
.footer-col h4{
  font-family:var(--font-mono);font-size:0.78rem;text-transform:uppercase;
  letter-spacing:0.1em;color:rgba(250,249,252,0.45);margin-bottom:16px;font-weight:500;
}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px;font-size:0.92rem;}
.footer-col ul a{text-decoration:none;transition:color .15s;}
.footer-col ul a:hover{color:var(--bg);}
.footer-bottom{
  border-top:1px solid rgba(250,249,252,0.12);padding:24px 0;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-size:0.82rem;color:rgba(250,249,252,0.45);
}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:0.01ms !important;animation-iteration-count:1 !important;}
  html{scroll-behavior:auto;}
}

/* ---------- BRAND LOGO (ExpertOps / Powered By NTG Clarity) ---------- */
.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  transition: opacity 0.2s ease;
}

.brand:hover {
  opacity: 0.85;
}

.brand-text {
  display: flex;
  flex-direction: column;
  line-height: 1.3;
}

.logo-text {
  font-size: 1.35rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  display: inline-flex;
}

.powered-by {
  font-size: 0.7em;
  font-weight: normal;
  opacity: 0.8;
}

.logo-expert {
  color: var(--text, #1a1a1a);
}

.logo-ops {
  background: linear-gradient(135deg, #C82622, #C82622);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

/* Animate the mark icon on hover */
.mark {
  display: inline-flex;
  gap: 3px;
}

.mark span {
  width: 6px;
  height: 6px;
  border-radius: 2px;
  background: #C82622;
  transition: transform 0.3s ease, background 0.3s ease;
}

.brand:hover .mark span:nth-child(1) {
  transform: translateY(-3px);
}

.brand:hover .mark span:nth-child(2) {
  background: #C82622;
  transform: translateY(3px);
}

.brand:hover .mark span:nth-child(3) {
  transform: translateY(-3px);
}


/* ---------- OPS EXCELLENCE BADGE ---------- */
.ops-excellence-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 8px 16px;
  font-size: 0.82rem;
  font-family: var(--font-mono);
  color: var(--ink-soft);
  margin-bottom: 14px;
  box-shadow: var(--shadow-sm);
}

.ops-badge-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--teal);
  flex-shrink: 0;
  animation: pulse 2s infinite;
}