
:root{--bg:#fff;--text:#0a2540;--muted:#5a6b7a;--brand:#0a2540;--brand-2:#0ea5b5;--border:#e5e8eb;--card:#f8fafc;--focus:#0ea5b5}
*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Arial,sans-serif;color:var(--text);background:var(--bg)}
a{color:var(--brand-2);text-decoration:none}a:hover{text-decoration:underline}.container{max-width:1100px;margin:0 auto;padding:0 20px}
header{border-bottom:1px solid var(--border);background:rgba(255,255,255,.9);backdrop-filter:saturate(1.2) blur(6px);position:sticky;top:0;z-index:10}
.nav{display:flex;align-items:center;justify-content:space-between;padding:12px 0;gap:16px}.nav a.logo{display:inline-flex;align-items:center;gap:10px}
.nav ul{list-style:none;display:flex;gap:16px;padding:0;margin:0;align-items:center}.nav li{position:relative}.nav .menu{display:flex;gap:12px}
.nav .menu a{padding:12px 10px;border-radius:6px}.nav .menu a:hover,.nav .menu a:focus{background:var(--card);outline:0}
.nav .dropdown{position:relative}
.nav .dropdown-menu{display:none;position:absolute;left:0;top:100%;margin-top:6px;background:#fff;border:1px solid var(--border);border-radius:10px;min-width:260px;padding:8px;box-shadow:0 10px 30px rgba(0,0,0,.06);transform-origin:top left;transform:scale(.98);opacity:0;transition:opacity .15s ease,transform .15s ease;z-index:1000}
.nav .dropdown:hover .dropdown-menu,.nav .dropdown:focus-within .dropdown-menu,.nav .dropdown .dropdown-menu:hover{display:block;opacity:1;transform:scale(1)}
.nav a[aria-current='page']{position:relative}
.nav a[aria-current='page']::after{content:"";position:absolute;left:6px;right:6px;bottom:-6px;height:2px;background:linear-gradient(90deg,#0ea5b5,#0a2540);border-radius:2px}
.mobile-toggle{display:none;border:1px solid var(--border);background:#fff;padding:8px 10px;border-radius:8px}
.hero{display:grid;grid-template-columns:1.2fr 1fr;gap:28px;align-items:center;padding:56px 0;background:radial-gradient(1200px 500px at 10% -10%, rgba(14,165,181,.18), transparent 60%),radial-gradient(900px 400px at 90% 0%, rgba(10,37,64,.10), transparent 60%);border-bottom:1px solid var(--border)}
.hero h1{font-size:clamp(28px,4vw,44px);margin:0 0 10px}.hero p{color:var(--muted);font-size:18px}
.cta{display:inline-block;padding:12px 16px;border-radius:12px;background:linear-gradient(135deg,#0ea5b5,#0a2540);color:#fff;border:0;box-shadow:0 8px 24px rgba(14,165,181,.25);transition:transform .18s ease,box-shadow .18s ease,filter .18s ease}
.cta:hover{transform:translateY(-2px);filter:brightness(1.03);box-shadow:0 14px 38px rgba(14,165,181,.28)}
.cta.secondary{background:transparent;color:var(--brand);border:1px solid rgba(10,37,64,.25);box-shadow:0 2px 10px rgba(0,0,0,.04)}
.section{padding:56px 0}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.card{background:linear-gradient(180deg,rgba(255,255,255,.9),rgba(248,250,252,.9));border:1px solid rgba(10,37,64,.06);border-radius:12px;padding:20px;box-shadow:0 10px 30px rgba(10,37,64,.06);transition:transform .25s ease, box-shadow .25s ease}
.card:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(0,0,0,.08)}
footer{border-top:1px solid var(--border);background:linear-gradient(180deg,#f8fafc,#ffffff);padding:36px 0;margin-top:40px}.footer-cols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:20px}
.kicker{text-transform:uppercase;letter-spacing:.12em;font-size:12px;color:var(--muted)}.breadcrumbs{font-size:14px;color:var(--muted);margin-bottom:12px}.lead{font-size:18px;color:var(--muted)}
ul.check{padding-left:18px}ul.check li{margin:6px 0}.wide{width:100%;border-radius:12px;border:1px solid var(--border)}
#whatsapp-float{position:fixed;right:18px;bottom:18px;z-index:50}
#whatsapp-float a{display:inline-flex;align-items:center;gap:8px;background:#25D366;color:#fff;padding:12px 14px;border-radius:999px;box-shadow:0 6px 16px rgba(0,0,0,.12);font-weight:600}
#whatsapp-float a:hover{filter:brightness(1.05);text-decoration:none}
/* Animations */
@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
:root{scroll-behavior:smooth}.fade-up{opacity:0;transform:translateY(14px);animation:fadeUp .6s ease-out forwards}.fade-in{opacity:0;animation:fadeIn .7s ease-out forwards}.stagger>*{opacity:0;transform:translateY(10px);animation:fadeUp .5s ease-out forwards}.stagger>*:nth-child(1){animation-delay:.05s}.stagger>*:nth-child(2){animation-delay:.12s}.stagger>*:nth-child(3){animation-delay:.18s}.stagger>*:nth-child(4){animation-delay:.24s}.stagger>*:nth-child(5){animation-delay:.30s}.stagger>*:nth-child(6){animation-delay:.36s}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{to{opacity:1}}
/* Emphasis sections */
.section.emphasis{background:linear-gradient(180deg,#f7fbfc,#ffffff);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
/* Mobile tweaks */
@media (max-width:900px){
  .hero{grid-template-columns:1fr;padding:28px 0}
  .hero h1{font-size:clamp(22px,6vw,30px);line-height:1.15}
  .hero p{font-size:16px}
  .grid-3{grid-template-columns:1fr}
  .footer-cols{grid-template-columns:1fr}
  .mobile-toggle{display:inline-flex;align-items:center;gap:8px}
  .nav{position:relative}
  .nav .menu{display:none;position:absolute;left:0;right:0;top:100%;flex-direction:column;gap:2px;background:#fff;border-bottom:1px solid var(--border);box-shadow:0 14px 24px rgba(0,0,0,.08);padding:8px;z-index:1000}
  .nav .menu a{padding:14px;border-radius:8px}
  .nav .dropdown .dropdown-menu{position:static;display:none!important}
  #whatsapp-float{bottom:20px;right:16px}
}
:focus{outline:3px solid var(--focus);outline-offset:2px}.skip-link{position:absolute;top:-40px;left:0;background:#000;color:#fff;padding:8px 12px;z-index:100}.skip-link:focus{top:0}


/* --- Desktop dropdown polish --- */
.nav { gap: 28px; }
.nav .dropdown { padding: 0 6px; }
.nav .dropdown-menu { left: 50%; transform: translateX(-50%) scale(.98); min-width: 280px; margin-top: 10px; }
.nav .dropdown-menu a { white-space: nowrap; }

/* --- Form controls --- */
.input, textarea, select { 
  width: 100%; padding: 12px; border: 1px solid var(--border); border-radius: 10px; 
  background: #fff; color: var(--text); font: inherit;
}
label { display: block; margin: 10px 0 6px; font-weight: 600; }
form .row { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
form .actions { display: flex; gap: 10px; margin-top: 12px; }


/* --- Desktop dropdown fix (anchor-left, no weird centering) --- */
@media (min-width: 901px) {
  .nav .menu { gap: 18px; }
  .nav .dropdown { padding: 0; }
  .nav .dropdown-menu {
    left: 0;                 /* anchor to tab */
    transform: scale(.98);   /* remove translateX center */
    min-width: 280px;
    margin-top: 10px;
  }
  .nav .dropdown-menu a { white-space: normal; display:block; }
}


/* --- Mobile tap-target boost --- */
@media (max-width: 900px) {
  .nav .menu li { margin: 4px 0; }
  .nav .menu a {
    display: block;
    padding: 16px 18px;      /* bigger tap area */
    font-size: 18px;
    line-height: 1.25;
    border-radius: 10px;
  }
  .nav .menu a:active { transform: scale(0.98); }
  .mobile-toggle { padding: 10px 12px; font-size: 16px; }
}


/* --- Full-bleed hero cover --- */
.hero.hero-cover{
  position: relative;
  min-height: 68vh;
  padding: 110px 0 120px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: grid;
  place-items: center;
  color: #fff;
  border-bottom: none;
}
.hero.hero-cover::before{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(10,37,64,.55), rgba(10,37,64,.35));
}
.hero.hero-cover .content{ position: relative; z-index: 1; text-align: center; }
.hero.hero-cover h1{ font-size: clamp(32px, 6vw, 56px); margin: 0 0 12px; color:#fff; }
.hero.hero-cover p{ color: rgba(255,255,255,.92); font-size: 18px; }
.hero.hero-cover .cta.secondary{ color:#fff; border-color: rgba(255,255,255,.7); }
@media (max-width:900px){
  .hero.hero-cover{ padding: 80px 0 90px; min-height: 60vh; }
  .hero.hero-cover p{ font-size: 16px; }
}


/* === Kaplan-like About layout === */
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.kp-breadcrumb{margin:16px 0}
.kp-bc{list-style:none;display:flex;gap:8px;padding:0;margin:0;color:#6b7280;font-size:14px}
.kp-bc li a{color:#6b7280;text-decoration:none}
.kp-bc li+li:before{content:"/";padding:0 6px;color:#d1d5db}
.kp-title{font-size:40px;line-height:1.1;margin:8px 0 10px}
.kp-sub{font-size:18px;color:#4b5563;max-width:920px}
.kp-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:22px 0}
.kp-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;box-shadow:0 6px 20px rgba(20,89,120,.06);padding:18px 20px}
.kp-card h3{margin:0 0 6px 0;font-size:18px}
.kp-about{margin:26px 0 10px}
.kp-row{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin:18px 0}
.kp-row-alt{align-items:start}
.kp-col h2{margin:0 0 8px 0}
.kp-col p{color:#4b5563}
.kp-col ul{margin:8px 0 0 18px}
.kp-col li{margin:6px 0}
.kp-stats{background:linear-gradient(180deg,#f7fbfd,transparent);border-top:1px solid #eef2f7;margin-top:28px;padding:22px 0}
.kp-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.kp-stat{text-align:center}
.kps-head{font-weight:700;font-size:20px}
.kps-sub{color:#6b7280;font-size:14px}
@media (max-width:920px){
  .kp-grid-3{grid-template-columns:1fr}
  .kp-row{grid-template-columns:1fr}
  .kp-title{font-size:32px}
  .kp-sub{font-size:16px}
}


/* === Icons and denser layout === */
.kp-ico{width:22px;height:22px;fill:#14597a;opacity:.9;margin-right:8px;flex:0 0 auto}
.kp-card,.kp-step{display:flex;gap:10px;align-items:flex-start}
.kp-card h3,.kp-step h3{margin:0 0 4px 0}
.kp-hero{padding-top:10px;padding-bottom:8px}
.kp-features{margin-top:8px;margin-bottom:6px}
.kp-about{padding-top:10px;padding-bottom:10px}
.kp-sec-title{font-size:26px;margin:6px 0 10px}
.kp-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.kp-step{background:#fff;border:1px solid #e5e7eb;border-radius:14px;box-shadow:0 6px 20px rgba(20,89,120,.06);padding:16px}
.kp-step p{margin:0;color:#4b5563}
.kp-stats .kp-ico{margin:0 auto 6px auto;display:block}
.kp-stat{padding:12px 6px}
@media (max-width:1024px){ .kp-grid-4{grid-template-columns:repeat(2,1fr)} }
@media (max-width:680px){ .kp-grid-4{grid-template-columns:1fr} }


/* === Kaplan About 1:1 layout === */
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.kp-breadcrumb{margin:12px 0}
.kp-bc{list-style:none;display:flex;gap:8px;padding:0;margin:0;color:#6b7280;font-size:14px}
.kp-bc li a{color:#6b7280;text-decoration:none}
.kp-bc li+li:before{content:"/";padding:0 6px;color:#d1d5db}
.kp-title{font-size:40px;line-height:1.1;margin:6px 0 12px}
.kp-sub{font-size:18px;color:#4b5563;max-width:980px;margin-bottom:18px}
.kp-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:18px 0 26px}
.kp-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;box-shadow:0 6px 20px rgba(20,89,120,.06);padding:18px 20px}
.kp-feature h3{font-size:16px;letter-spacing:.02em;margin:0 0 4px}
.kp-feature p{margin:0;color:#4b5563}
.kp-block{margin:24px auto}
.kp-h2{font-size:24px;margin:0 0 10px}
.kp-talent{background:linear-gradient(180deg,#f7fbfd,transparent);border-top:1px solid #eef2f7;margin-top:28px;padding:26px 0}
.kp-btn{display:inline-block;padding:10px 14px;border-radius:10px;border:1px solid #14597a;color:#14597a;text-decoration:none}
.kp-btn:hover{background:#14597a;color:#fff}
@media (max-width:960px){
  .kp-grid-3{grid-template-columns:1fr}
  .kp-title{font-size:32px}
}


/* === Asset-ready visuals === */
.kp-hero-strip{height:160px;background: #f8fafc url('assets/kaplan/hero-placeholder.svg') center/cover no-repeat;border-bottom:1px solid #eef2f7;margin-bottom:20px}
.kp-card{position:relative}
.kp-ico-img{display:block;margin:2px 8px 6px 2px}



/* allow user to drop custom hero image */
@media (max-width:960px){ .kp-hero-strip{height:120px} }

/* To use a photo hero, add this after upload:
.kp-hero-strip{background-image:url('assets/kaplan/hero.jpg')}
*/


/* About rows with images */
.kp-about-row{display:flex;align-items:center;gap:40px;margin:60px auto}
.kp-about-col{flex:1}
.kp-about-img{width:100%;border-radius:14px;box-shadow:0 6px 20px rgba(0,0,0,.1);object-fit:cover}
.kp-about-row-alt{flex-direction:row-reverse}
@media(max-width:900px){
  .kp-about-row{flex-direction:column;text-align:center}
  .kp-about-row-alt{flex-direction:column}
}


/* Hover-only blue for kp-card */
.kp-card {
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  box-shadow: 0 6px 20px rgba(20,89,120,.06);
  padding: 18px 20px;
  transition: all .25s ease;
}

.kp-card:hover {
  background: linear-gradient(135deg,#4338CA 0%,#0ea5e9 100%);
  border-color: transparent;
  color: #fff !important;
  transform: translateY(-4px);
}

.kp-card:hover h3,
.kp-card:hover p,
.kp-card:hover strong {
  color: #fff !important;
}

.kp-card:hover img.kp-ico-img {
  filter: brightness(0) invert(1);
}

.kp-card:hover svg path {
  stroke: #fff !important;
  fill: #fff !important;
}


/* Full-width dark talent section like Kaplan */
.kp-talent{
  background:#0f172a;
  padding:100px 0;
  text-align:center;
  color:#f8fafc;
}
.kp-talent .container{
  max-width:800px;
}
.kp-talent h2{
  font-size:28px;
  font-weight:700;
  margin-bottom:14px;
  color:#fff;
}
.kp-talent p{
  color:#cbd5e1;
  font-size:16px;
  margin-bottom:24px;
}
.kp-talent .kp-btn{
  background:linear-gradient(90deg,#fb4444,#ff7d52);
  padding:12px 24px;
  border-radius:8px;
  color:#fff;
  font-weight:600;
  text-decoration:none;
  display:inline-block;
}
.kp-talent .kp-btn:hover{
  opacity:0.9;
}


/* === Premium polish pack === */
/* Hero overlay gradient for more depth */
.kp-hero-strip{position:relative;isolation:isolate}
.kp-hero-strip:after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(15,23,42,.25),rgba(15,23,42,0));
  pointer-events:none;
}

/* Footer dark style */
footer{background:#0b1220;color:#cbd5e1;}
footer .container{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:28px;padding:34px 20px}
footer a{color:#93c5fd;text-decoration:none}
footer a:hover{text-decoration:underline}
footer h4{color:#fff;margin:0 0 10px 0}
footer .logo, footer img{filter:none}
@media(max-width:900px){
  footer .container{grid-template-columns:1fr;gap:14px}
}

/* Reveal-on-scroll */
.reveal{opacity:0;transform:translateY(22px);transition:all .6s cubic-bezier(.2,.8,.2,1)}
.reveal.reveal-in{opacity:1;transform:none}

/* Mobile typography */
@media(max-width:900px){
  .kp-title{font-size:30px}
  .kp-sub{font-size:16px}
  .kp-about-row{margin:34px auto;gap:18px}
  .kp-card{padding:16px}
}


/* flush between talent and footer */
.kp-talent{margin-bottom:0!important;}
footer{background:#060b16!important;} /* slightly darker */


/* hard kill any divider between talent and footer */
.kp-talent{margin-bottom:0!important;border-bottom:0!important;padding-bottom:90px}
footer{margin-top:0!important;border-top:0!important;background:#060b16!important}
.kp-talent + *{margin-top:0!important;border-top:0!important}
.kp-talent + hr, .kp-talent + .divider, .kp-talent + .section-divider{display:none!important;height:0!important;border:0!important}
/* generic hr/divider reset sitewide */
hr, .divider, .section-divider{border:0;height:0;background:none}


/* === Services gallery === */
.svc-hero{text-align:center;margin:24px auto 10px}
.svc-hero h1{font-size:28px;margin:0 0 6px}
.svc-hero p{color:#6b7280;margin:0 0 6px}
.svc-grid .svc-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;list-style:none;padding:0;margin:20px 0 32px}
.svc-card figure{margin:0}
.svc-card img{width:100%;height:180px;object-fit:cover;border-radius:14px;box-shadow:0 8px 24px rgba(0,0,0,.08);transition:transform .25s ease, box-shadow .25s ease}
.svc-card figcaption{font-weight:600;margin:8px 4px 0;color:#0f172a}
.svc-card a{text-decoration:none;color:inherit;display:block;padding:4px;border-radius:16px;transition:transform .2s ease}
.svc-card a:hover img{transform:scale(1.02);box-shadow:0 14px 30px rgba(20,89,120,.18)}
@media(max-width:1100px){ .svc-grid .svc-cards{grid-template-columns:repeat(3,1fr)} }
@media(max-width:820px){ .svc-grid .svc-cards{grid-template-columns:repeat(2,1fr)} }
@media(max-width:520px){ .svc-grid .svc-cards{grid-template-columns:1fr} }


/* === Our customers grid === */
.cust{text-align:center;margin:30px auto}
.cust h2{font-size:24px;margin:0 0 6px}
.cust p{color:#6b7280;margin:0 0 20px}
.cust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;list-style:none;padding:0;margin:0 auto;max-width:1200px}
.cust-card figure{margin:0}
.cust-card img{width:100%;height:140px;object-fit:cover;border-radius:14px;box-shadow:0 8px 24px rgba(0,0,0,.06);filter:none}
.cust-card figcaption{font-weight:600;margin:10px 4px 0;color:#1f2937}
@media(max-width:1100px){ .cust-grid{grid-template-columns:repeat(3,1fr)} }
@media(max-width:820px){ .cust-grid{grid-template-columns:repeat(2,1fr)} }
@media(max-width:520px){ .cust-grid{grid-template-columns:1fr} }


/* === Home services image grid === */
.home-svc h2{font-size:22px;margin:10px 0 8px}
.home-svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;list-style:none;padding:0;margin:8px 0 20px}
.home-svc-card figure{margin:0}
.home-svc-card img{width:100%;height:140px;object-fit:cover;border-radius:14px;box-shadow:0 10px 24px rgba(0,0,0,.08);transition:transform .25s ease, box-shadow .25s ease}
.home-svc-card figcaption{font-weight:700;margin:8px 4px 0;color:#0f172a}
.home-svc-card a{text-decoration:none;color:inherit;display:block;padding:4px;border-radius:16px}
.home-svc-card a:hover img{transform:scale(1.02);box-shadow:0 16px 36px rgba(20,89,120,.20)}
@media(max-width:1100px){ .home-svc-grid{grid-template-columns:repeat(2,1fr)} }
@media(max-width:680px){ .home-svc-grid{grid-template-columns:1fr} }

.home-svc-card img{transition:transform .25s ease;}
.home-svc-card:hover img{transform:scale(1.10);} 
.home-svc-card{overflow:hidden; border-radius:14px;}
.home-svc-card figure{overflow:hidden;}

/* === Design System: Kaplan-like Theme === */
:root{
  --bg: #f8fafc;
  --surface: #ffffff;
  --text: #0f172a;
  --muted: #6b7280;
  --primary: #14597a;
  --primary-2: #0ea5e9;
  --primary-3: #4338ca;
  --accent: #10b981;
  --radius: 14px;
  --shadow: 0 10px 30px rgba(20,89,122,.10);
  --shadow-2: 0 18px 40px rgba(20,89,122,.18);
}
html,body{background:var(--bg);color:var(--text);}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
a{color:var(--primary);}
.btn, .kp-btn{
  display:inline-block; padding:12px 18px; border-radius:10px;
  background: linear-gradient(135deg,var(--primary-3),var(--primary-2));
  color:#fff; text-decoration:none; font-weight:600; border:0;
  box-shadow: var(--shadow);
}
.btn:hover,.kp-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-2);opacity:.96}
.card, .kp-card, .kp-step{
  background:var(--surface); border:1px solid #e5e7eb; border-radius:var(--radius);
  box-shadow: var(--shadow);
}
/* Hero */
.hero, .kp-hero-strip{background:#062d3a; background-size:cover; background-position:center; border-bottom:1px solid #0b3b4c}
.hero .container{padding:80px 20px}
.hero h1{color:#fff; font-size:44px; margin:0 0 10px}
.hero p{color:#dbeafe; max-width:900px}
/* Home services grid tokens if not present */
.home-svc{margin:16px auto 22px}
.home-svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;list-style:none;padding:0;margin:8px 0 20px}
.home-svc-card{overflow:hidden;border-radius:var(--radius);background:var(--surface)}
.home-svc-card figure{margin:0}
.home-svc-card img{width:100%;height:160px;object-fit:cover;transition:transform .25s ease;display:block}
.home-svc-card:hover img{transform:scale(1.10)}
.home-svc-card figcaption{font-weight:700;margin:10px 8px 12px}
/* CTA band */
.cta-band{background:linear-gradient(90deg,rgba(14,165,233,.10),rgba(67,56,202,.10));border:1px solid #e5e7eb;border-radius:var(--radius);padding:20px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.cta-band p{margin:0;color:var(--muted)}
.cta-band .btn{margin-left:auto}
/* Footer */
footer{background:#060b16;color:#cbd5e1;margin-top:0;border-top:0}
footer .container{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:28px;padding:34px 20px}
footer h4{color:#fff;margin:0 0 10px}
footer a{color:#93c5fd;text-decoration:none}
footer a:hover{text-decoration:underline}
@media(max-width:1100px){ .home-svc-grid{grid-template-columns:repeat(2,1fr)} footer .container{grid-template-columns:1fr 1fr} }
@media(max-width:720px){ .home-svc-grid{grid-template-columns:1fr} .hero .container{padding:50px 16px} footer .container{grid-template-columns:1fr} }


/* === VM Kaplan-like page === */
.vmk-hero{background:#2b3a43 url('assets/kaplan/hero-placeholder.svg') center/cover no-repeat; padding:44px 0; color:#fff; border-bottom:1px solid rgba(0,0,0,.2)}
.vmk-hero h1{margin:0 0 6px; font-size:36px}
.vmk-breadcrumb{color:#c7d3dc; font-size:14px}
.vmk-center{display:flex; justify-content:center; padding:28px 0 6px}
.vmk-center img{max-width:340px; width:100%}
.vmk-block{max-width:920px; margin:18px auto 10px; text-align:center}
.vmk-block h2{font-size:26px; margin:10px 0 10px}
.vmk-block p{color:#475569; line-height:1.6}
.vmk-values{display:grid; grid-template-columns:repeat(3,1fr); gap:8px; list-style:disc; text-align:left; max-width:680px; margin:12px auto 30px; padding-left:24px}
@media(max-width:800px){ .vmk-values{grid-template-columns:repeat(2,1fr)} .vmk-hero h1{font-size:30px} }
@media(max-width:560px){ .vmk-values{grid-template-columns:1fr} }


header{position:relative!important;z-index:9999!important;background:rgba(5,25,45,.95)!important;}
.hero{position:relative!important;z-index:1!important;}


/* final fixes */
header{position:relative!important;z-index:9999!important;background:rgba(5,25,45,.96)!important;}
.hero{position:relative!important;z-index:1!important;}
.hero .container.content h1{color:#fff!important;}
.hero .container.content p{color:rgba(255,255,255,.9)!important;}


/* sticky navbar override */
header{position:sticky!important;top:0!important;z-index:9999!important;background:rgba(5,25,45,.96)!important;width:100%!important;}
main .breadcrumbs{color:#111!important;}


/* Navbar enlargement and logo */
header{min-height:84px!important;padding:12px 0!important;}
header .logo-img{height:56px!important;width:auto!important;display:inline-block!important;vertical-align:middle!important;}
header nav a, header .nav a{font-size:18px!important;padding:0 14px!important;line-height:1!important;}


/* Renesis: sticky enlarged navbar + logo size */
header{position:sticky!important;top:0!important;z-index:9999!important;background:#0b3344!important;padding:14px 0!important;min-height:84px!important;width:100%!important;}
header .renesis-logo{height:65px!important;width:auto!important;object-fit:contain!important;display:inline-block!important;vertical-align:middle!important;}
/* nav links a bit bigger */
header nav a, header .nav a{font-size:18px!important;padding:0 14px!important;line-height:1!important;}
/* mobile */
@media(max-width:768px){
  header .renesis-logo{height:48px!important;}
  header nav a, header .nav a{font-size:16px!important;padding:0 10px!important;}
}

/* Renesis fixes: ensure logo displays larger and not squashed */
a.logo img, .navbar-brand img, img.logo-img, img.renesis-logo {
  height: 56px !important;
  width: auto !important;
  object-fit: contain !important;
  display: inline-block !important;
  vertical-align: middle !important;
}

/* Auto-added by fix script: standardize navbar logo display */
.navbar-logo { height: 64px; max-height: 64px; width: auto; display: inline-block; vertical-align: middle; }

/* Hide extra top strip under navbar */
.kp-hero-strip{display:none!important;height:0!important;padding:0!important;margin:0!important;border:0!important}

/* Remove gap between last section and footer on Who We Are */
body.who-we-are main section:last-of-type{padding-bottom:0!important;margin-bottom:0!important}
body.who-we-are footer{margin-top:0!important;border-top:0!important}

/* Who We Are page: remove gaps before footer */
body.who-we-are .kp-talent{margin-bottom:0!important;padding-bottom:0!important;border-bottom:0!important}
body.who-we-are main section:last-of-type{padding-bottom:0!important;margin-bottom:0!important;border-bottom:0!important}
body.who-we-are footer{margin-top:0!important;border-top:0!important}

/* About Us hero */
.aboutus-hero{
  position: relative;
  background-image:url('assets/hero/about-us-hero.png');
  background-size: cover;
  background-position: center;
  padding: 90px 0 120px;
  color:#fff;
}
.aboutus-hero h1{ font-size:56px; line-height:1.1; margin:0 0 10px }
.aboutus-hero .page-bc{ margin:6px 0 0; opacity:.9 }
/* Dark overlay */
.aboutus-hero::before{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(10,37,64,.85), rgba(10,37,64,.75));
  pointer-events:none;
}
.aboutus-hero > .container{ position:relative; z-index:1 }
/* Remove any top strip spacing leftovers */
body.who-we-are .kp-hero-strip{display:none!important;height:0!important;margin:0!important;padding:0!important;border:0!important}


/* === OVERRIDES: requested by client === */
/* Bigger base typography */
body { font-size: 17px !important; line-height: 1.7 !important; }
p, li { font-size: 1.06rem !important; }
h1 { font-size: clamp(30px, 6.2vw, 58px) !important; }
h2 { font-size: clamp(22px, 4.8vw, 36px) !important; }
h3 { font-size: clamp(18px, 3.6vw, 26px) !important; }

/* Hero on homepage full photo */
.hero.hero-cover.fade-up { background-size: cover; background-position: center; }

/* Larger Inquiry CTA */
.cta.cta-lg { padding: 14px 22px !important; font-size: 1.04rem !important; border-radius: 10px !important; }

/* Categories spacing and larger labels */
.svc-grid .svc-cards { gap: 28px !important; }
.home-svc-grid { gap: 22px !important; }
.svc-card figcaption { font-size: 1.12rem !important; }


/* === Dropdown spacing + caret arrow === */
.nav .dropdown > a {
  position: relative;
  padding-right: 18px;
}
.nav .dropdown > a::after {
  content: "▾";
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  font-size: 12px;
  color: var(--brand-2);
}
.nav .dropdown:hover > a::after,
.nav .dropdown:focus-within > a::after {
  transform: translateY(-50%) rotate(180deg);
}
/* Menu item spacing and color */
.nav .dropdown-menu a {
  display:block;
  padding: 10px 14px;
  margin: 6px 0;
  border-radius: 10px;
  color: var(--text);
  font-weight: 600;
}
.nav .dropdown-menu a:hover { background: rgba(14,165,181,0.12); color: var(--text); }


/* === Nav underline fix === */
.nav .menu a,
.nav .menu a:hover,
.nav .menu a:focus,
.nav .menu a:active {
  text-decoration: none !important;
  text-decoration-color: transparent !important;
  outline: 0;
}


/* === Nav hover underline at bottom + bigger hover target === */
.nav .menu > li > a {
  display: inline-block;
  padding: 14px 14px;              /* larger base target */
  border-radius: 12px;
  text-decoration: none;
}
.nav .menu > li > a:hover,
.nav .menu > li > a:focus {
  background: rgba(14,165,181,0.12);
  transform: scale(1.06);
  text-decoration: underline !important;
  text-underline-offset: 6px !important;
  text-decoration-thickness: 2px !important;
  text-decoration-color: currentColor !important;
  background-image: none !important;
}


/* removed old underline rule */
.nav .menu > li > a,
.nav .menu > li > a:hover,
.nav .menu > li > a:focus,
.nav .menu > li > a:active {
  text-decoration: none !important;
  background: none !important;
  background-image: none !important;
}

.nav .menu > li > a {
  position: relative;
  display: inline-block;
  padding: 16px 16px;            /* slightly larger hover target */
  border-radius: 12px;
}

.nav .menu > li > a::after {
  content: "";
  position: absolute;
  left: 12%;
  right: 12%;
  bottom: 6px;                   /* underline sits near bottom */
  height: 2px;
  background: currentColor;
  border-radius: 2px;
  opacity: 0;
  transform: translateY(3px);
  transition: opacity .18s ease, transform .18s ease;
}

.nav .menu > li > a:hover::after,
.nav .menu > li > a:focus::after {
  opacity: 1;
  transform: translateY(0);
}

/* Prevent any global link rules from interfering inside nav */
header .nav a { text-decoration: none !important; background-image: none !important; }


/* === FINAL NAV FIX: correct bottom underline and caret, kill midline === */
/* Scope nav link defaults to avoid global 'a' rules */
header .nav .menu a { 
  display: inline-block !important; 
  padding: 12px 12px !important; 
  border-radius: 12px;
  background: transparent !important;
}

/* Make aria-current underline anchor relative so its ::after sits at its own bottom */
header .nav a[aria-current='page'] { position: relative !important; }
header .nav a[aria-current='page']::after { bottom: 2px !important; left: 10%; right: 10%; height: 2px; }

/* Remove any underline inside header regardless of global rules */
header a, header a:hover, header a:focus { 
  text-decoration: none !important;
  background-image: none !important;
  text-decoration-thickness: 0 !important;
  text-underline-offset: 0 !important;
}

/* Our explicit bottom underline on hover using ::before */
header .nav .menu > li > a { position: relative !important; }
header .nav .menu > li > a::before {
  content: "";
  position: absolute;
  left: 10%;
  right: 10%;
  bottom: 2px;
  height: 2px;
  background: currentColor;
  opacity: 0;
  transform: translateY(2px);
  transition: opacity .18s ease, transform .18s ease;
}
header .nav .menu > li > a:hover::before,
header .nav .menu > li > a:focus::before { opacity: 1; transform: translateY(0); }

/* Restore caret on dropdown titles */
header .nav .dropdown > a { padding-right: 18px !important; }
header .nav .dropdown > a::after {
  content: "▾";
  position: absolute;
  right: 2px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 12px;
  color: var(--brand-2);
}
header .nav .dropdown:hover > a::after,
header .nav .dropdown:focus-within > a::after { transform: translateY(-50%) rotate(180deg); }


/* === CLEAN NAV: remove caret and any midline sources; use inset bottom underline === */
/* Remove all pseudo underline/caret inside header nav */
header .nav a::after,
header .nav a::before { content: none !important; background: none !important; height: 0 !important; border: 0 !important; box-shadow: none !important; }

/* Kill gradient underline for active link if exists */
header .nav a[aria-current='page']::after { content: none !important; height: 0 !important; background: none !important; }

/* Neutralize global anchor hovers inside header */
header a, header a:hover, header a:focus, header a:active {
  text-decoration: none !important;
  background-image: none !important;
}

/* Base nav link box for reliable bottom underline */
header .nav .menu > li > a {
  position: relative;
  display: inline-block;
  padding: 14px 14px;
  border-radius: 10px;
  line-height: 1.2;
  box-shadow: inset 0 0 0 transparent; /* reset */
}

/* Bottom underline on hover using inset shadow, not text-decoration */
header .nav .menu > li > a:hover,
header .nav .menu > li > a:focus {
  box-shadow: inset 0 -2px 0 currentColor;
  background: rgba(14,165,181,0.10);
}

/* Active page also gets bottom line */
header .nav .menu > li > a[aria-current='page'] {
  box-shadow: inset 0 -2px 0 currentColor;
}


/* === CARET + HOVER-TAKES-PRIORITY UNDERLINE === */
/* Caret only for dropdown roots */
header .nav .dropdown > a {
  position: relative;
  padding-right: 18px;
}
header .nav .dropdown > a::after {
  content: "▾";
  position: absolute;
  right: 2px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 12px;
  color: var(--brand-2);
}

/* Keep our clean bottom underline via inset shadow */
header .nav .menu > li > a {
  position: relative;
  display: inline-block;
  padding: 14px 14px;
  border-radius: 10px;
  line-height: 1.2;
  box-shadow: inset 0 0 0 transparent;
}

/* Active page underline (default) */
header .nav .menu > li > a[aria-current='page'] {
  box-shadow: inset 0 -2px 0 currentColor;
}

/* Hover underline shows on hovered link */
header .nav .menu > li > a:hover,
header .nav .menu > li > a:focus {
  box-shadow: inset 0 -2px 0 currentColor;
  background: rgba(14,165,181,0.10);
}

/* When mouse is anywhere over the nav, hide the active-page underline
   so the underline appears only under the hovered item */
header .nav:hover .menu > li > a[aria-current='page'] {
  box-shadow: inset 0 -0px 0 transparent;
}

/* Restore active underline when leaving nav happens automatically via rule above */


/* === CARET VISIBILITY FIX === */
/* Earlier global pseudo reset had !important. Re-enable caret with stronger rule. */
header .nav .dropdown > a { position: relative; padding-right: 18px !important; }
header .nav .dropdown > a::after {
  content: "▾" !important;
  position: absolute !important;
  right: 2px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  font-size: 12px !important;
  color: rgba(255,255,255,.9) !important; /* high-contrast on dark navbar */
  filter: drop-shadow(0 1px 0 rgba(0,0,0,.35));
}
header .nav .dropdown:hover > a::after,
header .nav .dropdown:focus-within > a::after {
  transform: translateY(-50%) rotate(180deg) !important;
}


/* === ALWAYS-VISIBLE CARET via <span class="caret"> === */
header .nav .dropdown > a { position: relative; padding-right: 18px; }
header .nav .dropdown > a .caret {
  position: absolute;
  right: 2px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 12px;
  color: rgba(255,255,255,.9);
  pointer-events: none;
  filter: drop-shadow(0 1px 0 rgba(0,0,0,.35));
}
header .nav .dropdown:hover > a .caret,
header .nav .dropdown:focus-within > a .caret { transform: translateY(-50%) rotate(180deg); }
/* Disable any pseudo caret that might exist */
header .nav .dropdown > a::after { content: none !important; }


/* === CARET SIZE + THEME COLOR === */
header .nav .dropdown > a .caret{
  font-size: 16px !important;     /* bigger caret */
  color: var(--brand-2) !important; /* theme teal */
  filter: drop-shadow(0 1px 0 rgba(0,0,0,.35));
}


/* === BIGGER HEADER LOGO === */
header .nav a.logo img{ height: 64px !important;
  width: auto !important;
}
@media (max-width:520px){ header .nav a.logo img{ height: 56px !important; } }


/* === DROPDOWN FULL-ROW CLICK === */
header .nav .dropdown-menu{
  padding: 6px 0 !important;   /* no side padding so anchors can fill full width */
}
header .nav .dropdown-menu a{
  display:block !important;
  width:100% !important;
  margin:0 !important;          /* no gaps that are not clickable */
  padding:12px 16px !important; /* keep nice touch target */
  border-radius:0 !important;
}
/* optional subtle separators while keeping full clickable row */
header .nav .dropdown-menu a + a{
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
}

.img-pos-bottom{ object-position: center 85% !important; }

.img-pos-bottom-strong{ object-position:center 95% !important; }


/* === Overrides: hero images +5% except homepage (.fade-up) === */
.hero.hero-cover:not(.fade-up){
  padding: 84px 0 95px !important;
  min-height: 63vh !important;
}



/* === International Sourcing main image sizing === */
.intl-main-img{ width:50% !important; max-width:525px !important; min-width:350px; height:auto; }
@media (max-width: 768px){
  .intl-main-img{ width:50% !important; max-width:600px !important; }
}



/* === Service pages main image sizing (unified) === */
.svc-main-img{ display:block; margin:24px auto; width:50% !important; max-width:525px; min-width:350px; height:auto; object-fit:contain; border:none; box-shadow:none; }
@media (max-width: 768px){
  .svc-main-img{ width:50% !important; max-width:600px; }
}



/* === About Us final layout === */
.about-features .feature-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.about-features .feature-card{ background:#fff; border-radius:14px; padding:24px; box-shadow: 0 12px 30px rgba(2,18,33,.06); text-align:center }
.about-features .feature-card h3{ margin:0 0 8px; font-size:20px }
.about-features .feature-card p{ margin:0; color:var(--muted) }

.about-two-col .row{ display:grid; grid-template-columns: 1.1fr .9fr; gap: 28px; align-items:center }
.about-two-col .about-heading{ font-size: clamp(34px, 4.4vw, 48px); line-height:1.15; margin:0 0 12px }
.about-two-col p{ color:var(--muted); font-size:18px; margin:0 0 10px }
.about-two-col .about-side-img{ width:100%; max-width:640px; height:auto; border-radius:12px; display:block; margin:0 auto }

.about-wide-photo .about-wide-img{ width:100%; height:auto; border-radius:10px; display:block; }

@media (max-width: 900px){
  .about-features .feature-grid{ grid-template-columns: 1fr; }
  .about-two-col .row{ grid-template-columns: 1fr; }
}

