/* IMI — Navy & Red Edition (matched to logo) */
:root{
  /* Logo-matched palette */
  --navy-darker:#0a1633;
  --navy-dark:#13264d;
  --navy:#1e3a6f;
  --navy-light:#2d528f;
  --navy-lighter:#4a7bc4;

  --red-dark:#991b1b;
  --red:#dc2626;
  --red-bright:#e11d2e;
  --red-light:#ef4444;
  --red-lighter:#f87171;

  --cream:#fef8f8;
  --ink:#0f1e3d;
  --ink-2:#1e293b;
  --text:#1e293b;
  --muted:#64748b;
  --bg:#f8fafc;
  --surface:#ffffff;
  --border:#e2e8f0;

  /* Logo-matched gradients */
  --grad-hero:linear-gradient(135deg,#0a1633 0%,#13264d 30%,#1e3a6f 55%,#991b1b 85%,#dc2626 100%);
  --grad-primary:linear-gradient(135deg,#1e3a6f,#dc2626);
  --grad-navy:linear-gradient(135deg,#13264d,#2d528f);
  --grad-red:linear-gradient(135deg,#991b1b,#ef4444);
  --grad-mixed:linear-gradient(135deg,#2d528f,#dc2626);
  --grad-reverse:linear-gradient(135deg,#dc2626,#1e3a6f);
  --grad-deep:linear-gradient(135deg,#0a1633,#991b1b);
  --grad-bright:linear-gradient(135deg,#4a7bc4,#ef4444);

  --shadow-sm:0 4px 12px rgba(10,22,51,.08);
  --shadow:0 12px 32px rgba(10,22,51,.12);
  --shadow-lg:0 24px 60px rgba(10,22,51,.2);

  --radius:18px;
  --maxw:1240px;
  --trans:.4s cubic-bezier(.2,.7,.3,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter','Segoe UI',system-ui,-apple-system,sans-serif;
  color:var(--text);background:var(--bg);line-height:1.65;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ===== Header ===== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(255,255,255,.85);backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid rgba(226,232,240,.6);
  transition:var(--trans);
}
.site-header.scrolled{background:rgba(255,255,255,.96);box-shadow:0 10px 40px rgba(10,22,51,.12)}
.nav{display:flex;align-items:center;justify-content:space-between;height:112px}
.logo{display:flex;align-items:center;gap:16px;font-weight:900;font-size:22px;color:var(--navy-dark)}
.logo-mark{
  width:100px;height:100px;border-radius:16px;
  background:#fff;padding:6px;
  display:grid;place-items:center;
  box-shadow:0 12px 28px rgba(30,58,111,.28),0 0 0 1px rgba(220,38,38,.15);
  position:relative;overflow:hidden;object-fit:contain;
}
.logo-mark img{width:100%;height:100%;object-fit:contain;display:block}
.logo span:last-child{
  background:linear-gradient(90deg,#13264d,#dc2626);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.nav-links{display:flex;gap:36px;list-style:none;align-items:center}
.nav-links a{font-weight:500;font-size:15px;color:var(--text);position:relative;padding:6px 0;transition:var(--trans)}
.nav-links a:hover,.nav-links a.active{color:var(--red)}
.nav-links a::after{
  content:'';position:absolute;bottom:-2px;left:0;width:0;height:3px;border-radius:2px;
  background:var(--grad-primary);transition:var(--trans);
}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{
  background:var(--grad-primary);color:#fff!important;padding:12px 24px;
  border-radius:999px;font-weight:600;font-size:14px;
  box-shadow:0 8px 20px rgba(220,38,38,.35);
}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(220,38,38,.5)}
.nav-cta::after{display:none!important}
.burger{display:none;background:none;border:none;cursor:pointer;width:44px;height:44px;flex-direction:column;gap:5px;justify-content:center;align-items:center}
.burger span{width:26px;height:3px;background:var(--navy-dark);border-radius:3px;transition:var(--trans)}
.burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 30px;border-radius:999px;font-weight:600;font-size:15px;
  border:none;cursor:pointer;transition:var(--trans);
  text-decoration:none;white-space:nowrap;
}
.btn-primary{background:var(--grad-primary);color:#fff;box-shadow:0 10px 28px rgba(220,38,38,.4)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(220,38,38,.55)}
.btn-warm{background:var(--grad-red);color:#fff;box-shadow:0 10px 28px rgba(239,68,68,.45)}
.btn-warm:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(220,38,38,.6)}
.btn-outline{background:rgba(255,255,255,.12);color:#fff;border:2px solid rgba(255,255,255,.45);backdrop-filter:blur(10px)}
.btn-outline:hover{background:#fff;color:var(--red);border-color:#fff;transform:translateY(-3px)}
.btn-white{background:#fff;color:var(--red);box-shadow:0 10px 28px rgba(0,0,0,.2)}
.btn-white:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(0,0,0,.3);color:var(--navy-dark)}

/* ===== Hero ===== */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  background:var(--grad-hero);color:#fff;overflow:hidden;padding:140px 0 100px;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 15% 25%,rgba(255,255,255,.12) 0%,transparent 40%),
    radial-gradient(circle at 85% 75%,rgba(239,68,68,.35) 0%,transparent 45%),
    radial-gradient(circle at 50% 100%,rgba(74,123,196,.3) 0%,transparent 50%);
}
.hero::after{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 20% 30%,rgba(255,255,255,.08) 1px,transparent 1px),
    radial-gradient(circle at 70% 60%,rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:40px 40px,60px 60px;opacity:.8;
}
.hero .container{position:relative;z-index:2}
.hero-inner{max-width:860px}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 20px;border-radius:999px;
  background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);
  font-size:13px;font-weight:600;letter-spacing:.5px;margin-bottom:26px;
  backdrop-filter:blur(10px);
}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:#ef4444;box-shadow:0 0 12px #ef4444;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:.4}}
.hero h1{font-size:clamp(34px,5.5vw,62px);font-weight:900;line-height:1.05;margin-bottom:26px;letter-spacing:-1px}
.hero h1 .accent{
  background:linear-gradient(90deg,#ffffff,#f87171,#ef4444);
  -webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block;
}
.hero p.lead{font-size:clamp(17px,1.6vw,20px);color:rgba(255,255,255,.95);margin-bottom:18px;max-width:720px;font-weight:500}
.hero p.sub{font-size:15px;color:rgba(255,255,255,.82);margin-bottom:40px;max-width:680px}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap}
.hero-stats{display:flex;gap:50px;margin-top:70px;flex-wrap:wrap;padding-top:40px;border-top:1px solid rgba(255,255,255,.2)}
.hero-stats div strong{
  display:block;font-size:32px;font-weight:900;
  background:linear-gradient(90deg,#ffffff,#f87171);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-stats div span{font-size:13px;color:rgba(255,255,255,.82);font-weight:500}

/* ===== Sections ===== */
section{padding:100px 0;position:relative;overflow:hidden}
.section-head{text-align:center;max-width:740px;margin:0 auto 64px;position:relative;z-index:2}
.section-head .tag{
  display:inline-block;padding:8px 18px;border-radius:999px;
  background:linear-gradient(135deg,rgba(30,58,111,.12),rgba(220,38,38,.12));
  color:var(--red);font-weight:700;font-size:12px;letter-spacing:2px;
  text-transform:uppercase;margin-bottom:18px;border:1px solid rgba(220,38,38,.25);
}
.section-head h2{font-size:clamp(30px,3.8vw,46px);font-weight:900;color:var(--ink);margin-bottom:16px;letter-spacing:-1px;line-height:1.15}
.section-head h2 .grad{
  background:var(--grad-primary);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.section-head p{color:var(--muted);font-size:17px}
.bg-alt{background:#fff}
.bg-gradient{
  background:
    radial-gradient(ellipse at top left,rgba(30,58,111,.08),transparent 50%),
    radial-gradient(ellipse at bottom right,rgba(220,38,38,.08),transparent 50%),
    #fafbfc;
}
.bg-dark{background:linear-gradient(135deg,#0a1633 0%,#13264d 50%,#0a1633 100%);color:#fff}
.bg-dark::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(circle at 20% 30%,rgba(30,58,111,.35),transparent 40%),
    radial-gradient(circle at 80% 70%,rgba(220,38,38,.25),transparent 40%);
}
.bg-dark > .container{position:relative;z-index:2}
.bg-dark .section-head h2{color:#fff}
.bg-dark .section-head p{color:rgba(255,255,255,.75)}
.bg-dark .section-head .tag{background:rgba(220,38,38,.18);color:#fca5a5;border-color:rgba(252,165,165,.3)}

/* ===== Vision/Mission ===== */
.vm-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;position:relative;z-index:2}
.vm-card{
  background:#fff;padding:48px;border-radius:var(--radius);
  box-shadow:var(--shadow);position:relative;overflow:hidden;
  transition:var(--trans);border:1px solid var(--border);
}
.vm-card::before{content:'';position:absolute;top:0;left:0;right:0;height:6px}
.vm-card.vision::before{background:var(--grad-navy)}
.vm-card.mission::before{background:var(--grad-red)}
.vm-card::after{
  content:'';position:absolute;bottom:-100px;right:-100px;
  width:260px;height:260px;border-radius:50%;opacity:.1;transition:var(--trans);
}
.vm-card.vision::after{background:var(--grad-navy)}
.vm-card.mission::after{background:var(--grad-red)}
.vm-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-lg)}
.vm-card:hover::after{transform:scale(1.3)}
.vm-icon{
  width:70px;height:70px;border-radius:18px;
  display:grid;place-items:center;color:#fff;font-size:30px;margin-bottom:24px;
  position:relative;z-index:1;
}
.vm-card.vision .vm-icon{background:var(--grad-navy);box-shadow:0 12px 28px rgba(30,58,111,.4)}
.vm-card.mission .vm-icon{background:var(--grad-red);box-shadow:0 12px 28px rgba(220,38,38,.4)}
.vm-card h3{font-size:26px;color:var(--ink);margin-bottom:14px;font-weight:800;position:relative;z-index:1}
.vm-card p{color:var(--muted);font-size:16px;position:relative;z-index:1}

/* ===== About ===== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.about-text p{color:var(--muted);margin-bottom:20px;font-size:16px}
.about-text p:first-of-type{font-size:19px;color:var(--text);font-weight:500}
.about-visual{
  aspect-ratio:1/1;border-radius:24px;background:var(--grad-hero);
  display:grid;place-items:center;color:#fff;padding:50px;
  box-shadow:var(--shadow-lg);position:relative;overflow:hidden;
}
.about-visual::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(circle at 30% 20%,rgba(255,255,255,.2),transparent 50%),
    radial-gradient(circle at 70% 80%,rgba(239,68,68,.4),transparent 50%);
}
.about-visual::after{
  content:'';position:absolute;width:140%;height:140%;
  background:conic-gradient(from 0deg,transparent,rgba(255,255,255,.15),transparent 30%);
  top:-20%;left:-20%;animation:rotate 20s linear infinite;
}
@keyframes rotate{to{transform:rotate(360deg)}}
.about-visual-inner{position:relative;text-align:center;z-index:2}
.about-visual-inner .big{
  font-size:120px;line-height:1;margin-bottom:18px;
  filter:drop-shadow(0 10px 30px rgba(0,0,0,.4));
  animation:spin-slow 12s linear infinite;display:inline-block;
}
@keyframes spin-slow{to{transform:rotate(360deg)}}
.about-visual-inner .label{font-size:18px;font-weight:700;letter-spacing:2px;margin-bottom:14px}

/* ===== Services ===== */
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:28px;position:relative;z-index:2}
.service-card{
  background:#fff;padding:38px 32px;border-radius:var(--radius);
  border:1px solid var(--border);transition:var(--trans);
  position:relative;overflow:hidden;
}
.service-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:5px;
  transform:scaleX(0);transform-origin:left;transition:var(--trans);
}
.service-card:hover::before{transform:scaleX(1)}
.service-card:nth-child(8n+1)::before{background:var(--grad-primary)}
.service-card:nth-child(8n+2)::before{background:var(--grad-red)}
.service-card:nth-child(8n+3)::before{background:var(--grad-navy)}
.service-card:nth-child(8n+4)::before{background:var(--grad-reverse)}
.service-card:nth-child(8n+5)::before{background:var(--grad-bright)}
.service-card:nth-child(8n+6)::before{background:var(--grad-deep)}
.service-card:nth-child(8n+7)::before{background:var(--grad-mixed)}
.service-card:nth-child(8n)::before{background:linear-gradient(135deg,#2d528f,#991b1b)}
.service-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-lg);border-color:transparent}
.service-icon{
  width:64px;height:64px;border-radius:16px;
  display:grid;place-items:center;color:#fff;font-size:26px;margin-bottom:22px;
  transition:var(--trans);
}
.service-card:nth-child(8n+1) .service-icon{background:var(--grad-primary);box-shadow:0 10px 24px rgba(220,38,38,.35)}
.service-card:nth-child(8n+2) .service-icon{background:var(--grad-red);box-shadow:0 10px 24px rgba(239,68,68,.4)}
.service-card:nth-child(8n+3) .service-icon{background:var(--grad-navy);box-shadow:0 10px 24px rgba(30,58,111,.4)}
.service-card:nth-child(8n+4) .service-icon{background:var(--grad-reverse);box-shadow:0 10px 24px rgba(220,38,38,.35)}
.service-card:nth-child(8n+5) .service-icon{background:var(--grad-bright);box-shadow:0 10px 24px rgba(74,123,196,.35)}
.service-card:nth-child(8n+6) .service-icon{background:var(--grad-deep);box-shadow:0 10px 24px rgba(153,27,27,.4)}
.service-card:nth-child(8n+7) .service-icon{background:var(--grad-mixed);box-shadow:0 10px 24px rgba(45,82,143,.4)}
.service-card:nth-child(8n) .service-icon{background:linear-gradient(135deg,#2d528f,#991b1b);box-shadow:0 10px 24px rgba(45,82,143,.4)}
.service-card:hover .service-icon{transform:scale(1.1) rotate(-6deg)}
.service-card h3{font-size:20px;color:var(--ink);margin-bottom:16px;font-weight:800;line-height:1.3}
.service-card ul{list-style:none}
.service-card li{color:var(--muted);font-size:14px;padding:7px 0 7px 26px;position:relative}
.service-card li::before{
  content:'';position:absolute;left:0;top:14px;width:14px;height:3px;border-radius:3px;
  background:var(--grad-primary);
}

/* ===== Process ===== */
.process{display:grid;grid-template-columns:repeat(6,1fr);gap:20px;position:relative;z-index:2}
.step{
  background:rgba(255,255,255,.06);backdrop-filter:blur(10px);
  padding:32px 20px;border-radius:18px;
  border:1px solid rgba(255,255,255,.12);text-align:center;
  transition:var(--trans);
}
.step:hover{background:rgba(255,255,255,.12);transform:translateY(-8px);border-color:rgba(239,68,68,.4)}
.step-num{
  width:52px;height:52px;border-radius:50%;
  display:grid;place-items:center;color:#fff;font-weight:900;
  margin:0 auto 18px;font-size:18px;box-shadow:0 10px 24px rgba(0,0,0,.4);
}
.step:nth-child(1) .step-num{background:var(--grad-navy)}
.step:nth-child(2) .step-num{background:var(--grad-bright)}
.step:nth-child(3) .step-num{background:var(--grad-mixed)}
.step:nth-child(4) .step-num{background:var(--grad-primary)}
.step:nth-child(5) .step-num{background:var(--grad-red)}
.step:nth-child(6) .step-num{background:var(--grad-deep)}
.step h4{font-size:17px;margin-bottom:10px;color:#fff;font-weight:700}
.step p{font-size:13px;color:rgba(255,255,255,.72);line-height:1.5}

/* ===== Sectors ===== */
.sectors-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;position:relative;z-index:2}
.sector{
  background:#fff;padding:42px;border-radius:var(--radius);
  border:1px solid var(--border);box-shadow:var(--shadow);
  transition:var(--trans);position:relative;overflow:hidden;
}
.sector::before{content:'';position:absolute;top:0;left:0;width:100%;height:5px}
.sector:nth-child(1)::before{background:var(--grad-navy)}
.sector:nth-child(2)::before{background:var(--grad-red)}
.sector:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.sector h3{color:var(--ink);font-size:22px;margin-bottom:22px;font-weight:800;display:flex;align-items:center;gap:14px}
.sector h3 i{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;font-size:22px}
.sector:nth-child(1) h3 i{background:rgba(30,58,111,.12);color:var(--navy)}
.sector:nth-child(2) h3 i{background:rgba(220,38,38,.12);color:var(--red)}
.sector ul{list-style:none;display:grid;gap:12px}
.sector li{color:var(--muted);font-size:15px;padding-left:30px;position:relative}
.sector li::before{
  content:'✓';position:absolute;left:0;top:2px;width:20px;height:20px;
  background:var(--grad-primary);color:#fff;border-radius:50%;
  display:grid;place-items:center;font-size:11px;font-weight:900;
}

/* ===== Why IMI ===== */
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;position:relative;z-index:2}
.why-card{
  background:rgba(255,255,255,.06);backdrop-filter:blur(10px);
  padding:36px 26px;border-radius:18px;
  border:1px solid rgba(255,255,255,.12);text-align:center;transition:var(--trans);
  position:relative;overflow:hidden;
}
.why-card:hover{transform:translateY(-8px);border-color:rgba(255,255,255,.3);background:rgba(255,255,255,.1)}
.why-card .ico{
  width:70px;height:70px;border-radius:18px;margin:0 auto 20px;
  display:grid;place-items:center;color:#fff;font-size:30px;
}
.why-card:nth-child(1) .ico{background:var(--grad-navy);box-shadow:0 12px 28px rgba(30,58,111,.5)}
.why-card:nth-child(2) .ico{background:var(--grad-red);box-shadow:0 12px 28px rgba(220,38,38,.5)}
.why-card:nth-child(3) .ico{background:var(--grad-bright);box-shadow:0 12px 28px rgba(74,123,196,.5)}
.why-card:nth-child(4) .ico{background:var(--grad-primary);box-shadow:0 12px 28px rgba(220,38,38,.5)}
.why-card:nth-child(5) .ico{background:var(--grad-deep);box-shadow:0 12px 28px rgba(153,27,27,.5)}
.why-card h4{color:#fff;font-size:17px;font-weight:700}

/* ===== Market context ===== */
.market-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px;max-width:1100px;margin:0 auto;position:relative;z-index:2}
.market-item{
  background:#fff;padding:28px;border-radius:14px;
  box-shadow:var(--shadow-sm);font-weight:600;transition:var(--trans);
  display:flex;align-items:center;gap:16px;border:1px solid var(--border);
  position:relative;overflow:hidden;
}
.market-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:5px}
.market-item:nth-child(1)::before{background:var(--grad-navy)}
.market-item:nth-child(2)::before{background:var(--grad-red)}
.market-item:nth-child(3)::before{background:var(--grad-primary)}
.market-item:nth-child(4)::before{background:var(--grad-bright)}
.market-item:nth-child(5)::before{background:var(--grad-deep)}
.market-item:hover{transform:translateX(8px);box-shadow:var(--shadow)}
.market-item i{
  width:46px;height:46px;border-radius:12px;display:grid;place-items:center;
  color:#fff;font-size:20px;flex-shrink:0;
}
.market-item:nth-child(1) i{background:var(--grad-navy)}
.market-item:nth-child(2) i{background:var(--grad-red)}
.market-item:nth-child(3) i{background:var(--grad-primary)}
.market-item:nth-child(4) i{background:var(--grad-bright)}
.market-item:nth-child(5) i{background:var(--grad-deep)}

/* ===== Testimonials ===== */
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:28px;position:relative;z-index:2}
.testimonial{
  background:#fff;padding:38px 32px;border-radius:var(--radius);
  box-shadow:var(--shadow);transition:var(--trans);
  position:relative;border:1px solid var(--border);
}
.testimonial::before{
  content:'"';position:absolute;top:-10px;right:28px;
  font-size:120px;font-family:Georgia,serif;line-height:1;font-weight:900;
  -webkit-background-clip:text;background-clip:text;color:transparent;opacity:.28;
}
.testimonial:nth-child(1)::before{background:var(--grad-navy);-webkit-background-clip:text;background-clip:text}
.testimonial:nth-child(2)::before{background:var(--grad-red);-webkit-background-clip:text;background-clip:text}
.testimonial:nth-child(3)::before{background:var(--grad-primary);-webkit-background-clip:text;background-clip:text}
.testimonial:nth-child(4)::before{background:var(--grad-bright);-webkit-background-clip:text;background-clip:text}
.testimonial:nth-child(5)::before{background:var(--grad-deep);-webkit-background-clip:text;background-clip:text}
.testimonial:nth-child(6)::before{background:var(--grad-reverse);-webkit-background-clip:text;background-clip:text}
.testimonial:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.testimonial .stars{color:#fbbf24;font-size:16px;margin-bottom:16px;letter-spacing:2px}
.testimonial .quote{color:var(--text);font-size:15.5px;line-height:1.75;margin-bottom:24px;position:relative;z-index:1}
.testimonial .author{display:flex;align-items:center;gap:14px;padding-top:20px;border-top:1px solid var(--border)}
.avatar{
  width:52px;height:52px;border-radius:50%;
  display:grid;place-items:center;color:#fff;font-weight:800;font-size:18px;flex-shrink:0;
}
.testimonial:nth-child(1) .avatar{background:var(--grad-navy)}
.testimonial:nth-child(2) .avatar{background:var(--grad-red)}
.testimonial:nth-child(3) .avatar{background:var(--grad-primary)}
.testimonial:nth-child(4) .avatar{background:var(--grad-bright)}
.testimonial:nth-child(5) .avatar{background:var(--grad-deep)}
.testimonial:nth-child(6) .avatar{background:var(--grad-reverse)}
.author-info strong{display:block;color:var(--ink);font-size:15px;font-weight:700}
.author-info span{color:var(--muted);font-size:13px}

/* ===== FAQ ===== */
.faq{max-width:860px;margin:0 auto;position:relative;z-index:2}
.faq-item{
  background:#fff;border:1px solid var(--border);border-radius:14px;
  margin-bottom:16px;overflow:hidden;transition:var(--trans);box-shadow:var(--shadow-sm);
}
.faq-item:hover{border-color:var(--red)}
.faq-item.active{border-color:var(--red);box-shadow:0 12px 30px rgba(220,38,38,.15)}
.faq-q{
  width:100%;padding:24px 28px;background:none;border:none;text-align:left;
  font-size:16px;font-weight:700;color:var(--ink);cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;gap:16px;font-family:inherit;
}
.faq-q::after{
  content:'+';font-size:22px;color:#fff;font-weight:400;flex-shrink:0;
  width:34px;height:34px;border-radius:50%;display:grid;place-items:center;
  background:var(--grad-primary);transition:var(--trans);line-height:1;
}
.faq-item.active .faq-q::after{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease;padding:0 28px;color:var(--muted);font-size:15px}
.faq-item.active .faq-a{max-height:400px;padding:0 28px 24px}

/* ===== CTA Banner ===== */
.cta-banner{
  background:var(--grad-hero);padding:80px 50px;border-radius:28px;
  text-align:center;color:#fff;box-shadow:0 30px 70px rgba(30,58,111,.35);
  position:relative;overflow:hidden;
}
.cta-banner::before{
  content:'';position:absolute;top:-50%;right:-20%;width:600px;height:600px;
  background:radial-gradient(circle,rgba(239,68,68,.4),transparent 60%);border-radius:50%;
}
.cta-banner::after{
  content:'';position:absolute;bottom:-50%;left:-20%;width:500px;height:500px;
  background:radial-gradient(circle,rgba(74,123,196,.35),transparent 60%);border-radius:50%;
}
.cta-banner h2{font-size:clamp(28px,3.4vw,42px);margin-bottom:16px;position:relative;z-index:2;font-weight:900}
.cta-banner p{font-size:18px;margin-bottom:34px;opacity:.95;position:relative;z-index:2}
.cta-banner .btn{position:relative;z-index:2}

/* ===== Contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:50px;position:relative;z-index:2}
.contact-info h3{
  font-size:30px;margin-bottom:14px;font-weight:900;
  background:var(--grad-primary);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.contact-info > p{color:var(--muted);margin-bottom:34px;font-size:16px}
.contact-item{display:flex;align-items:flex-start;gap:18px;padding:20px 0;border-bottom:1px solid var(--border)}
.contact-item:last-child{border-bottom:none}
.contact-item .ico{
  width:52px;height:52px;border-radius:14px;flex-shrink:0;
  display:grid;place-items:center;color:#fff;font-size:20px;
}
.contact-item:nth-of-type(1) .ico{background:var(--grad-navy);box-shadow:0 8px 20px rgba(30,58,111,.35)}
.contact-item:nth-of-type(2) .ico{background:linear-gradient(135deg,#25d366,#128c7e);box-shadow:0 8px 20px rgba(37,211,102,.35)}
.contact-item:nth-of-type(3) .ico{background:var(--grad-red);box-shadow:0 8px 20px rgba(220,38,38,.35)}
.contact-item:nth-of-type(4) .ico{background:var(--grad-bright);box-shadow:0 8px 20px rgba(74,123,196,.35)}
.contact-item strong{display:block;color:var(--ink);font-size:15px;margin-bottom:4px;font-weight:700}
.contact-item a,.contact-item span{color:var(--muted);font-size:14px;word-break:break-all;transition:var(--trans)}
.contact-item a:hover{color:var(--red)}
.socials{display:flex;gap:14px;margin-top:30px}
.socials a{
  width:48px;height:48px;border-radius:14px;color:#fff;
  display:grid;place-items:center;transition:var(--trans);font-size:20px;
}
.socials a:nth-child(1){background:linear-gradient(135deg,#0077b5,#00a0dc)}
.socials a:nth-child(2){background:linear-gradient(135deg,#25d366,#128c7e)}
.socials a:nth-child(3){background:var(--grad-primary)}
.socials a:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 10px 24px rgba(0,0,0,.2)}

.contact-form{
  background:#fff;padding:46px;border-radius:24px;
  box-shadow:var(--shadow-lg);border:1px solid var(--border);
  position:relative;overflow:hidden;
}
.contact-form::before{content:'';position:absolute;top:0;left:0;right:0;height:6px;background:var(--grad-hero)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-size:14px;font-weight:700;color:var(--ink);margin-bottom:8px}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:14px 18px;border:2px solid var(--border);
  border-radius:12px;font-size:15px;font-family:inherit;color:var(--text);
  background:#f8fafc;transition:var(--trans);
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  outline:none;border-color:var(--red);background:#fff;
  box-shadow:0 0 0 4px rgba(220,38,38,.15);
}
.form-group textarea{resize:vertical;min-height:130px}
.form-group .err{color:#dc2626;font-size:13px;margin-top:6px;display:none;font-weight:500}
.form-group.invalid input,.form-group.invalid select,.form-group.invalid textarea{border-color:#dc2626;background:#fef2f2}
.form-group.invalid .err{display:block}
.form-msg{padding:16px;border-radius:12px;margin-bottom:18px;font-size:14px;display:none;font-weight:500}
.form-msg.success{display:block;background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#047857;border:1px solid #86efac}

.map-wrap{margin-top:60px;border-radius:24px;overflow:hidden;box-shadow:var(--shadow-lg);height:420px;border:6px solid #fff;position:relative;z-index:2}
.map-wrap iframe{width:100%;height:100%;border:none}

/* ===== Footer ===== */
.footer{
  background:linear-gradient(135deg,#0a1633 0%,#13264d 100%);
  color:rgba(255,255,255,.78);padding:80px 0 30px;
  position:relative;overflow:hidden;
}
.footer::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:var(--grad-primary)}
.footer::after{
  content:'';position:absolute;bottom:-200px;right:-100px;width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(220,38,38,.15),transparent 60%);
}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:44px;margin-bottom:50px;position:relative;z-index:2}
.footer-brand .logo{color:#fff;margin-bottom:20px}
.footer-brand .logo span:last-child{
  background:linear-gradient(90deg,#ffffff,#f87171);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.footer-brand p{font-size:14px;line-height:1.75;margin-bottom:24px}
.footer h5{
  color:#fff;font-size:15px;font-weight:800;margin-bottom:22px;
  text-transform:uppercase;letter-spacing:1.5px;position:relative;padding-bottom:12px;
}
.footer h5::after{content:'';position:absolute;bottom:0;left:0;width:40px;height:3px;border-radius:2px;background:var(--grad-primary)}
.footer ul{list-style:none;display:grid;gap:12px}
.footer ul a{font-size:14px;transition:var(--trans)}
.footer ul a:hover{color:#f87171;padding-left:6px}
.footer-bottom{padding-top:28px;border-top:1px solid rgba(255,255,255,.1);text-align:center;font-size:13px;color:rgba(255,255,255,.55);position:relative;z-index:2}

/* ===== WhatsApp floater ===== */
.wa-float{
  position:fixed;bottom:30px;right:30px;z-index:999;
  width:64px;height:64px;border-radius:50%;
  background:linear-gradient(135deg,#25d366,#128c7e);color:#fff;
  display:grid;place-items:center;font-size:32px;
  box-shadow:0 14px 36px rgba(37,211,102,.55);
  transition:var(--trans);animation:pulse-wa 2.5s infinite;
}
.wa-float:hover{transform:scale(1.15) rotate(10deg)}
@keyframes pulse-wa{
  0%,100%{box-shadow:0 14px 36px rgba(37,211,102,.55),0 0 0 0 rgba(37,211,102,.5)}
  50%{box-shadow:0 14px 36px rgba(37,211,102,.55),0 0 0 22px rgba(37,211,102,0)}
}

/* ===== Reveal Animations ===== */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s ease,transform .9s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ===== Responsive ===== */
@media (max-width:980px){
  .nav-links{
    position:fixed;top:112px;left:0;right:0;
    background:#fff;flex-direction:column;gap:0;
    padding:24px 0;box-shadow:0 10px 30px rgba(0,0,0,.1);
    transform:translateY(-150%);transition:var(--trans);
  }
  .nav-links.open{transform:translateY(0)}
  .nav-links li{width:100%;text-align:center}
  .nav-links a{display:block;padding:16px 20px}
  .burger{display:flex}
  .about-grid,.vm-grid,.sectors-grid,.contact-grid{grid-template-columns:1fr;gap:40px}
  .process{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .footer-brand{grid-column:1/-1}
  .form-row{grid-template-columns:1fr}
  section{padding:80px 0}
  .hero{min-height:auto;padding:140px 0 80px}
  .hero-stats{gap:30px}
  .cta-banner{padding:60px 30px}
}
@media (max-width:560px){
  .process{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .contact-form{padding:32px 24px}
  .vm-card{padding:36px 28px}
  .testimonial{padding:32px 26px}
}

/* ===== Footer logo larger ===== */
.footer-brand .logo{font-size:26px;gap:18px}
.footer-brand .logo-mark{width:110px;height:110px;border-radius:18px;padding:8px}

/* ===== How IMI Works diagram ===== */
.diagram-wrap{
  max-width:1000px;margin:56px auto 0;position:relative;z-index:2;
  background:#fff;padding:30px;border-radius:24px;
  box-shadow:0 30px 70px rgba(10,22,51,.25);
  border:1px solid rgba(255,255,255,.15);
}
.diagram-wrap img{
  width:100%;height:auto;display:block;border-radius:14px;
}
@media (max-width:560px){
  .nav{height:92px}
  .logo{font-size:17px;gap:12px}
  .logo-mark{width:76px;height:76px}
  .footer-brand .logo{font-size:22px}
  .footer-brand .logo-mark{width:90px;height:90px}
  .diagram-wrap{padding:16px;margin-top:40px}
}

/* ===== HyPure Nav Link ===== */
.nav-hypure{color:var(--red)!important;font-weight:700!important}
.nav-hypure::before{content:'⚡';margin-right:4px}

/* ===== Credibility Strip ===== */
.cred-strip{
  background:var(--ink);padding:22px 0;overflow:hidden;
  border-bottom:3px solid var(--red);
}
.cred-scroll{
  display:flex;gap:50px;animation:scroll-left 30s linear infinite;
  white-space:nowrap;
}
.cred-item{
  display:flex;align-items:center;gap:10px;
  color:rgba(255,255,255,.9);font-size:14px;font-weight:600;
  flex-shrink:0;
}
.cred-item i{
  color:var(--red-light);font-size:18px;
}
@keyframes scroll-left{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* ===== Two Verticals Section ===== */
.verticals-row{display:grid;grid-template-columns:1fr 1fr;gap:32px;position:relative;z-index:2}
.vertical-card{
  background:#fff;padding:44px 36px;border-radius:var(--radius);
  box-shadow:var(--shadow);border:1px solid var(--border);
  transition:var(--trans);position:relative;overflow:hidden;
}
.vertical-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:6px;
}
.vertical-card.v1::before{background:var(--grad-navy)}
.vertical-card.v2::before{background:var(--grad-red)}
.vertical-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-lg)}
.v-badge{
  display:inline-block;padding:6px 14px;border-radius:999px;
  background:var(--grad-navy);color:#fff;font-size:11px;
  font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:20px;
}
.v-badge-red{background:var(--grad-red)}
.v-icon{
  width:70px;height:70px;border-radius:18px;
  background:var(--grad-navy);color:#fff;
  display:grid;place-items:center;font-size:30px;margin-bottom:20px;
  box-shadow:0 12px 28px rgba(30,58,111,.4);
}
.v-icon-red{background:var(--grad-red);box-shadow:0 12px 28px rgba(220,38,38,.4)}
.vertical-card h3{font-size:24px;color:var(--ink);margin-bottom:10px;font-weight:900}
.vertical-card > p{color:var(--muted);font-size:15px;margin-bottom:18px;font-weight:500}
.vertical-card ul{list-style:none;display:grid;gap:10px;margin-bottom:8px}
.vertical-card li{color:var(--muted);font-size:14px;padding-left:24px;position:relative}
.vertical-card.v1 li::before{
  content:'✓';position:absolute;left:0;top:1px;width:18px;height:18px;
  background:var(--grad-navy);color:#fff;border-radius:50%;
  display:grid;place-items:center;font-size:10px;font-weight:900;
}
.vertical-card.v2 li::before{
  content:'✓';position:absolute;left:0;top:1px;width:18px;height:18px;
  background:var(--grad-red);color:#fff;border-radius:50%;
  display:grid;place-items:center;font-size:10px;font-weight:900;
}

/* ===== HyPure Showcase Section ===== */
.hypure-hero-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;
  position:relative;z-index:2;
}
.hypure-img-wrap{
  background:rgba(255,255,255,.05);border-radius:24px;padding:24px;
  border:1px solid rgba(255,255,255,.1);
}
.hypure-img-wrap img{width:100%;border-radius:16px}
.hypure-info h3{color:#fff;font-size:28px;margin-bottom:14px;font-weight:900}
.hypure-info p{color:rgba(255,255,255,.85);margin-bottom:20px;font-size:16px}
.hypure-features{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px;
}
.hypure-features div{
  background:rgba(255,255,255,.08);padding:14px 12px;border-radius:12px;
  border:1px solid rgba(255,255,255,.12);text-align:center;
  transition:var(--trans);
}
.hypure-features div:hover{background:rgba(255,255,255,.14);transform:translateY(-3px)}
.hypure-features i{display:block;font-size:20px;margin-bottom:8px;color:#fbbf24}
.hypure-features span{color:#fff;font-size:12px;font-weight:600}
.hypure-apps{display:flex;flex-wrap:wrap;gap:8px}
.hypure-apps span{
  padding:8px 16px;border-radius:999px;font-size:13px;font-weight:600;
  background:rgba(255,255,255,.1);color:rgba(255,255,255,.9);
  border:1px solid rgba(255,255,255,.2);
}

/* ===== HyPure Page Hero ===== */
.hypure-page-hero{
  background:
    radial-gradient(circle at 80% 40%,rgba(239,68,68,.3),transparent 50%),
    radial-gradient(circle at 20% 70%,rgba(74,123,196,.3),transparent 50%),
    var(--grad-hero);
}

/* ===== Specs Table ===== */
.specs-table-wrap{max-width:900px;margin:0 auto;overflow-x:auto;position:relative;z-index:2}
.specs-table{
  width:100%;border-collapse:separate;border-spacing:0;
  border-radius:16px;overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.specs-table thead{background:var(--grad-hero)}
.specs-table th{
  padding:20px 24px;color:#fff;font-weight:700;font-size:16px;
  text-align:center;
}
.specs-table th:first-child{text-align:left}
.specs-table td{
  padding:16px 24px;background:#fff;border-bottom:1px solid var(--border);
  text-align:center;font-size:15px;color:var(--text);
}
.specs-table td:first-child{
  text-align:left;font-weight:600;color:var(--ink);background:#fafbfc;
}
.specs-table tr.highlight td{
  background:linear-gradient(135deg,rgba(220,38,38,.05),rgba(30,58,111,.05));
  font-weight:700;color:var(--red-dark);
}
.specs-table tbody tr:hover td{background:rgba(30,58,111,.04)}

/* ===== Responsive additions ===== */
@media (max-width:980px){
  .verticals-row{grid-template-columns:1fr}
  .hypure-hero-grid{grid-template-columns:1fr;gap:36px}
  .hypure-features{grid-template-columns:repeat(2,1fr)}
  .cred-scroll{animation-duration:20s}
}
@media (max-width:560px){
  .hypure-features{grid-template-columns:1fr 1fr}
  .specs-table th,.specs-table td{padding:12px 14px;font-size:13px}
  .vertical-card{padding:32px 24px}
}

/* ===== Hero Carousel ===== */
.hero-carousel{position:relative;min-height:70vh}
.hero-slide{
  position:absolute;inset:0;opacity:0;
  transition:opacity .8s ease,transform .6s ease;
  display:flex;align-items:center;
  transform:translateX(30px);pointer-events:none;
}
.hero-slide.active{opacity:1;transform:translateX(0);position:relative;pointer-events:all}
.hero-dots{
  display:flex;gap:10px;justify-content:center;
  position:relative;z-index:10;margin-top:30px;
}
.hero-dot{
  width:40px;height:5px;border-radius:3px;border:none;cursor:pointer;
  background:rgba(255,255,255,.3);transition:var(--trans);
}
.hero-dot.active{background:#fff;width:60px}
.hero-arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:10;
  width:50px;height:50px;border-radius:50%;border:2px solid rgba(255,255,255,.3);
  background:rgba(255,255,255,.1);backdrop-filter:blur(10px);
  color:#fff;font-size:18px;cursor:pointer;transition:var(--trans);
  display:grid;place-items:center;
}
.hero-arrow:hover{background:rgba(255,255,255,.25);border-color:#fff}
.hero-prev{left:24px}
.hero-next{right:24px}

/* 3 verticals grid */
.verticals-row{grid-template-columns:repeat(3,1fr)!important}

/* Zero Waste nav link */
.nav-zw{color:#059669!important;font-weight:700!important}
.nav-zw::before{content:'🌿';margin-right:4px;font-size:12px}

/* Zero Waste hero */
.zw-hero{
  background:
    radial-gradient(circle at 20% 40%,rgba(16,185,129,.35),transparent 50%),
    radial-gradient(circle at 80% 70%,rgba(30,58,111,.35),transparent 50%),
    var(--grad-hero);
}

@media (max-width:980px){
  .verticals-row{grid-template-columns:1fr!important}
  .hero-arrow{display:none}
  .hero-carousel{min-height:auto}
  .process{grid-template-columns:repeat(2,1fr)!important}
}

/* ===== Full-width hero carousel fix ===== */
.hero-carousel{position:relative;min-height:72vh;display:flex;flex-direction:column;justify-content:center}
.hero-slide{
  position:absolute;inset:0;opacity:0;
  transition:opacity .8s ease,transform .6s ease;
  display:flex;align-items:center;
  transform:translateX(40px);pointer-events:none;
}
.hero-slide.active{opacity:1;transform:translateX(0);position:relative;pointer-events:all}
.hero .hero-stats{position:relative;z-index:5}
@media(max-width:980px){.hero-carousel{min-height:auto}}

/* ===== FINAL: Full-screen carousel override ===== */
.hero{padding-bottom:80px}
.hero-carousel{position:relative;width:100%}
.hero-slide{
  position:absolute;inset:0;opacity:0;pointer-events:none;
  display:flex;align-items:center;
  transition:opacity .8s ease,transform .8s ease;
  transform:scale(.97);
}
.hero-slide.active{opacity:1;position:relative;pointer-events:all;transform:scale(1)}
.hero-slide .hero-inner{max-width:900px;width:100%}
.hero-dots{position:relative;z-index:10;display:flex;gap:12px;justify-content:center;margin-top:40px}
.hero-dot{width:50px;height:5px;border-radius:3px;border:none;cursor:pointer;background:rgba(255,255,255,.25);transition:.3s}
.hero-dot.active{background:#fff;width:70px}
.hero-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:54px;height:54px;border-radius:50%;border:2px solid rgba(255,255,255,.25);background:rgba(0,0,0,.2);backdrop-filter:blur(10px);color:#fff;font-size:20px;cursor:pointer;display:grid;place-items:center;transition:.3s}
.hero-arrow:hover{background:rgba(255,255,255,.2);border-color:#fff}
.hero-prev{left:20px}
.hero-next{right:20px}
@media(max-width:980px){.hero-arrow{display:none}}
