:root{
  /* Light theme colours */
  --bg:#f9fafb;
  --text:#222;
  --muted:#5f6b7b;
  --card:#ffffff;
  --accent:#2e7d6e;
  --line:#e0e4e9;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial}
img{max-width:100%;height:auto;border-radius:12px}
.container{max-width:1100px;margin:0 auto;padding:0 20px}
a{color:var(--text);text-decoration:none}
.btn{padding:10px 16px;border:1px solid var(--line);border-radius:10px;display:inline-block}
.btn.primary{background:var(--accent);color:#ffffff;border-color:var(--accent);font-weight:600}
.btn.ghost{background:transparent}
h1,h2,h3,h4{margin:0 0 10px}
h2{font-size:40px;line-height:1.1}
h3{font-size:28px}
p{margin:0 0 12px;color:var(--muted)}

.site-header{position:sticky;top:0;background:rgba(255,255,255,0.9);backdrop-filter:saturate(1.2) blur(6px);z-index:10;border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;gap:12px;align-items:center}
.brand .logo{font-size:28px}
.brand h1{
  /* Increase the size of the company name in the header for better visibility */
  font-size:28px;
}
.brand .tag{
  /* Increase the tagline size so it's easier to read */
  font-size:16px;
  color:var(--muted);
}

.nav nav a{margin-left:14px;color:var(--muted)}
.nav nav a.btn{color:#081018;margin-left:16px}

.hero{padding:40px 0 10px;background:radial-gradient(80% 120% at 80% -10%, rgba(46,125,110,.15), transparent 60%)}
.hero-inner{display:grid;grid-template-columns:1.2fr .8fr;gap:26px;align-items:center}
.hero .hero-media img{box-shadow:0 10px 40px rgba(0,0,0,.45)}

.cta-row{display:flex;gap:12px;margin:14px 0}
.trust{display:flex;gap:16px;padding:0;margin:8px 0 0;list-style:none;color:var(--muted);font-size:14px}

.services{padding:40px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:18px}
.card{background:var(--card);border:1px solid var(--line);padding:16px;border-radius:12px}
.card h4{margin-bottom:6px}

.gallery{padding:40px 0}
.masonry{columns:2;column-gap:16px}
.masonry img{break-inside:avoid;margin:0 0 16px;border:1px solid var(--line)}

.pricing{padding:40px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:16px}
.price-card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px}
.price{font-size:22px;font-weight:700;color:#fff;margin:4px 0}
.note{font-size:14px;color:var(--muted);margin-top:12px}

.contact{padding:40px 0}
form{max-width:760px}
label{display:block;margin:10px 0 6px;font-weight:600}
input,textarea{width:100%;padding:12px;border-radius:10px;border:1px solid var(--line);background:var(--card);color:var(--text)}
.row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-note{font-size:13px;color:var(--muted);margin-top:8px}
#formStatus{margin-top:10px;font-size:14px}

.site-footer{padding:26px 0;border-top:1px solid var(--line);color:var(--muted)}

@media (max-width:900px){
  .hero-inner{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr 1fr}
  .price-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .grid,.price-grid{grid-template-columns:1fr}
  .row{grid-template-columns:1fr}
  h2{font-size:32px}
}


/* Reviews section styles */
.reviews{padding:40px 0;border-top:1px solid var(--line)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:16px 0}
.review{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px;color:var(--text)}
.review cite{display:block;margin-top:8px;color:var(--muted);font-style:normal}
@media (max-width:900px){
  .reviews-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .reviews-grid{grid-template-columns:1fr}
}
/* Logo styling */
.brand img.logo{display:block;border-radius:10px;box-shadow:0 0 0 1px var(--line)}

/* Social icons */
.social-icons{
  display:flex;
  gap:8px;
  align-items:center;
}
.social-icons img{
  width:24px;
  height:24px;
  display:block;
}

/* Carousel styles */
.carousel{position:relative;overflow:hidden;margin-top:20px}
.carousel-track{display:flex;transition:transform .5s ease}
.carousel-track img{min-width:100%;flex-shrink:0;border-radius:12px;border:1px solid var(--line)}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background:var(--accent);color:#fff;border:none;padding:8px 12px;border-radius:50%;cursor:pointer;z-index:1}
.carousel-btn.prev{left:10px}
.carousel-btn.next{right:10px}
.carousel-dots{display:flex;justify-content:center;margin-top:10px}
.carousel-dots button{width:10px;height:10px;border:none;border-radius:50%;margin:0 4px;background:var(--line);cursor:pointer}
.carousel-dots button.active{background:var(--accent)}

/* Profile section */
.profile{padding:40px 0;border-top:1px solid var(--line)}
.profile .profile-container{text-align:center}
.profile img{
  /* Enlarge the profile image so that the photo and rating details are clear */
  max-width:480px;
  margin:0 auto;
  display:block;
  border-radius:12px;
  border:1px solid var(--line);
}
.profile p{color:var(--muted);margin-top:12px}

/* Photo grid gallery */
.photo-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(250px, 1fr));
  gap:16px;
}
.photo-grid img{
  width:100%;
  height:auto;
  border-radius:12px;
  border:1px solid var(--line);
  cursor:pointer;
  transition:transform 0.15s ease;
}
.photo-grid img:hover{
  transform:scale(1.03);
}

/* Lightbox overlay */
.lightbox{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:100%;
  background:rgba(0,0,0,0.8);
  display:flex;
  align-items:center;
  justify-content:center;
  visibility:hidden;
  opacity:0;
  transition:opacity 0.3s, visibility 0s 0.3s;
  z-index:1000;
}
.lightbox.open{
  visibility:visible;
  opacity:1;
  transition:opacity 0.3s;
}
.lightbox-image{
  max-width:90%;
  max-height:80%;
  border-radius:12px;
}
.lightbox-prev,
.lightbox-next,
.lightbox-close{
  position:absolute;
  background:var(--accent);
  color:#fff;
  border:none;
  padding:10px 14px;
  border-radius:50%;
  font-size:20px;
  cursor:pointer;
  z-index:1001;
}
.lightbox-prev{
  top:50%;
  left:20px;
  transform:translateY(-50%);
}
.lightbox-next{
  top:50%;
  right:20px;
  transform:translateY(-50%);
}
.lightbox-close{
  top:20px;
  right:20px;
  transform:none;
}
