/* ============================================================
   TECHOPS AFRICA — Shared Design System
   Blue & white corporate system. Edit the tokens in :root to
   rebrand (e.g. change --royal to your exact brand blue).
   ============================================================ */

:root{
  /* ---- Brand colour tokens (change these to rebrand) ---- */
  --navy:#06183F;
  --navy-2:#0A2455;
  --royal:#1E50E5;
  --royal-2:#2E6BFF;
  --azure:#5B92FF;
  --sky:#A9C7FF;
  --ice:#EEF4FF;
  --ice-2:#F6F9FF;
  --white:#FFFFFF;
  --ink:#0A1A38;
  --slate:#5A6A86;
  --slate-2:#8A98B2;
  --line:#E3EAF6;
  --line-d:rgba(255,255,255,.14);
  /* ---- Type ---- */
  --d:"Clash Display",sans-serif;
  --b:"Switzer",sans-serif;
  /* ---- Motion & elevation ---- */
  --e:cubic-bezier(.19,1,.22,1);
  --shadow:0 24px 60px -28px rgba(10,35,90,.32);
  --shadow-sm:0 10px 30px -16px rgba(10,35,90,.28);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{background:var(--white);color:var(--ink);font-family:var(--b);font-size:17px;line-height:1.65;overflow-x:hidden}
::selection{background:var(--royal);color:#fff}
::-webkit-scrollbar{width:11px}
::-webkit-scrollbar-track{background:var(--ice-2)}
::-webkit-scrollbar-thumb{background:#c3d3f0;border-radius:10px;border:3px solid var(--ice-2)}
::-webkit-scrollbar-thumb:hover{background:var(--royal)}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
h1,h2,h3,h4{font-family:var(--d);font-weight:600;line-height:1.06;letter-spacing:-.02em}

/* ---- Layout helpers ---- */
.wrap{width:min(1240px,90vw);margin:0 auto}
.sec{padding:130px 0}
.sec-sm{padding:90px 0}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:.78rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--royal);margin-bottom:22px}
.eyebrow::before{content:"";width:26px;height:2px;background:linear-gradient(90deg,var(--royal),var(--azure))}
.eyebrow.light{color:var(--sky)}.eyebrow.light::before{background:linear-gradient(90deg,var(--sky),transparent)}
.shead{max-width:680px;margin:0 auto 70px;text-align:center}
.shead h2{font-size:clamp(2.1rem,4.8vw,3.5rem);margin-bottom:18px}
.shead p{color:var(--slate);font-size:1.12rem}
.shead.left{margin-left:0;text-align:left}

/* ---- Reveal animation ---- */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 1s var(--e),transform 1s var(--e)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.09s}.d2{transition-delay:.18s}.d3{transition-delay:.27s}
.d4{transition-delay:.36s}.d5{transition-delay:.45s}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--b);font-weight:600;font-size:.96rem;
  padding:14px 28px;border-radius:12px;cursor:pointer;border:none;transition:all .45s var(--e);white-space:nowrap}
.btn .ar{transition:transform .45s var(--e)}.btn:hover .ar{transform:translateX(4px)}
.btn-p{background:linear-gradient(135deg,var(--royal-2),var(--royal));color:#fff;
  box-shadow:0 14px 32px -12px rgba(30,80,229,.6)}
.btn-p:hover{transform:translateY(-3px);box-shadow:0 22px 44px -12px rgba(30,80,229,.75)}
.btn-o{background:var(--white);color:var(--ink);border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.btn-o:hover{transform:translateY(-3px);border-color:var(--azure);color:var(--royal)}
.btn-w{background:#fff;color:var(--royal)}.btn-w:hover{transform:translateY(-3px);box-shadow:0 18px 40px -14px rgba(0,0,0,.4)}
.btn-glass{background:rgba(255,255,255,.1);color:#fff;border:1px solid var(--line-d);backdrop-filter:blur(10px)}
.btn-glass:hover{background:rgba(255,255,255,.2);transform:translateY(-3px)}

/* ---- Navigation (shared) ---- */
nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:all .5s var(--e)}
.ni{display:flex;align-items:center;justify-content:space-between;padding:22px 0;transition:padding .5s var(--e)}
nav.s{background:rgba(255,255,255,.82);backdrop-filter:blur(20px);border-bottom:1px solid var(--line)}
nav.s .ni{padding:14px 0}
.brand{display:flex;align-items:center;gap:12px}
.bm{width:44px;height:44px;border-radius:13px;background:linear-gradient(135deg,var(--royal-2),var(--navy));
  color:#fff;display:grid;place-items:center;font-family:var(--d);font-weight:600;font-size:1.3rem;
  box-shadow:0 10px 24px -8px rgba(30,80,229,.55)}
.bt{font-family:var(--d);font-weight:600;font-size:1.2rem;line-height:1;color:var(--ink)}
.bt span{display:block;font-family:var(--b);font-weight:500;font-size:.58rem;letter-spacing:.38em;color:var(--slate-2);margin-top:4px}
.nl{display:flex;align-items:center;gap:38px}
.nl a{font-size:.96rem;font-weight:500;color:var(--slate);position:relative;transition:color .3s}
.nl a::after{content:"";position:absolute;left:0;bottom:-7px;width:0;height:2px;background:var(--royal);transition:width .4s var(--e)}
.nl a:hover{color:var(--ink)}.nl a:hover::after{width:100%}
.nl a.active{color:var(--ink)}.nl a.active::after{width:100%}
.mtog{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:8px}
.mtog span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}

/* ---- Page hero (interior pages) ---- */
.phero{position:relative;overflow:hidden;padding:180px 0 90px;
  background:
    radial-gradient(ellipse 60% 60% at 85% 0%,rgba(91,146,255,.16),transparent 60%),
    radial-gradient(ellipse 50% 50% at 5% 100%,rgba(30,80,229,.1),transparent 60%),
    linear-gradient(180deg,var(--ice-2),var(--white))}
.phero::before{content:"";position:absolute;inset:0;z-index:0;opacity:.45;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:60px 60px;mask:radial-gradient(ellipse 80% 80% at 50% 20%,#000 30%,transparent 75%)}
.phero .wrap{position:relative;z-index:1}
.crumb{font-size:.86rem;color:var(--slate-2);margin-bottom:20px}
.crumb a:hover{color:var(--royal)}.crumb span{color:var(--royal)}
.phero h1{font-size:clamp(2.6rem,6vw,4.6rem);max-width:18ch;margin-bottom:22px}
.phero h1 .g{background:linear-gradient(110deg,var(--royal),var(--azure));-webkit-background-clip:text;
  background-clip:text;-webkit-text-fill-color:transparent}
.phero p{color:var(--slate);font-size:1.2rem;max-width:54ch}

/* ---- Service cards (home) ---- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.svc{position:relative;background:#fff;border:1px solid var(--line);border-radius:22px;padding:40px 34px;
  overflow:hidden;transition:all .55s var(--e)}
.svc::before{content:"";position:absolute;inset:0;opacity:0;transition:opacity .55s var(--e);
  background:linear-gradient(160deg,var(--royal),var(--navy))}
.svc>*{position:relative;z-index:1;transition:color .45s var(--e)}
.svc:hover{transform:translateY(-10px);box-shadow:0 30px 60px -24px rgba(30,80,229,.45);border-color:transparent}
.svc:hover::before{opacity:1}
.svc:hover h3,.svc:hover .ar2{color:#fff}
.svc:hover p{color:rgba(255,255,255,.82)}
.svc:hover .ic{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.2)}
.svc .ic{width:62px;height:62px;border-radius:17px;display:grid;place-items:center;font-size:1.6rem;
  background:var(--ice);border:1px solid var(--line);margin-bottom:26px;transition:all .45s var(--e)}
.svc h3{font-size:1.4rem;margin-bottom:13px}
.svc p{color:var(--slate);font-size:.96rem;margin-bottom:22px}
.svc .ar2{font-weight:600;font-size:.9rem;color:var(--royal);display:inline-flex;align-items:center;gap:7px}

/* ---- Detailed service rows (services page) ---- */
.svc-detail{display:flex;flex-direction:column;gap:28px}
.sd{display:grid;grid-template-columns:auto 1fr auto;gap:36px;align-items:center;
  background:#fff;border:1px solid var(--line);border-radius:24px;padding:42px 44px;transition:all .55s var(--e)}
.sd:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:#cfddf7}
.sd .ic{width:78px;height:78px;border-radius:20px;display:grid;place-items:center;font-size:2rem;
  background:linear-gradient(160deg,var(--royal),var(--navy));color:#fff;box-shadow:0 14px 30px -12px rgba(30,80,229,.6)}
.sd .num{position:absolute}
.sd h3{font-size:1.7rem;margin-bottom:10px}
.sd p{color:var(--slate);margin-bottom:16px;max-width:62ch}
.sd .tags{display:flex;gap:8px;flex-wrap:wrap}
.sd .tag{font-size:.8rem;font-weight:600;color:var(--royal);background:var(--ice);border:1px solid var(--line);
  padding:6px 14px;border-radius:50px}
.sd .idx{font-family:var(--d);font-size:1.1rem;color:var(--slate-2)}
@media(max-width:760px){.sd{grid-template-columns:1fr;gap:22px;text-align:left}.sd .idx{display:none}}

/* ---- Process / steps ---- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.step{position:relative;padding:34px 28px;border:1px solid var(--line);border-radius:20px;background:#fff;transition:all .5s var(--e)}
.step:hover{transform:translateY(-6px);box-shadow:var(--shadow-sm)}
.step .n{font-family:var(--d);font-size:2.6rem;font-weight:600;color:var(--ice);-webkit-text-stroke:1px var(--azure);line-height:1;margin-bottom:18px}
.step h3{font-size:1.25rem;margin-bottom:10px}
.step p{color:var(--slate);font-size:.92rem}

/* ---- About: rich dark band ---- */
.darkband{background:linear-gradient(165deg,var(--navy),var(--navy-2));color:#fff;position:relative;overflow:hidden}
.darkband::before{content:"";position:absolute;width:60vw;height:60vw;border-radius:50%;top:-30vw;right:-20vw;
  background:radial-gradient(circle,rgba(30,80,229,.35),transparent 65%);filter:blur(40px)}
.darkband::after{content:"";position:absolute;width:46vw;height:46vw;border-radius:50%;bottom:-26vw;left:-16vw;
  background:radial-gradient(circle,rgba(91,146,255,.18),transparent 65%);filter:blur(40px)}
.db-grid{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.darkband h2{font-size:clamp(2rem,4.5vw,3.2rem);color:#fff;margin-bottom:22px}
.darkband p{color:rgba(255,255,255,.74);margin-bottom:20px}
.darkband p strong{color:#fff;font-weight:600}
.db-vis{position:relative;aspect-ratio:1/1;border-radius:24px;overflow:hidden;
  background:linear-gradient(150deg,rgba(91,146,255,.25),rgba(10,36,85,.6));border:1px solid var(--line-d);backdrop-filter:blur(6px)}
.db-vis .mesh{position:absolute;inset:0;
  background:radial-gradient(circle at 25% 25%,rgba(91,146,255,.5),transparent 50%),
             radial-gradient(circle at 78% 72%,rgba(30,80,229,.4),transparent 50%)}
.db-vis .badge{position:absolute;background:rgba(255,255,255,.1);backdrop-filter:blur(16px);
  border:1px solid var(--line-d);border-radius:18px;padding:20px 24px}
.db-vis .badge h4{font-size:2rem;color:#fff}.db-vis .badge p{font-size:.84rem;color:var(--sky);margin:0}
.db-vis .bg1{top:24px;left:24px}.db-vis .bg2{bottom:24px;right:24px}
.db-vis .bg3{top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}
.db-vis .bg3 .lbl{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sky)}

/* ---- Pillars ---- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pillar{background:rgba(255,255,255,.05);border:1px solid var(--line-d);border-radius:20px;padding:34px 30px;
  backdrop-filter:blur(8px);transition:all .5s var(--e)}
.pillar:hover{transform:translateY(-6px);background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.25)}
.pillar .n{font-family:var(--d);font-size:.9rem;color:var(--azure);margin-bottom:16px;letter-spacing:.05em}
.pillar h3{font-size:1.4rem;color:#fff;margin-bottom:12px}
.pillar p{color:rgba(255,255,255,.66);font-size:.93rem;margin:0}

/* ---- Feature list (why) ---- */
.feat{display:flex;gap:20px;padding:26px 0;border-bottom:1px solid var(--line);transition:padding .4s var(--e)}
.feat:hover{padding-left:10px}
.feat:last-child{border-bottom:none}
.feat .fi{flex-shrink:0;width:54px;height:54px;border-radius:15px;display:grid;place-items:center;font-size:1.4rem;
  background:linear-gradient(135deg,var(--ice),#fff);border:1px solid var(--line);color:var(--royal)}
.feat h3{font-size:1.22rem;margin-bottom:6px}
.feat p{color:var(--slate);font-size:.94rem;margin:0}

/* ---- Stats band ---- */
.statband{background:linear-gradient(135deg,var(--royal),var(--royal-2));border-radius:30px;
  padding:64px 50px;display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center;
  position:relative;overflow:hidden;box-shadow:0 40px 80px -30px rgba(30,80,229,.6)}
.statband::before{content:"";position:absolute;top:-50%;left:-10%;width:50%;height:200%;
  background:radial-gradient(circle,rgba(255,255,255,.18),transparent 60%)}
.st{position:relative;z-index:1}
.st .n{font-family:var(--d);font-weight:600;font-size:clamp(2.6rem,5vw,4rem);color:#fff;line-height:1}
.st .l{color:rgba(255,255,255,.82);font-size:.94rem;margin-top:10px}
.st:not(:last-child)::after{content:"";position:absolute;right:-15px;top:15%;height:70%;width:1px;background:rgba(255,255,255,.22)}

/* ---- Team ---- */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.mem{background:#fff;border:1px solid var(--line);border-radius:22px;overflow:hidden;transition:all .55s var(--e);box-shadow:var(--shadow-sm)}
.mem:hover{transform:translateY(-10px);box-shadow:0 34px 64px -26px rgba(30,80,229,.4);border-color:#cfddf7}
.mem .ph{aspect-ratio:1/1;overflow:hidden;position:relative;background:var(--ice)}
.mem .ph img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--e);filter:saturate(.9)}
.mem:hover .ph img{transform:scale(1.07);filter:saturate(1.05)}
.mem .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 60%,rgba(6,24,63,.45))}
.mem .info{padding:24px 26px}
.mem .role{font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:var(--royal);font-weight:600;margin-bottom:7px}
.mem .nm{font-family:var(--d);font-size:1.4rem;margin-bottom:13px}
.mem .bio{color:var(--slate);font-size:.88rem;line-height:1.6}
.mem.join{display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,var(--royal),var(--navy));border:none;text-align:center}
.mem.join .nm{color:#fff;margin-bottom:14px}.mem.join .bio{color:rgba(255,255,255,.8)}

/* ---- Partners ---- */
.plogos{display:flex;flex-wrap:wrap;gap:18px;justify-content:center}
.plogo{display:grid;place-items:center;min-width:170px;height:96px;padding:0 30px;background:#fff;
  border:1px solid var(--line);border-radius:16px;font-family:var(--d);font-weight:600;font-size:1.4rem;
  color:#9fb0d0;transition:all .45s var(--e)}
.plogo:hover{color:var(--royal);border-color:#cfddf7;transform:translateY(-4px);box-shadow:var(--shadow-sm)}

/* ---- CTA ---- */
.cta{position:relative;overflow:hidden;border-radius:34px;padding:84px 60px;text-align:center;color:#fff;
  background:linear-gradient(150deg,var(--navy),var(--royal))}
.cta::before{content:"";position:absolute;width:500px;height:500px;border-radius:50%;top:-200px;right:-100px;
  background:radial-gradient(circle,rgba(91,146,255,.45),transparent 65%);filter:blur(30px)}
.cta::after{content:"";position:absolute;width:400px;height:400px;border-radius:50%;bottom:-180px;left:-80px;
  background:radial-gradient(circle,rgba(30,80,229,.5),transparent 65%);filter:blur(30px)}
.cta h2{font-size:clamp(2.2rem,5vw,3.6rem);color:#fff;margin-bottom:18px;position:relative}
.cta p{color:rgba(255,255,255,.82);max-width:50ch;margin:0 auto 38px;position:relative;font-size:1.12rem}
.cta-form{display:flex;gap:12px;max-width:500px;margin:0 auto;position:relative;flex-wrap:wrap}
.cta-form input{flex:1;min-width:230px;background:rgba(255,255,255,.12);border:1px solid var(--line-d);
  border-radius:12px;padding:15px 22px;color:#fff;font-family:var(--b);font-size:1rem;backdrop-filter:blur(8px)}
.cta-form input::placeholder{color:rgba(255,255,255,.6)}
.cta-form input:focus{outline:none;border-color:#fff;background:rgba(255,255,255,.18)}

/* ---- Contact form (contact page) ---- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.cform{background:#fff;border:1px solid var(--line);border-radius:24px;padding:44px;box-shadow:var(--shadow-sm)}
.field{margin-bottom:20px}
.field label{display:block;font-size:.84rem;font-weight:600;color:var(--ink);margin-bottom:8px}
.field input,.field textarea,.field select{width:100%;background:var(--ice-2);border:1px solid var(--line);
  border-radius:12px;padding:14px 16px;font-family:var(--b);font-size:1rem;color:var(--ink);transition:border-color .3s}
.field textarea{resize:vertical;min-height:130px}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--royal);background:#fff}
.cinfo .ci{display:flex;gap:18px;padding:24px 0;border-bottom:1px solid var(--line)}
.cinfo .ci:last-child{border-bottom:none}
.cinfo .ci .ic{flex-shrink:0;width:54px;height:54px;border-radius:15px;display:grid;place-items:center;font-size:1.4rem;
  background:var(--ice);border:1px solid var(--line);color:var(--royal)}
.cinfo .ci h4{font-size:1.05rem;margin-bottom:4px}
.cinfo .ci p,.cinfo .ci a{color:var(--slate);font-size:.96rem;display:block}
.cinfo .ci a:hover{color:var(--royal)}
.formnote{font-size:.84rem;color:var(--slate-2);margin-top:14px}
.toast{margin-top:16px;padding:14px 18px;border-radius:12px;background:var(--ice);border:1px solid var(--azure);
  color:var(--royal);font-weight:600;font-size:.92rem;display:none}
.toast.show{display:block;animation:pop .4s var(--e)}
@keyframes pop{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---- FAQ ---- */
.faq{max-width:800px;margin:0 auto}
.qa{border:1px solid var(--line);border-radius:16px;margin-bottom:14px;background:#fff;overflow:hidden;transition:border-color .3s}
.qa.open{border-color:var(--azure)}
.qa .q{width:100%;text-align:left;background:none;border:none;cursor:pointer;font-family:var(--b);
  font-weight:600;font-size:1.08rem;color:var(--ink);padding:24px 26px;display:flex;justify-content:space-between;align-items:center;gap:16px}
.qa .q .pm{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:var(--ice);color:var(--royal);
  display:grid;place-items:center;font-size:1.2rem;transition:transform .4s var(--e)}
.qa.open .q .pm{transform:rotate(45deg);background:var(--royal);color:#fff}
.qa .a{max-height:0;overflow:hidden;transition:max-height .5s var(--e)}
.qa .a p{padding:0 26px 24px;color:var(--slate)}

/* ---- Footer (shared) ---- */
footer{background:var(--ice-2);border-top:1px solid var(--line);padding:80px 0 38px}
.fg{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:44px;margin-bottom:56px}
.fg h5{font-family:var(--d);font-size:1.02rem;margin-bottom:20px}
.fg a,.fg p{display:block;color:var(--slate);font-size:.93rem;margin-bottom:12px;transition:color .3s}
.fg a:hover{color:var(--royal)}
.fbrand p{max-width:32ch;margin-top:18px}
.soc{display:flex;gap:11px;margin-top:22px}
.soc a{width:42px;height:42px;border-radius:12px;border:1px solid var(--line);background:#fff;display:grid;
  place-items:center;color:var(--slate);font-weight:600;transition:all .4s var(--e)}
.soc a:hover{background:var(--royal);color:#fff;border-color:var(--royal);transform:translateY(-3px)}
.fbot{display:flex;justify-content:space-between;align-items:center;padding-top:32px;border-top:1px solid var(--line);
  color:var(--slate-2);font-size:.86rem;flex-wrap:wrap;gap:12px}

/* ---- Responsive ---- */
@media(max-width:980px){
  .svc-grid{grid-template-columns:1fr}
  .db-grid{grid-template-columns:1fr;gap:46px}
  .pillars{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
  .statband{grid-template-columns:repeat(2,1fr);gap:44px 20px;padding:50px 30px}
  .st:nth-child(2)::after,.st:last-child::after{display:none}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .fg{grid-template-columns:1fr 1fr}
  .nl{position:fixed;inset:0;flex-direction:column;justify-content:center;gap:30px;font-size:1.4rem;
    background:rgba(255,255,255,.98);backdrop-filter:blur(20px);transform:translateX(100%);transition:transform .5s var(--e)}
  .nl.open{transform:none}.nl a{color:var(--ink)}.mtog{display:flex;z-index:101}.nav-cta{display:none}
}
@media(max-width:600px){
  .team-grid{grid-template-columns:1fr}.steps{grid-template-columns:1fr}
  .fg{grid-template-columns:1fr}.cta{padding:54px 26px}.sec{padding:90px 0}.cform{padding:30px 24px}
}
