/* ======================================================
   AFRITECH — SHARED DESIGN SYSTEM
   Grey · Blue · White · Black
====================================================== */
@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@300;400;600;700;800&family=Barlow:wght@300;400;500;600&display=swap');

:root{
  --white:#ffffff;
  --off-white:#f4f6f8;
  --blue:#0e87c0;
  --blue-dark:#0a6a97;
  --blue-light:#d6edf8;
  --grey-100:#e8ecf0;
  --grey-300:#b0bbc6;
  --grey-500:#6b7a8d;
  --grey-700:#3a4553;
  --black:#111820;
  --font-head:'Barlow Condensed',sans-serif;
  --font-body:'Barlow',sans-serif;
  --radius:6px;
  --shadow:0 4px 24px rgba(14,135,192,.12);
  --transition:0.3s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);background:var(--white);color:var(--grey-700);overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}

/* ===== UTILITY ===== */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.section{padding:80px 0}
.section-title{font-family:var(--font-head);font-size:clamp(2rem,4vw,2.8rem);font-weight:700;color:var(--black);letter-spacing:.5px;margin-bottom:8px}
.section-sub{font-size:1rem;color:var(--grey-500);margin-bottom:48px;max-width:540px}
.tag{display:inline-block;background:var(--blue-light);color:var(--blue-dark);font-family:var(--font-head);font-size:.75rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:4px 14px;border-radius:2px;margin-bottom:16px}
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 32px;border-radius:var(--radius);font-family:var(--font-head);font-size:1.05rem;font-weight:700;letter-spacing:.5px;cursor:pointer;transition:var(--transition);border:none}
.btn-primary{background:var(--blue);color:var(--white)}
.btn-primary:hover{background:var(--blue-dark);transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-outline{background:transparent;color:var(--white);border:2px solid var(--white)}
.btn-outline:hover{background:var(--white);color:var(--blue-dark)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.text-center{text-align:center}

/* ===== CENTRED SECTION HELPERS ===== */
.section-centered{text-align:center}
.tag-centered{display:inline-block}
.section-title-centered{text-align:center;margin-left:auto;margin-right:auto}
.section-sub-centered{text-align:center;margin-left:auto;margin-right:auto;max-width:640px}

/* ===== BACKGROUND IMAGE SECTIONS ===== */
.section-bg-pattern{position:relative}
.section-bg-industrial{
  position:relative;
  background-size:cover;
  background-position:center;
  background-attachment:fixed;
}
.section-bg-subtle{
  position:relative;
  background-size:cover;
  background-position:center;
  background-attachment:fixed;
}
.section-bg-dark{
  position:relative;
  background-size:cover;
  background-position:center;
  background-attachment:fixed;
}
.section-bg-overlay{
  position:absolute;
  inset:0;
  background:rgba(244,246,248,.93);
  z-index:0;
}
.section-bg-overlay-light{
  background:rgba(255,255,255,.88);
}

/* ===== TOP BAR ===== */
.topbar{background:var(--grey-700);color:var(--grey-300);font-size:.8rem;padding:7px 0}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.topbar a{color:var(--grey-300);transition:color var(--transition)}
.topbar a:hover{color:var(--blue)}
.topbar-contacts{display:flex;gap:20px;align-items:center}
.topbar-icon{margin-right:4px}

/* ===== NAVBAR ===== */
header{position:sticky;top:0;z-index:1000;background:var(--white);border-bottom:1px solid var(--grey-100);box-shadow:0 2px 12px rgba(0,0,0,.06)}
nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{display:flex;align-items:center;gap:0}
.logo img{height:52px;width:auto;object-fit:contain}
.nav-links{display:flex;gap:4px;align-items:center}
.nav-links a{font-family:var(--font-head);font-size:1rem;font-weight:600;letter-spacing:.3px;padding:8px 16px;border-radius:var(--radius);color:var(--grey-700);transition:var(--transition);cursor:pointer}
.nav-links a:hover,.nav-links a.active{color:var(--blue);background:var(--blue-light)}
.nav-cta{background:var(--blue)!important;color:var(--white)!important;border-radius:var(--radius)!important}
.nav-cta:hover{background:var(--blue-dark)!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
.hamburger span{display:block;width:24px;height:2px;background:var(--grey-700);border-radius:2px;transition:var(--transition)}
.mobile-menu{display:none;position:fixed;inset:0;background:var(--white);z-index:1100;padding:80px 24px 40px;flex-direction:column;gap:8px;overflow-y:auto}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:var(--font-head);font-size:1.4rem;font-weight:700;color:var(--grey-700);padding:14px 20px;border-radius:var(--radius);transition:var(--transition)}
.mobile-menu a:hover{background:var(--blue-light);color:var(--blue)}
.mobile-close{position:absolute;top:20px;right:24px;font-size:2rem;cursor:pointer;color:var(--grey-500);background:none;border:none}

/* ===== WHATSAPP FLOATING BUTTON ===== */
.whatsapp-float{position:fixed;bottom:28px;right:28px;z-index:2000;display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.wa-btn{width:56px;height:56px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.4);transition:var(--transition);cursor:pointer}
.wa-btn:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(37,211,102,.5)}
.wa-btn svg{width:28px;height:28px;fill:#fff}
.wa-tooltip{background:var(--black);color:var(--white);font-family:var(--font-body);font-size:.85rem;padding:8px 14px;border-radius:20px;white-space:nowrap;opacity:0;transform:translateX(10px);transition:var(--transition);pointer-events:none}
.whatsapp-float:hover .wa-tooltip{opacity:1;transform:translateX(0)}

/* ===== PAGE HERO ===== */
.page-hero{position:relative;background:linear-gradient(135deg,var(--grey-700) 0%,var(--black) 100%);color:var(--white);padding:100px 0;text-align:center;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%230e87c0' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.page-hero .tag{background:rgba(14,135,192,.25);color:#7fd3f5;border:1px solid rgba(14,135,192,.3)}
.page-hero h1{font-family:var(--font-head);font-size:clamp(2.5rem,5vw,3.8rem);font-weight:800;margin-bottom:14px;position:relative;z-index:1}
.page-hero p{color:var(--grey-300);font-size:1.05rem;max-width:600px;margin:0 auto;position:relative;z-index:1}

/* PAGE HERO WITH BACKGROUND IMAGE */
.page-hero-bg{
  background-size:cover !important;
  background-position:center !important;
  background-repeat:no-repeat !important;
}
.page-hero-bg::before{display:none}
.page-hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(10,20,35,.82) 0%,rgba(10,30,50,.75) 100%);
  z-index:0;
}

/* ===== HERO — FULL-WIDTH CENTERED (HOME) ===== */
.hero{
  position:relative;
  color:var(--white);
  min-height:90vh;
  display:flex;
  align-items:center;
  overflow:hidden;
}
.hero-centered{
  background:transparent;
  text-align:center;
  justify-content:center;
}
.hero-bg-img{
  position:absolute;
  inset:0;
  z-index:0;
}
.hero-bg-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(10,18,30,.85) 0%,rgba(10,30,50,.78) 60%,rgba(8,40,60,.82) 100%);
  z-index:1;
}
.hero-inner-centered{
  position:relative;
  z-index:2;
  display:flex;
  flex-direction:column;
  align-items:center;
  padding:100px 24px;
  max-width:900px;
  margin:0 auto;
  width:100%;
}
.hero-inner-centered h1{
  font-family:var(--font-head);
  font-size:clamp(3rem,6vw,5rem);
  font-weight:800;
  line-height:1.05;
  margin-bottom:20px;
  text-align:center;
}
.hero-inner-centered h1 em{font-style:normal;color:var(--blue)}
.hero-inner-centered p{
  font-size:1.15rem;
  color:var(--grey-300);
  line-height:1.7;
  margin-bottom:36px;
  max-width:620px;
  text-align:center;
}
.hero-inner-centered .hero-actions{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
  justify-content:center;
}
.hero-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:rgba(14,135,192,.2);
  border:1px solid rgba(14,135,192,.4);
  color:#7fd3f5;
  font-family:var(--font-head);
  font-size:.8rem;
  font-weight:700;
  letter-spacing:2px;
  text-transform:uppercase;
  padding:6px 16px;
  border-radius:20px;
  margin-bottom:24px;
}
.hero-stats{display:flex;gap:36px;margin-top:48px;padding-top:36px;border-top:1px solid rgba(255,255,255,.15)}
.hero-stats-centered{justify-content:center;flex-wrap:wrap;gap:48px}
.stat-num{font-family:var(--font-head);font-size:2.4rem;font-weight:800;color:var(--blue);line-height:1}
.stat-label{font-size:.82rem;color:var(--grey-300);margin-top:4px}

/* ===== WHY CARDS ===== */
.why-card{background:var(--white);border:1px solid var(--grey-100);border-radius:10px;padding:32px 28px;transition:var(--transition);position:relative;overflow:hidden;text-align:left}
.why-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:var(--blue);transform:scaleY(0);transition:var(--transition);transform-origin:top}
.why-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.why-card:hover::before{transform:scaleY(1)}
.why-icon{width:52px;height:52px;background:var(--blue-light);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;overflow:hidden}
.why-icon img{width:30px;height:30px;object-fit:contain}
.why-card h3{font-family:var(--font-head);font-size:1.25rem;font-weight:700;color:var(--black);margin-bottom:10px}
.why-card p{font-size:.9rem;color:var(--grey-500);line-height:1.65}

/* ===== SERVICE BLOCKS (CENTERED PAGE) ===== */
.service-block{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:56px;
  align-items:center;
  padding:64px 0;
  border-bottom:1px solid var(--grey-100);
  text-align:left;
}
.service-block:last-of-type{border-bottom:none}
.service-block-rev .service-block-img{order:2}
.service-block-rev .service-block-content{order:1}
.service-block-img{border-radius:12px;overflow:hidden;aspect-ratio:4/3;background:var(--grey-100)}
.service-block-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.service-block-img:hover img{transform:scale(1.04)}
.service-block-content h2{font-family:var(--font-head);font-size:2rem;font-weight:800;color:var(--black);margin-bottom:16px}
.service-block-content p{color:var(--grey-500);line-height:1.7;margin-bottom:20px}

/* Keep old .service-row for backwards compat */
.service-row{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;padding:64px 0;border-bottom:1px solid var(--grey-100)}
.service-row:last-of-type{border-bottom:none}
.service-row.rev .service-img-box{order:2}
.service-row.rev .service-content{order:1}
.service-img-box{border-radius:12px;overflow:hidden;aspect-ratio:4/3;background:var(--grey-100)}
.service-img-box img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.service-img-box:hover img{transform:scale(1.04)}
.service-content h2{font-family:var(--font-head);font-size:2rem;font-weight:800;color:var(--black);margin-bottom:16px}
.service-content p{color:var(--grey-500);line-height:1.7;margin-bottom:20px}
.service-list li{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px;font-size:.9rem;color:var(--grey-700)}
.service-list li::before{content:'';display:block;width:16px;height:16px;background:var(--blue);border-radius:50%;flex-shrink:0;margin-top:2px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='white'%3E%3Cpath d='M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 011.06-1.06L6 10.94l6.72-6.72a.75.75 0 011.06 0z'/%3E%3C/svg%3E");background-size:10px;background-repeat:no-repeat;background-position:center}
.service-list-centered{display:inline-block;text-align:left;margin:0 auto}

/* ===== VALUE CARDS ===== */
.value-card{text-align:center;padding:28px 20px;background:var(--white);border:1px solid var(--grey-100);border-radius:10px;transition:var(--transition)}
.value-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.value-icon{width:64px;height:64px;background:var(--blue);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;overflow:hidden}
.value-icon img{width:34px;height:34px;object-fit:contain;filter:brightness(0) invert(1)}
.value-card h3{font-family:var(--font-head);font-size:1.2rem;font-weight:700;color:var(--black);margin-bottom:8px}
.value-card p{font-size:.88rem;color:var(--grey-500)}

/* ===== PRODUCT CARDS ===== */
.product-card{background:var(--white);border:1px solid var(--grey-100);border-radius:10px;overflow:hidden;transition:var(--transition)}
.product-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.product-img{aspect-ratio:16/9;overflow:hidden;background:var(--grey-100)}
.product-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.product-card:hover .product-img img{transform:scale(1.05)}
.product-body{padding:24px;text-align:left}
.product-body h3{font-family:var(--font-head);font-size:1.3rem;font-weight:700;color:var(--black);margin-bottom:8px}
.product-body p{font-size:.88rem;color:var(--grey-500);line-height:1.6;margin-bottom:16px}
.product-tag{display:inline-block;background:var(--blue-light);color:var(--blue-dark);font-size:.75rem;font-weight:600;padding:3px 10px;border-radius:3px}

/* ===== TEAM CARDS ===== */
.team-card{background:var(--white);border:1px solid var(--grey-100);border-radius:12px;overflow:hidden;transition:var(--transition);text-align:center}
.team-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.team-img{aspect-ratio:1/1;overflow:hidden;background:var(--grey-100)}
.team-img img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .5s ease}
.team-card:hover .team-img img{transform:scale(1.04)}
.team-body{padding:20px}
.team-name{font-family:var(--font-head);font-size:1.2rem;font-weight:700;color:var(--black);margin-bottom:4px}
.team-role{font-size:.85rem;color:var(--blue);font-weight:600;margin-bottom:10px;text-transform:uppercase;letter-spacing:.5px}
.team-bio{font-size:.85rem;color:var(--grey-500);line-height:1.55}

/* ===== TEAM GRID — two rows of 3 ===== */
.team-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.team-grid + .team-grid{
  margin-top:28px;
}

/* ===== ABOUT PAGE SPECIFIC ===== */
.about-intro-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  margin:40px 0 32px;
}
.about-intro-img{
  border-radius:12px;
  overflow:hidden;
  aspect-ratio:4/3;
  background:var(--grey-100);
}
.about-intro-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .5s ease;
}
.about-intro-img:hover img{transform:scale(1.03)}
.about-text-cols{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:32px;
  text-align:left;
}
.about-text-cols p{color:var(--grey-500);line-height:1.75}

/* ===== HORIZONTAL TIMELINE ===== */
.timeline-centered{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
  margin-top:48px;
}
.tl-item-h{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
  padding:28px 22px;
  text-align:left;
  position:relative;
}
.tl-item-h::before{
  content:'';
  display:block;
  width:12px;height:12px;
  background:var(--blue);
  border-radius:50%;
  margin-bottom:12px;
}
.tl-item-h .tl-year{font-family:var(--font-head);font-size:.85rem;font-weight:700;color:var(--blue);letter-spacing:1px;margin-bottom:8px;text-transform:uppercase}
.tl-item-h h4{font-family:var(--font-head);font-size:1.1rem;font-weight:700;color:var(--white);margin-bottom:8px}
.tl-item-h p{font-size:.85rem;color:rgba(255,255,255,.65);line-height:1.6}

/* Old vertical timeline */
.timeline{border-left:2px solid var(--blue-light);padding-left:32px;margin-top:32px}
.tl-item{position:relative;margin-bottom:32px}
.tl-item::before{content:'';position:absolute;left:-40px;top:4px;width:14px;height:14px;background:var(--blue);border-radius:50%;border:3px solid var(--white);box-shadow:0 0 0 2px var(--blue)}
.tl-year{font-family:var(--font-head);font-size:.85rem;font-weight:700;color:var(--blue);letter-spacing:1px;margin-bottom:4px;text-transform:uppercase}
.tl-item h4{font-family:var(--font-head);font-size:1.1rem;font-weight:700;color:var(--black);margin-bottom:4px}
.tl-item p{font-size:.88rem;color:var(--grey-500)}

/* ===== WHY LIST CENTERED ===== */
.why-list-centered{display:flex;justify-content:center}
.why-list-centered .service-list{display:inline-block;text-align:left;max-width:600px}

/* ===== CTA BANNER ===== */
.cta-banner{background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:var(--white);padding:64px 0;text-align:center}
.cta-banner h2{font-family:var(--font-head);font-size:clamp(1.8rem,3vw,2.6rem);font-weight:800;margin-bottom:12px}
.cta-banner p{color:rgba(255,255,255,.85);margin-bottom:28px;font-size:1.05rem}
.cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ===== SERVICES STRIP ===== */
.services-strip{background:var(--blue);color:var(--white);padding:18px 0}
.strip-inner{display:flex;gap:0;align-items:center;overflow-x:auto;scrollbar-width:none}
.strip-inner::-webkit-scrollbar{display:none}
.strip-item{display:flex;align-items:center;gap:8px;white-space:nowrap;font-family:var(--font-head);font-weight:600;font-size:.95rem;letter-spacing:.3px;padding:0 24px;border-right:1px solid rgba(255,255,255,.2)}
.strip-item:last-child{border-right:none}
.strip-item img{width:18px;height:18px;filter:brightness(0) invert(1);opacity:.85}

/* ===== SLIDESHOW ===== */
.slideshow{position:relative;overflow:hidden;border-radius:12px;aspect-ratio:16/7;background:var(--black)}
.slide{position:absolute;inset:0;opacity:0;transition:opacity .8s ease}
.slide.active{opacity:1}
.slide img{width:100%;height:100%;object-fit:cover}
.slide-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.65) 0%,transparent 55%)}
.slide-caption{position:absolute;bottom:28px;left:36px;color:var(--white);text-align:left}
.slide-caption h3{font-family:var(--font-head);font-size:1.5rem;font-weight:700;margin-bottom:4px}
.slide-caption p{font-size:.88rem;color:rgba(255,255,255,.75)}
.slide-controls{position:absolute;bottom:28px;right:28px;display:flex;gap:8px}
.slide-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.4);cursor:pointer;transition:var(--transition)}
.slide-dot.active{background:var(--blue);width:28px;border-radius:5px}
.slide-arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.2);color:var(--white);width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);font-size:1.1rem}
.slide-arrow:hover{background:var(--blue);border-color:var(--blue)}
.slide-arrow.prev{left:16px}
.slide-arrow.next{right:16px}

/* ===== GALLERY ===== */
.gallery-filter{display:flex;gap:10px;margin-bottom:32px;flex-wrap:wrap;justify-content:center}
.filter-btn{padding:9px 22px;border-radius:20px;border:1.5px solid var(--grey-300);background:transparent;color:var(--grey-500);font-family:var(--font-head);font-size:.9rem;font-weight:600;cursor:pointer;transition:var(--transition)}
.filter-btn.active,.filter-btn:hover{background:var(--blue);color:var(--white);border-color:var(--blue)}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.gallery-item{border-radius:10px;overflow:hidden;aspect-ratio:4/3;cursor:pointer;position:relative;background:var(--grey-100)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;display:block}
.gallery-item:hover img{transform:scale(1.06)}
.gallery-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 55%);opacity:0;transition:var(--transition);display:flex;align-items:flex-end;padding:20px}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-label{color:var(--white);font-family:var(--font-head);font-size:1rem;font-weight:700}
.gallery-item.hidden{display:none}

/* ===== CONTACT ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:48px;padding:64px 0 32px}
.contact-info-card{background:var(--white);border:1px solid var(--grey-100);border-radius:10px;padding:24px;margin-bottom:16px;display:flex;gap:16px;align-items:flex-start;transition:var(--transition)}
.contact-info-card:hover{box-shadow:var(--shadow);transform:translateX(4px)}
.ci-icon{width:44px;height:44px;background:var(--blue);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.ci-icon img{width:22px;height:22px;filter:brightness(0) invert(1)}
.ci-label{font-size:.78rem;text-transform:uppercase;letter-spacing:1px;color:var(--grey-500);font-weight:600;margin-bottom:4px}
.ci-value{font-family:var(--font-head);font-size:1.05rem;font-weight:700;color:var(--black)}
.ci-value a{color:var(--black);transition:var(--transition)}
.ci-value a:hover{color:var(--blue)}
.map-pin-btn{display:inline-flex;align-items:center;gap:8px;background:var(--blue);color:var(--white);padding:10px 22px;border-radius:var(--radius);font-family:var(--font-head);font-weight:700;font-size:.95rem;cursor:pointer;transition:var(--transition);border:none;margin-top:10px;text-decoration:none}
.map-pin-btn:hover{background:var(--blue-dark);transform:translateY(-2px);box-shadow:var(--shadow)}
.contact-form-wrap{background:var(--white);border:1px solid var(--grey-100);border-radius:12px;padding:40px;box-shadow:0 2px 20px rgba(0,0,0,.04)}
.contact-form-wrap h2{font-family:var(--font-head);font-size:1.8rem;font-weight:800;color:var(--black);margin-bottom:6px}
.contact-form-wrap > p{color:var(--grey-500);font-size:.9rem;margin-bottom:28px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:.83rem;font-weight:600;color:var(--grey-700);margin-bottom:6px;letter-spacing:.3px}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 16px;border:1.5px solid var(--grey-100);border-radius:var(--radius);font-family:var(--font-body);font-size:.95rem;color:var(--grey-700);background:var(--off-white);transition:var(--transition);outline:none}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--blue);background:var(--white);box-shadow:0 0 0 3px rgba(14,135,192,.1)}
.form-group textarea{resize:vertical;min-height:120px}
.form-submit{width:100%;padding:15px;background:var(--blue);color:var(--white);border:none;border-radius:var(--radius);font-family:var(--font-head);font-size:1.1rem;font-weight:700;letter-spacing:.5px;cursor:pointer;transition:var(--transition)}
.form-submit:hover{background:var(--blue-dark);transform:translateY(-2px);box-shadow:var(--shadow)}
.form-success{display:none;text-align:center;padding:24px;background:var(--blue-light);border-radius:var(--radius);margin-top:16px}
.form-success h3{font-family:var(--font-head);font-size:1.4rem;color:var(--blue-dark);margin-bottom:8px}
.form-success p{color:var(--grey-500);font-size:.9rem}
.map-section{padding:0 0 64px}
.map-embed-container{border-radius:12px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--grey-100)}

/* ===== HOURS TABLE ===== */
.hours-table{width:100%;border-collapse:collapse;margin-top:16px}
.hours-table tr{border-bottom:1px solid var(--grey-100)}
.hours-table td{padding:12px 0;font-size:.9rem}
.hours-table td:first-child{color:var(--grey-700);font-weight:600}
.hours-table td:last-child{color:var(--blue);font-weight:700;text-align:right}
.hours-table .closed{color:var(--grey-500)!important}

/* ===== FOOTER ===== */
footer{background:var(--black);color:var(--grey-300);padding:56px 0 24px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:48px}
.footer-brand p{font-size:.86rem;line-height:1.7;color:var(--grey-500);margin-bottom:20px;margin-top:14px}
.footer-logo{height:44px;width:auto;object-fit:contain;margin-bottom:0}
.social-links{display:flex;gap:10px}
.social-link{width:36px;height:36px;background:rgba(255,255,255,.07);border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--grey-300);transition:var(--transition);font-family:var(--font-head);font-weight:700;font-size:.9rem}
.social-link:hover{background:var(--blue);color:var(--white)}
.footer-col h4{font-family:var(--font-head);font-size:.95rem;font-weight:700;color:var(--white);margin-bottom:16px;letter-spacing:.5px;text-transform:uppercase}
.footer-col ul li{margin-bottom:10px}
.footer-col ul li a{color:var(--grey-500);font-size:.86rem;transition:var(--transition)}
.footer-col ul li a:hover{color:var(--blue)}
.footer-contact-item{display:flex;gap:10px;margin-bottom:14px;align-items:flex-start}
.fc-icon{width:18px;height:18px;flex-shrink:0;margin-top:1px;opacity:.6}
.fc-icon img{width:100%;height:100%;filter:invert(1)}
.fc-text{font-size:.84rem;color:var(--grey-500);line-height:1.5}
.fc-text a{color:var(--grey-500);transition:var(--transition)}
.fc-text a:hover{color:var(--blue)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding-top:22px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.footer-bottom p{font-size:.79rem;color:var(--grey-500)}
.footer-bottom a{color:var(--grey-500);transition:var(--transition)}
.footer-bottom a:hover{color:var(--blue)}

/* ===== STATS ROW ===== */
.stats-row{background:var(--blue);padding:40px 0}
.stats-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:0;text-align:center}
.stat-item{padding:10px 20px;border-right:1px solid rgba(255,255,255,.2)}
.stat-item:last-child{border-right:none}
.stat-item .num{font-family:var(--font-head);font-size:2.6rem;font-weight:800;color:var(--white);line-height:1}
.stat-item .lbl{font-size:.85rem;color:rgba(255,255,255,.75);margin-top:6px}

/* ===== RESPONSIVE ===== */
@media(max-width:960px){
  .grid-2,
  .grid-3,
  .team-grid,
  .service-block,
  .contact-grid,
  .footer-grid,
  .about-intro-grid,
  .about-text-cols{grid-template-columns:1fr}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .hero-inner-centered{padding:80px 24px}
  .hero-stats-centered{gap:28px}
  .service-block-rev .service-block-img{order:0}
  .service-block-rev .service-block-content{order:0}
  .service-row.rev .service-img-box{order:0}
  .service-row.rev .service-content{order:0}
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .stat-item:nth-child(2){border-right:none}
  .nav-links{display:none}
  .hamburger{display:flex}
  .timeline-centered{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .section{padding:56px 0}
  .topbar-contacts{display:none}
  .form-row{grid-template-columns:1fr}
  .grid-4{grid-template-columns:1fr}
  .hero-stats-centered{flex-direction:column;gap:16px;align-items:center}
  .timeline-centered{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
}