
:root{
  --navy:#232258;
  --navy-2:#1a1942;
  --cyan:#00a6d6;
  --cyan-2:#008cb5;
  --magenta:#b9299b;
  --magenta-2:#a01c83;
  --white:#ffffff;
  --bg:#f8fafc;
  --muted:#64748b;
  --text:#0f172a;
  --line:#e2e8f0;
  --line-soft:#eef2f7;
  --shadow:0 12px 32px rgba(15,23,42,.08);
  --shadow-soft:0 8px 20px rgba(15,23,42,.05);
  --radius:22px;
  --max:1200px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}

.container{
  width:min(var(--max), calc(100% - 2rem));
  margin:0 auto;
}
.narrow{max-width:840px}
main{padding-top:88px}

.site-header{
  position:fixed;
  top:0; left:0; right:0;
  z-index:1000;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(226,232,240,.8);
  transition:box-shadow .25s ease, background .25s ease;
}
.site-header.scrolled{box-shadow:0 8px 22px rgba(15,23,42,.07)}
.nav-wrap{
  min-height:88px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1.5rem;
}
.brand img{height:54px;width:auto}
.desktop-nav{
  display:flex;
  align-items:center;
  gap:1.5rem;
}
.nav-link{
  font-weight:600;
  font-size:.96rem;
  color:var(--navy);
  position:relative;
}
.nav-link:hover,.nav-link.active{color:var(--cyan)}
.nav-link.active::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:-.55rem;
  height:2px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--cyan),var(--magenta));
}
.nav-cta{margin-left:.5rem}
.menu-toggle{
  display:none;
  width:48px;height:48px;
  border:none;border-radius:14px;
  background:#f1f5f9;
  align-items:center;justify-content:center;
  flex-direction:column;
  gap:5px; cursor:pointer;
}
.menu-toggle span{
  display:block; width:20px; height:2px;
  background:var(--navy); border-radius:999px;
}
.mobile-menu{
  display:none;
  border-top:1px solid var(--line);
  background:#fff;
}
.mobile-menu.open{display:block}
.mobile-menu-inner{
  padding:1rem 0 1.25rem;
  display:flex;
  flex-direction:column;
}
.mobile-link{
  padding:1rem 0;
  border-bottom:1px solid var(--line-soft);
  font-weight:600;
  color:var(--navy);
}
.mobile-link.active,.mobile-link:hover{color:var(--cyan)}

.hero{
  position:relative;
  overflow:hidden;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}
.hero-home{
  min-height:86vh;
  display:flex;
  align-items:center;
}
.hero-page{
  min-height:520px;
  display:flex;
  align-items:center;
}
.hero-contact{
  background:var(--navy);
  color:#fff;
  padding:5.5rem 0 4.5rem;
}
.hero-overlay{
  position:absolute; inset:0;
}
.hero-overlay-home{
  background:
    radial-gradient(circle at 8% 38%, rgba(255,255,255,.08), transparent 30%),
    radial-gradient(circle at 2% 80%, rgba(255,255,255,.08), transparent 40%),
    linear-gradient(90deg, rgba(35,34,88,.94) 0%, rgba(35,34,88,.76) 52%, rgba(35,34,88,.14) 100%);
}
.hero-overlay-page{
  background:linear-gradient(90deg, rgba(35,34,88,.9) 0%, rgba(35,34,88,.66) 55%, rgba(35,34,88,.28) 100%);
}
.hero-overlay-page.center{
  background:linear-gradient(180deg, rgba(35,34,88,.68) 0%, rgba(35,34,88,.84) 100%);
}
.hero-content{
  position:relative;
  z-index:2;
  color:#fff;
  padding:4rem 0;
}
.hero-content h1{
  margin:0 0 1.25rem;
  font-size:clamp(2.6rem, 6vw, 5.25rem);
  line-height:1.03;
  letter-spacing:-.04em;
  font-weight:800;
  max-width:13ch;
}
.hero-content p{
  margin:0 0 2rem;
  font-size:1.15rem;
  max-width:42rem;
  color:rgba(255,255,255,.86);
}
.hero-content-page h1{font-size:clamp(2.4rem, 5vw, 4.5rem);max-width:15ch}
.hero-content.center{text-align:center}
.hero-content.center h1,.hero-content.center p{margin-left:auto;margin-right:auto}
.pill,.eyebrow{
  display:inline-block;
  margin-bottom:1rem;
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.78rem;
  font-weight:800;
  color:var(--cyan);
}
.pill{
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.1);
  color:#9ce8ff;
  letter-spacing:.12em;
  border-radius:999px;
  padding:.55rem .95rem;
}
.gradient-text{
  background:linear-gradient(90deg,var(--cyan),var(--magenta));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.button-row{
  display:flex; flex-wrap:wrap; gap:1rem;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  min-height:52px;
  padding:.9rem 1.45rem;
  border-radius:999px;
  border:2px solid transparent;
  font-weight:700;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
  cursor:pointer;
}
.btn:hover{transform:translateY(-2px); box-shadow:var(--shadow-soft)}
.btn-primary{background:var(--cyan); color:#fff}
.btn-primary:hover{background:var(--cyan-2)}
.btn-secondary{background:var(--magenta); color:#fff}
.btn-secondary:hover{background:var(--magenta-2)}
.btn-white{background:#fff; color:var(--navy)}
.btn-white:hover{background:#f8fafc}
.btn-outline{
  border-color:var(--navy);
  color:var(--navy);
  background:transparent;
}
.btn-outline:hover{background:var(--navy); color:#fff}
.btn-outline-light{
  border-color:rgba(255,255,255,.35);
  color:#fff;
}
.btn-outline-light:hover{background:#fff;color:var(--navy)}

.section{padding:6rem 0}
.section-white{background:#fff}
.section-tint{background:#f8fafc}
.section-muted{background:#f1f5f9}
.section-primary{
  background:linear-gradient(135deg,var(--cyan) 0%, var(--cyan-2) 100%);
  color:#fff;
}
.section-dark{
  position:relative;
  background:var(--navy);
  color:#fff;
}
.bordered-top{border-top:1px solid var(--line-soft)}
.section-heading{
  margin-bottom:2.5rem;
  max-width:52rem;
}
.section-heading-center{
  text-align:center;
  margin-left:auto;
  margin-right:auto;
}
.section-heading h2{
  margin:.2rem 0 0;
  font-size:clamp(2rem, 4vw, 3.3rem);
  line-height:1.1;
  color:var(--navy);
  letter-spacing:-.03em;
}
.section-dark .section-heading h2{color:#fff}
.heading-line{
  width:86px;
  height:4px;
  margin-top:1.1rem;
  border-radius:999px;
  background:linear-gradient(90deg,var(--cyan),var(--magenta));
}
.section-heading-center .heading-line{margin-left:auto;margin-right:auto}
.section-intro{
  margin:-1rem auto 0;
  max-width:42rem;
  text-align:center;
  color:var(--muted);
  font-size:1.05rem;
}

.split-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:4rem;
  align-items:center;
}
.lead-copy{
  color:#475569;
  font-size:1.08rem;
  margin:0 0 1.1rem;
}
.image-card{
  position:relative;
}
.image-card::before{
  content:"";
  position:absolute; inset:-18px;
  background:linear-gradient(135deg, rgba(0,166,214,.16), rgba(185,41,155,.12));
  filter:blur(28px);
  z-index:0;
  border-radius:28px;
}
.image-card img{
  position:relative;
  z-index:1;
  width:100%;
  border-radius:28px;
  box-shadow:var(--shadow);
  min-height:420px;
  object-fit:cover;
}

.stats-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:1rem;
  margin-top:1.8rem;
}
.stat-card{
  background:#fff;
  border-left:4px solid var(--cyan);
  border-radius:16px;
  padding:1rem 1.1rem;
  box-shadow:var(--shadow-soft);
}
.stat-card strong{
  display:block;
  color:var(--navy);
  font-size:2.3rem;
  line-height:1;
}
.stat-card span{
  display:block;
  margin-top:.35rem;
  font-size:.8rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:#64748b;
  font-weight:700;
}
.stat-accent-b{border-left-color:var(--magenta)}

.card-grid{
  display:grid;
  gap:1.5rem;
}
.card-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.card-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.info-card,.feature-card,.service-card,.statement-card,.detail-card,.contact-card,.partner-card{
  background:#fff;
  border:1px solid var(--line-soft);
  border-radius:28px;
  padding:2rem;
  box-shadow:var(--shadow-soft);
}
.info-card:hover,.feature-card:hover,.service-card:hover,.partner-card:hover,.detail-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow);
}
.info-card.large{padding:2.2rem}
.info-card h3,.feature-card h3,.service-card h3,.statement-card h3,.detail-card h3,.solution-copy h3,.contact-card h3,.partner-card-title{
  margin:.1rem 0 .65rem;
  font-size:1.4rem;
  line-height:1.2;
  color:var(--navy);
}
.info-card p,.feature-card p,.service-card p,.statement-card p,.detail-card p,.contact-card p,.partner-card-url,.solution-copy p{
  margin:0;
  color:#475569;
}
.icon-chip,.feature-icon,.service-badge,.statement-icon,.solution-icon{
  width:62px;height:62px;border-radius:18px;
  background:rgba(0,166,214,.1);
  margin-bottom:1.15rem;
}
.feature-icon-b,.service-badge-b,.statement-icon-b{background:rgba(185,41,155,.12)}
.feature-icon-c{background:rgba(35,34,88,.09)}
.service-card{
  text-align:center;
  display:flex;
  align-items:center;
  flex-direction:column;
  gap:.5rem;
}
.service-card .btn{margin-top:1rem}
.cta-card{
  border-radius:28px;
  padding:2rem;
  background:linear-gradient(135deg,var(--navy) 0%, var(--navy-2) 100%);
  color:#fff;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
}
.cta-card h3{font-size:1.9rem;line-height:1.15;margin:.1rem 0 1.3rem}
.feature-card,.statement-card{text-align:center}
.statement-card .quote{font-style:italic}
.mini-cta{
  margin-top:1rem !important;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:800;
  color:var(--cyan) !important;
  font-size:.82rem;
}
.detail-card{
  background:#f8fafc;
  border-color:transparent;
}
.detail-card-b{background:#fff7fc}
.prose-center{
  text-align:center;
  color:#475569;
}
.prose-center p{font-size:1.08rem; margin:0 auto 1rem}
.center-cards .feature-card{text-align:center}

.philosophy-band{
  position:relative;
  background-size:cover;
  background-position:center;
}
.band-overlay{
  position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(35,34,88,.92) 0%, rgba(35,34,88,.85) 42%, rgba(35,34,88,.5) 100%);
}
.philosophy-inner{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:1fr 1fr;
}
.philosophy-copy{
  padding:0 0;
  color:#fff;
}
.philosophy-copy h2{
  font-size:clamp(2rem, 4vw, 3.6rem);
  line-height:1.08;
  margin:0 0 1rem;
}
.philosophy-copy p{
  color:rgba(255,255,255,.82);
  font-size:1.08rem;
  margin:0 0 1.4rem;
}
.check-list{
  list-style:none;
  margin:0 0 2rem;
  padding:0;
  display:grid;
  gap:.9rem;
}
.check-list li{
  position:relative;
  padding-left:2rem;
  color:rgba(255,255,255,.88);
}
.check-list.dark-text li{color:#1e293b}
.check-list li::before{
  content:"";
  position:absolute;
  left:0; top:.4rem;
  width:1rem; height:1rem;
  border-radius:50%;
  background:linear-gradient(135deg,var(--cyan),var(--magenta));
  box-shadow:0 0 0 5px rgba(0,166,214,.13);
}
.partners-strip .mini-title{
  margin:0 0 1.5rem;
  text-align:center;
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.78rem;
  font-weight:800;
  color:#64748b;
}
.partner-pills{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:1rem;
}
.partner-pill{
  background:#fff;
  border:1px solid var(--line-soft);
  border-radius:16px;
  padding:1rem 1.25rem;
  box-shadow:var(--shadow-soft);
  font-weight:700;
  color:var(--navy);
}
.fine-print{
  text-align:center;
  color:#94a3b8;
  font-size:.78rem;
  margin-top:1rem;
}

.cta-center{text-align:center}
.cta-center h2{
  margin:0 0 1rem;
  font-size:clamp(2rem,4vw,3.2rem);
  line-height:1.08;
  letter-spacing:-.03em;
}
.cta-center p{
  max-width:44rem;
  margin:0 auto 2rem;
  font-size:1.08rem;
  color:inherit;
}
.cta-glow::before,.cta-glow::after{
  content:"";
  position:absolute;
  width:34vw; height:34vw;
  border-radius:50%;
  filter:blur(60px);
  opacity:.22;
}
.cta-glow::before{background:var(--cyan); left:-8vw; bottom:-8vw}
.cta-glow::after{background:var(--magenta); right:-8vw; top:-8vw}
.cta-glow > *{position:relative; z-index:2}

.stack-list{
  display:grid;
  gap:1rem;
}
.solution-row{
  display:grid;
  grid-template-columns:90px 1fr;
  gap:1.5rem;
  align-items:flex-start;
  background:#fff;
  padding:2rem;
  border-radius:28px;
  border:2px solid transparent;
  box-shadow:var(--shadow-soft);
}
.solution-row:hover{border-color:rgba(0,166,214,.28); box-shadow:var(--shadow)}
.solution-icon{
  background:linear-gradient(135deg, rgba(0,166,214,.12), rgba(35,34,88,.08));
  width:74px; height:74px;
  border-radius:24px;
}
.solution-copy h3{font-size:1.7rem}

.tag-cloud{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:.85rem;
}
.tag-pill{
  padding:.95rem 1.25rem;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.06);
  color:#fff;
  backdrop-filter:blur(8px);
  font-weight:600;
}
.growth-card{
  border-radius:30px;
  padding:2.4rem;
  background:linear-gradient(135deg,var(--navy) 0%, var(--navy-2) 100%);
  color:#fff;
  box-shadow:0 22px 50px rgba(35,34,88,.25);
  position:relative;
  overflow:hidden;
}
.growth-card::before{
  content:"";
  position:absolute;
  right:-4rem; top:-4rem;
  width:16rem; height:16rem;
  border-radius:50%;
  background:rgba(0,166,214,.2);
  filter:blur(22px);
}
.growth-card h3{
  margin:0 0 1rem;
  font-size:2rem;
}
.growth-card p{
  margin:0 0 1.4rem;
  color:rgba(255,255,255,.84);
}
.standard-box{
  padding:1.3rem;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
  border-radius:20px;
  backdrop-filter:blur(10px);
}
.standard-box strong{
  display:block;
  color:#fff;
  font-size:1.3rem;
}
.partner-grid .partner-card{
  min-height:170px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.partner-card-title{
  display:block;
  font-size:1.35rem;
}
.partner-card-url{
  display:block;
  margin-top:.35rem;
  font-weight:600;
  color:var(--cyan) !important;
}
.partner-card-subtext{
  display:inline-flex;
  align-self:flex-start;
  margin-top:.8rem;
  background:#fff3fb;
  color:var(--magenta);
  border-radius:999px;
  padding:.35rem .7rem;
  font-size:.76rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.subtle-grid::before{
  content:"";
  position:absolute; inset:0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size:24px 24px;
  pointer-events:none;
}

.contact-shell{padding-top:0; margin-top:-2rem}
.contact-grid{
  display:grid;
  grid-template-columns:.95fr 1.35fr;
  gap:1.5rem;
}
.contact-stack{
  display:flex;
  flex-direction:column;
  gap:1rem;
}
.contact-card a{color:var(--cyan)}
.contact-card small{display:block;margin-top:.45rem;color:#94a3b8}
.form-wrap{
  background:#fff;
  border:1px solid var(--line-soft);
  border-radius:30px;
  padding:2rem;
  box-shadow:var(--shadow-soft);
}
.form-wrap .section-heading{margin-bottom:1.25rem}
.form-note{
  margin:0 0 1.25rem;
  padding:1rem 1.1rem;
  border-radius:18px;
  background:#eff6ff;
  color:#334155;
  font-size:.95rem;
  border:1px solid #dbeafe;
}
.form-success{
  text-align:center;
  padding:1rem 0 0;
}
.form-success h3{
  margin:0 0 .7rem;
  color:#166534;
  font-size:1.7rem;
}
.form-success p{
  margin:0 0 1.3rem;
  color:#166534;
}
.contact-form{display:grid; gap:1rem}
.form-row{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:1rem;
}
.field{display:grid; gap:.45rem}
.field label{
  color:var(--navy);
  font-weight:700;
  font-size:.95rem;
}
.field input,.field select,.field textarea{
  width:100%;
  border:1px solid #cbd5e1;
  background:#f8fafc;
  border-radius:18px;
  padding:.95rem 1rem;
  color:#0f172a;
  outline:none;
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--cyan);
  box-shadow:0 0 0 4px rgba(0,166,214,.14);
  background:#fff;
}
.field textarea{resize:vertical; min-height:180px}

.site-footer{
  background:var(--navy);
  color:rgba(255,255,255,.82);
}
.footer-grid{
  padding:4rem 0 2rem;
  display:grid;
  grid-template-columns:1.3fr .8fr .9fr .95fr;
  gap:2rem;
}
.footer-logo{height:54px; width:auto; filter:brightness(0) invert(1); opacity:.92}
.footer-copy{
  max-width:26rem;
  font-size:.96rem;
}
.site-footer h3{
  margin:0 0 1rem;
  color:#fff;
  text-transform:uppercase;
  font-size:.82rem;
  letter-spacing:.14em;
}
.footer-list{
  list-style:none;
  padding:0; margin:0;
  display:grid; gap:.75rem;
}
.footer-list a:hover{color:#9ce8ff}
.footer-bottom{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:1.1rem 0 1.5rem;
  border-top:1px solid rgba(255,255,255,.1);
  font-size:.85rem;
}
.footer-policies{
  display:flex; gap:1rem;
}
.footer-policies a:hover{color:#fff}

@media (max-width: 1080px){
  .desktop-nav{display:none}
  .menu-toggle{display:flex}
  .split-grid,.card-grid-3,.footer-grid,.contact-grid{grid-template-columns:1fr}
  .philosophy-inner{grid-template-columns:1fr}
  .card-grid-2{grid-template-columns:1fr}
}

@media (max-width: 720px){
  main{padding-top:84px}
  .container{width:min(var(--max), calc(100% - 1.25rem))}
  .nav-wrap{min-height:84px}
  .brand img{height:48px}
  .section{padding:4.5rem 0}
  .hero-home{min-height:76vh}
  .hero-page{min-height:440px}
  .hero-content{padding:3rem 0}
  .button-row{flex-direction:column; align-items:flex-start}
  .hero-content.center .button-row,.cta-center .button-row{align-items:center}
  .stats-grid,.form-row{grid-template-columns:1fr}
  .solution-row{grid-template-columns:1fr}
  .footer-bottom{
    flex-direction:column;
    align-items:flex-start;
  }
}


/* Contact form + utility additions */
.honeypot-field{
  position:absolute !important;
  left:-9999px !important;
  width:1px;height:1px;
  overflow:hidden;
}
.form-note.is-success{
  background:#ecfdf5;
  border-color:#bbf7d0;
  color:#166534;
}
.form-note.is-error{
  background:#fef2f2;
  border-color:#fecaca;
  color:#991b1b;
}
.contact-card{
  background:#fff;
  border:1px solid var(--line-soft);
  border-radius:28px;
  padding:2rem;
  box-shadow:var(--shadow-soft);
}
.contact-card h3{
  margin:.1rem 0 .65rem;
  font-size:1.35rem;
  line-height:1.2;
  color:var(--navy);
}
.contact-card p{margin:0;color:#475569}
.contact-card a:hover{color:var(--cyan)}
button[disabled]{
  opacity:.7;
  cursor:not-allowed;
  transform:none !important;
}
.desktop-nav .btn.active{
  background:var(--magenta-2);
}
