/* assets/css/style.css */
/* Design tokens */
:root{
  --navy: #0A2342;
  --accent: #1F73C9;
  --white: #ffffff;
  --max-width: 1100px;
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;
  color:var(--navy);
  background:#fff;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.5;
}

.container{
  max-width:var(--max-width);
  margin:0 auto;
  padding:0 20px;
}

/* Header */
.site-header{
  background:var(--white);
  border-bottom:1px solid #eef2f6;
  padding:18px 0;
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.brand h1{
  margin:0;
  font-family: 'Poppins', sans-serif;
  font-weight:700;
  color:var(--navy);
  font-size:20px;
}
.tagline{margin:2px 0 0;font-size:13px;color:#58697b}

/* Nav */
.main-nav{background:transparent;padding:10px 0}
.main-nav ul{display:flex;gap:18px;list-style:none;padding:0;margin:0}
.main-nav a{text-decoration:none;color:var(--navy);font-weight:600}

/* Hero */
.hero{
  position:relative;
  min-height:520px;
  background-image:url('/assets/images/hero.jpg');
  background-size:cover;
  background-position:center center;
  display:flex;
  align-items:center;
  color:var(--white);
}
.hero-overlay{
  width:100%;
  background:linear-gradient(180deg, rgba(10,35,66,0.55), rgba(10,35,66,0.65));
  padding:80px 0;
}
.hero-content{
  text-align:left;
  max-width:720px;
}
.hero-content h2{
  font-family:'Poppins',sans-serif;
  font-size:44px;
  margin:0 0 12px;
}
.sub{font-size:18px;margin:0 0 20px;opacity:0.95}

/* Buttons */
.btn{display:inline-block;padding:10px 18px;border-radius:10px;text-decoration:none;font-weight:600}
.btn-primary{background:var(--accent);color:var(--white);box-shadow:0 6px 18px rgba(31,115,201,0.18)}
.btn-secondary{background:transparent;color:var(--white);border:2px solid rgba(255,255,255,0.18)}
.btn.large{padding:14px 22px;border-radius:12px}

/* Feature bar */
.feature-bar{padding:20px 0;background:#f7fbff}
.features{display:flex;gap:16px;align-items:center;justify-content:space-between}
.feature{display:flex;gap:8px;align-items:center;font-weight:600;color:var(--navy)}

/* Footer */
.site-footer{padding:26px 0;background:#fafbfc;border-top:1px solid #eef2f6;color:#5a6772;text-align:center}
.site-footer p{margin:6px 0}

/* Responsive */
@media(max-width:800px){
  .hero-content h2{font-size:32px}
  .features{flex-direction:column;align-items:flex-start;gap:10px}
  .header-inner{flex-direction:column;gap:12px;align-items:flex-start}
}

/* === GOOGLE REVIEW CAROUSEL === */

.carousel {
    position: relative;
    width: 100%;
    max-width: 700px;
    margin: 40px auto;
    overflow: hidden; /* IMPORTANT */
}

.carousel-inner {
    display: flex; /* IMPORTANT */
    flex-wrap: nowrap; /* prevent wrapping */
    transition: transform 0.6s ease;
    width: 100%; /* ensures proper transform */
}

.carousel-slide {
    width: 100%; /* Critical to ensure only 1 slide is visible */
    flex: 0 0 100%; /* Do NOT grow or shrink */
    padding: 30px;
    background: white;
    border-radius: 12px;
    box-shadow: 0 4px 16px rgba(0,0,0,0.1);
    text-align: center;
}

.carousel-slide .stars {
    font-size: 20px;
    margin-bottom: 10px;
    color: #fbbf24;
}

.carousel-slide p {
    font-size: 18px;
    line-height: 1.5;
}

.carousel-slide span {
    display: block;
    margin-top: 12px;
    font-size: 14px;
    opacity: 0.7;
}

/* Buttons */
.carousel-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: #0A2342;
    color: white;
    border: none;
    padding: 10px 14px;
    cursor: pointer;
    border-radius: 50%;
    font-size: 26px;
    opacity: 0.8;
    transition: 0.2s;
    z-index: 10;
}

.carousel-btn:hover {
    opacity: 1;
}

.prev { left: 10px; }
.next { right: 10px; }

/* Dots */
.carousel-dots {
    text-align: center;
    margin-top: 12px;
}

.carousel-dot {
    height
