/* =====================================================
   Devonstank IT Services — Landing CSS
   Brand: blue #1A4F9C  /  green #3DA84A
   ===================================================== */

:root{
  --blue:#1A4F9C;
  --blue-deep:#0E3673;
  --blue-soft:#E8F0FB;
  --green:#3DA84A;
  --green-soft:#E8F6EA;
  --ink:#0B1B3A;
  --ink-2:#1F2E50;
  --muted:#5B6B8C;
  --line:#E4EAF3;
  --bg:#FFFFFF;
  --bg-2:#F5F8FE;
  --bg-3:#F0F4FB;
  --radius:18px;
  --radius-lg:28px;
  --shadow-sm:0 4px 14px rgba(13,32,76,.06);
  --shadow:0 18px 50px rgba(13,32,76,.12);
  --shadow-lg:0 30px 80px rgba(13,32,76,.18);
  --font:"Inter","Manrope",system-ui,-apple-system,sans-serif;
  --display:"Manrope","Inter",sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font);
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none}

.container{width:100%;max-width:1240px;margin:0 auto;padding:0 28px}

/* =============== Buttons =============== */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;border-radius:999px;
  font-weight:600;font-size:15px;letter-spacing:.01em;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease;
  white-space:nowrap;
}
.btn-primary{
  background:linear-gradient(135deg,var(--blue) 0%,var(--blue-deep) 100%);
  color:#fff;box-shadow:0 10px 24px rgba(26,79,156,.32);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(26,79,156,.42)}
.btn-ghost{color:var(--blue);border:1.5px solid rgba(26,79,156,.25)}
.btn-ghost:hover{background:var(--blue-soft);border-color:var(--blue)}
.btn-lg{padding:18px 34px;font-size:16px}

/* =============== Header — bulletproof =============== */
.nav-wrap{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:#ffffff;
  border-bottom:1px solid var(--line);
}
.nav-wrap.scrolled{box-shadow:0 6px 18px rgba(11,27,58,.06)}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  height:72px;gap:16px;min-width:0;
}
.nav-logo{
  display:flex;align-items:center;flex:0 0 auto;
  text-decoration:none;line-height:0;
  max-width:60vw;
}
.nav-logo img{
  height:48px;width:auto;max-width:100%;
  object-fit:contain;display:block;
  transition:transform .25s ease;
}
.nav-logo:hover img{transform:scale(1.04)}

/* Desktop links */
.nav-links{
  display:flex;align-items:center;gap:28px;flex-wrap:nowrap;
}
.nav-links a{
  font-family:var(--font);
  font-size:14px;font-weight:500;color:var(--ink-2);
  position:relative;padding:6px 0;text-decoration:none;
}
.nav-links a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:2px;
  background:linear-gradient(90deg,var(--blue),var(--green));
  transform:scaleX(0);transform-origin:left;transition:transform .3s ease;
}
.nav-links a:hover{color:var(--blue)}
.nav-links a:hover::after,
.nav-links a.active::after{transform:scaleX(1)}

.nav-cta{display:flex;align-items:center;gap:12px;flex:0 0 auto}

.nav-toggle{
  display:none;width:42px;height:42px;
  flex-direction:column;justify-content:center;align-items:center;gap:5px;
  background:transparent;border:1px solid var(--line);border-radius:10px;
  padding:0;cursor:pointer;flex:0 0 auto;
}
.nav-toggle span{
  width:20px;height:2px;background:var(--ink);border-radius:2px;
  transition:transform .3s ease, opacity .2s ease;
}

/* =============== Hero =============== */
.hero{
  position:relative;
  padding:160px 0 90px;
  background:
    radial-gradient(1100px 540px at 85% -10%, rgba(61,168,74,.10), transparent 60%),
    radial-gradient(900px 600px at -10% 30%, rgba(26,79,156,.10), transparent 60%),
    linear-gradient(180deg,#fff 0%, var(--bg-2) 100%);
  overflow:hidden;
}
.hero-grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 16px;border-radius:999px;
  background:var(--blue-soft);color:var(--blue);
  font-weight:600;font-size:13px;letter-spacing:.05em;text-transform:uppercase;
}
.eyebrow.blue{background:linear-gradient(135deg,#fff,#fff);border:1px solid var(--line);color:var(--blue)}
.eyebrow.blue img{height:14px}
.hero-copy h1{
  font-family:var(--display);
  font-size:clamp(40px,5.4vw,68px);
  line-height:1.05;letter-spacing:-.02em;
  margin:18px 0 22px;font-weight:800;color:var(--ink);
}
.hero-copy h1 em{
  font-style:normal;
  background:linear-gradient(135deg,var(--blue) 0%,var(--green) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  position:relative;
}
.lede{font-size:18px;color:var(--muted);max-width:560px;margin:0 0 30px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:36px}
.hero-meta{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(3,auto);gap:36px;
}
.hero-meta li{display:flex;flex-direction:column}
.hero-meta strong{font-family:var(--display);font-size:26px;color:var(--blue);font-weight:800}
.hero-meta span{font-size:13px;color:var(--muted)}

.hero-art{position:relative}
.hero-art-frame{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-lg);aspect-ratio:4/3;
  transform:rotate(-1deg);
}
.hero-art-frame img{width:100%;height:100%;object-fit:cover}
.hero-badge{
  position:absolute;bottom:-22px;left:-22px;
  background:#fff;border-radius:18px;padding:14px;box-shadow:var(--shadow);
  transform:rotate(2deg);
}
.hero-badge img{height:90px;width:auto}
.hero-pulse{
  position:absolute;top:-22px;right:-22px;width:94px;height:94px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--blue),var(--green));
  display:grid;place-items:center;color:#fff;font-weight:700;font-size:12px;
  box-shadow:0 18px 40px rgba(61,168,74,.4);
  animation:pulse 3s ease-in-out infinite;
}
.hero-pulse::after{content:"NEW\A 2026 →";white-space:pre;text-align:center;line-height:1.2}
@keyframes pulse{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.06)}
}

/* =============== Trusted by =============== */
.trusted{padding:64px 0 40px;background:#fff}
.section-title-sm{
  font-family:var(--display);
  font-size:clamp(20px,2.2vw,26px);
  font-weight:600;color:var(--ink-2);text-align:center;margin:0 0 36px;
}
.logo-row{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(10,1fr);gap:30px;
  align-items:center;
}
.logo-row.tight{grid-template-columns:repeat(8,1fr);gap:50px}
.logo-row li{display:flex;justify-content:center}
.logo-row img{
  height:38px;width:auto;max-width:120px;object-fit:contain;
  filter:grayscale(1) opacity(.62);
  transition:filter .3s ease, transform .3s ease;
}
.logo-row li:hover img{filter:none;transform:translateY(-2px)}

/* =============== Different =============== */
.different{padding:120px 0 100px;background:var(--bg-2)}
.different-head{max-width:980px;margin:0 auto 70px;text-align:center}
.different-head .eyebrow{
  background:#fff;color:var(--blue);border:1px solid var(--line);
  text-transform:none;font-weight:500;font-size:14px;
}
.different-head .eyebrow img{height:14px}
.different-head h2{
  font-family:var(--display);
  font-size:clamp(28px,3.6vw,48px);
  line-height:1.15;letter-spacing:-.02em;
  font-weight:700;margin:22px 0 22px;color:var(--ink);
}
.different-head h2 .accent{
  background:linear-gradient(135deg,var(--blue),var(--green));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.different-head p{color:var(--muted);font-size:17px;max-width:760px;margin:0 auto}
.stats{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
}
.stats li{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:36px 28px;text-align:center;box-shadow:var(--shadow-sm);
  transition:transform .35s ease, box-shadow .35s ease;
}
.stats li:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.stats span{
  display:block;font-family:var(--display);font-size:54px;font-weight:800;
  background:linear-gradient(135deg,var(--blue),var(--green));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  line-height:1;
}
.stats em{font-style:normal;font-size:38px;font-weight:700}
.stats p{margin:8px 0 0;color:var(--muted);font-weight:500}

/* =============== Section heads =============== */
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:44px;gap:24px;flex-wrap:wrap}
.section-title,.section-head h2{
  font-family:var(--display);
  font-size:clamp(30px,3.6vw,46px);
  font-weight:800;letter-spacing:-.02em;margin:0;color:var(--ink);
}
.section-title{text-align:center;margin:0 0 50px}
.section-title-lg{
  font-family:var(--display);
  font-size:clamp(30px,3.4vw,44px);line-height:1.2;
  font-weight:700;letter-spacing:-.01em;
  max-width:1000px;margin:0 auto 50px;text-align:center;color:var(--ink);
}
.section-title-lg .accent{
  background:linear-gradient(135deg,var(--blue),var(--green));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.link-arrow{color:var(--blue);font-weight:600;font-size:15px}
.link-arrow:hover{text-decoration:underline}

/* =============== Work =============== */
.work{padding:110px 0;background:#fff}
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.work-card{
  background:#fff;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);border:1px solid var(--line);
  display:flex;flex-direction:column;
  transition:transform .35s ease, box-shadow .35s ease;
}
.work-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.work-img{position:relative;aspect-ratio:16/10;overflow:hidden}
.work-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.work-card:hover .work-img img{transform:scale(1.06)}
.work-brand{
  position:absolute;left:18px;bottom:18px;
  background:#fff;border-radius:10px;padding:8px 12px;box-shadow:var(--shadow-sm);
  display:inline-flex;align-items:center;
}
.work-brand img{height:26px;width:auto;max-width:110px;object-fit:contain}
.work-body{padding:26px}
.work-body h3{
  display:flex;align-items:flex-start;gap:10px;
  font-family:var(--display);font-size:20px;line-height:1.3;font-weight:700;
  margin:0 0 12px;color:var(--ink);
}
.work-body h3 img{height:18px;margin-top:6px;flex-shrink:0}
.work-body p{color:var(--muted);margin:0;font-size:15px}

/* =============== Services =============== */
.services{padding:110px 0;background:var(--bg-2)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc{
  background:#fff;border-radius:var(--radius);padding:34px 28px;
  border:1px solid var(--line);box-shadow:var(--shadow-sm);
  transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;
  position:relative;overflow:hidden;
}
.svc::before{
  content:"";position:absolute;inset:auto -40% -40% auto;width:200px;height:200px;
  background:radial-gradient(circle,rgba(26,79,156,.08),transparent 70%);
  transition:transform .5s ease;
}
.svc:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:rgba(26,79,156,.2)}
.svc:hover::before{transform:translate(-30px,-30px) scale(1.4)}
.svc-icon{
  width:64px;height:64px;border-radius:14px;
  background:linear-gradient(135deg,var(--blue-soft),var(--green-soft));
  display:grid;place-items:center;margin-bottom:20px;
}
.svc-icon img{height:34px;width:auto}
.svc h3{font-family:var(--display);font-size:20px;margin:0 0 10px;font-weight:700;color:var(--ink)}
.svc p{color:var(--muted);margin:0;font-size:15px}

/* =============== Tech =============== */
.tech{padding:64px 0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* =============== Framework =============== */
.framework{padding:120px 0;background:linear-gradient(180deg,#fff 0%, var(--bg-3) 100%)}
.framework-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:center}
.framework-left .lede{font-size:22px;color:var(--ink);font-weight:600;line-height:1.4;margin:18px 0 28px}
.framework-right h2{
  font-family:var(--display);
  font-size:clamp(26px,2.8vw,38px);
  font-weight:800;margin:0 0 24px;color:var(--ink);
}
.framework-right h2 .accent{
  background:linear-gradient(135deg,var(--blue),var(--green));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.framework-card{
  background:#fff;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow);display:grid;grid-template-columns:1fr 1.2fr;
  border:1px solid var(--line);
}
.framework-img{aspect-ratio:4/5}
.framework-img img{width:100%;height:100%;object-fit:cover}
.framework-body{padding:32px 30px}
.framework-body h3{font-family:var(--display);font-size:22px;margin:0 0 16px;font-weight:700}
.framework-body ul{padding:0;margin:0;list-style:none}
.framework-body li{
  padding:12px 0 12px 30px;border-bottom:1px dashed var(--line);
  position:relative;color:var(--ink-2);font-weight:500;
}
.framework-body li:last-child{border-bottom:none}
.framework-body li::before{
  content:"";position:absolute;left:0;top:18px;width:18px;height:18px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue),var(--green));
}

/* =============== About =============== */
.about{padding:120px 0;background:#fff}
.about-marquee{overflow:hidden;margin:0 -28px 70px;mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{
  list-style:none;padding:0;margin:0;display:flex;gap:24px;
  animation:marquee 38s linear infinite;width:max-content;
}
.marquee-track li{flex:0 0 auto;width:320px;aspect-ratio:4/5;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}
.marquee-track li img{width:100%;height:100%;object-fit:cover}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
.principles{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.principle{position:relative;padding:34px 0 0;border-top:2px solid var(--ink)}
.principle .step{font-family:var(--display);font-size:14px;color:var(--blue);font-weight:600;letter-spacing:.06em}
.principle h3{font-family:var(--display);font-size:22px;margin:10px 0 12px;font-weight:700;color:var(--ink)}
.principle p{color:var(--muted);font-size:15px;margin:0}

/* =============== Testimonials =============== */
.testimonials{padding:100px 0;background:var(--ink);color:#fff;position:relative;overflow:hidden}
.testimonials::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(800px 400px at 80% 0%,rgba(61,168,74,.18),transparent 60%);
}
.t-carousel{position:relative;display:flex;align-items:center;gap:18px}
.t-viewport{flex:1;overflow:hidden}
.t-track{
  list-style:none;padding:0;margin:0;display:flex;
  transition:transform .6s cubic-bezier(.7,.2,.2,1);
}
.t-track li{flex:0 0 100%;padding:0 60px;text-align:center}
.t-track h3{
  font-family:var(--display);font-size:14px;letter-spacing:.2em;font-weight:600;
  color:var(--green);text-transform:uppercase;margin:0 0 22px;
}
.t-track p{
  font-family:var(--display);font-size:clamp(20px,2.4vw,32px);
  line-height:1.4;font-weight:600;color:#fff;max-width:920px;margin:0 auto;
}
.t-arrow{
  width:54px;height:54px;border-radius:50%;color:#fff;
  background:rgba(255,255,255,.08);font-size:24px;display:grid;place-items:center;
  transition:background .25s ease;flex-shrink:0;
}
.t-arrow:hover{background:rgba(255,255,255,.18)}

/* =============== Awards =============== */
.awards{padding:120px 0;background:var(--bg-2)}
.awards-grid{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
}
.awards-grid li{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 22px;text-align:center;box-shadow:var(--shadow-sm);
  transition:transform .35s ease, box-shadow .35s ease;
}
.awards-grid li:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.awards-grid img{height:110px;width:auto;object-fit:contain;margin:0 auto 16px}
.awards-grid h3{font-family:var(--display);font-size:15px;font-weight:600;margin:0;color:var(--ink-2)}

/* =============== Insights =============== */
.insights{padding:110px 0;background:#fff}
.insights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.insight{
  display:block;border-radius:var(--radius);overflow:hidden;
  background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm);
  transition:transform .35s ease, box-shadow .35s ease;
}
.insight:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.insight-img{aspect-ratio:16/10;overflow:hidden}
.insight-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.insight:hover .insight-img img{transform:scale(1.06)}
.insight h3{font-family:var(--display);font-size:18px;margin:22px 24px 8px;font-weight:700;line-height:1.35}
.insight p{color:var(--muted);font-size:14px;margin:0 24px 26px}

/* =============== CTA =============== */
.cta{
  padding:120px 0;color:#fff;position:relative;overflow:hidden;
  background:
    radial-gradient(700px 400px at 90% 100%,rgba(61,168,74,.30),transparent 60%),
    linear-gradient(135deg,#0E3673 0%, var(--blue) 60%, #1A4F9C 100%);
}
.cta-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center;position:relative;z-index:1}
.cta-left h2{
  font-family:var(--display);
  font-size:clamp(40px,5.2vw,72px);
  line-height:1.02;letter-spacing:-.02em;font-weight:800;margin:0;
}
.cta-left h2 span{display:block}
.cta-left h2 span:nth-child(2){color:rgba(255,255,255,.7)}
.cta-left h2 span:nth-child(3){
  background:linear-gradient(135deg,#fff,var(--green));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.cta-right{position:relative;padding-left:60px}
.cta-arrow{position:absolute;left:0;top:-30px;height:90px;width:auto;filter:invert(1) opacity(.7)}
.cta-right p{font-size:18px;color:rgba(255,255,255,.85);margin:0 0 24px}
.cta-right .btn-primary{
  background:#fff;color:var(--blue);box-shadow:0 14px 30px rgba(0,0,0,.2);
}
.cta-right .btn-primary:hover{background:var(--green);color:#fff}

/* =============== Footer =============== */
.footer{background:#0A1530;color:#C7D1E6;padding:80px 0 0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-brand img{height:64px;width:auto;margin-bottom:18px}
.footer-brand p{margin:0;color:#8A9BBC;max-width:340px}
.footer-col h4{font-family:var(--display);color:#fff;font-size:15px;letter-spacing:.04em;text-transform:uppercase;margin:0 0 18px}
.footer-col ul:not(.socials){list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.footer-col a{color:#C7D1E6;font-size:15px;transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-col ul.socials{
  list-style:none;padding:0;margin:0 0 22px;
  display:flex;flex-direction:row;flex-wrap:wrap;gap:12px;
}
.socials li{display:inline-flex}
.socials a{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:50%;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  transition:background .25s ease, border-color .25s ease, transform .25s ease;
}
.socials a:hover{background:rgba(61,168,74,.18);border-color:var(--green);transform:translateY(-2px)}
.socials img{
  width:20px;height:20px;border-radius:0;background:none;padding:0;
  object-fit:contain;filter:brightness(0) invert(1);
}
.socials svg{
  width:18px;height:18px;color:#fff;
  transition:color .25s ease;
}
.socials a:hover svg{color:var(--green)}
.rating{display:flex;align-items:center;gap:8px;color:#fff;font-weight:600}
.rating img{height:20px;width:auto}
.rating .stars{height:14px}
.footer-bottom{padding:24px 0;background:#080F22}
.footer-bottom .container{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.footer-bottom p{margin:0;font-size:13px;color:#8A9BBC}
.footer-bottom ul{display:flex;gap:22px;list-style:none;padding:0;margin:0}
.footer-bottom a{color:#8A9BBC;font-size:13px}
.footer-bottom a:hover{color:#fff}

/* =============== Reveal animation =============== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}

/* =============== Industries pills =============== */
.industries{
  list-style:none;padding:0;margin:0;
  display:flex;flex-wrap:wrap;justify-content:center;gap:12px 14px;
}
.industries li{
  padding:10px 22px;border-radius:999px;
  border:1px solid var(--line);background:#fff;color:var(--ink-2);
  font-weight:500;font-size:15px;box-shadow:var(--shadow-sm);
  transition:transform .25s ease, border-color .25s ease, color .25s ease;
}
.industries li:hover{transform:translateY(-2px);border-color:var(--blue);color:var(--blue)}

/* =============== Work brand text replacement =============== */
.work-brand-text{
  position:absolute;left:18px;bottom:18px;
  background:#fff;border-radius:10px;padding:8px 14px;
  box-shadow:var(--shadow-sm);
  font-family:var(--display);font-weight:700;font-size:13px;color:var(--blue);
  letter-spacing:.02em;
}

/* =============== Clutch band =============== */
.clutch{padding:80px 0;background:var(--bg-2)}
.clutch-band{
  display:flex;align-items:center;justify-content:space-between;gap:30px;
  padding:30px 40px;border-radius:var(--radius-lg);
  background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);
  flex-wrap:wrap;
}
.clutch-left{display:flex;align-items:center;gap:20px}
.clutch-left img{height:54px;width:auto}
.clutch-left h3{font-family:var(--display);font-size:22px;margin:0 0 4px;color:var(--ink)}
.clutch-left p{margin:0;color:var(--muted);font-size:15px;max-width:520px}

/* =============== Footer contact list =============== */
.footer-contact{
  list-style:none;padding:0;margin:20px 0 0;
  display:flex;flex-direction:column;gap:10px;
}
.footer-contact li{display:flex;align-items:center;gap:10px;color:#C7D1E6;font-size:14px}
.footer-contact span{
  width:26px;height:26px;border-radius:6px;display:grid;place-items:center;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);
  font-size:13px;
}
.footer-contact a{color:#C7D1E6;transition:color .2s}
.footer-contact a:hover{color:#fff}
.clutch-pill{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 16px;border-radius:999px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  color:#fff;font-weight:600;font-size:14px;
  transition:background .25s, border-color .25s;
}
.clutch-pill:hover{background:rgba(61,168,74,.18);border-color:var(--green);color:#fff}
.clutch-pill img{height:20px;width:auto;filter:brightness(1.2)}

/* =============== Page hero (subpages) =============== */
.page-hero{
  position:relative;padding:170px 0 80px;
  background:
    radial-gradient(800px 400px at 90% 0%,rgba(61,168,74,.10),transparent 60%),
    radial-gradient(800px 500px at -10% 30%,rgba(26,79,156,.10),transparent 60%),
    linear-gradient(180deg,#fff 0%, var(--bg-2) 100%);
  overflow:hidden;text-align:center;
}
.page-hero .eyebrow{margin-bottom:18px}
.page-hero h1{
  font-family:var(--display);
  font-size:clamp(38px,5vw,64px);
  line-height:1.05;letter-spacing:-.02em;font-weight:800;margin:0 0 18px;
}
.page-hero p{font-size:18px;color:var(--muted);max-width:720px;margin:0 auto 28px}
.page-hero .breadcrumbs{
  display:flex;justify-content:center;gap:8px;font-size:13px;
  color:var(--muted);margin-bottom:14px;
}
.page-hero .breadcrumbs a{color:var(--blue)}

/* =============== Generic content sections =============== */
.section{padding:90px 0}
.section.alt{background:var(--bg-2)}
.section h2{
  font-family:var(--display);font-size:clamp(28px,3.4vw,42px);
  font-weight:800;letter-spacing:-.02em;margin:0 0 18px;line-height:1.15;
}
.section .lead{font-size:18px;color:var(--muted);max-width:760px;margin:0 0 36px}
.section.center{text-align:center}
.section.center .lead{margin-left:auto;margin-right:auto}

.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.feature{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 26px;box-shadow:var(--shadow-sm);
  transition:transform .35s ease, box-shadow .35s ease;
}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.feature-icon{
  width:54px;height:54px;border-radius:12px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--blue-soft),var(--green-soft));
  margin-bottom:16px;font-size:24px;
}
.feature h3{font-family:var(--display);font-size:18px;margin:0 0 8px;font-weight:700}
.feature p{margin:0;color:var(--muted);font-size:15px}

.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split img{border-radius:var(--radius-lg);box-shadow:var(--shadow)}
.split h2{margin-bottom:14px}
.split ul{padding:0;margin:18px 0 0;list-style:none}
.split li{
  padding:10px 0 10px 28px;position:relative;color:var(--ink-2);
  border-bottom:1px dashed var(--line);
}
.split li:last-child{border-bottom:none}
.split li::before{
  content:"";position:absolute;left:0;top:16px;width:14px;height:14px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue),var(--green));
}

.callout{
  background:linear-gradient(135deg,var(--blue) 0%, var(--blue-deep) 100%);
  color:#fff;border-radius:var(--radius-lg);
  padding:50px 60px;display:flex;align-items:center;justify-content:space-between;
  gap:30px;flex-wrap:wrap;box-shadow:var(--shadow-lg);
}
.callout h3{font-family:var(--display);font-size:clamp(22px,2.4vw,30px);margin:0 0 6px;font-weight:800}
.callout p{margin:0;opacity:.85}
.callout .btn-primary{background:#fff;color:var(--blue)}
.callout .btn-primary:hover{background:var(--green);color:#fff}

/* =============== Blog =============== */
.blog{padding:100px 0;background:#fff}
.blog-hero{padding:160px 0 60px;background:linear-gradient(180deg,#fff,var(--bg-2))}
.blog-hero .meta{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}
.blog-hero h1{font-family:var(--display);font-size:clamp(34px,4.4vw,56px);line-height:1.1;letter-spacing:-.02em;margin:0 0 18px;font-weight:800}
.blog-hero p.lede{font-size:19px;color:var(--muted);max-width:780px}
.blog-cover{margin:40px auto 0;max-width:1080px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:21/9}
.blog-cover img{width:100%;height:100%;object-fit:cover}

.article{max-width:780px;margin:0 auto;font-size:17px;color:var(--ink-2);line-height:1.75}
.article h2{font-family:var(--display);font-size:30px;font-weight:800;letter-spacing:-.01em;margin:42px 0 14px;color:var(--ink)}
.article h3{font-family:var(--display);font-size:22px;font-weight:700;margin:32px 0 10px}
.article p{margin:0 0 18px}
.article ul,.article ol{padding-left:22px;margin:0 0 22px}
.article li{margin:6px 0}
.article blockquote{
  border-left:4px solid var(--blue);background:var(--bg-2);
  margin:24px 0;padding:18px 24px;border-radius:0 12px 12px 0;
  font-style:italic;color:var(--ink);
}
.article code{
  background:var(--bg-3);padding:2px 8px;border-radius:6px;
  font-size:.92em;color:var(--blue-deep);
}
.tag-row{display:flex;flex-wrap:wrap;gap:8px;margin:32px 0}
.tag-row span{
  padding:6px 14px;border-radius:999px;background:var(--blue-soft);
  color:var(--blue);font-size:13px;font-weight:600;
}

/* =============== Insights list =============== */
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.post-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;
  transition:transform .35s, box-shadow .35s;
}
.post-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.post-card .img{aspect-ratio:16/10;overflow:hidden}
.post-card .img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.post-card:hover .img img{transform:scale(1.06)}
.post-card .body{padding:24px}
.post-card .meta{font-size:12px;color:var(--blue);font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:10px}
.post-card h3{font-family:var(--display);font-size:19px;font-weight:700;margin:0 0 8px;line-height:1.35;color:var(--ink)}
.post-card p{margin:0;color:var(--muted);font-size:14px}

/* =============== Pricing / plans (used on SaaS pages) =============== */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.plan{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:34px 28px;box-shadow:var(--shadow-sm);position:relative;
  transition:transform .35s, box-shadow .35s;
}
.plan:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.plan.feat{
  background:linear-gradient(180deg,#0E3673,var(--blue));color:#fff;
  border:none;box-shadow:var(--shadow-lg);
}
.plan.feat p,.plan.feat li{color:rgba(255,255,255,.85)}
.plan .tier{font-family:var(--display);font-size:14px;text-transform:uppercase;letter-spacing:.1em;color:var(--blue);margin:0 0 14px;font-weight:700}
.plan.feat .tier{color:var(--green)}
.plan .price{font-family:var(--display);font-size:36px;font-weight:800;margin:0 0 6px}
.plan .price small{font-size:14px;font-weight:500;opacity:.7}
.plan ul{list-style:none;padding:0;margin:22px 0 26px}
.plan li{padding:8px 0 8px 26px;position:relative;font-size:15px;border-bottom:1px dashed var(--line)}
.plan.feat li{border-bottom-color:rgba(255,255,255,.12)}
.plan li:last-child{border:none}
.plan li::before{content:"✓";position:absolute;left:0;color:var(--green);font-weight:800}

/* =============== Contact form =============== */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:start}
.contact-info{
  background:linear-gradient(180deg,#0E3673,var(--blue));color:#fff;
  padding:40px;border-radius:var(--radius-lg);box-shadow:var(--shadow);
}
.contact-info h3{font-family:var(--display);font-size:24px;margin:0 0 8px}
.contact-info p{opacity:.85;margin:0 0 22px}
.contact-info ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.contact-info li{display:flex;align-items:flex-start;gap:14px;font-size:15px}
.contact-info li span{
  width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.12);
  display:grid;place-items:center;flex-shrink:0;
}
.contact-info a{color:#fff;border-bottom:1px solid rgba(255,255,255,.3);padding-bottom:2px}
.contact-info a:hover{border-bottom-color:#fff}
.contact-form{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:40px;box-shadow:var(--shadow-sm);
}
.contact-form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.contact-form label{display:block;font-size:13px;font-weight:600;color:var(--ink-2);margin:0 0 8px}
.contact-form input,.contact-form select,.contact-form textarea{
  width:100%;padding:14px 16px;border-radius:12px;
  border:1.5px solid var(--line);background:#fff;font:inherit;color:var(--ink);
  transition:border-color .25s, box-shadow .25s;
}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{
  outline:none;border-color:var(--blue);box-shadow:0 0 0 4px rgba(26,79,156,.12);
}
.contact-form .field{margin-bottom:18px}
.contact-form textarea{min-height:140px;resize:vertical}
.contact-form .submit{margin-top:8px}

/* =============== Internship badges =============== */
.intern-badges{
  list-style:none;padding:0;margin:34px auto 0;
  display:flex;flex-wrap:wrap;justify-content:center;gap:10px 12px;
  max-width:900px;
}
.intern-badges li{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 16px;border-radius:999px;
  background:#fff;border:1px solid var(--line);
  font-size:14px;font-weight:500;color:var(--ink-2);
  box-shadow:var(--shadow-sm);
}
.intern-badges span{font-size:15px}

.nav-links a.active{color:var(--blue)}
.nav-links a.active::after{transform:scaleX(1)}

/* =============== FAQ =============== */
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.faq-item{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:0;overflow:hidden;box-shadow:var(--shadow-sm);
  transition:box-shadow .25s;
}
.faq-item[open]{box-shadow:var(--shadow);border-color:rgba(26,79,156,.25)}
.faq-item summary{
  list-style:none;cursor:pointer;
  padding:20px 26px;font-weight:600;color:var(--ink);
  font-family:var(--display);font-size:17px;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";font-size:24px;color:var(--blue);
  transition:transform .25s ease;flex-shrink:0;
}
.faq-item[open] summary::after{content:"\2013";transform:rotate(0deg)}
.faq-item p{margin:0;padding:0 26px 22px;color:var(--muted);font-size:15px;line-height:1.65}
.faq-item a{color:var(--blue);font-weight:600}
.article .faq-item{margin:14px 0}
.article .faq-item summary{padding:16px 22px;font-size:16px}
.article .faq-item p{padding:0 22px 18px}

/* =============== Responsive =============== */
@media (max-width:1080px){
  .hero-grid,.framework-grid,.cta-grid,.split,.contact-grid{grid-template-columns:1fr;gap:48px}
  .hero{padding:130px 0 70px}
  .work-grid,.services-grid,.insights-grid,.feature-grid,.posts-grid,.plans{grid-template-columns:repeat(2,1fr)}
  .principles{grid-template-columns:repeat(2,1fr)}
  .logo-row{grid-template-columns:repeat(5,1fr)}
  .logo-row.tight{grid-template-columns:repeat(4,1fr);gap:30px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
  .cta-right{padding-left:0}
  .cta-arrow{display:none}
  .contact-form .row{grid-template-columns:1fr}
  .nav-links{gap:20px}
  .nav-links a{font-size:13px}
}
@media (max-width:900px){
  .nav-toggle{display:flex}
  .nav-links{
    position:fixed;top:72px;left:0;right:0;bottom:0;
    display:flex;flex-direction:column;align-items:flex-start;gap:0;
    background:#fff;padding:24px;
    border-top:1px solid var(--line);
    transform:translateY(-110%);transition:transform .35s ease;
    overflow-y:auto;z-index:99;
  }
  .nav-links.open{transform:translateY(0)}
  .nav-links a{font-size:18px;padding:16px 0;border-bottom:1px solid var(--line);width:100%}
  .nav-cta{
    position:fixed;top:auto;bottom:0;left:0;right:0;z-index:99;
    padding:14px 20px;background:#fff;border-top:1px solid var(--line);
    transform:translateY(100%);transition:transform .35s ease;
    display:none;
  }
  .nav-cta.open{display:flex;transform:translateY(0)}
  .nav-cta .btn{flex:1;justify-content:center}
}
@media (max-width:1080px){
  .faq-grid{grid-template-columns:1fr}
}
@media (max-width:680px){
  .container{padding:0 16px}
  .nav{height:64px;gap:10px}
  .nav-logo{max-width:65vw}
  .nav-logo img{height:38px}
  .nav-links{top:64px;padding:20px}
  .nav-toggle{transition:transform .25s ease}
  body:has(.nav-links.open) .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  body:has(.nav-links.open) .nav-toggle span:nth-child(2){opacity:0}
  body:has(.nav-links.open) .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .work-grid,.services-grid,.insights-grid,.feature-grid,.posts-grid,.plans{grid-template-columns:1fr}
  .principles{grid-template-columns:1fr}
  .hero{padding:100px 0 50px}
  .hero-grid{gap:36px}
  .hero-meta{grid-template-columns:1fr 1fr;gap:14px}
  .hero-art-frame{transform:none}
  .hero-badge{left:auto;right:-12px;bottom:-16px;padding:10px}
  .hero-badge img{height:64px}
  .hero-pulse{width:72px;height:72px;font-size:11px;top:-14px;right:-14px}
  .framework-card{grid-template-columns:1fr}
  .framework-img{aspect-ratio:16/10}
  .logo-row.tight{grid-template-columns:repeat(3,1fr);gap:20px}
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .footer-bottom .container{flex-direction:column;text-align:center}
  .clutch-band{flex-direction:column;align-items:stretch;text-align:left;padding:24px}
  .clutch-band .btn{justify-content:center}
  .callout{padding:28px 24px;flex-direction:column;align-items:stretch;text-align:left}
  .callout .btn{justify-content:center}
  .contact-info,.contact-form{padding:24px}
  .page-hero{padding:130px 0 56px}
  .blog-hero{padding:130px 0 40px}
  .blog{padding:60px 0}
  .section{padding:60px 0}
  .section-title,.section-head h2{font-size:30px}
  .t-track li{padding:0 14px}
  .t-arrow{width:42px;height:42px;font-size:20px}
  .different{padding:70px 0 60px}
  .work,.services,.tech,.about,.testimonials,.cta{padding:70px 0}
  .cta-left h2,.cta-right p{text-align:left}
  .cta-right{padding-left:0}
  .article h2{font-size:24px}
  .article{font-size:16px}
  .industries li{font-size:14px;padding:8px 16px}
  .footer-contact li{font-size:13px}
}
@media (max-width:420px){
  .hero-copy h1{font-size:34px}
  .hero-meta{grid-template-columns:1fr}
  .stats span{font-size:42px}
  .blog-cover{aspect-ratio:16/10}
}
