/* Theme */
:root{
  --bg:#000; --panel:#0b0b0b; --text:#e8e8e8; --muted:#a9a9a9;
  --blue:#1E90FF; --blue-2:#3AA6FF; --shadow:0 10px 30px rgba(0,0,0,.5);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Poppins',system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,'Helvetica Neue',Arial,'Noto Sans',sans-serif;background:var(--bg);color:var(--text);line-height:1.6}

/* Top Bar */
.topbar{position:sticky;top:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:rgba(0,0,0,.8);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid rgba(255,255,255,.06)}
.brand{font-weight:700;color:var(--text)}
.menu-toggle{display:none;font-size:1.5rem;background:none;border:none;color:#fff}
.nav{display:flex;gap:1rem}
.nav a{color:var(--blue);text-decoration:none;font-weight:600;padding:.4rem .6rem;border-radius:.5rem}
.nav a:hover{color:#fff;background:rgba(30,144,255,.15)}

/* HERO: uses /images/hero.jpg if present; otherwise gradient only */
.hero{
  min-height:72vh;display:grid;place-items:center;text-align:center;padding:4rem 1rem;
  background: linear-gradient(180deg,rgba(0,0,0,.55),rgba(0,0,0,.85)), url('images/hero.jpg') center/cover no-repeat;
}
.overlay{max-width:820px;padding:1.25rem;box-shadow:var(--shadow);border-radius:1rem;background:rgba(0,0,0,.35)}
.hero h1{font-size:clamp(2rem, 5vw, 3.25rem);margin:.25rem 0;color:var(--blue)}
.hero p{margin:.35rem 0;color:#e9f4ff}
.cta,.call{display:inline-block;margin-top:1rem;padding:.9rem 1.25rem;border-radius:.75rem;background:var(--blue);color:#000;font-weight:800;text-decoration:none;box-shadow:0 8px 20px rgba(30,144,255,.35)}
.cta:hover,.call:hover{background:var(--blue-2)}

/* Sections */
.section{padding:3rem 1.25rem;max-width:1100px;margin:0 auto}
.section h2{color:var(--blue);margin:0 0 1rem;font-size:clamp(1.5rem,3vw,2rem)}
.cards{display:grid;gap:1rem;grid-template-columns: repeat(4, minmax(0,1fr))}
.card{background:var(--panel);padding:1.1rem;border-radius:1rem;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.06)}
.card h3{margin:.25rem 0 .5rem;color:#fff;font-size:1.1rem}
.card p{color:var(--muted)}

/* Gallery with robust placeholders */
.gallery{display:grid;gap:1rem;grid-template-columns: repeat(5, 1fr)}
.thumb{
  width:100%;aspect-ratio:1/1;border-radius:.75rem;position:relative;overflow:hidden;
  background:
    linear-gradient(135deg, rgba(30,144,255,.15), rgba(30,144,255,.05)),
    radial-gradient(120% 100% at 0% 0%, rgba(255,255,255,.06), rgba(0,0,0,.0)),
    #0d0d0d;
  box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.06);
}
.thumb::before{
  content:'';position:absolute;inset:0;
  background-image: var(--img);
  background-position:center;background-size:cover;background-repeat:no-repeat;
  filter:saturate(1.05) contrast(1.02);
}
.thumb::after{
  content: attr(aria-label);
  position:absolute;left:.5rem;bottom:.5rem;font-size:.8rem;color:#cfe8ff;opacity:.6;
}

/* Contact */
.form{margin-top:1rem;display:grid;gap:.75rem}
.form input,.form textarea{width:100%;padding:.85rem 1rem;border-radius:.75rem;border:1px solid rgba(255,255,255,.08);background:#0e0e0e;color:#fff}
.form button{padding:.9rem 1.25rem;border-radius:.75rem;border:none;font-weight:800;cursor:pointer;background:var(--blue);color:#000}
.form button:hover{background:var(--blue-2)}

/* Footer */
.footer{text-align:center;padding:2rem 1rem;color:#9a9a9a;border-top:1px solid rgba(255,255,255,.06);background:#050505}

/* Responsive */
@media (max-width: 1100px){ .gallery{grid-template-columns: repeat(4, 1fr)} }
@media (max-width: 900px){ .gallery{grid-template-columns: repeat(3, 1fr)} }
@media (max-width: 680px){
  .menu-toggle{display:block}
  .nav{display:none;position:absolute;right:1rem;top:58px;background:#0b0b0b;padding:.75rem;border-radius:.75rem;box-shadow:var(--shadow);flex-direction:column;gap:.4rem}
  .nav.open{display:flex}
  .gallery{grid-template-columns: repeat(2, 1fr)}
  .cta{width:100%;max-width:320px}
}


/* Logo in hero header */
header.hero .site-logo {
  max-width: 180px;
  margin-bottom: 1rem;
}


/* Instagram link in header */
header.hero .instagram-link {
  display: inline-block;
  margin-top: 1rem;
  font-size: 1.2rem;
  color: #fff;
  text-decoration: none;
  background: #E1306C;
  padding: 0.5rem 1rem;
  border-radius: 6px;
  transition: background 0.3s;
}
header.hero .instagram-link:hover {
  background: #C13584;
}


/* Brighten hero photo */
header.hero::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(255,255,255,0.2); /* adds a light overlay */
  z-index: 0;
}
header.hero .overlay {
  position: relative;
  z-index: 1;
}


/* Remove gallery label overlays */
.thumb::after{ content: none !important; }

/* Ensure hero brightening applies to section.hero */
section.hero{ position: relative; }

section.hero .overlay{ position:relative; z-index:1; }

/* Instagram link styles */
header.topbar .nav a.instagram{
  margin-left: .75rem;
  padding: .35rem .6rem;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: .5rem;
  font-weight: 600;
}
section.hero .instagram-hero{
  display:inline-block;margin-top:.75rem;
  padding:.5rem .9rem;border-radius:.5rem;
  background:#E1306C;color:#fff;text-decoration:none;
}
section.hero .instagram-hero:hover{ filter: brightness(1.1); }


/* Better hero brightness */
section.hero {
  position: relative;
  filter: brightness(1.15) contrast(1.05);
}

/* Instagram button with icon */
section.hero .instagram-hero svg {
  margin-right: 6px;
}


/* Instagram link in nav */
header.topbar .nav a.instagram {
  display:inline-flex;align-items:center;
  margin-left: .75rem;
  padding:.35rem .6rem;
  border:1px solid rgba(255,255,255,.2);
  border-radius:.5rem;
  font-weight:600;
}
header.topbar .nav a.instagram:hover{
  background:#E1306C;color:#fff;
}


@media (max-width: 1100px){ .cards{grid-template-columns: repeat(3, minmax(0,1fr))} }
@media (max-width: 900px){ .cards{grid-template-columns: repeat(2, minmax(0,1fr))} }
@media (max-width: 680px){ .cards{grid-template-columns: 1fr} }


/* Google Reviews rating */
.google-reviews {
  margin-top:1rem;
  font-size:1.2rem;
  color:#FFD700;
  text-align:center;
}
.google-reviews strong {
  display:block;
  font-size:1rem;
  color:#fff;
}
.google-reviews p {
  margin:0.25rem 0 0;
  color:#ccc;
  font-size:0.9rem;
}
