@import url('https://fonts.googleapis.com/css2?family=Cairo:wght@400;600;700&family=Montserrat:wght@600;700;800&family=Poppins:wght@400;600;700&display=swap');

:root{
  --bg:#071425;
  --panel:#0b203a;
  --card:#0f2a4a;
  --text:#eef4ff;
  --muted:#b9c7e6;
  --accent:#2fb3ff;
  --accent2:#0fd3b5;
  --line:rgba(255,255,255,.12);
  --radius:16px;

  --ease:cubic-bezier(.2,.8,.2,1);
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family: Poppins, Cairo, Arial, Helvetica, sans-serif;
  background:
    radial-gradient(circle at 18% 28%, rgba(47,179,255,.10) 0 1.6px, transparent 2.4px),
    radial-gradient(circle at 62% 18%, rgba(15,211,181,.10) 0 1.6px, transparent 2.4px),
    radial-gradient(circle at 78% 64%, rgba(47,179,255,.08) 0 1.6px, transparent 2.4px),
    radial-gradient(circle at 34% 72%, rgba(15,211,181,.08) 0 1.6px, transparent 2.4px),
    repeating-linear-gradient(90deg, rgba(255,255,255,.035) 0 1px, transparent 1px 72px),
    repeating-linear-gradient(0deg, rgba(255,255,255,.03) 0 1px, transparent 1px 72px),
    linear-gradient(180deg, var(--bg), #050d18);
  color:var(--text);
  overflow-y: scroll;
}

h1,h2,h3{
  letter-spacing:-0.01em;
}

@keyframes fadeUp{
  from{opacity:0; transform:translateY(10px);}
  to{opacity:1; transform:translateY(0);}
}

.hero .content{
  animation: fadeUp .8s var(--ease) both;
  text-align:center;
}

.container{max-width:1100px; margin:0 auto; padding:0 16px;}
a{color:inherit}

.header{
  position:sticky; top:0; z-index:20;
  background:#ffffff;
  border-bottom:1px solid rgba(0,0,0,.08);
}
.header-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:16px 0;
}
.brand{
  display:flex;
  flex-direction:row;
  align-items:center;
  gap:12px;
  line-height:1.1;
  flex:0 0 auto;
}
.logo{
  height:82px;
  width:auto;
  max-width:180px;
  object-fit:contain;
}
.brand b{color:var(--accent);}
.brand small{color:var(--muted);}

.nav{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  flex:1 1 auto;
  justify-content:flex-end;
}
.nav a{
  text-decoration:none;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid transparent;
  color:rgba(10,20,35,.70);
  text-transform:uppercase;
  letter-spacing:.06em;
  font-size:14px;
  font-weight:700;
  transition: background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease), transform .25s var(--ease);
}
.nav a:hover{
  border-color:rgba(47,179,255,.35);
  background:rgba(47,179,255,.10);
  color:var(--accent);
  transform: translateY(-1px);
}
.nav a:focus-visible{
  outline:2px solid rgba(47,179,255,.55);
  outline-offset:2px;
}
.nav a.active{
  border-color:rgba(47,179,255,.55);
  color:rgba(10,20,35,.95);
}

.nav-toggle{
  display:none;
  width:44px;
  height:44px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.10);
  background: rgba(0,0,0,.02);
  cursor:pointer;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px;
  padding:0;
}

.nav-toggle span{
  display:block;
  width:20px;
  height:2px;
  background: rgba(10,20,35,.80);
  border-radius:999px;
}

.hero{
  position:relative;
  min-height:420px;
  display:flex;
  align-items:center;
  overflow:hidden;
}
.hero img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  filter:brightness(.45);
  transition: opacity .6s ease;
}
.hero img.is-fading{
  opacity:0;
}
.hero .content{
  position:relative;
  padding:70px 0;
}
.hero h1{
  margin:0 0 10px;
  font-size:40px;
}

.hero-title{
  font-family: Montserrat, Poppins, Cairo, Arial, Helvetica, sans-serif;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.06em;
  font-size:clamp(34px, 5.2vw, 64px);
  line-height:1.05;
}

.glint-once{
  position:relative;
  display:inline-block;
  overflow:hidden;
}

.glint-once::after{
  content:"";
  position:absolute;
  inset:-25% -60%;
  background: linear-gradient(120deg, rgba(255,255,255,0) 30%, rgba(255,255,255,.55) 50%, rgba(255,255,255,0) 70%);
  transform: translateX(-120%) skewX(-18deg);
  mix-blend-mode: screen;
  pointer-events:none;
  opacity:0;
  animation: heroGlint 1.1s ease-out .35s 1 both;
}

@keyframes heroGlint{
  0%{opacity:0; transform: translateX(-120%) skewX(-18deg);}
  12%{opacity:.9;}
  55%{opacity:.55;}
  100%{opacity:0; transform: translateX(120%) skewX(-18deg);}
}
.hero p{
  margin:0;
  max-width:760px;
  color:var(--muted);
  line-height:1.7;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:12px 18px;
  border-radius:12px;
  font-weight:700;
  letter-spacing:.02em;
  text-decoration:none;
  transition: transform .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease), color .25s var(--ease), box-shadow .25s var(--ease);
}

.btn-outline{
  border:2px solid rgba(255,255,255,.45);
  color:#ffffff;
  background:rgba(0,0,0,.10);
  backdrop-filter: blur(6px);
}

.btn-outline:hover{
  border-color: rgba(47,179,255,.70);
  color: #ffffff;
  background: rgba(47,179,255,.15);
  transform: translateY(-2px);
  box-shadow: 0 14px 34px rgba(0,0,0,.35);
}

.section{padding:46px 0}
.section.alt{
  background:rgba(255,255,255,.03);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}

.muted{color:var(--muted)}

.company-intro{
  padding-top:26px;
  padding-bottom:26px;
}

.company-intro p{
  margin:0;
  text-align:center;
  max-width: 980px;
  margin-left:auto;
  margin-right:auto;
  line-height:1.8;
}

.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:14px;
}

.gallery-item{
  position:relative;
  display:block;
  border-radius: var(--radius);
  overflow:hidden;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  text-decoration:none;
}

.gallery-item img{
  width:100%;
  height:160px;
  object-fit:cover;
  display:block;
  transition: transform .35s var(--ease), filter .35s var(--ease);
}

.gallery-cap{
  position:absolute;
  left:10px;
  bottom:10px;
  padding:8px 10px;
  border-radius:12px;
  background: rgba(7,20,37,.72);
  border:1px solid rgba(255,255,255,.14);
  color:#ffffff;
  font-weight:700;
  font-size:13px;
  letter-spacing:.02em;
}

.gallery-item::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(0,0,0,.35) 100%);
  pointer-events:none;
}

.gallery-item:hover img{
  transform: scale(1.05);
  filter: saturate(1.05) contrast(1.02);
}

.hd{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
  margin-bottom:14px;
}

.grid-2{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
}
.grid-3{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}

.filter-bar{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  margin:14px 0 18px;
}

.chip{
  appearance:none;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.04);
  color:rgba(255,255,255,.86);
  padding:10px 14px;
  border-radius:999px;
  cursor:pointer;
  font:inherit;
  transition: transform .18s var(--ease), border-color .25s var(--ease), background .25s var(--ease), color .25s var(--ease);
}

.chip:hover{
  transform: translateY(-1px);
  border-color: rgba(47,179,255,.45);
  background: rgba(47,179,255,.10);
}

.chip.active{
  border-color: rgba(47,179,255,.75);
  background: rgba(47,179,255,.18);
  color:#ffffff;
}

.projects-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}

.project-card{
  background:rgba(255,255,255,.05);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
}

.project-card:hover{
  transform: translateY(-4px);
  border-color: rgba(47,179,255,.28);
  box-shadow: 0 16px 40px rgba(0,0,0,.35);
}

.project-top{
  padding:16px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
}

.project-k{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(255,255,255,.68);
}

.project-title{
  font-size:18px;
  margin:8px 0 6px;
}

.project-desc{
  color:var(--muted);
  line-height:1.6;
  margin:0;
}

.project-actions{
  padding:0 16px 16px;
}

.modal{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  padding:20px;
  z-index:1000;
}

.modal.open{display:flex;}

.modal-overlay{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.70);
  backdrop-filter: blur(6px);
}

.modal-panel{
  position:relative;
  width:min(940px, 100%);
  max-height:min(82vh, 760px);
  overflow:auto;
  background: linear-gradient(180deg, rgba(15,35,56,.98), rgba(7,20,37,.98));
  border:1px solid rgba(255,255,255,.16);
  border-radius: calc(var(--radius) + 6px);
  box-shadow: 0 28px 90px rgba(0,0,0,.55);
}

.modal-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  padding:18px 18px 0;
}

.modal-title{
  margin:0;
  font-size:22px;
}

.modal-close{
  border:1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.04);
  color:#fff;
  border-radius:12px;
  padding:10px 12px;
  cursor:pointer;
}

.modal-body{padding:16px 18px 18px;}

.modal-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}

.modal-grid h4{
  margin:0 0 8px;
}

.modal-grid p,.modal-grid ul{color:var(--muted);}

.modal-grid ul{margin:8px 0 0; padding-left:18px;}

.service-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
}

.service-card{
  display:flex;
  flex-direction:column;
}

.service-card h4{margin:14px 0 8px;}

.service-meta{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:12px;
}

.service-cta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:14px;
}

.service-card .service-cta{
  margin-top:auto;
}

.accreditation-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-top:12px;
}

.accreditation-card{
  text-align:center;
  padding:18px;
}

.accreditation-badge{
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:10px;
}

.accreditation-title{
  margin:0 0 6px;
  font-size:16px;
}

.stats{
  margin:0;
}

.stats-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
}

.stats-card{
  background:rgba(255,255,255,.05);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
  text-align:center;
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
}

.stats-card:hover{
  transform: translateY(-4px);
  border-color: rgba(47,179,255,.28);
  box-shadow: 0 16px 40px rgba(0,0,0,.35);
}

.stats-value{
  font-family: Montserrat, Poppins, Cairo, Arial, Helvetica, sans-serif;
  font-weight:800;
  font-size: clamp(34px, 4vw, 54px);
  letter-spacing: .02em;
  color: var(--accent);
  margin-bottom:8px;
}

.stats-label{
  color: rgba(255,255,255,.90);
  font-weight:700;
  line-height:1.35;
}

.card{
  background:rgba(255,255,255,.05);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:16px;
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
}
.card:hover{
  transform: translateY(-4px);
  border-color: rgba(47,179,255,.28);
  box-shadow: 0 16px 40px rgba(0,0,0,.35);
}

.services-highlights{
  display:grid;
  grid-template-columns:repeat(12, minmax(0, 1fr));
  gap:14px;
}

.service-link{
  display:block;
  color:inherit;
  text-decoration:none;
}

.services-highlights > :nth-child(-n + 3){
  grid-column: span 4;
}

.services-highlights > :nth-child(n + 4){
  grid-column: span 3;
}
.card p{
  color:var(--muted);
  line-height:1.6;
}
.card ul{
  margin:10px 0 0;
  padding-left:18px;
  color:var(--muted);
}
.card ul + ul{margin-top:12px;}
.card li{margin:6px 0;}

.contact-item{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding:10px 0;
  border-top:1px solid rgba(255,255,255,.08);
}

.contact-item:first-of-type{border-top:none; padding-top:0;}

.contact-icon{
  width:40px;
  height:40px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg, rgba(47,179,255,.20), rgba(15,211,181,.12));
  border:1px solid rgba(255,255,255,.16);
  color:var(--accent);
  flex:0 0 auto;
}

.contact-text{color:var(--muted);}
.contact-label{
  color:var(--text);
  font-weight:700;
  margin-bottom:2px;
}

.contact-text a{
  color:var(--muted);
  text-decoration:none;
  transition: color .2s var(--ease);
}

.contact-text a:hover{color:var(--accent);}

.logos-grid{
  margin:6px 0 18px;
  display:grid;
  grid-template-columns:repeat(6, minmax(0, 1fr));
  gap:12px;
}

.logo-card{
  background:rgba(255,255,255,.06);
  border:1px solid var(--line);
  border-radius:16px;
  padding:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  min-width:120px;
  min-height:72px;
  transition: transform .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease);
}

.logo-card:hover{
  transform: translateY(-3px);
  border-color: rgba(47,179,255,.28);
  background: rgba(47,179,255,.08);
}

.logo-card img{
  display:block;
  max-width:100%;
  max-height:62px;
  width:auto;
  height:auto;
  object-fit:contain;
  filter: brightness(1.05) contrast(1.05);
}

@keyframes logoScroll{
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}

.logo-ticker{
  margin:6px 0 18px;
  border:1px solid var(--line);
  border-radius:16px;
  background:rgba(255,255,255,.04);
  overflow:hidden;
  position:relative;
}

.logo-ticker::before,
.logo-ticker::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  width:110px;
  z-index:2;
  pointer-events:none;
}

.logo-ticker::before{
  left:0;
  background:linear-gradient(90deg, rgba(7,20,37,1), rgba(7,20,37,0));
}

.logo-ticker::after{
  right:0;
  background:linear-gradient(270deg, rgba(7,20,37,1), rgba(7,20,37,0));
}

.logo-track{
  display:flex;
  gap:16px;
  align-items:center;
  width:max-content;
  padding:18px;
  animation: logoScroll 60s linear infinite;
}

.logo-ticker:hover .logo-track{
  animation-play-state: paused;
}

.clients-mobile-grid{
  display:none;
  margin:6px 0 18px;
  gap:10px;
}

#clients{
  scroll-margin-top: 120px;
}

.clients-grid{
  margin-top:16px;
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:12px;
}

.client-badge{
  background:rgba(255,255,255,.06);
  border:1px solid var(--line);
  border-radius:999px;
  padding:12px 14px;
  text-align:center;
  color:var(--text);
  font-weight:700;
  letter-spacing:.02em;
  transition: transform .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease);
}

.client-badge:hover{
  transform: translateY(-3px);
  border-color: rgba(15,211,181,.28);
  background: rgba(15,211,181,.08);
}

.scroll-top{
  position:fixed;
  right:18px;
  bottom:18px;
  width:44px;
  height:44px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
  color:#ffffff;
  cursor:pointer;
  z-index:1001;
  opacity:0;
  transform: translateY(8px);
  pointer-events:none;
  transition: opacity .25s var(--ease), transform .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease);
}

.scroll-top.is-visible{
  opacity:1;
  transform: translateY(0);
  pointer-events:auto;
}

.scroll-top:hover{
  background: rgba(47,179,255,.12);
  border-color: rgba(47,179,255,.25);
}

.vvv-grid{
  margin-top:10px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px;
}

.vvv-card{
  background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
  position:relative;
  overflow:hidden;
  transition: transform .25s var(--ease), border-color .25s var(--ease), box-shadow .25s var(--ease);
}

.vvv-card:hover{
  transform: translateY(-4px);
  border-color: rgba(47,179,255,.30);
  box-shadow: 0 18px 50px rgba(0,0,0,.38);
}

.vvv-card::before{
  content:"";
  position:absolute;
  inset:-2px;
  background:radial-gradient(500px 120px at 20% 0%, rgba(47,179,255,.22), transparent 60%),
             radial-gradient(500px 120px at 80% 0%, rgba(15,211,181,.18), transparent 60%);
  pointer-events:none;
}

.vvv-top{
  position:relative;
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:10px;
}

.vvv-icon{
  width:44px;
  height:44px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:14px;
  background:linear-gradient(135deg, rgba(47,179,255,.20), rgba(15,211,181,.12));
  border:1px solid rgba(255,255,255,.16);
  color:var(--accent);
  flex:0 0 auto;
}

.vvv-title h3{
  margin:0;
  color:var(--text);
}

.vvv-card p{
  position:relative;
  margin:0;
  color:var(--muted);
  line-height:1.7;
}

.split{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:14px;
}

.media{
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid var(--line);
}
.media img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.footer{
  border-top:1px solid var(--line);
  padding:18px 0;
  color:var(--muted);
}

.site-footer{
  margin-top:40px;
  background:linear-gradient(180deg, rgba(47,179,255,.12), rgba(7,20,37,1));
  border-top:1px solid rgba(255,255,255,.10);
}

.site-footer .footer-inner{
  padding:38px 0 18px;
}

.footer-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr;
  gap:24px;
  align-items:start;
}

.footer-brand{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.footer-brand img{
  height:56px;
  width:auto;
  max-width:200px;
  object-fit:contain;
}

.footer-brand p{
  margin:0;
  color:rgba(255,255,255,.78);
  line-height:1.7;
}

.footer-h{
  margin:6px 0 12px;
  font-weight:800;
  color:#ffffff;
}

.footer-links{
  display:grid;
  gap:10px;
}

.footer-links a{
  color:rgba(255,255,255,.82);
  text-decoration:none;
  transition: color .2s var(--ease), transform .2s var(--ease);
}

.footer-links a:hover{
  color:var(--accent);
  transform: translateX(2px);
}

.footer-cta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:14px;
}

.btn-solid{
  border:0;
  color:#071425;
  background:linear-gradient(135deg, var(--accent), var(--accent2));
  box-shadow: 0 14px 34px rgba(0,0,0,.32);
}

.btn-solid:hover{
  transform: translateY(-2px);
  box-shadow: 0 18px 44px rgba(0,0,0,.38);
}

.footer-row{
  display:flex;
  gap:10px;
  align-items:center;
  margin:8px 0;
  color:rgba(255,255,255,.82);
}

.footer-row a{
  color:rgba(255,255,255,.82);
  text-decoration:none;
}

.footer-row a:hover{color:var(--accent);}

.footer-ico{
  width:34px;
  height:34px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  color:#ffffff;
  flex:0 0 auto;
}

.footer-bottom{
  margin-top:22px;
  padding-top:14px;
  border-top:1px solid rgba(255,255,255,.10);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  color:rgba(255,255,255,.72);
}

.footer-social{
  display:flex;
  gap:10px;
}

.footer-social a{
  width:38px;
  height:38px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  color:#ffffff;
  text-decoration:none;
  transition: transform .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease);
}

.footer-social a:hover{
  transform: translateY(-2px);
  background: rgba(47,179,255,.12);
  border-color: rgba(47,179,255,.25);
}

@media (max-width: 860px){
  .grid-2{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
  .projects-grid{grid-template-columns:1fr}
  .modal-grid{grid-template-columns:1fr}
  .service-grid{grid-template-columns:1fr}
  .service-meta{grid-template-columns:1fr}
}

@media (max-width: 980px){
  .gallery-grid{grid-template-columns:repeat(2, 1fr);}
  .accreditation-grid{grid-template-columns:repeat(2, 1fr);}
  .projects-grid{grid-template-columns:repeat(2, 1fr);}
}

@media (max-width: 900px){
  .grid-3{grid-template-columns:1fr;}
  .grid-2{grid-template-columns:1fr;}
  .split{grid-template-columns:1fr;}
  .hero h1{font-size:32px;}
  .logo{height:64px;}
  .services-highlights{grid-template-columns:repeat(2, minmax(0, 1fr));}
  .services-highlights > :nth-child(-n + 3){grid-column:auto;}
  .services-highlights > :nth-child(n + 4){grid-column:auto;}
  .clients-grid{grid-template-columns:repeat(2, minmax(0, 1fr));}
  .logos-grid{grid-template-columns:repeat(2, minmax(0, 1fr));}
  .vvv-grid{grid-template-columns:1fr;}
  .nav a{font-size:13px; padding:8px 9px;}
  .footer-grid{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column; align-items:flex-start;}
}

@media (max-width: 768px){
  .header-row{
    flex-direction:row;
    align-items:center;
    justify-content:space-between;
    padding:12px 0;
  }

  .hero{
    min-height:360px;
  }

  .hero .content{
    padding:52px 0;
  }

  .hero p{
    font-size:15px;
  }

  .section{
    padding:38px 0;
  }

  .hd{
    flex-direction:column;
    align-items:flex-start;
  }

  .footer-cta .btn{
    width:100%;
  }

  .modal-body .btn + .btn{
    margin-left:0 !important;
    margin-top:10px;
  }
}

@media (max-width: 600px){
  .header-row{
    flex-wrap:wrap;
  }

  .nav-toggle{display:inline-flex;}

  .nav{
    display:none;
    width:100%;
    flex:0 0 100%;
    flex-direction:column;
    align-items:stretch;
    justify-content:flex-start;
    gap:10px;
    padding:10px 0 2px;
  }

  .nav.is-open{display:flex;}

  .nav a{
    width:100%;
    text-align:left;
    border:1px solid rgba(0,0,0,.08);
    background: rgba(0,0,0,.02);
  }

  .logo-ticker{display:none;}
  .clients-mobile-grid{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
  }

  .clients-mobile-grid .logo-card{
    min-width:0;
    min-height:64px;
    padding:10px;
    border-radius:14px;
  }

  .clients-mobile-grid .logo-card img{
    max-height:44px;
  }
}

@media (pointer: coarse) and (max-width: 900px){
  .header-row{
    flex-wrap:wrap;
  }

  .nav-toggle{display:inline-flex;}

  .nav{
    display:none;
    width:100%;
    flex:0 0 100%;
    flex-direction:column;
    align-items:stretch;
    justify-content:flex-start;
    gap:10px;
    padding:10px 0 2px;
  }

  .nav.is-open{display:flex;}

  .nav a{
    width:100%;
    text-align:left;
    border:1px solid rgba(0,0,0,.08);
    background: rgba(0,0,0,.02);
  }
}

@media (max-width: 520px){
  .container{padding:0 14px;}

  .gallery-grid{grid-template-columns:1fr;}
  .accreditation-grid{grid-template-columns:1fr;}
  .projects-grid{grid-template-columns:1fr;}
  .gallery-item img{height:140px;}
  .modal-panel{max-height: 86vh;}

  .logo{
    height:56px;
    max-width:160px;
  }

  .nav a{
    font-size:12px;
    padding:8px 10px;
  }

  .hero{
    min-height:320px;
  }

  .hero .content{
    padding:46px 0;
  }

  .hero-title{
    font-size:clamp(28px, 9vw, 40px);
  }

  .footer-cta .btn{
    width:100%;
  }

  .footer-row{
    flex-wrap:wrap;
  }

  .clients-mobile-grid{grid-template-columns:repeat(2, minmax(0, 1fr));}

  .stats-grid{grid-template-columns:1fr;}

  .services-highlights{grid-template-columns:1fr;}
}

@media (prefers-reduced-motion: reduce){
  *{animation:none !important; transition:none !important; scroll-behavior:auto !important;}
}
