/* ========== Base ========== */
:root{
    --green-600:#10B981; /* primary */
    --green-700:#0EA371;
    --green-50:#ECFDF5;
    --ink-900:#0F172A;   /* deep navy for headings */
    --ink-800:#1E293B;
    --ink-700:#334155;
    --ink-600:#475569;
    --ink-100:#E2E8F0;
    --bg:#FFFFFF;
    --card:#F7FAF9;
    --accent:#232B4D;    /* dark indigo for pills/buttons */
    --ring: rgba(16,185,129,.3);
    --radius:14px;
    --shadow:0 10px 30px rgba(2,6,23,.08);
  }
  
  *{box-sizing:border-box}
  html,body{height:100%}
  body{
    margin:0;
    font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,"Apple Color Emoji","Segoe UI Emoji",sans-serif;
    color:var(--ink-800);
    background:var(--bg);
    line-height:1.55;
    -webkit-font-smoothing:antialiased;
  }
  
  /* Containers & Layout */
  .container{
    width:min(1120px, 92vw);
    margin-inline:auto;
  }
  
  .section{
    padding:64px 0;
  }
  .section-alt{
    background:var(--green-50);
  }
  
  .section-title{
    font-size:clamp(1.4rem, 1.1rem + 1vw, 2rem);
    color:var(--ink-900);
    margin:0 0 24px;
  }
  
  .grid{
    display:grid;
    gap:22px;
  }
  .grid-2{ grid-template-columns:repeat(2, minmax(0,1fr)); }
  .grid-3{ grid-template-columns:repeat(3, minmax(0,1fr)); }
  .grid-4{ grid-template-columns:repeat(4, minmax(0,1fr)); }
  @media (max-width: 960px){
    .grid-4{ grid-template-columns:repeat(2, minmax(0,1fr));}
  }
  @media (max-width: 720px){
    .grid-2, .grid-3, .grid-4{ grid-template-columns:1fr;}
  }
  
  /* ========== Header ========== */
  .site-header{
    position:sticky; top:0; z-index:50;
    background:#fff;
    border-bottom:1px solid var(--ink-100);
  }
  .header-inner{
    display:flex; align-items:center; justify-content:space-between;
    padding:14px 0;
    gap:16px;
  }
  .brand{display:flex; align-items:center; gap:12px; color:inherit; text-decoration:none}
  .logo{
    height: 36px;
    width: 36px;
  }
  .logo img{
    height: 100%;
    width: 100%;
  }
  .logo{color:var(--green-600)}
  .brand-title{font-weight:700; letter-spacing:.2px}
  .brand-sub{font-size:.8rem; color:var(--ink-600); display:block}
  
  .nav{display:flex; gap:18px; align-items:center}
  .nav a{
    color:var(--ink-700); text-decoration:none; font-weight:500;
  }
  .nav a:hover{color:var(--ink-900)}
  .nav .btn{margin-left:4px}
  
  .nav-toggle{
    display:none; border:0; background:#fff; font-size:24px; color:var(--ink-800);
  }
  @media (max-width:880px){
    .nav{position:absolute; inset:60px 0 auto 0; padding:14px 24px; background:#fff; border-bottom:1px solid var(--ink-100); display:none}
    .nav.open{display:flex; flex-direction:column; align-items:flex-start; gap:12px}
    .nav-toggle{display:block}
  }
  
  /* Buttons */
  .btn{
    --p: var(--green-600);
    appearance:none; border:0; background:var(--p); color:#fff;
    padding:12px 18px; border-radius:12px; font-weight:600; text-decoration:none;
    box-shadow:0 6px 18px rgba(16,185,129,.25);
  }
  .btn:hover{filter:brightness(.95)}
  .btn:active{transform:translateY(1px)}
  .btn--ghost{
    background:transparent; color:var(--accent); border:1.5px solid var(--accent);
    box-shadow:none;
  }
  .btn--sm{padding:8px 12px; border-radius:10px}
  
  /* ========== Hero ========== */
  .hero{
    background: radial-gradient(1200px 450px at 20% -20%, #ECFDF5 0%, #fff 60%);
    padding:28px 0 48px;
    border-bottom:1px solid var(--ink-100);
  }
  .hero-inner{
    display:grid; gap:26px; align-items:stretch;
    grid-template-columns: 1.25fr .9fr;
  }
  @media (max-width: 980px){
    .hero-inner{grid-template-columns:1fr}
  }
  .hero-copy h1{
    margin: 8px 0 10px;
    font-size:clamp(1.4rem, 1rem + 2.2vw, 2.4rem);
    color:var(--ink-900);
  }
  .lead{font-size:1.05rem; color:var(--ink-700)}
  .hero-cta{display:flex; gap:12px; margin-top:14px; flex-wrap:wrap}
  
  .hero-card{
    background:var(--green-600);
    color:#fff;
    border-radius:18px;
    padding:22px 22px 24px;
    box-shadow:var(--shadow);
  }
  .hero-card h2{margin:0 0 10px; font-size:1.2rem}
  .hero-card p{margin:0; opacity:.95}
  
  /* ========== Offerings ========== */
  .list-card{
    background:#fff;
    border:1px solid var(--ink-100);
    border-radius:18px;
    padding:18px;
    box-shadow:var(--shadow);
  }
  .list-item{
    display:grid; grid-template-columns:auto 1fr; gap:14px;
    padding:12px 6px; align-items:flex-start;
    border-bottom:1px dashed #E6EEF0;
  }
  .list-item:last-child{border-bottom:0}
  .list-item h3{margin:0 0 6px; font-size:1rem; color:var(--ink-900)}
  .list-item p{margin:0; color:var(--ink-700)}
  .badge{
    width:40px; height:40px; display:inline-grid; place-items:center;
    border-radius:50%;
    background:var(--green-50); color:var(--green-700);
    border:1px solid rgba(16,185,129,.25);
  }
  
  /* ========== Capacity & Experience ========== */
  .tick-list{
    list-style:none; padding:0; margin:0;
    display:grid; gap:12px;
  }
  .tick-list li{
    background:#fff; border:1px solid var(--ink-100);
    border-radius:14px; padding:14px 14px 14px 44px; position:relative;
    box-shadow:var(--shadow);
  }
  .tick-list li::before{
    content:""; position:absolute; left:14px; top:14px;
    width:20px; height:20px; border-radius:50%;
    background:conic-gradient(from 0deg, var(--green-600), var(--green-700));
    mask: radial-gradient(circle at 50% 50%, #0000 58%, #000 60%);
  }
  .logo-strip{display:flex; flex-wrap:wrap; gap:10px; margin-top:16px}
  .logo-pill{
    /* font-size:.86rem; */
    /* color:#fff; background:var(--accent); */
    padding:8px; 
    /* border: 1px solid red; */
    height: 150px;
    width: 200px;
    /* border-radius:999px; */
  }
  .logo-pill img{
    height: 100%;
    width: 100%;
    object-fit: scale-down;
  }
  
  /* ========== Why Cards ========== */
  .why-card{
    background:#fff; border:1px solid var(--ink-100);
    border-radius:16px; padding:18px; text-align:left; box-shadow:var(--shadow);
  }
  .why-card i{font-size:24px; color:var(--green-600)}
  .why-card h3{margin:8px 0 6px; font-size:1rem; color:var(--ink-900)}
  .why-card p{margin:0; color:var(--ink-700)}
  
  /* ========== Contact ========== */
  .contact{
    display:grid; grid-template-columns: 1.1fr 1fr; gap:22px;
  }
  @media (max-width: 900px){
    .contact{grid-template-columns:1fr}
  }
  .contact-card{
    background:#fff; border:1px solid var(--ink-100); border-radius:18px; padding:22px; box-shadow:var(--shadow);
  }
  .contact-card h2{margin-top:0}
  .org{margin:4px 0 14px; font-weight:600; color:var(--ink-900)}
  .contact-list{list-style:none; padding:0; margin:0 0 12px; display:grid; gap:8px}
  .contact-list i{color:var(--green-600); margin-right:8px}
  .contact-list a{color:var(--ink-800); text-decoration:none}
  .contact .social{display:flex; gap:10px; margin-top:8px}
  .contact .social a{
    width:38px; height:38px; display:grid; place-items:center; border-radius:10px;
    background:var(--green-50); color:var(--green-700); border:1px solid rgba(16,185,129,.25);
  }
  .contact .social a:hover{background:#fff}
  
  .contact-form{
    background:#fff; border:1px solid var(--ink-100); border-radius:18px; padding:22px; box-shadow:var(--shadow);
  }
  .contact-form h3{margin:0 0 10px}
  .form-grid{display:grid; grid-template-columns:1fr 1fr; gap:14px}
  .form-grid .full{grid-column:1 / -1}
  label span{display:block; font-size:.9rem; color:var(--ink-700); margin-bottom:6px}
  input, textarea{
    width:100%; padding:12px 12px; border-radius:12px; border:1.5px solid #DDE5EA; outline:none; font:inherit;
    transition:border .15s, box-shadow .15s, background .15s;
    background:#FBFDFD;
  }
  input:focus, textarea:focus{
    border-color:var(--green-600);
    box-shadow:0 0 0 3px var(--ring);
  }
  .fine-print{color:var(--ink-600); font-size:.85rem; margin:8px 0 0}
  
  /* ========== Footer ========== */
  .site-footer{
    padding:22px 0;
    border-top:1px solid var(--ink-100);
    background:#fff;
  }
  .footer-inner{
    display:flex; align-items:center; justify-content:space-between; gap:12px;
  }
  .to-top{color:var(--ink-700); text-decoration:none; font-weight:600}
  .to-top:hover{color:var(--ink-900)}
  