/* ==========================================================
   MAZIBUKO TRADING & PROJECTS — SITE STYLESHEET
   Shared across all pages.
========================================================== */

:root{
  --navy-950:#060a16;
  --navy-900:#0a1330;
  --navy-800:#0f1c47;
  --navy-700:#132458;
  --blue-600:#1657ff;
  --blue-700:#0d3fd1;
  --blue-100:#e7edff;
  --ink:#0f172a;
  --body-text:#57606f;
  --light-bg:#f4f6fb;
  --white:#ffffff;
  --border:#e6e9f2;
  --shadow:0 20px 45px rgba(15,28,71,.10);
  --shadow-sm:0 8px 20px rgba(15,28,71,.08);
  --radius-lg:16px;
  --radius-md:10px;
  --radius-sm:6px;
  --ease:cubic-bezier(.22,.9,.32,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  color:var(--body-text);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{
  font-family:'Poppins',system-ui,sans-serif;
  color:var(--ink);
  margin:0;
  line-height:1.15;
  font-weight:800;
}
p{ margin:0; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; margin:0; padding:0; }
img{ max-width:100%; display:block; }
button{ font-family:inherit; cursor:pointer; }
input,textarea,select{ font-family:inherit; }
.container{ max-width:1240px; margin:0 auto; padding:0 24px; }

/* ---------------- Eyebrow / section heading pattern ---------------- */
.eyebrow{
  display:inline-block; font-size:12.5px; font-weight:700; letter-spacing:.14em;
  text-transform:uppercase; color:var(--blue-600); margin-bottom:10px;
}
.eyebrow.on-dark{ color:#5b8bff; }
.section-head{ text-align:center; max-width:640px; margin:0 auto 44px; }
.section-head.align-left{ text-align:left; margin:0 0 32px; max-width:none; }
.section-title{ font-size:30px; text-transform:uppercase; letter-spacing:.01em; }
@media (min-width:900px){ .section-title{ font-size:36px; } }
.section-title .hi{ color:var(--blue-600); }
.section-sub{ margin-top:12px; font-size:15px; color:var(--body-text); }

section{ padding:72px 0; }
.section-light{ background:var(--light-bg); }
.section-white{ background:var(--white); }
.section-dark{ background:var(--navy-900); color:#c6cde3; }
.section-dark .section-title{ color:var(--white); }

/* ---------------- Buttons ---------------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-size:13.5px; font-weight:700; letter-spacing:.04em; text-transform:uppercase;
  padding:14px 26px; border-radius:8px; border:2px solid transparent;
  transition:transform .18s var(--ease), background .2s, color .2s, border-color .2s, box-shadow .2s;
  white-space:nowrap;
}
.btn svg{ width:16px; height:16px; flex-shrink:0; }
.btn:hover{ transform:translateY(-2px); }
.btn-primary{ background:var(--blue-600); color:#fff; box-shadow:0 10px 24px rgba(22,87,255,.35); }
.btn-primary:hover{ background:var(--blue-700); }
.btn-outline-dark{ border-color:rgba(255,255,255,.35); color:#fff; }
.btn-outline-dark:hover{ border-color:#fff; background:rgba(255,255,255,.08); }
.btn-outline-blue{ border-color:var(--blue-600); color:var(--blue-600); background:#fff; }
.btn-outline-blue:hover{ background:var(--blue-100); }
.btn-white{ background:#fff; color:var(--blue-700); }
.btn-white:hover{ background:#eef2ff; }
.btn-block{ width:100%; }

/* ==========================================================
   HEADER / NAV
========================================================== */
.site-header{
  position:sticky; top:0; z-index:100;
  background:var(--navy-900);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.nav-row{ display:flex; align-items:center; justify-content:space-between; padding-top:16px; padding-bottom:16px; gap:20px; }
.brand{ display:flex; align-items:center; gap:12px; color:#fff; flex-shrink:0; }
.brand-mark{ width:44px; height:auto; flex-shrink:0; object-fit:contain; display:block; }
.brand-text{ line-height:1.15; }
.brand-name{ font-family:'Poppins',sans-serif; font-weight:800; font-size:18px; letter-spacing:.03em; }
.brand-tag{ font-size:9.5px; letter-spacing:.16em; color:#8b95b8; font-weight:600; }
.brand-slogan{ display:block; font-size:10.5px; letter-spacing:.02em; color:var(--blue-600); font-weight:600; font-style:italic; margin-top:2px; }

.nav-links{ display:none; align-items:center; gap:30px; }
@media (min-width:960px){ .nav-links{ display:flex; } }
.nav-links a{
  font-size:14px; font-weight:600; color:#cfd6ec; padding:6px 0; position:relative;
  display:flex; align-items:center; gap:5px;
}
.nav-links a:hover, .nav-links a.active{ color:#fff; }
.nav-links a.active::after{
  content:""; position:absolute; left:0; right:0; bottom:-6px; height:2px; background:var(--blue-600);
}
.nav-links svg{ width:11px; height:11px; }
.has-dropdown{ position:relative; }
.dropdown{
  position:absolute; top:calc(100% + 18px); left:50%; transform:translateX(-50%);
  background:#fff; border-radius:var(--radius-md); box-shadow:var(--shadow); padding:10px;
  min-width:220px; opacity:0; visibility:hidden; transform:translateX(-50%) translateY(6px);
  transition:opacity .2s var(--ease), transform .2s var(--ease), visibility .2s;
}
.has-dropdown:hover .dropdown{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.dropdown a{ display:block; color:var(--ink); font-size:13.5px; padding:10px 12px; border-radius:7px; }
.dropdown a:hover{ background:var(--light-bg); color:var(--blue-600); }

.nav-cta{ display:none; }
@media (min-width:960px){ .nav-cta{ display:inline-flex; } }
.nav-toggle{
  display:flex; align-items:center; justify-content:center; width:40px; height:40px;
  background:none; border:1px solid rgba(255,255,255,.25); border-radius:8px; color:#fff;
}
@media (min-width:960px){ .nav-toggle{ display:none; } }
.nav-toggle svg{ width:20px; height:20px; }

.mobile-menu{
  max-height:0; overflow:hidden; background:var(--navy-800);
  transition:max-height .3s var(--ease);
}
.mobile-menu.is-open{ max-height:640px; }
.mobile-menu-inner{ padding:8px 24px 20px; display:flex; flex-direction:column; gap:2px; }
.mobile-menu a{
  color:#dbe1f4; font-size:14.5px; font-weight:600; padding:12px 4px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.mobile-menu a.active{ color:#5b8bff; }
.mobile-submenu{ padding-left:14px; display:flex; flex-direction:column; }
.mobile-submenu a{ font-size:13px; font-weight:500; color:#aab3d1; padding:9px 4px; border-bottom:none; }
.mobile-menu .btn{ margin-top:12px; text-align:center; }

/* ==========================================================
   HERO (split layout, used on all inner pages + home)
========================================================== */
.hero{
  position:relative; background:var(--navy-900); overflow:hidden;
  padding:56px 0 0;
}
.hero-grid{
  display:grid; grid-template-columns:1fr; gap:36px; align-items:center;
  position:relative; z-index:2;
}
@media (min-width:960px){ .hero-grid{ grid-template-columns:1.05fr 1fr; gap:40px; } }
.hero-copy .eyebrow{ color:#5b8bff; }
.hero-title{
  font-size:34px; color:#fff; text-transform:uppercase; letter-spacing:.005em; margin-bottom:18px;
}
@media (min-width:640px){ .hero-title{ font-size:44px; } }
@media (min-width:1100px){ .hero-title{ font-size:50px; } }
.hero-title .hi{ color:#3b76ff; }
.hero-text{ font-size:15.5px; line-height:1.7; color:#aab3d1; max-width:46ch; margin-bottom:28px; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:56px; }

.hero-media{ position:relative; }
.hero-media-frame{
  position:relative; border-radius:var(--radius-lg); overflow:hidden;
  aspect-ratio:16/11; box-shadow:0 30px 60px rgba(0,0,0,.45);
}
.hero-media-frame img{ width:100%; height:100%; object-fit:cover; }
.hero-badge{
  position:absolute; background:var(--blue-600); color:#fff; border-radius:var(--radius-md);
  padding:18px 20px; box-shadow:0 18px 34px rgba(22,87,255,.4);
  font-size:14px; font-weight:700; line-height:1.55; max-width:190px;
}
.hero-badge svg{ width:22px; height:22px; margin-bottom:8px; }
.hero-badge.bottom-left{ left:-14px; bottom:-24px; }
.hero-badge.bottom-right{ right:-14px; bottom:-24px; text-align:left; }
@media (max-width:539px){ .hero-badge{ position:static; margin-top:16px; max-width:none; } }

/* Stat bar overlapping the hero bottom edge (home page) */
.stat-bar-wrap{ position:relative; z-index:3; margin-top:-46px; }
.stat-bar{
  background:#fff; border-radius:var(--radius-lg); box-shadow:var(--shadow);
  padding:28px 30px; display:grid; grid-template-columns:1fr; gap:24px;
}
@media (min-width:720px){ .stat-bar{ grid-template-columns:repeat(4,1fr); gap:20px; } }
.stat-item{ display:flex; align-items:flex-start; gap:14px; }
.stat-icon{
  width:46px; height:46px; border-radius:50%; border:2px solid var(--blue-600); color:var(--blue-600);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.stat-icon svg{ width:22px; height:22px; }
.stat-item h4{ font-size:14.5px; font-weight:700; margin-bottom:4px; }
.stat-item p{ font-size:12.5px; color:var(--body-text); line-height:1.4; }
.hero.has-stat-bar{ padding-bottom:0; }
.hero-spacer{ height:72px; }

/* ==========================================================
   CARD GRIDS (services, values)
========================================================== */
.grid{ display:grid; gap:22px; grid-template-columns:1fr; }
@media (min-width:620px){ .grid-2{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:760px){ .grid-3{ grid-template-columns:repeat(3,1fr); } }
@media (min-width:900px){ .grid-4{ grid-template-columns:repeat(4,1fr); } }

.card{
  background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:28px 24px; transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s;
}
.card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-sm); border-color:transparent; }
.card-icon{
  width:52px; height:52px; border-radius:12px; border:2px solid var(--blue-600); color:var(--blue-600);
  display:flex; align-items:center; justify-content:center; margin-bottom:18px;
}
.card-icon svg{ width:26px; height:26px; }
.card h3{ font-size:16.5px; margin-bottom:8px; }
.card p{ font-size:13.5px; line-height:1.6; color:var(--body-text); margin-bottom:14px; }
.card-link{
  display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase; color:var(--blue-600);
}
.card-link svg{ width:14px; height:14px; transition:transform .2s var(--ease); }
.card:hover .card-link svg{ transform:translateX(3px); }

.value-card{ text-align:center; }
.value-card .card-icon{ margin:0 auto 18px; }
.value-card .underline{ width:26px; height:3px; background:var(--blue-600); border-radius:2px; margin:14px auto 0; }

/* ==========================================================
   DARK "WHY CHOOSE" SPLIT SECTION
========================================================== */
.split-dark{ display:grid; grid-template-columns:1fr; gap:40px; align-items:center; }
@media (min-width:960px){ .split-dark{ grid-template-columns:1fr 1.15fr; gap:56px; } }
.why-copy .section-title{ color:#fff; text-align:left; }
.why-copy p{ margin:16px 0 24px; font-size:14.5px; line-height:1.7; color:#aab3d1; max-width:44ch; }
.why-features{ display:grid; grid-template-columns:1fr; gap:22px 28px; margin-bottom:24px; }
@media (min-width:520px){ .why-features{ grid-template-columns:1fr 1fr; } }
.why-feature{ display:flex; gap:14px; align-items:flex-start; }
.why-feature-icon{
  width:38px; height:38px; border-radius:10px; background:rgba(22,87,255,.18); color:#5b8bff;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.why-feature-icon svg{ width:19px; height:19px; }
.why-feature h4{ font-size:14px; color:#fff; margin-bottom:3px; }
.why-feature p{ font-size:12.5px; color:#8b95b8; line-height:1.5; margin:0; }
.why-media-wrap{ position:relative; }
.why-media{
  border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:4/3.1; box-shadow:0 26px 50px rgba(0,0,0,.4);
}
.why-media img{ width:100%; height:100%; object-fit:cover; }

/* ---------------- Industries row ---------------- */
.industries-row{
  display:grid; grid-template-columns:repeat(2,1fr); gap:26px 18px; text-align:center;
}
@media (min-width:720px){ .industries-row{ grid-template-columns:repeat(5,1fr); } }
.industry-item{ display:flex; flex-direction:column; align-items:center; gap:10px; }
.industry-icon{
  width:52px; height:52px; border-radius:50%; border:2px solid var(--blue-600); color:var(--blue-600);
  display:flex; align-items:center; justify-content:center;
}
.industry-icon svg{ width:24px; height:24px; }
.industry-item h4{ font-size:13.5px; }
.industry-item p{ font-size:11.5px; color:var(--body-text); }

/* ==========================================================
   CTA BAR (blue strip)
========================================================== */
.cta-bar{ background:var(--blue-600); }
.cta-bar-inner{
  padding-top:26px; padding-bottom:26px; display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:18px;
}
.cta-bar-left{ display:flex; align-items:center; gap:16px; color:#fff; }
.cta-bar-icon{
  width:46px; height:46px; border-radius:50%; background:rgba(255,255,255,.16);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.cta-bar-icon svg{ width:22px; height:22px; }
.cta-bar-left h4{ font-size:16px; color:#fff; margin-bottom:2px; }
.cta-bar-left p{ font-size:13px; color:#d9e3ff; }
.cta-bar-actions{ display:flex; flex-wrap:wrap; gap:12px; }

/* ==========================================================
   FOOTER
========================================================== */
.site-footer{ background:var(--navy-950); color:#8b95b8; padding-top:60px; }
.footer-grid{ display:grid; grid-template-columns:1fr; gap:36px; padding-bottom:40px; border-bottom:1px solid rgba(255,255,255,.08); }
@media (min-width:760px){ .footer-grid{ grid-template-columns:1.3fr 1fr 1.1fr; gap:24px; } }
.footer-brand .brand{ margin-bottom:14px; }
.footer-brand p{ font-size:13px; line-height:1.7; max-width:32ch; margin-bottom:18px; }
.footer-social{ display:flex; gap:10px; }
.footer-social a{
  width:34px; height:34px; border-radius:50%; background:rgba(255,255,255,.06);
  display:flex; align-items:center; justify-content:center; color:#cfd6ec; transition:background .2s, color .2s;
}
.footer-social a:hover{ background:var(--blue-600); color:#fff; }
.footer-social svg{ width:15px; height:15px; }
.footer-col h5{ color:#fff; font-size:13px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; margin-bottom:18px; }
.footer-col ul{ display:flex; flex-direction:column; gap:11px; }
.footer-col a{ font-size:13.5px; color:#aab3d1; }
.footer-col a:hover{ color:#fff; }
.footer-contact li{ display:flex; gap:10px; font-size:13.5px; color:#aab3d1; align-items:flex-start; }
.footer-contact svg{ width:15px; height:15px; margin-top:2px; flex-shrink:0; color:#5b8bff; }
.footer-bottom{
  padding:20px 0; display:flex; flex-wrap:wrap; gap:8px; justify-content:space-between;
  font-size:12px; color:#6b7594;
}

/* ==========================================================
   TIMELINE (about page)
========================================================== */
.timeline-panel{ background:var(--navy-800); border-radius:var(--radius-lg); padding:40px 30px; }
.timeline{
  display:grid; grid-template-columns:1fr; gap:34px; position:relative;
}
@media (min-width:900px){ .timeline{ grid-template-columns:repeat(5,1fr); gap:18px; } }
@media (min-width:900px){
  .timeline::before{
    content:""; position:absolute; top:20px; left:6%; right:6%; height:1px;
    background:repeating-linear-gradient(90deg, rgba(255,255,255,.25) 0 6px, transparent 6px 12px);
  }
}
.timeline-item{ position:relative; }
.timeline-dot{
  width:40px; height:40px; border-radius:50%; background:var(--blue-600); color:#fff;
  display:flex; align-items:center; justify-content:center; margin-bottom:16px; position:relative; z-index:2;
}
.timeline-dot svg{ width:18px; height:18px; }
.timeline-item h4{ color:#fff; font-size:13.5px; margin-bottom:6px; }
.timeline-item .year{ color:#5b8bff; font-weight:700; font-size:12px; letter-spacing:.05em; margin-bottom:4px; display:block; }
.timeline-item p{ font-size:12px; line-height:1.6; color:#8b95b8; }

/* ==========================================================
   TEAM (about page)
========================================================== */
.team-head{ display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom:36px; }
.team-head .section-head{ margin:0; text-align:left; max-width:none; }
.team-grid{ display:grid; grid-template-columns:1fr; gap:44px; align-items:start; }
@media (min-width:900px){ .team-grid{ grid-template-columns:1.5fr 1fr; } }
.team-photos{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
@media (min-width:520px){ .team-photos{ grid-template-columns:repeat(4,1fr); } }
.team-card{ border-radius:var(--radius-md); overflow:hidden; background:var(--light-bg); }
.team-photo{
  aspect-ratio:3/3.4; background:linear-gradient(160deg,#dbe3f5,#c3cdea);
  display:flex; align-items:center; justify-content:center; color:#7c88b3;
}
.team-photo svg{ width:44%; height:44%; }
.team-card-body{ padding:12px 10px 16px; }
.team-card-body h4{ font-size:13px; }
.team-card-body p{ font-size:11.5px; color:var(--body-text); margin-top:2px; }
.team-checklist{ display:flex; flex-direction:column; gap:14px; }
.team-checklist li{ display:flex; align-items:center; gap:10px; font-size:14px; color:var(--ink); font-weight:500; }
.team-checklist svg{ width:19px; height:19px; color:var(--blue-600); flex-shrink:0; }

.credentials-bar{
  background:var(--navy-800); border-radius:var(--radius-lg); padding:30px 30px;
  display:grid; grid-template-columns:1fr; gap:26px; text-align:center;
}
@media (min-width:760px){ .credentials-bar{ grid-template-columns:repeat(4,1fr); text-align:left; } }
.credentials-bar .cred-item h3{ color:#fff; font-size:30px; }
.credentials-bar .cred-item p{ font-size:12.5px; color:#8b95b8; margin-top:4px; }
.credentials-bar .cred-item.location{ display:flex; align-items:center; gap:12px; justify-content:center; }
@media (min-width:760px){ .credentials-bar .cred-item.location{ justify-content:flex-start; } }
.credentials-bar .cred-item.location p{ color:#8b95b8; font-size:12.5px; }
.credentials-bar .cred-item.location strong{ color:#5b8bff; font-size:19px; display:block; }
.credentials-bar .loc-icon{ width:40px; height:40px; border:2px solid var(--blue-600); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--blue-600); flex-shrink:0; }
.credentials-bar .loc-icon svg{ width:19px; height:19px; }

/* ==========================================================
   CONTACT PAGE
========================================================== */
.contact-grid{ display:grid; grid-template-columns:1fr; gap:28px; align-items:start; }
@media (min-width:960px){ .contact-grid{ grid-template-columns:1.55fr 1fr; } }
.form-card{ background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); box-shadow:var(--shadow-sm); padding:34px 30px; }
.form-card h2{ font-size:24px; text-transform:uppercase; }
.form-card > p{ margin-top:10px; font-size:13.5px; color:var(--body-text); margin-bottom:26px; }
.form-row{ display:grid; grid-template-columns:1fr; gap:18px; margin-bottom:18px; }
@media (min-width:560px){ .form-row.cols-2{ grid-template-columns:1fr 1fr; } }
.field label{ display:block; font-size:12.5px; font-weight:600; color:var(--ink); margin-bottom:7px; }
.field label .req{ color:#e0432c; }
.field input, .field select, .field textarea{
  width:100%; border:1px solid var(--border); border-radius:8px; padding:12px 14px;
  font-size:13.5px; color:var(--ink); background:#fbfcfe;
}
.field input:focus, .field select:focus, .field textarea:focus{ outline:2px solid var(--blue-600); outline-offset:1px; background:#fff; }
.field textarea{ resize:vertical; min-height:110px; }
.consent{ display:flex; align-items:flex-start; gap:10px; font-size:12.5px; color:var(--body-text); margin-bottom:20px; }
.consent input{ margin-top:2px; }

.info-card{ background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); box-shadow:var(--shadow-sm); padding:30px 26px; }
.info-card h2{ font-size:22px; text-transform:uppercase; margin-bottom:22px; }
.info-row{ display:flex; gap:14px; padding:16px 0; border-bottom:1px solid var(--border); }
.info-row:last-child{ border-bottom:none; padding-bottom:0; }
.info-row:first-child{ padding-top:0; }
.info-icon{
  width:42px; height:42px; border-radius:50%; background:var(--blue-600); color:#fff;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.info-icon svg{ width:19px; height:19px; }
.info-row h4{ font-size:11.5px; text-transform:uppercase; letter-spacing:.06em; color:var(--blue-600); margin-bottom:4px; }
.info-row strong{ display:block; font-size:15px; color:var(--ink); margin-bottom:2px; }
.info-row span{ font-size:12px; color:var(--body-text); }

.area-map-grid{ display:grid; grid-template-columns:1fr; gap:22px; margin-top:26px; }
@media (min-width:820px){ .area-map-grid{ grid-template-columns:1fr 1.5fr; } }
.area-card{ background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); padding:30px 26px; box-shadow:var(--shadow-sm); }
.area-card h3{ font-size:19px; text-transform:uppercase; margin-bottom:12px; }
.area-card p{ font-size:13.5px; line-height:1.7; margin-bottom:20px; }
.map-frame{
  border-radius:var(--radius-lg); overflow:hidden; min-height:260px; border:1px solid var(--border);
}
.map-frame iframe{ width:100%; height:100%; min-height:260px; border:0; display:block; }

.why-row{ display:grid; grid-template-columns:1fr; gap:26px; text-align:center; }
@media (min-width:760px){ .why-row{ grid-template-columns:repeat(4,1fr); text-align:left; } }
.why-row-item{ display:flex; flex-direction:column; align-items:center; gap:12px; }
@media (min-width:760px){ .why-row-item{ flex-direction:row; align-items:flex-start; } }
.why-row-item .icon{
  width:44px; height:44px; border:2px solid var(--blue-600); border-radius:50%; color:var(--blue-600);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.why-row-item .icon svg{ width:20px; height:20px; }
.why-row-item h4{ color:#fff; font-size:14px; margin-bottom:4px; }
.why-row-item p{ font-size:12px; color:#8b95b8; }

/* ==========================================================
   SERVICES DETAIL + PROJECTS PAGES
========================================================== */
.service-detail{
  display:grid; grid-template-columns:1fr; gap:16px; margin-bottom:16px;
}
.service-detail-card{
  scroll-margin-top:110px;
  background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg); padding:30px;
  display:grid; grid-template-columns:1fr; gap:18px;
}
@media (min-width:760px){ .service-detail-card{ grid-template-columns:70px 1fr; align-items:start; } }
.service-detail-card .card-icon{ margin-bottom:0; }
.service-detail-card h3{ font-size:19px; margin-bottom:8px; }
.service-detail-card p{ font-size:14px; line-height:1.7; color:var(--body-text); }
.service-tags{ display:flex; flex-wrap:wrap; gap:8px; margin-top:14px; }
.service-tags span{ font-size:11px; font-weight:600; color:var(--blue-700); background:var(--blue-100); padding:5px 11px; border-radius:999px; }

.project-grid{ display:grid; grid-template-columns:1fr; gap:24px; }
@media (min-width:640px){ .project-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:980px){ .project-grid{ grid-template-columns:repeat(3,1fr); } }
.project-card{ border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--border); background:#fff; }
.project-media{
  aspect-ratio:4/3; background:linear-gradient(155deg,#0f1c47,#1657ff);
  display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.85); position:relative;
}
.project-media svg{ width:34%; height:34%; }
.project-tag{
  position:absolute; top:14px; left:14px; background:rgba(255,255,255,.14); backdrop-filter:blur(6px);
  color:#fff; font-size:10.5px; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  padding:5px 10px; border-radius:999px;
}
.project-body{ padding:20px 20px 22px; }
.project-body h3{ font-size:16px; margin-bottom:6px; }
.project-body p{ font-size:12.5px; color:var(--body-text); line-height:1.6; }

.projects-cta{ text-align:center; margin-top:12px; }

/* ---------------- Page hero (secondary pages, non-split) ---------------- */
.page-note{
  background:var(--light-bg); border:1px dashed var(--border); border-radius:var(--radius-md);
  padding:16px 18px; font-size:12.5px; color:var(--body-text); margin-bottom:30px;
}

/* utility */
.mt-0{ margin-top:0; }
.text-center{ text-align:center; }
