:root{--bg:#070b12;--card:#0d1422;--muted:#b7c3d7;--text:#f4f7ff;--brand:#FC7E17;--brand2:#FC7E17;--line:rgba(255,255,255,.10);}
*{box-sizing:border-box} html,body{margin:0;padding:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:linear-gradient(180deg,#05070c, #070b12 40%, #05070c);overflow-x:hidden;width:100%;}
a{color:inherit;text-decoration:none}
.container{max-width:1400px;margin:0 auto;padding:0 20px;width:100%;}
@media (max-width: 768px){.container{padding:0 16px;}}
.topbar{background:rgba(255,255,255,.03);border-bottom:1px solid var(--line)}
.topbar .row{display:flex;gap:24px;align-items:center;justify-content:center;padding:10px 0}
.badge{display:inline-flex;gap:8px;align-items:center;font-size:13px;color:var(--muted)}
.badge i{width:10px;height:10px;border-radius:99px;background:var(--brand2);display:inline-block}
.header{position:sticky;top:0;z-index:50;background:rgba(7,12,23,.85);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--line)}
.header .row{display:flex;align-items:center;justify-content:center;padding:14px 0 14px 80px;gap:14px;width:100%;margin:0 auto}
@media (max-width: 768px){.header .row{padding:14px 0;flex-wrap:wrap;justify-content:center;gap:10px;}}
.brand{display:flex;flex-direction:column;align-items:center;text-align:center}
.brand a{display:flex;flex-direction:column;align-items:center;text-align:center}
.brand .logo{display:none} /* hide logo image. */
.header-btns{display:none} /* hide legacy buttons. */
.nav{display:none} /* hide legacy nav. */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:11px 14px;border-radius:12px;background:linear-gradient(135deg,var(--brand),var(--brand2));color:#0a0f1a;font-weight:800;border:0;cursor:pointer;box-shadow:0 0 20px rgba(252,126,23,0.4), 0 0 40px rgba(252,126,23,0.2);transition:all 0.3s ease;}
.btn:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 0 30px rgba(252,126,23,0.6), 0 0 60px rgba(252,126,23,0.4), 0 0 90px rgba(252,126,23,0.2);animation:pulse-glow 1.5s ease-in-out infinite;}
@keyframes pulse-glow{0%,100%{box-shadow:0 0 30px rgba(252,126,23,0.6), 0 0 60px rgba(252,126,23,0.4), 0 0 90px rgba(252,126,23,0.2);}50%{box-shadow:0 0 40px rgba(252,126,23,0.8), 0 0 80px rgba(252,126,23,0.5), 0 0 120px rgba(252,126,23,0.3);}}
.btn.secondary{background:transparent;border:1px solid var(--line);color:var(--text);font-weight:700;box-shadow:0 0 15px rgba(252,126,23,0.2);}
.btn.secondary:hover{box-shadow:0 0 25px rgba(252,126,23,0.4), 0 0 50px rgba(252,126,23,0.2);}
.btn.small{padding:9px 12px;border-radius:10px;font-size:14px}
.hero{padding:48px 0 28px;text-align:center;}
@media (max-width: 768px){.hero{padding:32px 0 20px;}}
.grid{display:grid;grid-template-columns:1.3fr .9fr;gap:80px;align-items:start}
@media (max-width: 940px){.grid{grid-template-columns:1fr} .nav{display:none}}
.pill{display:inline-flex;gap:8px;align-items:center;padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid var(--line);font-size:13px;color:var(--muted)}
h1{font-size:40px;line-height:1.1;margin:14px 0 10px;word-wrap:break-word;overflow-wrap:break-word;text-align:center;background:linear-gradient(90deg,#fff 0%,#FC7E17 25%,#FFB347 50%,#FC7E17 75%,#fff 100%);background-size:200% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:gradient-shift 4s ease infinite;}
@keyframes gradient-shift{0%,100%{background-position:0% center;}50%{background-position:100% center;}}
@media (max-width: 768px){h1{font-size:32px;padding:0 10px;}}
@media (max-width: 520px){h1{font-size:28px;padding:0 8px;}}
.lead{color:var(--muted);font-size:16px;line-height:1.6;max-width:60ch}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin:18px 0 14px}
.note{font-size:13px;color:var(--muted)}
.card{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:18px;padding:18px;width:100%;box-sizing:border-box;position:relative;overflow:hidden;transition:all 0.2s ease;}
.card::before{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(252,126,23,0.5),transparent);transform:translateX(-100%);pointer-events:none;z-index:1;transition:transform 0.5s ease;}
.card:hover::before{transform:translateX(100%);}
.card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 12px 32px rgba(252,126,23,0.35), 0 6px 16px rgba(0,0,0,0.4);border-color:rgba(252,126,23,0.3);}
.card > *{position:relative;z-index:2;}
@media (max-width: 768px){.card{padding:16px;margin:0 auto;max-width:100%;}}
.card h2{margin:0 0 10px;font-size:18px}
.form{display:grid;gap:10px}
label{display:grid;gap:6px;font-size:13px;color:var(--muted)}
input,select,textarea{padding:11px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:rgba(0,0,0,.2);color:var(--text);outline:none}
input:focus,select:focus,textarea:focus{border-color:rgba(103,211,255,.65)}
.fine{font-size:12px;color:var(--muted);line-height:1.5}
.section{padding:18px 0 44px;overflow-x:hidden;word-wrap:break-word;width:100%;}
@media (max-width: 768px){.section{padding:16px 0 32px;text-align:center;}}
.section h2{font-size:22px;margin:0 0 10px;word-wrap:break-word;overflow-wrap:break-word;text-align:center;}
@media (max-width: 768px){.section h2{font-size:20px;padding:0 8px;}}
.section p{color:var(--muted);line-height:1.7;margin:0 0 16px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;width:100%;}
@media (max-width: 940px){.cards{grid-template-columns:1fr;gap:12px;}}
@media (max-width: 768px){.cards{padding:0;}}
.card h3{margin:2px 0 8px}
ul{margin:0;padding-left:18px;color:var(--muted);line-height:1.6}
.kpi{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:14px}
@media (max-width: 940px){.kpi{grid-template-columns:1fr}}
.kpi .box{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:16px;padding:14px}
.kpi .box .t{font-weight:800}
.kpi .box .s{color:var(--muted);font-size:13px;margin-top:3px}
.footer{border-top:1px solid var(--line);padding:22px 0 34px;color:var(--muted)}
.footer a{color:var(--text)}
.sticky-call{position:fixed;left:0;right:0;bottom:0;z-index:60;background:rgba(7,12,23,.92);border-top:1px solid var(--line);display:none}
.sticky-call .row{display:flex;gap:12px;align-items:center;justify-content:space-between;padding:12px 18px}
@media (max-width: 940px){.sticky-call{display:block}}
@media (min-width: 941px){.sticky-call{display:none !important}}
.smallmuted{font-size:12px;color:var(--muted)}
/* media helpers. */
.heroimg{width:100%;max-height:380px;object-fit:cover;border-radius:18px;border:1px solid var(--line);box-shadow:0 18px 55px rgba(0,0,0,.35);margin-top:14px}
.gallery{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:14px}
@media(max-width:900px){.gallery{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:560px){.gallery{grid-template-columns:1fr}}
.gallery figure{margin:0}
.gallery img{width:100%;height:190px;object-fit:cover;border-radius:16px;border:1px solid var(--line);transition:transform 0.25s ease, box-shadow 0.25s ease;transform-style:preserve-3d;}
.gallery img:hover{transform:scale(1.15) translateZ(30px);box-shadow:0 16px 50px rgba(252,126,23,0.4), 0 10px 30px rgba(0,0,0,0.6);cursor:pointer;}
.gallery figcaption{margin-top:6px;color:var(--muted);font-size:.92rem;line-height:1.35}


/* whatsapp widget. */
.wa-float{
  position:fixed;
  right:16px;
  bottom:90px;

  z-index:50;
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 18px 12px 12px;
  border-radius:50px;
  border:4px solid #fff;
  background:#000;
  color:#fff;
  text-decoration:none;
  box-shadow:0 8px 24px rgba(0,0,0,.35);
  transition: transform 0.2s;
}
.wa-float:hover{transform:translateY(-2px) scale(1.02);}
.wa-float::before{
  content:'';
  width:48px;
  height:48px;
  border-radius:50%;
  background:#25D366;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M17.472 14.382c-.297-.149-1.758-.867-2.03-.967-.273-.099-.471-.148-.67.15-.197.297-.767.966-.94 1.164-.173.199-.347.223-.644.075-.297-.15-1.255-.463-2.39-1.475-.883-.788-1.48-1.761-1.653-2.059-.173-.297-.018-.458.13-.606.134-.133.298-.347.446-.52.149-.174.198-.298.298-.497.099-.198.05-.371-.025-.52-.075-.149-.669-1.612-.916-2.207-.242-.579-.487-.5-.669-.51-.173-.008-.371-.01-.57-.01-.198 0-.52.074-.792.372-.272.297-1.04 1.016-1.04 2.479 0 1.462 1.065 2.875 1.213 3.074.149.198 2.096 3.2 5.077 4.487.709.306 1.262.489 1.694.625.712.227 1.36.195 1.871.118.571-.085 1.758-.719 2.006-1.413.248-.694.248-1.289.173-1.413-.074-.124-.272-.198-.57-.347m-5.421 7.403h-.004a9.87 9.87 0 01-5.031-1.378l-.361-.214-3.741.982.998-3.648-.235-.374a9.86 9.86 0 01-1.51-5.26c.001-5.45 4.436-9.884 9.888-9.884 2.64 0 5.122 1.03 6.988 2.898a9.825 9.825 0 012.893 6.994c-.003 5.45-4.437 9.884-9.885 9.884m8.413-18.297A11.815 11.815 0 0012.05 0C5.495 0 .16 5.335.157 11.892c0 2.096.547 4.142 1.588 5.945L.057 24l6.305-1.654a11.882 11.882 0 005.683 1.448h.005c6.554 0 11.89-5.335 11.893-11.893a11.821 11.821 0 00-3.48-8.413Z'/%3E%3C/svg%3E");
  background-size:28px 28px;
  background-position:center;
  background-repeat:no-repeat;
  flex-shrink:0;
}
.wa-float-text{
  display:flex;
  flex-direction:column;
  line-height:1.2;
}
.wa-float-title{
  font-size:16px;
  font-weight:700;
  letter-spacing:0.3px;
}
.wa-float-subtitle{
  font-size:11px;
  color:#25D366;
  font-weight:600;
}
@media (max-width: 768px){
  .wa-float{
    bottom:80px;
    right:12px;
  }
}

/* topbar logo. */
.topbar-logo{
  display: inline-flex;
  align-items: center;
  margin-left: 12px;
  width: 36px;
  height: 36px;
  margin-top: 4px;
}
.topbar-logo img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: 50%;
}

/* mobile larger logo. */
@media (max-width: 600px) {
  .topbar{
    position: relative;
    padding-top: 130px;
  }
  .topbar-logo{
    position: absolute;
    left: 50%;
    top: 10px;
    transform: translateX(-50%);
    width: 120px;
    height: 120px;
    margin-left: 0;
    margin-top: 0;
  }
}


/* brand name styling. */
.brand .name{
  font-weight: 900;
}

/* header mobile improvements. */
@media (max-width: 800px){
  .header .row{display:flex;flex-direction:column;gap:16px}
  .header-btns{justify-self:center;width:100%;justify-content:center}
  .header-btns .btn{flex:1;justify-content:center}
}

/* modal google reviews. */
.modal{position:fixed;inset:0;display:none;z-index:80}
.modal.is-open{display:block}
.modal__overlay{position:absolute;inset:0;background:rgba(0,0,0,.6)}
.modal__panel{position:relative;max-width:920px;width:calc(100% - 24px);max-height:calc(100% - 24px);
  margin:12px auto;background:rgba(15,23,42,.98);border:1px solid var(--line);border-radius:20px;
  box-shadow:0 18px 55px rgba(0,0,0,.45);overflow:hidden}
.modal__header{display:flex;gap:12px;justify-content:space-between;align-items:flex-start;padding:14px 16px;border-bottom:1px solid var(--line)}
.modal__title{font-weight:900;font-size:1.15rem;color:var(--text)}
.modal__close{appearance:none;border:1px solid var(--line);background:transparent;color:var(--text);
  border-radius:12px;padding:6px 10px;font-size:1.2rem;line-height:1;cursor:pointer}
.modal__body{padding:14px 16px}
.embed{border:1px solid var(--line);border-radius:18px;overflow:hidden}
.embed iframe{width:100%;height:520px;border:0}
@media(max-width:640px){.embed iframe{height:460px}}

/* service tiles. seo safe. */
.sectionhead{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;margin:6px 0 12px 0}
.tilegrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
@media(max-width:900px){.tilegrid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:560px){.tilegrid{grid-template-columns:1fr}}
.tile{position:relative;display:block;border-radius:18px;overflow:hidden;border:1px solid var(--line);
  box-shadow:0 18px 55px rgba(0,0,0,.25);transform:translateZ(0);text-decoration:none}
.tile img{width:100%;height:170px;object-fit:cover;display:block;filter:saturate(1.05) contrast(1.02)}
.tile:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.62))}
.tile__label{position:absolute;left:12px;right:12px;bottom:12px;z-index:2;
  color:#fff;font-weight:900;letter-spacing:.2px;font-size:1.02rem;text-shadow:0 8px 26px rgba(0,0,0,.55)}
.tile:hover{transform:translateY(-1px)}



/* localisation pill. seo safe. */
.localpill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top:10px;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.06);
  backdrop-filter:blur(8px);
  box-shadow:0 14px 44px rgba(0,0,0,.22);
  font-weight:900;
  font-size:1.05rem;
}
.localpill span{font-weight:900;text-decoration:underline}
@media(max-width:640px){
  .localpill{width:100%;justify-content:center;font-size:1.08rem}
}
/* fade header subline. */
.sub{opacity:.75;font-weight:600}


/* mobile topbar centering. */
@media (max-width: 640px){
  .topbar .row{
    justify-content:center;
    text-align:center;
    flex-wrap:wrap;
  }
  .topbar .badge{
    width:100%;
    justify-content:center;
  }
}

/* about page. centered and boxed. */
.about-hero{
  display:block;
  text-align:center;
  margin: 20px auto 40px;
  max-width: 940px;
}
.about-hero__content{
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 18px;
  padding: 32px;
  margin-bottom: 24px;
}
.about-hero__lead{
  font-size: 1.15rem;
  opacity: 0.9;
  margin: 12px auto 20px;
  max-width: 700px;
  line-height:1.6;
}
.about-hero__highlights{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px;
  margin-top: 18px;
}
.about-chip{
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 999px;
  padding: 8px 16px;
  font-size: 0.95rem;
  background: rgba(255,255,255,0.03);
}
.about-hero__media{
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 18px;
  overflow:hidden;
  height: 340px;
}
.about-hero__media img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}
.about-section{
  margin: 40px auto;
  max-width: 940px;
  text-align: center;
}
.about-section--alt{
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 18px;
  padding: 32px;
  max-width: 940px;
  margin: 40px auto;
  text-align:center;
}
.about-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 24px;
  align-items:center;
}
.about-card{
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(0,0,0,0.15);
  border-radius: 18px;
  padding: 24px;
  text-align: left;
  max-width: 700px;
  margin: 0 auto;
}
.about-card h3{
    text-align:center;
    margin-bottom: 14px;
}
.about-card ul{
  display:table; 
  margin: 0 auto;
  text-align:left;
}
.about-hero__media--left{
  height: 280px;
  margin-bottom: 24px;
}
.about-cta{
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.02);
  border-radius: 18px;
  padding: 32px;
  text-align: center;
  max-width: 700px;
  margin: 0 auto;
}
.about-cta .btn{
  display:inline-block;
  margin-top: 14px;
  padding: 12px 24px;
  font-size: 1.1rem;
}
@media (min-width: 900px){
    /* restore side-by-side but centered. */
    .about-section .about-grid{ grid-template-columns: 1fr 1fr; text-align:left; }
    .about-section .about-grid > div:first-child { padding-right:20px; }
}

/* faq grid. */
.faq-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 24px;
}
@media (max-width: 768px) {
  .faq-grid {
    grid-template-columns: 1fr;
  }
}
.faq-grid .card {
    height: 100%; /* equal height. */
    display: flex;
    flex-direction: column;
}
.faq-grid .card h3 {
    margin-top: 0;
    color: var(--brand); /* highlight question. */
    margin-bottom: 12px;
}

/* homepage mobile reorder. form below tiles. */
@media (max-width: 940px) {
  .homepage-grid {
    display: flex !important;
    flex-direction: column;
    gap: 20px;
  }
  .tiles-column {
    order: 1;
    margin-top: 0 !important;
  }
  .form-column {
    order: 2;
    max-width: 100% !important;
    margin-top: 0 !important;
  }
}



/* ========== MOBILE-FIRST ENHANCEMENTS ========== */
@media (max-width: 768px) {
  body, main, .section { text-align: center; }
  .container { padding-left: 12px !important; padding-right: 12px !important; }
  h1, h2, h3, h4, h5, h6 { text-align: center !important; padding-left: 4px; padding-right: 4px; word-wrap: break-word; overflow-wrap: break-word; hyphens: auto; }
  .lead { text-align: center !important; max-width: 100% !important; padding: 0 8px; margin-left: auto; margin-right: auto; font-size: 14px; }
  .card { width: 100% !important; max-width: 100% !important; margin-left: 0 !important; margin-right: 0 !important; box-sizing: border-box; padding: 12px !important; }
  .cards { width: 100% !important; padding: 0 !important; gap: 10px !important; }
  .hero-cta, .btn { justify-content: center; text-align: center; }
  .footer { text-align: center !important; padding: 16px 12px !important; }
  .kpi .box { width: 100%; margin: 0; text-align: center; padding: 10px !important; }
  h1 { font-size: 24px !important; line-height: 1.15; margin: 10px 0 8px !important; }
  h2 { font-size: 20px !important; line-height: 1.25; margin: 8px 0 6px !important; }
  h3 { font-size: 16px !important; line-height: 1.3; margin: 6px 0 4px !important; }
  * { max-width: 100%; overflow-wrap: break-word; }
  img { max-width: 100%; height: auto; }
  
  /* Force header brand centering */
  .brand { margin: 0 !important; padding: 0 !important; }
  .brand .name { text-align: center !important; font-size: 18px !important; }
  .brand .sub { text-align: center !important; font-size: 13px !important; }
  .btn.small { margin: 0 !important; padding: 8px 10px !important; font-size: 13px !important; }
  
  /* Compact sections */
  .section { padding: 12px 0 28px !important; }
  .section p { font-size: 13px; line-height: 1.5; margin: 0 0 12px; }
  .fine { font-size: 11px !important; line-height: 1.4; }
  
  /* Compact header */
  .header .row { padding: 10px 0 !important; gap: 8px !important; }
  .topbar .row { padding: 8px 0 !important; }
  .badge { font-size: 12px !important; }
  
  /* Regional Coverage boxes - make narrower on mobile */
  main > .container > div[style*="min-width"] {
    min-width: 100% !important;
    width: 100% !important;
  }
}

/* Transparent Background Utility */
.transparent-bg {
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
  border-radius: 0 !important;
}

/* Shadow for transparent PNGs (no ghost bubble) */
.png-shadow {
  filter: drop-shadow(0 8px 16px rgba(0,0,0,0.5));
}

