
:root{
  --orange:#ff6a00;
  --orange-dark:#e85f00;
  --black:#050505;
  --grey:#f6f6f6;
  --text:#111;
  --green:#25D366;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:Arial,Helvetica,sans-serif;background:#fff;color:var(--text);line-height:1.55}
a{text-decoration:none;color:inherit}
.container{width:min(1180px,94%);margin:0 auto}
.site-header{background:#000;color:#fff;position:sticky;top:0;z-index:20;box-shadow:0 4px 16px rgba(0,0,0,.35)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:25px;padding:16px 0}
.logo img{width:270px;display:block}
.main-nav ul{display:flex;align-items:center;gap:32px;list-style:none;text-transform:uppercase;font-weight:800;font-size:.9rem}
.main-nav a{display:block;padding:8px 0;border-bottom:3px solid transparent}
.main-nav a:hover,.main-nav a.active{color:var(--orange);border-color:var(--orange)}
.header-phone{text-align:right;font-size:1.32rem;font-weight:900}
.header-phone small{display:block;color:var(--orange);font-size:.82rem}
.hero{
  min-height:575px;
  background:
    linear-gradient(90deg,#fff 0%,rgba(255,255,255,.96) 42%,rgba(255,255,255,.45) 63%,rgba(255,255,255,.05) 100%),
    url("images/hero-lock.jpg") center right/cover no-repeat;
}
.hero-content{padding:64px 0 34px;max-width:610px}
.hero h1{font-size:clamp(3rem,6vw,5rem);line-height:1.04;font-weight:900;letter-spacing:-2px;margin-bottom:16px}
.hero h1 span{color:var(--orange);display:block}
.hero p{font-size:1.27rem;max-width:560px;margin-bottom:24px}
.button-row{display:flex;gap:18px;flex-wrap:wrap;align-items:center}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:14px 25px;border-radius:9px;font-weight:900}
.btn-orange{background:var(--orange);color:#fff;box-shadow:0 10px 22px rgba(255,106,0,.25)}
.btn-dark{background:#0a0a0a;color:#fff;box-shadow:0 10px 22px rgba(0,0,0,.18)}
.btn-whatsapp{background:var(--green);color:#fff}
.trust-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:42px;max-width:980px}
.trust-item{display:flex;align-items:center;gap:13px;padding:0 15px 0 0;border-right:1px solid #ddd;font-weight:800}
.trust-item:last-child{border-right:0}
.trust-icon{color:var(--orange);font-size:2rem;line-height:1}
.meet-section{background:#fff;padding:18px 0 38px}
.meet-card{
  display:grid;grid-template-columns:400px 1fr;gap:48px;align-items:center;
  background:#fff;border-radius:18px;padding:24px;box-shadow:0 12px 35px rgba(0,0,0,.13);border:1px solid #eee;
}
.meet-card img{width:100%;height:360px;object-fit:cover;border-radius:18px;box-shadow:0 10px 25px rgba(0,0,0,.18)}
.meet-card h2{font-size:clamp(2.2rem,4vw,3.4rem);line-height:1.02;margin-bottom:14px}
.meet-card h2 span{color:var(--orange)}
.orange-line{width:65px;height:4px;background:var(--orange);margin:0 0 22px}
.meet-card p{font-size:1.08rem;margin-bottom:12px}
.services-panel{padding:18px 0 34px}
.services-box{background:#fff;border-radius:18px;padding:30px 36px;box-shadow:0 10px 35px rgba(0,0,0,.1);border:1px solid #eee}
.section-heading{display:flex;align-items:center;justify-content:center;gap:26px;margin-bottom:25px}
.section-heading:before,.section-heading:after{content:"";height:3px;background:var(--orange);flex:1;max-width:245px}
.section-heading h2{font-size:clamp(2rem,4vw,3rem);text-align:center}
.service-list{columns:3;column-gap:48px;list-style:none}
.service-list li{break-inside:avoid;margin:0 0 12px;padding-left:31px;position:relative;font-weight:700}
.service-list li:before{content:"✓";position:absolute;left:0;top:1px;background:var(--orange);color:#fff;width:20px;height:20px;border-radius:50%;display:grid;place-items:center;font-size:.78rem;font-weight:900}
.cta-band{padding:22px 0 26px}
.cta-inner{background:#080808;color:#fff;border-radius:15px;padding:22px 30px;display:flex;align-items:center;justify-content:space-between;gap:25px}
.cta-left{display:flex;align-items:center;gap:20px}.phone-circle{width:70px;height:70px;background:var(--orange);border-radius:50%;display:grid;place-items:center;font-size:2rem}
.cta-inner h2{font-size:1.7rem}.cta-inner p{font-size:1.05rem}
.content-section{padding:55px 0}.content-section h1,.content-section h2{text-align:center;font-size:clamp(2.2rem,4vw,3.2rem);margin-bottom:18px}
.content-section .intro{text-align:center;max-width:760px;margin:0 auto 30px;color:#555}
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.service-card{background:#fff;border:1px solid #e3e3e3;border-radius:14px;padding:24px;box-shadow:0 10px 28px rgba(0,0,0,.08)}
.service-card h3{color:var(--orange);text-transform:uppercase;margin-bottom:10px;font-size:1.05rem}
.service-card p{color:#555}
.form-wrap{max-width:780px;margin:25px auto 0;background:#fff;border:1px solid #ddd;border-radius:16px;padding:28px;box-shadow:0 12px 35px rgba(0,0,0,.1)}
.form-wrap label{display:block;font-weight:900;margin:14px 0 7px}.form-wrap input,.form-wrap textarea{width:100%;padding:13px;border:1px solid #ccc;border-radius:8px;font-size:1rem}.g-recaptcha{margin-top:18px}
footer{background:#000;color:#fff;padding:40px 0 18px;margin-top:20px}
.footer-grid{display:grid;grid-template-columns:1.25fr 1fr 1.25fr;gap:44px}.footer-logo{width:230px;margin-bottom:14px}
footer h3{color:var(--orange);margin-bottom:12px;text-transform:uppercase}footer ul{list-style:none}footer li{margin:7px 0;color:#ddd}
.footer-social{display:flex;gap:12px;margin-top:18px}.footer-social a{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--orange);color:var(--orange);font-weight:900}
.copyright{text-align:center;margin-top:28px;padding-top:16px;border-top:1px solid #222;color:#ccc}
.floating-whatsapp{position:fixed;right:18px;bottom:18px;background:var(--green);color:#fff;width:58px;height:58px;border-radius:50%;display:grid;place-items:center;font-size:28px;font-weight:900;z-index:50;box-shadow:0 12px 28px rgba(0,0,0,.3)}
@media(max-width:1020px){
  .header-inner{flex-direction:column}.header-phone{text-align:center}.main-nav ul{gap:18px;flex-wrap:wrap;justify-content:center}
  .trust-row{grid-template-columns:repeat(2,1fr)}.meet-card{grid-template-columns:1fr}.service-list{columns:2}.service-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  .logo img{width:230px}.hero{background:#fff}.hero-content{padding:42px 0}.trust-row{grid-template-columns:1fr}.trust-item{border-right:0;border-bottom:1px solid #ddd;padding-bottom:12px}
  .service-list{columns:1}.cta-inner,.cta-left{display:block;text-align:center}.phone-circle{margin:0 auto 15px}.footer-grid,.service-grid{grid-template-columns:1fr}
  .meet-card{padding:18px}.meet-card img{height:auto}
}


/* Extra performance optimisation */
img {
  height: auto;
}
.meet-section,
.services-panel,
.cta-band,
.content-section,
footer {
  content-visibility: auto;
  contain-intrinsic-size: 1px 800px;
}
@media(max-width:680px){
  .hero{
    background:#fff !important;
  }
}


/* Areas Covered Section */
.areas-section{
  padding:20px 0 45px;
}
.areas-box{
  background:#fff;
  border-radius:18px;
  padding:32px 36px;
  border:1px solid #eee;
  box-shadow:0 10px 35px rgba(0,0,0,.08);
}
.areas-intro{
  text-align:center;
  max-width:900px;
  margin:0 auto 28px;
  color:#555;
  font-size:1.05rem;
}
.areas-list{
  columns:4;
  column-gap:40px;
  list-style:none;
}
.areas-list li{
  break-inside:avoid;
  margin-bottom:12px;
  padding-left:24px;
  position:relative;
  font-weight:700;
}
.areas-list li:before{
  content:"📍";
  position:absolute;
  left:0;
  top:0;
}
@media(max-width:900px){
  .areas-list{
    columns:2;
  }
}
@media(max-width:600px){
  .areas-list{
    columns:1;
  }
}


/* Cookie consent bar */
.cookie-consent{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:9999;
  background:#000;
  color:#fff;
  border-top:4px solid var(--orange);
  padding:18px 0;
  box-shadow:0 -8px 24px rgba(0,0,0,.35);
  display:none;
}
.cookie-consent.show{
  display:block;
}
.cookie-inner{
  width:min(1180px,94%);
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.cookie-inner p{
  margin:0;
  color:#f2f2f2;
  font-size:.95rem;
}
.cookie-inner a{
  color:var(--orange);
  font-weight:900;
  text-decoration:underline;
}
.cookie-actions{
  display:flex;
  gap:12px;
  flex-shrink:0;
}
.cookie-btn{
  border:0;
  border-radius:7px;
  padding:11px 18px;
  font-weight:900;
  cursor:pointer;
}
.cookie-accept{
  background:var(--orange);
  color:#000;
}
.cookie-reject{
  background:#222;
  color:#fff;
  border:1px solid #555;
}
.policy-content{
  max-width:920px;
  margin:0 auto;
  background:#fff;
  border:1px solid #e4e4e4;
  border-radius:16px;
  padding:34px;
  box-shadow:0 12px 35px rgba(0,0,0,.08);
}
.policy-content h2{
  margin:28px 0 10px;
  color:#000;
}
.policy-content h3{
  margin:20px 0 8px;
  color:var(--orange);
}
.policy-content p,
.policy-content li{
  margin-bottom:10px;
  color:#444;
}
.policy-content ul{
  padding-left:22px;
}
@media(max-width:760px){
  .cookie-inner{
    display:block;
  }
  .cookie-actions{
    margin-top:15px;
  }
}

/* Updates: full Clive photo and reviews page */
.meet-card img,
.about-grid img{
  object-fit:contain !important;
  background:#f3f3f3;
  object-position:center;
}
.reviews-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:24px;
  align-items:start;
}
.review-card{
  background:#fff;
  border:1px solid #e7e7e7;
  border-radius:14px;
  padding:12px;
  box-shadow:0 10px 30px rgba(0,0,0,.08);
}
.review-card img{
  width:100%;
  height:auto;
  display:block;
  border-radius:10px;
}


/* Clive Noble image rounded corners */
.meet-card img,
.meet-section img,
.about-section img,
.about-image img{
    border-radius: 30px !important;
    overflow: hidden !important;
}

.meet-card img,
.meet-section img,
img[src*="clive-noble"]{
border-radius:35px !important;
-webkit-border-radius:35px !important;
overflow:hidden !important;
display:block;
}


/* Clive Noble image - 15% smaller with rounded corners */
.meet-card img,
.meet-section img,
img[src*="clive-noble"]{
    width:85% !important;
    max-width:340px !important;
    height:auto !important;
    display:block !important;
    margin:0 auto !important;
    border-radius:30px !important;
    overflow:hidden !important;
    box-shadow:0 8px 20px rgba(0,0,0,.15) !important;
    object-fit:contain !important;
}


/* Header call and WhatsApp buttons */
.header-actions{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.header-actions .btn{
  white-space:nowrap;
}
@media(max-width:1020px){
  .header-actions{
    justify-content:center;
  }
}


/* Equal-sized header Call and WhatsApp buttons */
.header-actions{
    gap:10px;
}

.header-actions .btn{
    width:160px !important;
    min-width:160px !important;
    height:42px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    padding:0 12px !important;
    font-size:14px !important;
    font-weight:700 !important;
    box-sizing:border-box !important;
}


/* Services page recent work gallery */
.service-gallery-section{
  padding:50px 0;
  background:#f7f7f7;
}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:24px;
  margin-top:30px;
}
.gallery-item{
  background:#fff;
  border:1px solid #e5e5e5;
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 10px 28px rgba(0,0,0,.08);
}
.gallery-item img{
  width:100%;
  height:280px;
  object-fit:cover;
  display:block;
}
.gallery-item h3{
  padding:16px;
  font-size:1.05rem;
  color:#111;
  text-align:center;
}


/* Header Call, WhatsApp and Email buttons - equal smaller size */
.header-actions{
  display:flex !important;
  align-items:center !important;
  gap:8px !important;
  flex-wrap:wrap !important;
  justify-content:flex-end !important;
}
.header-actions .header-btn,
.header-actions .btn{
  width:118px !important;
  min-width:118px !important;
  height:38px !important;
  padding:0 10px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  font-size:13px !important;
  line-height:1 !important;
  font-weight:800 !important;
  border-radius:7px !important;
  box-sizing:border-box !important;
  white-space:nowrap !important;
}
.btn-email{
  background:#fff !important;
  color:#000 !important;
  border:2px solid var(--orange) !important;
}
@media(max-width:1020px){
  .header-actions{
    justify-content:center !important;
  }
}
@media(max-width:430px){
  .header-actions .header-btn,
  .header-actions .btn{
    width:105px !important;
    min-width:105px !important;
    font-size:12px !important;
  }
}


/* Equal-size header buttons */
.header-actions{
 display:flex!important;
 gap:8px!important;
 flex-wrap:wrap!important;
 justify-content:flex-end!important;
 align-items:center!important;
}
.header-actions .header-btn{
 width:118px!important;
 min-width:118px!important;
 height:38px!important;
 display:flex!important;
 align-items:center!important;
 justify-content:center!important;
 padding:0!important;
 font-size:13px!important;
 font-weight:700!important;
 border-radius:6px!important;
 box-sizing:border-box!important;
}
.btn-email{
 background:#fff!important;
 color:#000!important;
 border:2px solid #f7941d!important;
}
