/* --- Base --- */
:root{
  --bg: #0b1220;
  --bg-2: #0d1628;
  --card: #0e1c32cc;
  --text: #e6eef9;
  --muted: #a9b8d0;
  --brand: #0ea5e9;
  --brand-2:#22d3ee;
  --glass: rgba(255,255,255,0.06);
  --border: rgba(255,255,255,0.12);
  --shadow: 0 10px 30px rgba(0,0,0,0.25), 0 2px 8px rgba(0,0,0,0.2);
  --radius: 14px;

  /* Gradient scroll hues */
  --h: 205;
  --sat: 70%;
  --d1: 10%;
  --d2: 12%;
  --d3: 14%;
}

* { box-sizing: border-box }
html, body { height: 100% }
body {
  margin: 0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, 'Helvetica Neue', Arial, 'Noto Sans', 'Apple Color Emoji', 'Segoe UI Emoji';
  color: var(--text);
  background: transparent;
  line-height: 1.6;
}

/* Seamless gradient backdrop */
body::before{
  content:"";
  position: fixed;
  inset: -10%;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(1200px 800px at 10% -10%, hsl(var(--h) var(--sat) 18% / 0.23), transparent 60%),
    radial-gradient(1200px 800px at 110% 10%, hsl(calc(var(--h) + 30) var(--sat) 20% / 0.16), transparent 50%),
    linear-gradient(
      180deg,
      hsl(var(--h) var(--sat) var(--d1)),
      hsl(calc(var(--h) + 30) var(--sat) var(--d2)) 50%,
      hsl(calc(var(--h) + 60) var(--sat) var(--d3))
    );
  filter: saturate(1.05);
}

img { max-width: 100%; height: auto; display: block }
a { color: var(--brand) }
.container { width: min(1100px, 92vw); margin: 0 auto; }
.section { padding: 64px 0; background: transparent }
.section.alt { background: transparent }
h1,h2,h3 { line-height: 1.2; margin: 0 0 12px 0 }
h1 { font-size: clamp(2rem, 3.6vw + 1rem, 3rem) }
h2 { font-size: clamp(1.5rem, 2.4vw + 1rem, 2rem) }
h3 { font-size: 1.1rem; letter-spacing: 0.2px }
p { margin: 0 0 14px 0 }
ul { padding-left: 18px }
.fine { color: var(--muted); font-size: 0.9rem }
.accent { background: linear-gradient(90deg, var(--brand), var(--brand-2)); -webkit-background-clip: text; background-clip: text; color: transparent }

/* Accessibility */
.skip-link{
  position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip-link:focus{ left: 12px; top: 12px; width:auto; height:auto; padding:8px 10px; background:#fff; color:#000; border-radius:8px }

/* --- Header --- */
.site-header { position: sticky; top: 0; backdrop-filter: blur(10px); background: rgba(10,16,32,0.6); border-bottom: 1px solid var(--border); z-index: 40 }
.header-inner { display:flex; align-items:center; justify-content:space-between; height:64px }
.brand { display:flex; align-items:center; gap:10px; text-decoration:none; color: var(--text); font-weight: 700; letter-spacing: 0.2px }
.brand img{ width:44px; height:44px; border-radius:6px }
.nav-toggle { display: none; font-size: 22px; background:none; border:none; color:var(--text) }
.nav-menu { display:flex; gap:18px; align-items:center; list-style:none; margin:0; padding:0 }
.nav-menu a { text-decoration:none; color: var(--text) }
.nav-menu .btn-small{ padding: 8px 12px; }

/* Mobile nav overlay (dims background) */
.nav-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.45);
  backdrop-filter: blur(2px);
  z-index: 30;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;
}

.nav-overlay.active {
  opacity: 1;
  pointer-events: auto;
}


/* --- Hero --- */
.hero { padding: 64px 0 24px 0 }
.hero-inner { display:grid; grid-template-columns:1.1fr 0.9fr; gap: 28px; align-items:center }
.hero .sub{ color:var(--muted) }
.cta-row{ display:flex; gap:12px; margin:16px 0 8px }
.badges{ display:flex; gap:12px; list-style:none; padding:0; margin:10px 0 0 0; color:var(--muted); flex-wrap:wrap }
.hero-card{ border:1px solid var(--border); border-radius: var(--radius); overflow:hidden; background: var(--glass) }
.hero-img{ width:100%; height:auto }
.scroll-indicator{ text-align:center; color:var(--muted) }
.glass { background: var(--glass); border:1px solid var(--border); border-radius: var(--radius) }
.shadow { box-shadow: var(--shadow) }

/* --- Cards & UI --- */
.cards{ display:grid; grid-template-columns: repeat(3, 1fr); gap:16px }
.cards.three .card{ min-height: 180px }
.card{ background: var(--card); border:1px solid var(--border); border-radius: var(--radius); padding:16px }
.card.hi{ background: linear-gradient(180deg, rgba(14,165,233,0.05), rgba(34,211,238,0.04)) }
.pill{ font-size:12px; padding:3px 8px; border-radius:999px; border:1px solid var(--border); color: var(--muted) }
.pill-blue{ background:#0ea5e922; color:#bfe9ff }
.pill-dark{ background:#0b2235; border-color:#184766 }
.features{ margin: 10px 0; padding-left: 18px }
.price{ font-weight:800; font-size: 1.3rem }
.price-row{ display:flex; align-items:baseline; gap:12px }
.btn{ display:inline-block; padding: 12px 16px; border-radius: 12px; text-decoration:none; background: linear-gradient(90deg, var(--brand), var(--brand-2)); color:#001019; font-weight:800; border: none; cursor: pointer; text-align:center }
.btn:hover{ filter: brightness(1.05) }
.btn-outline{ background: transparent; color: var(--text); border:1px solid var(--border) }
.btn.block{ display:block; width:100% }
.btn-small{ padding:8px 10px; font-size: 0.95rem }

/* --- Split & Misc --- */
.split{ display:grid; grid-template-columns: 1fr 1fr; gap: 20px; align-items:start }
.quote { padding: 16px }
.quote p{ font-size:1.1rem }
.quote-author{ color: var(--muted) }

/* --- Gallery --- */
.grid.gallery{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px }
.gallery-item{ background:transparent; border:1px solid var(--border); border-radius: 10px; padding:0; overflow:hidden; cursor:pointer }
.gallery-item img{ display:block; width:100%; height:auto }
.map img{ width:100%; border-radius: 12px }

/* --- Reviews (Marquee) --- */
.reviews-header{ display:flex; align-items:baseline; justify-content:space-between; gap: 12px; margin-bottom: 10px; }
.google-link{ text-decoration:none }
.reviews-marquee{ margin-top: 10px; position: relative; overflow: hidden; border:1px solid var(--border); border-radius: var(--radius); background: var(--glass) }
.reviews-marquee .track{ display:flex; gap: 16px; padding: 16px; animation: scrollX 28s linear infinite }
.reviews-marquee:hover .track{ animation-play-state: paused }
.review-card{ min-width: clamp(260px, 60vw, 360px); background: var(--card); border: 1px solid var(--border); border-radius: 12px; padding: 14px; box-shadow: var(--shadow) }
.review-card .stars{ letter-spacing: 3px; margin-bottom: 8px; color: #ffd166 }
.review-card .quote{ font-size: 1.02rem }
.review-card .meta{ color: var(--muted); margin-top: 8px; display:flex; gap:8px }
@keyframes scrollX {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* --- Map embed --- */
.map-embed iframe{ width: 100%; height: 380px; border: 0; border-radius: 12px; display: block }

/* --- Form --- */
.form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.form label{ display:block; font-weight:600 }
.form input,
.form textarea {
  display:block;
  width:100%;
  margin-top:6px;
  padding:12px;
  background:#0a1527;
  color: var(--text);
  border:1px solid var(--border);
  border-radius: 10px;
  outline:none;
}
.form input:focus,.form textarea:focus{ border-color: var(--brand) }

/* --- Service Areas --- */
.service-list {
  list-style: none;
  padding: 0;
  margin: 20px 0;
}
.service-list li {
  margin: 8px 0;
}
.service-list a {
  display: inline-block;
  padding: 10px 14px;
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: 10px;
  color: var(--text);
  text-decoration: none;
  transition: background 0.2s, transform 0.15s;
}
.service-list a:hover {
  background: rgba(255,255,255,0.08);
  transform: translateX(4px);
}

/* --- Footer --- */
.site-footer{ padding: 28px 0; border-top: 1px solid var(--border); background: rgba(0,0,0,0.2) }
.footer-inner{ display:flex; align-items:center; justify-content:space-between; gap: 16px; flex-wrap:wrap }
.brand-mini{ display:flex; align-items:center; gap:10px }
.site-footer a{ color: var(--muted); text-decoration:none }
.legal{ color: var(--muted) }

/* --- Responsive nav with animation --- */
@media (max-width: 900px){
  .nav-toggle{ display:block; cursor:pointer; font-size:26px; background:none; border:none; color:var(--text) }

  .nav-menu{
    display:none;
    position:absolute;
    right: 12px;
    top:64px;
    background:#0a1426;
    border:1px solid var(--border);
    border-radius:12px;
    padding:12px;
    width:min(88vw, 280px);
    flex-direction:column;
    gap:10px;
    box-shadow: var(--shadow);
    opacity:0;
    transform: translateY(-10px);
    transition: opacity 0.25s ease, transform 0.25s ease;
  }
  .nav-menu li{ list-style:none }
  .nav-menu a{
    display:block;
    padding:10px 14px;
    text-decoration:none;
    color: var(--text);
    border-radius:8px;
    transition: background 0.2s;
  }
  .nav-menu a:hover{ background:rgba(255,255,255,0.08) }

  .nav-menu.show{ 
    display:flex;
    opacity:1;
    transform: translateY(0);
  }

  .hero-inner{ grid-template-columns:1fr }
  .split{ grid-template-columns:1fr }
  .cards{ grid-template-columns:1fr; }
  .grid.gallery{ grid-template-columns:repeat(2,1fr) }
}
