@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;600;700;800;900&family=Open+Sans:wght@300;400;500;600&display=swap');

:root {
  --primary: #0a1628;
  --primary2: #162a4a;
  --gold: #c8960c;
  --orange: #e87722;
  --white: #fff;
  --offwhite: #f8f9fa;
  --gray: #6c757d;
  --lgray: #e9ecef;
  --dark: #1a1a2e;
  --fh: 'Montserrat', sans-serif;
  --fb: 'Open Sans', sans-serif;
  --s1: 0 2px 12px rgba(0,0,0,.08);
  --s2: 0 8px 32px rgba(0,0,0,.12);
  --s3: 0 20px 60px rgba(0,0,0,.18);
  --r: 12px;
  --rl: 22px;
  --tr: all .35s cubic-bezier(.4,0,.2,1);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:var(--fb); color:var(--dark); overflow-x:hidden; background:#fff; }
img { max-width:100%; height:auto; display:block; }
a { text-decoration:none; color:inherit; }
ul { list-style:none; }
button { cursor:pointer; border:none; outline:none; background:none; }

/* ── PAGE TRANSITION ── */
.pg-overlay {
  position:fixed; inset:0; z-index:9999;
  background:var(--primary); transform:translateX(-100%);
  transition:transform .55s cubic-bezier(.77,0,.175,1); pointer-events:none;
}
.pg-overlay.in  { transform:translateX(0); }
.pg-overlay.out { transform:translateX(100%); }

/* ── HEADER ── */
header {
  position:fixed; inset:0 0 auto; z-index:1000;
  padding:0 20px; transition:var(--tr);
}
header.solid { background:var(--primary); box-shadow:var(--s3); }
.h-inner {
  max-width:1300px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; height:68px;
}
.logo { display:flex; align-items:center; gap:10px; }
.logo svg { width:44px; height:44px; flex-shrink:0; }
.logo-txt strong { display:block; font-family:var(--fh); color:#fff; font-size:1.05rem; font-weight:800; line-height:1.15; }
.logo-txt span   { font-size:.58rem; letter-spacing:2.5px; text-transform:uppercase; color:var(--gold); }

nav { display:flex; align-items:center; gap:4px; }
nav a {
  color:rgba(255,255,255,.82); font-family:var(--fh); font-size:.78rem;
  font-weight:700; letter-spacing:.6px; text-transform:uppercase;
  padding:8px 14px; border-radius:8px; transition:var(--tr);
}
nav a:hover, nav a.on { color:#fff; background:rgba(200,150,12,.18); }
nav a.on { color:var(--gold); }
.nav-btn {
  background:linear-gradient(135deg,var(--gold),var(--orange));
  color:#fff !important; padding:10px 22px !important;
  border-radius:30px !important; box-shadow:0 4px 16px rgba(200,150,12,.4);
}
.nav-btn:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(200,150,12,.55) !important; }

.hbg { display:none; flex-direction:column; gap:5px; padding:8px; }
.hbg span { width:24px; height:2px; background:#fff; border-radius:2px; transition:var(--tr); display:block; }
.hbg.x span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hbg.x span:nth-child(2) { opacity:0; }
.hbg.x span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

.mnav {
  display:none; position:fixed; top:68px; inset-x:0; z-index:998;
  background:var(--primary); padding:16px; border-bottom:1px solid rgba(255,255,255,.08);
  flex-direction:column; gap:3px;
  opacity:0; transform:translateY(-16px); transition:var(--tr); pointer-events:none;
}
.mnav.open { opacity:1; transform:translateY(0); pointer-events:all; }
.mnav a {
  color:rgba(255,255,255,.82); font-family:var(--fh); font-size:.86rem; font-weight:700;
  letter-spacing:.6px; text-transform:uppercase; padding:13px 16px;
  border-radius:8px; transition:var(--tr);
}
.mnav a:hover, .mnav a.on { background:rgba(200,150,12,.15); color:var(--gold); }

/* ── HERO ── */
.hero {
  position:relative; height:100vh; min-height:580px;
  overflow:hidden; display:flex; align-items:center;
}
.slides { position:absolute; inset:0; }
.slide {
  position:absolute; inset:0; background-size:cover; background-position:center;
  opacity:0; transition:opacity 1.4s ease;
  animation:kb 8s ease-in-out infinite alternate;
}
.slide.on { opacity:1; }
@keyframes kb { from{transform:scale(1)} to{transform:scale(1.07)} }
.slide:nth-child(1) { background-image:url('https://images.unsplash.com/photo-1486325212027-8081e485255e?w=1920&q=80'); }
.slide:nth-child(2) { background-image:url('https://images.unsplash.com/photo-1545324418-cc1a3fa10c00?w=1920&q=80'); animation-delay:-2s; }
.slide:nth-child(3) { background-image:url('https://images.unsplash.com/photo-1504307651254-35680f356dfd?w=1920&q=80'); animation-delay:-4s; }
.slide:nth-child(4) { background-image:url('https://images.unsplash.com/photo-1564013799919-ab600027ffc6?w=1920&q=80'); animation-delay:-6s; }
.slide:nth-child(5) { background-image:url('https://images.unsplash.com/photo-1580587771525-78b9dba3b914?w=1920&q=80'); animation-delay:-8s; }
.hero-dim {
  position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(10,22,40,.9) 0%,rgba(10,22,40,.5) 55%,rgba(10,22,40,.2) 100%);
}
.hero-body {
  position:relative; z-index:2; max-width:1300px;
  margin:0 auto; padding:0 24px; width:100%;
}
.hero-tag {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(200,150,12,.18); border:1px solid rgba(200,150,12,.4);
  color:var(--gold); padding:8px 20px; border-radius:30px;
  font-family:var(--fh); font-size:.7rem; font-weight:700;
  letter-spacing:2px; text-transform:uppercase; margin-bottom:22px;
  backdrop-filter:blur(8px); animation:fu .8s ease both;
}
.hero-h1 {
  font-family:var(--fh); color:#fff;
  font-size:clamp(2.2rem,5.5vw,4.4rem); font-weight:900;
  line-height:1.1; margin-bottom:20px; letter-spacing:-1px;
  animation:fu .8s .2s ease both;
}
.hero-h1 em {
  font-style:normal;
  background:linear-gradient(135deg,var(--gold),var(--orange));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.hero-p {
  color:rgba(255,255,255,.8); font-size:clamp(.95rem,1.8vw,1.1rem);
  line-height:1.85; max-width:540px; margin-bottom:34px;
  animation:fu .8s .4s ease both;
}
.hero-btns { display:flex; flex-wrap:wrap; gap:14px; animation:fu .8s .6s ease both; }
@keyframes fu { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }

.hero-bar {
  position:absolute; bottom:32px; left:0; right:0; z-index:2;
  max-width:1300px; margin:0 auto; padding:0 24px;
}
.hero-bar-inner {
  display:flex; max-width:580px;
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.15);
  border-radius:var(--rl); overflow:hidden; backdrop-filter:blur(16px);
}
.hstat { flex:1; text-align:center; padding:16px 12px; border-right:1px solid rgba(255,255,255,.1); }
.hstat:last-child { border:none; }
.hstat b { display:block; font-family:var(--fh); font-size:1.5rem; font-weight:900; color:var(--gold); }
.hstat s { font-size:.65rem; letter-spacing:1px; text-transform:uppercase; color:rgba(255,255,255,.65); text-decoration:none; }

.sdots { position:absolute; bottom:38px; right:24px; z-index:2; display:flex; gap:8px; }
.sdot { width:8px; height:8px; border-radius:50%; background:rgba(255,255,255,.4); cursor:pointer; transition:var(--tr); }
.sdot.on { background:var(--gold); transform:scale(1.35); }

/* ── BUTTONS ── */
.btn-g {
  display:inline-flex; align-items:center; gap:8px;
  background:linear-gradient(135deg,var(--gold),var(--orange));
  color:#fff; padding:13px 30px; border-radius:50px;
  font-family:var(--fh); font-size:.86rem; font-weight:700;
  letter-spacing:.5px; text-transform:uppercase;
  box-shadow:0 6px 28px rgba(200,150,12,.4); transition:var(--tr);
}
.btn-g:hover { transform:translateY(-3px); box-shadow:0 12px 36px rgba(200,150,12,.55); }
.btn-o {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.1); color:#fff; padding:13px 30px; border-radius:50px;
  border:1px solid rgba(255,255,255,.3); font-family:var(--fh); font-size:.86rem;
  font-weight:700; letter-spacing:.5px; text-transform:uppercase;
  backdrop-filter:blur(10px); transition:var(--tr);
}
.btn-o:hover { background:rgba(255,255,255,.2); transform:translateY(-3px); }
.btn-d {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--primary); color:#fff; padding:13px 30px; border-radius:50px;
  font-family:var(--fh); font-size:.86rem; font-weight:700;
  letter-spacing:.5px; text-transform:uppercase; transition:var(--tr);
  box-shadow:0 4px 16px rgba(10,22,40,.3);
}
.btn-d:hover { transform:translateY(-3px); box-shadow:0 10px 32px rgba(10,22,40,.5); }

/* ── SECTIONS ── */
section { padding:80px 24px; }
.wrap { max-width:1300px; margin:0 auto; }
.stag {
  display:inline-flex; align-items:center; gap:8px;
  color:var(--gold); font-family:var(--fh); font-size:.7rem;
  font-weight:700; letter-spacing:3px; text-transform:uppercase; margin-bottom:14px;
}
.stag::before, .stag::after {
  content:''; width:28px; height:2px;
  background:linear-gradient(to right,var(--gold),var(--orange));
}
.stag::after { display:none; }
.sh { font-family:var(--fh); color:var(--primary); font-size:clamp(1.75rem,3.5vw,2.75rem); font-weight:800; line-height:1.2; margin-bottom:14px; letter-spacing:-.4px; }
.sh span { background:linear-gradient(135deg,var(--gold),var(--orange)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.sp { color:var(--gray); font-size:.97rem; line-height:1.85; max-width:540px; margin-bottom:48px; }
.tc { text-align:center; }
.tc .stag { justify-content:center; }
.tc .stag::before { display:none; }
.tc .stag::after { display:block; }
.tc .sp { margin:0 auto 48px; }

/* ── SERVICES ── */
.svc-bg { background:var(--offwhite); }
.svc-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(270px,1fr)); gap:22px; margin-top:48px; }
.svc-card {
  background:#fff; border-radius:var(--rl); padding:34px 26px;
  box-shadow:var(--s1); transition:var(--tr);
  border:1px solid rgba(0,0,0,.04); position:relative; overflow:hidden;
}
.svc-card::after {
  content:''; position:absolute; top:0; inset-x:0; height:4px;
  background:linear-gradient(to right,var(--gold),var(--orange));
  transform:scaleX(0); transform-origin:left; transition:var(--tr);
}
.svc-card:hover { transform:translateY(-8px); box-shadow:var(--s3); }
.svc-card:hover::after { transform:scaleX(1); }
.svc-ico {
  width:62px; height:62px; background:linear-gradient(135deg,rgba(200,150,12,.1),rgba(232,119,34,.1));
  border-radius:14px; display:flex; align-items:center; justify-content:center;
  font-size:28px; margin-bottom:22px; transition:var(--tr);
}
.svc-card:hover .svc-ico { background:linear-gradient(135deg,var(--gold),var(--orange)); transform:scale(1.08); }
.svc-card h3 { font-family:var(--fh); font-size:1.02rem; font-weight:700; color:var(--primary); margin-bottom:10px; }
.svc-card p { color:var(--gray); font-size:.86rem; line-height:1.75; }
.svc-lnk {
  display:inline-flex; align-items:center; gap:6px; color:var(--gold);
  font-family:var(--fh); font-size:.75rem; font-weight:700;
  text-transform:uppercase; letter-spacing:1px; margin-top:18px; transition:var(--tr);
}
.svc-lnk:hover { gap:10px; }

/* ── ABOUT ── */
.ab-grid { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
.ab-imgs { position:relative; }
.ab-main { width:100%; height:460px; object-fit:cover; border-radius:var(--rl); box-shadow:var(--s3); }
.ab-accent {
  position:absolute; bottom:-28px; right:-18px;
  width:210px; height:170px; object-fit:cover;
  border-radius:var(--r); border:6px solid #fff; box-shadow:var(--s2);
}
.ab-badge {
  position:absolute; top:28px; left:-18px;
  background:linear-gradient(135deg,var(--gold),var(--orange));
  color:#fff; padding:18px 22px; border-radius:var(--rl);
  box-shadow:var(--s2); text-align:center;
}
.ab-badge b { display:block; font-family:var(--fh); font-size:2rem; font-weight:900; }
.ab-badge s { text-decoration:none; font-size:.7rem; letter-spacing:1px; opacity:.9; }
.ab-feats { margin:26px 0; display:flex; flex-direction:column; gap:14px; }
.ab-feat {
  display:flex; align-items:flex-start; gap:12px;
  padding:14px; background:var(--offwhite); border-radius:var(--r);
}
.ab-feat-ico {
  width:38px; height:38px; flex-shrink:0;
  background:linear-gradient(135deg,var(--gold),var(--orange));
  border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:17px;
}
.ab-feat h4 { font-family:var(--fh); font-size:.86rem; font-weight:700; color:var(--primary); margin-bottom:3px; }
.ab-feat p { font-size:.82rem; color:var(--gray); }

/* ── STATS ── */
.stats-bg {
  background:linear-gradient(135deg,var(--primary),var(--primary2));
  padding:56px 24px;
}
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.stat-c { text-align:center; padding:26px 16px; }
.stat-n {
  display:block; font-family:var(--fh);
  font-size:clamp(2rem,4.5vw,3.4rem); font-weight:900;
  color:var(--gold); line-height:1; margin-bottom:8px;
}
.stat-l { color:rgba(255,255,255,.68); font-size:.78rem; letter-spacing:1px; text-transform:uppercase; }

/* ── PROJECTS ── */
.proj-bg { background:var(--offwhite); }
.proj-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.proj-card { border-radius:var(--rl); overflow:hidden; box-shadow:var(--s1); transition:var(--tr); background:#fff; }
.proj-card:hover { transform:translateY(-8px); box-shadow:var(--s3); }
.proj-img { position:relative; height:230px; overflow:hidden; }
.proj-img img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.proj-card:hover .proj-img img { transform:scale(1.07); }
.proj-tag {
  position:absolute; top:14px; left:14px;
  background:linear-gradient(135deg,var(--gold),var(--orange));
  color:#fff; padding:4px 13px; border-radius:20px;
  font-family:var(--fh); font-size:.65rem; font-weight:700;
  letter-spacing:1px; text-transform:uppercase;
}
.proj-info { padding:18px 20px; }
.proj-info h3 { font-family:var(--fh); font-size:.96rem; font-weight:700; color:var(--primary); margin-bottom:6px; }
.proj-info p { color:var(--gray); font-size:.83rem; line-height:1.7; }
.proj-meta {
  display:flex; justify-content:space-between; align-items:center;
  margin-top:14px; padding-top:14px; border-top:1px solid var(--lgray);
  font-size:.76rem; color:var(--gold); font-weight:600;
}

/* ── TEAM ── */
.team-bg { background:var(--offwhite); }
.team-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:26px; }
.team-card { background:#fff; border-radius:var(--rl); overflow:hidden; box-shadow:var(--s1); transition:var(--tr); text-align:center; }
.team-card:hover { transform:translateY(-8px); box-shadow:var(--s3); }
.team-img-w { position:relative; height:270px; overflow:hidden; background:linear-gradient(135deg,var(--primary),var(--primary2)); }
.team-img-w img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.team-card:hover .team-img-w img { transform:scale(1.05); }
.team-ov {
  position:absolute; inset:0; background:rgba(10,22,40,.72);
  display:flex; align-items:center; justify-content:center; gap:12px;
  opacity:0; transition:var(--tr);
}
.team-card:hover .team-ov { opacity:1; }
.t-btn {
  width:40px; height:40px; border-radius:50%;
  background:var(--gold); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:.95rem; transition:var(--tr);
}
.t-btn:hover { background:#fff; color:var(--gold); transform:scale(1.1); }
.team-info { padding:22px 18px; }
.t-name { font-family:var(--fh); font-size:1.05rem; font-weight:800; color:var(--primary); margin-bottom:4px; }
.t-role { color:var(--gold); font-size:.72rem; font-weight:700; letter-spacing:1px; text-transform:uppercase; margin-bottom:10px; }
.t-desc { color:var(--gray); font-size:.82rem; line-height:1.65; }
.t-badge { display:inline-block; background:rgba(200,150,12,.1); color:var(--gold); padding:3px 11px; border-radius:18px; font-size:.68rem; font-weight:600; margin-top:10px; }

/* ── TESTIMONIALS ── */
.testi-bg { background:#fff; }
.testi-outer { position:relative; overflow:hidden; }
.testi-track { display:flex; transition:transform .5s cubic-bezier(.4,0,.2,1); }
.testi-slide { min-width:100%; padding:0 4px; }
.testi-card {
  background:var(--offwhite); border-radius:var(--rl); padding:38px;
  max-width:780px; margin:0 auto; position:relative;
  border:1px solid rgba(200,150,12,.1);
}
.testi-card::before {
  content:'"'; font-size:7rem; font-family:Georgia,serif;
  color:rgba(200,150,12,.1); position:absolute; top:-18px; left:28px; line-height:1;
}
.t-stars { color:var(--gold); font-size:1.1rem; margin-bottom:18px; }
.t-text { color:var(--dark); font-size:.97rem; line-height:1.85; font-style:italic; margin-bottom:26px; }
.t-author { display:flex; align-items:center; gap:13px; }
.t-avatar { width:52px; height:52px; border-radius:50%; object-fit:cover; border:3px solid var(--gold); }
.t-aname { font-family:var(--fh); font-size:.92rem; font-weight:700; color:var(--primary); }
.t-acity { font-size:.76rem; color:var(--gold); }
.testi-nav { display:flex; justify-content:center; align-items:center; gap:10px; margin-top:28px; }
.tbtn {
  width:40px; height:40px; border-radius:50%;
  background:var(--offwhite); border:1px solid var(--lgray);
  color:var(--primary); font-size:.95rem;
  display:flex; align-items:center; justify-content:center; transition:var(--tr);
}
.tbtn:hover { background:var(--gold); color:#fff; border-color:var(--gold); }
.tdots { display:flex; gap:7px; }
.tdot { width:7px; height:7px; border-radius:50%; background:var(--lgray); border:none; cursor:pointer; transition:var(--tr); }
.tdot.on { background:var(--gold); transform:scale(1.3); }

/* ── CTA ── */
.cta-bg {
  background:linear-gradient(135deg,var(--primary),var(--primary2));
  padding:80px 24px; text-align:center; position:relative; overflow:hidden;
}
.cta-bg::before {
  content:''; position:absolute; inset:0;
  background:url('https://images.unsplash.com/photo-1503387762-592deb58ef4e?w=1920&q=40') center/cover;
  opacity:.07;
}
.cta-in { position:relative; z-index:1; max-width:680px; margin:0 auto; }
.cta-in .sh { color:#fff; }
.cta-in > p { color:rgba(255,255,255,.72); font-size:.97rem; line-height:1.85; margin-bottom:34px; }
.cta-btns { display:flex; flex-wrap:wrap; gap:14px; justify-content:center; }

/* ── PAGE BANNER ── */
.pg-banner {
  height:300px; position:relative; display:flex; align-items:center;
  background:linear-gradient(135deg,var(--primary),var(--primary2));
  overflow:hidden; margin-top:68px;
}
.pg-banner::before { content:''; position:absolute; inset:0; background-size:cover; background-position:center; opacity:.14; }
.pg-banner.ab::before { background-image:url('https://images.unsplash.com/photo-1503387762-592deb58ef4e?w=1400&q=50'); }
.pg-banner.pr::before { background-image:url('https://images.unsplash.com/photo-1486325212027-8081e485255e?w=1400&q=50'); }
.pg-banner.gl::before { background-image:url('https://images.unsplash.com/photo-1545324418-cc1a3fa10c00?w=1400&q=50'); }
.pg-banner-in { position:relative; z-index:1; padding:0 24px; max-width:1300px; margin:0 auto; width:100%; }
.pg-banner-in h1 { font-family:var(--fh); color:#fff; font-size:clamp(2rem,5vw,3.4rem); font-weight:900; margin-bottom:10px; }
.bc { display:flex; align-items:center; gap:7px; }
.bc a, .bc span { color:rgba(255,255,255,.58); font-size:.88rem; }
.bc .sep, .bc .cur { color:var(--gold); }
.bc a:hover { color:var(--gold); }

/* ── GALLERY ── */
.gal-filter { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:34px; }
.fbtn {
  padding:8px 20px; border-radius:28px;
  border:2px solid var(--lgray); background:#fff;
  color:var(--gray); font-family:var(--fh); font-size:.75rem;
  font-weight:700; text-transform:uppercase; letter-spacing:1px; cursor:pointer; transition:var(--tr);
}
.fbtn.on, .fbtn:hover { background:linear-gradient(135deg,var(--gold),var(--orange)); border-color:transparent; color:#fff; }
.gal-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(270px,1fr)); gap:14px; }
.gal-item { position:relative; border-radius:var(--r); overflow:hidden; cursor:pointer; aspect-ratio:4/3; }
.gal-item img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.gal-item:hover img { transform:scale(1.07); }
.gal-ov {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(10,22,40,.88) 0%,transparent 55%);
  opacity:0; transition:var(--tr); display:flex; align-items:flex-end; padding:18px;
}
.gal-item:hover .gal-ov { opacity:1; }
.gal-ov h4 { color:#fff; font-family:var(--fh); font-size:.86rem; font-weight:700; }
.gal-ov p { color:rgba(255,255,255,.65); font-size:.76rem; }
.gal-zoom {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%) scale(0);
  width:46px; height:46px; border-radius:50%;
  background:rgba(255,255,255,.18); backdrop-filter:blur(8px);
  border:2px solid rgba(255,255,255,.45);
  color:#fff; font-size:1.15rem;
  display:flex; align-items:center; justify-content:center; transition:var(--tr);
}
.gal-item:hover .gal-zoom { transform:translate(-50%,-50%) scale(1); }
.gal-item.lg { grid-column:span 2; }

/* ── LIGHTBOX ── */
.lb {
  position:fixed; inset:0; background:rgba(0,0,0,.95); z-index:9500;
  display:flex; align-items:center; justify-content:center; padding:20px;
  opacity:0; visibility:hidden; transition:var(--tr);
}
.lb.open { opacity:1; visibility:visible; }
.lb-wrap { position:relative; max-width:90vw; max-height:85vh; }
.lb-wrap img { max-width:100%; max-height:85vh; object-fit:contain; border-radius:var(--r); }
.lb-x {
  position:absolute; top:-15px; right:-15px;
  width:38px; height:38px; border-radius:50%;
  background:var(--gold); color:#fff;
  display:flex; align-items:center; justify-content:center; font-size:1rem; cursor:pointer; transition:var(--tr);
}
.lb-x:hover { background:var(--orange); transform:scale(1.1); }
.lb-nav {
  position:absolute; top:50%; transform:translateY(-50%);
  width:46px; height:46px; border-radius:50%;
  background:rgba(255,255,255,.15); backdrop-filter:blur(8px);
  color:#fff; font-size:1.1rem; cursor:pointer;
  display:flex; align-items:center; justify-content:center; transition:var(--tr);
  border:1px solid rgba(255,255,255,.2);
}
.lb-nav:hover { background:var(--gold); }
.lb-prev { left:-56px; }
.lb-next { right:-56px; }

/* ── PROJECTS FULL PAGE ── */
.pf-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:26px; }
.pf-card { background:#fff; border-radius:var(--rl); overflow:hidden; box-shadow:var(--s1); transition:var(--tr); }
.pf-card:hover { transform:translateY(-6px); box-shadow:var(--s3); }
.pf-img { position:relative; height:250px; overflow:hidden; }
.pf-img img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.pf-card:hover .pf-img img { transform:scale(1.05); }
.pf-body { padding:22px; }
.pf-badge {
  display:inline-block; background:linear-gradient(135deg,var(--gold),var(--orange));
  color:#fff; padding:3px 12px; border-radius:18px;
  font-family:var(--fh); font-size:.65rem; font-weight:700;
  letter-spacing:1px; text-transform:uppercase; margin-bottom:8px;
}
.pf-body h3 { font-family:var(--fh); font-size:1.02rem; font-weight:700; color:var(--primary); margin-bottom:7px; }
.pf-body p { color:var(--gray); font-size:.84rem; line-height:1.72; }
.pf-specs { display:flex; flex-wrap:wrap; gap:8px; margin-top:14px; }
.spec { background:var(--offwhite); color:var(--gold); padding:3px 11px; border-radius:18px; font-size:.7rem; font-weight:600; border:1px solid rgba(200,150,12,.2); }

/* ── FOOTER ── */
footer { background:#060d1a; color:rgba(255,255,255,.65); padding:58px 24px 0; }
.ft-grid {
  max-width:1300px; margin:0 auto;
  display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:44px;
  padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.07);
}
.ft-about p { font-size:.86rem; line-height:1.85; max-width:270px; margin-top:14px; }
.ft-social { display:flex; gap:9px; margin-top:22px; }
.fsoc {
  width:38px; height:38px; border-radius:9px;
  display:flex; align-items:center; justify-content:center; font-size:.95rem;
  color:#fff; transition:var(--tr);
}
.fsoc:hover { transform:translateY(-4px); opacity:.9; }
.fsoc.fb { background:#1877F2; }
.fsoc.ig { background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); }
.fsoc.tw { background:#1DA1F2; }
.fsoc.yt { background:#FF0000; }
.ft-col h4 {
  font-family:var(--fh); color:#fff; font-size:.84rem; font-weight:700;
  text-transform:uppercase; letter-spacing:1px; margin-bottom:22px;
  padding-bottom:10px; border-bottom:2px solid var(--gold); display:inline-block;
}
.ft-links { display:flex; flex-direction:column; gap:9px; }
.ft-links a { color:rgba(255,255,255,.58); font-size:.83rem; transition:var(--tr); display:flex; align-items:center; gap:7px; }
.ft-links a::before { content:'›'; color:var(--gold); font-size:1.1rem; }
.ft-links a:hover { color:var(--gold); padding-left:4px; }
.ft-contacts { display:flex; flex-direction:column; gap:13px; }
.ftc { display:flex; align-items:flex-start; gap:11px; }
.ftc-ico { width:34px; height:34px; flex-shrink:0; background:rgba(200,150,12,.14); border-radius:8px; display:flex; align-items:center; justify-content:center; color:var(--gold); font-size:.85rem; }
.ftc strong { display:block; color:#fff; font-size:.8rem; margin-bottom:2px; }
.ftc a, .ftc span { color:rgba(255,255,255,.58); font-size:.8rem; transition:var(--tr); }
.ftc a:hover { color:var(--gold); }
.ft-bot {
  max-width:1300px; margin:0 auto;
  display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between;
  padding:18px 0; gap:10px;
}
.ft-bot p { font-size:.78rem; }
.ft-bot-links { display:flex; gap:18px; }
.ft-bot-links a { color:rgba(255,255,255,.42); font-size:.78rem; transition:var(--tr); }
.ft-bot-links a:hover { color:var(--gold); }

/* ── FLOATING ── */
.fabs { position:fixed; bottom:26px; right:18px; z-index:900; display:flex; flex-direction:column; gap:11px; align-items:flex-end; }
.fab {
  width:52px; height:52px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:1.25rem; transition:var(--tr); box-shadow:0 4px 18px rgba(0,0,0,.28); cursor:pointer;
}
.fab:hover { transform:scale(1.1); }
.fab-c { background:linear-gradient(135deg,var(--gold),var(--orange)); color:#fff; position:relative; }
.fab-w { background:#25D366; color:#fff; animation:bou 2.5s ease infinite; }
.fab-w:hover { animation:none; }
.fab-p { background:var(--primary); color:var(--gold); border:2px solid var(--gold); }
@keyframes bou { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-7px)} }
.fab-ring { position:absolute; inset:-5px; border-radius:50%; border:2px solid var(--gold); animation:pr 2s ease infinite; }
@keyframes pr { 0%{transform:scale(1);opacity:.8} 100%{transform:scale(1.6);opacity:0} }

/* ── POPUP ── */
.pop-ov {
  position:fixed; inset:0; background:rgba(0,0,0,.72);
  backdrop-filter:blur(4px); z-index:9000;
  display:flex; align-items:center; justify-content:center; padding:20px;
  opacity:0; visibility:hidden; transition:var(--tr);
}
.pop-ov.open { opacity:1; visibility:visible; }
.pop {
  background:#fff; border-radius:var(--rl); width:100%; max-width:480px;
  overflow:hidden; transform:translateY(28px) scale(.95);
  transition:var(--tr); box-shadow:0 40px 80px rgba(0,0,0,.35);
}
.pop-ov.open .pop { transform:translateY(0) scale(1); }
.pop-head {
  background:linear-gradient(135deg,var(--primary),var(--primary2));
  padding:26px 26px 18px; position:relative;
}
.pop-head h3 { font-family:var(--fh); color:#fff; font-size:1.15rem; font-weight:800; margin-bottom:5px; }
.pop-head p { color:rgba(255,255,255,.66); font-size:.82rem; }
.pop-x {
  position:absolute; top:14px; right:14px;
  width:34px; height:34px; border-radius:50%;
  background:rgba(255,255,255,.14); color:#fff;
  display:flex; align-items:center; justify-content:center; font-size:1rem; cursor:pointer; transition:var(--tr);
}
.pop-x:hover { background:rgba(255,255,255,.28); transform:rotate(90deg); }
.pop-qc { display:flex; gap:9px; padding:18px 26px; border-bottom:1px solid var(--lgray); }
.qcbtn {
  flex:1; padding:11px 6px; border-radius:var(--r);
  display:flex; flex-direction:column; align-items:center; gap:5px;
  border:2px solid; transition:var(--tr); text-decoration:none;
}
.qcbtn:hover { transform:translateY(-2px); }
.qcbtn.ph { border-color:var(--gold); background:rgba(200,150,12,.05); }
.qcbtn.wa { border-color:#25D366; background:rgba(37,211,102,.05); }
.qcbtn.em { border-color:var(--primary); background:rgba(10,22,40,.05); }
.qcbtn span { font-size:1.3rem; }
.qcbtn strong { font-family:var(--fh); font-size:.64rem; text-transform:uppercase; letter-spacing:1px; }
.qcbtn.ph strong { color:var(--gold); }
.qcbtn.wa strong { color:#25D366; }
.qcbtn.em strong { color:var(--primary); }
.qcbtn small { font-size:.64rem; color:#999; }
.pop-form { padding:18px 26px 26px; }
.pop-form h4 { font-family:var(--fh); font-size:.86rem; font-weight:700; color:var(--primary); margin-bottom:14px; }
.fg { margin-bottom:12px; }
.fg input, .fg textarea, .fg select {
  width:100%; padding:11px 15px; border-radius:var(--r);
  border:1.5px solid var(--lgray); font-family:var(--fb); font-size:.86rem;
  color:var(--dark); background:var(--offwhite); transition:var(--tr); outline:none;
}
.fg input:focus, .fg textarea:focus, .fg select:focus { border-color:var(--gold); background:#fff; box-shadow:0 0 0 3px rgba(200,150,12,.1); }
.fg textarea { height:82px; resize:none; }
.pop-send {
  width:100%; padding:13px;
  background:linear-gradient(135deg,var(--gold),var(--orange));
  color:#fff; border-radius:var(--r); font-family:var(--fh); font-size:.86rem;
  font-weight:700; letter-spacing:.5px; text-transform:uppercase; cursor:pointer;
  transition:var(--tr); box-shadow:0 4px 14px rgba(200,150,12,.3);
}
.pop-send:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(200,150,12,.4); }

/* ── MISSION ── */
.mis-grid { display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.mis-card { padding:34px; border-radius:var(--rl); border:1px solid var(--lgray); transition:var(--tr); position:relative; overflow:hidden; }
.mis-card::before { content:''; position:absolute; top:0; left:0; bottom:0; width:4px; background:linear-gradient(to bottom,var(--gold),var(--orange)); }
.mis-card:hover { box-shadow:var(--s2); border-color:rgba(200,150,12,.2); }
.mis-ico { font-size:2.3rem; margin-bottom:18px; }
.mis-card h3 { font-family:var(--fh); font-size:1.1rem; font-weight:800; color:var(--primary); margin-bottom:12px; }
.mis-card p { color:var(--gray); line-height:1.82; font-size:.9rem; }

/* ── SCROLL REVEAL ── */
.rv { opacity:0; transform:translateY(36px); transition:opacity .7s ease,transform .7s ease; }
.rl { opacity:0; transform:translateX(-36px); transition:opacity .7s ease,transform .7s ease; }
.rr { opacity:0; transform:translateX(36px); transition:opacity .7s ease,transform .7s ease; }
.rv.vis, .rl.vis, .rr.vis { opacity:1; transform:none; }

/* ── RESPONSIVE ── */
@media(max-width:1024px) {
  .ab-grid { grid-template-columns:1fr; gap:36px; }
  .ab-imgs { display:none; }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .proj-grid { grid-template-columns:repeat(2,1fr); }
  .ft-grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:768px) {
  section { padding:56px 18px; }
  nav { display:none; }
  .hbg { display:flex; }
  .mnav { display:flex; }
  .proj-grid { grid-template-columns:1fr; }
  .team-grid { grid-template-columns:repeat(2,1fr); }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .ft-grid { grid-template-columns:1fr; gap:28px; }
  .gal-item.lg { grid-column:span 1; }
  .pf-grid { grid-template-columns:1fr; }
  .mis-grid { grid-template-columns:1fr; }
  .lb-prev { left:-8px; }
  .lb-next { right:-8px; }
}
@media(max-width:480px) {
  .hero-h1 { font-size:2rem; }
  .hero-btns { flex-direction:column; }
  .hero-bar { display:none; }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .team-grid { grid-template-columns:1fr; }
  .cta-btns { flex-direction:column; align-items:center; }
  .ft-social { justify-content:center; }
  .pop-qc { flex-direction:column; }
}
