/* ---------- COLOR PALETTE ---------- */
:root{
  --brand-red: #B71C1C;
  --brand-blue:#0A3D62;
  --brand-grey:#6B6F72;
  --bg-surface:#F6F7F8;
  --text-strong:#0F1720;
  --muted:#8A9197;
  --accent-gradient: linear-gradient(180deg, rgba(10,61,98,0.06) 0%, rgba(183,28,28,0.04) 100%);
}

/* ---------- Reset & base ---------- */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial;
  color:var(--text-strong);
  background:var(--bg-surface);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.45;
  font-size:16px;
}

a{color:var(--brand-blue);text-decoration:none}

/* ---------- Layout containers ---------- */
.container{width:min(1200px,92%);margin:0 auto}
header{background:white;border-bottom:1px solid rgba(15,23,32,0.04);position:sticky;top:0;z-index:1000}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.brand{display:flex;align-items:center;gap:16px}
.brand img{height:42px;width:auto}
.brand h1{font-family:Oswald,Inter,sans-serif;margin:0;font-size:18px;letter-spacing:0.6px}

nav{display:flex;gap:18px;align-items:center}
.nav a{font-weight:600;color:var(--muted);font-size:14px;transition:color 0.2s}
.nav a:hover{color:var(--brand-blue)}
.btn{display:inline-flex;align-items:center;gap:10px;padding:10px 16px;border-radius:6px;border:1px solid rgba(15,23,32,0.06);font-weight:600;transition:all 0.2s}
.btn-primary{background:var(--brand-red);color:white;border:none}
.btn-primary:hover{background:#9a1616}
.btn-ghost{background:transparent;color:var(--brand-blue);border:1px solid rgba(10,61,98,0.08)}
.btn-ghost:hover{background:rgba(10,61,98,0.05)}

/* ---------- Hero Slider ---------- */
.hero-slider{
  height: 480px;
  position:relative;
  overflow:hidden;
}
.slide{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  background-size:cover;
  background-position:center center;
  opacity:0;
  transition:opacity 1s ease-in-out;
}
.slide.active{
  opacity:1;
}
.slide::after{
  content:"";
  position:absolute;
  inset:0;
  background: rgba(0,0,0,0.4);
  pointer-events:none;
}
.hero-content{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:1fr 420px;
  gap:40px;
  align-items:center;
  height:480px;
}
.hero-text {
  color: white;
  padding: 20px;
}
.eyebrow{color:white;font-weight:700;font-size:13px;letter-spacing:1px}
h2{font-family:Oswald,Inter,sans-serif;font-size:34px;margin:10px 0 12px;color:white;line-height:1.05}
p.lead{color:rgba(255,255,255,0.9);margin:0 0 20px}
.hero-ctas{display:flex;gap:10px}

.badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px}
.badge{background:rgba(255,255,255,0.2);border:1px solid rgba(255,255,255,0.3);padding:8px 10px;font-size:13px;border-radius:4px;color:white}

.slider-controls{
  position:absolute;
  bottom:20px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  gap:8px;
  z-index:10;
}
.slider-dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background:rgba(255,255,255,0.5);
  cursor:pointer;
  transition:background 0.3s;
}
.slider-dot.active{
  background:white;
}

.capabilities-card{
  background:rgba(255,255,255,0.15);
  backdrop-filter:blur(10px);
  padding:20px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,0.2);
  color:white;
}
.capabilities-card h4{
  margin:0 0 8px;
  font-family:Oswald;
  color:white;
}
.capabilities-card ul{
  margin:0;
  padding:0 0 0 18px;
  color:rgba(255,255,255,0.9);
}

/* ---------- About Us ---------- */
section{padding:56px 0}
.two-col{display:grid;grid-template-columns:1fr 420px;gap:40px}
.section-title{font-family:Oswald;margin-bottom:16px}
.section-description{color:var(--muted);margin-bottom:24px}
.center{text-align:center}

.cap-icons{display:flex;flex-direction:column;gap:14px}
.cap-item{display:flex;gap:12px;align-items:center}
.cap-item svg{width:44px;height:44px;flex:0 0 44px;border-radius:6px;padding:8px;background:white;border:1px solid rgba(15,23,32,0.04)}
.cap-description{color:var(--muted);font-size:13px}

.info-card{
  background:white;
  padding:20px;
  border-radius:8px;
  border:1px solid rgba(15,23,32,0.04);
}
.info-card h4{
  margin:0 0 8px;
  font-family:Oswald;
}
.info-card ul{
  margin:0;
  padding-left:18px;
  color:var(--muted);
}

/* mission/vision */
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.card{background:white;padding:22px;border-radius:8px;border:1px solid rgba(15,23,32,0.04);transition:transform 0.3s, box-shadow 0.3s}
.card:hover{transform:translateY(-5px);box-shadow:0 10px 25px rgba(10,24,40,0.08)}
.card h3{margin:0 0 8px;font-family:Oswald}
.card p{color:var(--muted);margin:0}

/* services grid */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.service{background:white;padding:18px;border-radius:8px;border:1px solid rgba(15,23,32,0.04);display:flex;gap:12px;align-items:flex-start;transition:transform 0.3s, box-shadow 0.3s}
.service:hover{transform:translateY(-5px);box-shadow:0 10px 25px rgba(10,24,40,0.08)}
.service .icon{width:56px;height:56px;flex:0 0 56px;display:grid;place-items:center;border-radius:6px;border:1px solid rgba(10,61,98,0.06)}
.service h4{margin:0;font-size:16px}
.service p{margin:8px 0 0;color:var(--muted);font-size:14px}

/* detailed sections */
.detail{display:grid;grid-template-columns:1fr 360px;gap:30px;align-items:start}
.info-list{padding:0;margin:0;list-style:none}
.info-list li{padding:10px 0;border-bottom:1px dashed rgba(15,23,32,0.03);color:var(--muted)}

table{width:100%;border-collapse:collapse;background:white;border:1px solid rgba(15,23,32,0.04)}
table th, table td{padding:12px 14px;text-align:left;border-bottom:1px solid rgba(15,23,32,0.04);font-size:14px}
table thead th{background:rgba(10,61,98,0.02);font-weight:700}

.compact-table{width:100%;border-collapse:collapse}
.compact-table th, .compact-table td{padding:8px 10px;font-size:13px}
.table-note{margin-top:12px;color:var(--muted);font-size:14px}

/* Image sections */
.image-section {
  position: relative;
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
  padding: 80px 0;
}
.image-section::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(10, 61, 98, 0.7);
  z-index: 1;
}
.image-section .container {
  position: relative;
  z-index: 2;
}
.image-section h2, .image-section h3 {
  color: white;
  text-align: center;
}
.image-section p {
  color: rgba(255,255,255,0.9);
  text-align: center;
  max-width: 800px;
  margin: 0 auto;
}

/* our clients section */
.clients-section{background:white;padding:56px 0}
.clients-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;margin-top:30px}
.client-logo{display:grid;place-items:center;height:120px;padding:20px;border-radius:8px;border:1px solid rgba(15,23,32,0.04);transition:transform 0.3s, box-shadow 0.3s}
.client-logo:hover{transform:translateY(-5px);box-shadow:0 10px 25px rgba(10,24,40,0.08)}
.client-logo img{max-width:100%;max-height:80px;filter:grayscale(100%);transition:filter 0.3s}
.client-logo:hover img{filter:grayscale(0%)}

/* contact */
.contact-section{padding:36px 0;border-top:1px solid rgba(15,23,32,0.03)}
.contact-grid{display:grid;grid-template-columns:1fr 420px;gap:28px}
.contact-info{display:grid;gap:10px;margin-top:12px}
.contact-item{background:white;padding:14px;border-radius:8px;border:1px solid rgba(15,23,32,0.04)}
.contact-item div{color:var(--muted);margin-top:6px}

.map-placeholder{
  height:280px;
  background:linear-gradient(180deg,rgba(10,61,98,0.06),rgba(183,28,28,0.03));
  border-radius:8px;
  border:1px solid rgba(15,23,32,0.04);
  display:grid;
  place-items:center;
  color:var(--muted);
  position:relative;
  overflow:hidden;
}
.map-overlay{
  text-align:center;
  padding:20px;
}
.map-overlay h4{
  margin:0 0 8px;
  font-family:Oswald;
}
.map-overlay p{
  color:var(--muted);
  margin-bottom:16px;
}

/* footer */
footer{background:#0f1720;color:white;padding:40px 0;margin-top:40px}
.footer-content{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;
  flex-wrap:wrap;
}
.footer-description{color:rgba(255,255,255,0.7);margin-top:6px}
.copyright{color:rgba(255,255,255,0.7);font-size:14px}

/* ---------- Minimal Animations ---------- */
.fade-up{transform:translateY(10px);opacity:0;animation:fadeUp .7s forwards}
@keyframes fadeUp{to{transform:none;opacity:1}}