:root{
  --teal:#2a9d8f;
  --blue:#00357a;
  --white:#ffffff;
  --gray:#f7f9fb;
}

*{box-sizing:border-box;margin:0;padding:0;}
html,body{max-width:100%;overflow-x:hidden;}
body{
  font-family:'Poppins',sans-serif;
  background:var(--white);
  color:#333;
  line-height:1.6;
}

/* ===== Shared Header / Nav (identical across pages) ===== */
nav{
  height:70px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 18px;
  background:var(--white);
  box-shadow:0 2px 8px rgba(0,0,0,0.08);
  position:sticky;
  top:0;
  z-index:1000;
}

.logo{
  display:flex;
  align-items:center;
  gap:10px;
  flex:0 0 auto;
}

.logo img{
  height:46px;
  width:auto;
  display:block;
  animation:logoRollIn 700ms ease-out both;
  transform-origin:left center;
}

/* roll-in animation for logo (all pages) */
@keyframes logoRollIn{
  from{opacity:0;transform:translateX(-16px) rotate(-8deg) scale(0.96);}
  to{opacity:1;transform:translateX(0) rotate(0) scale(1);}
}

.nav-links{
  list-style:none;
  display:flex;
  align-items:center;
  gap:10px;
}

.nav-links a{
  text-decoration:none;
  color:var(--blue);
  font-weight:700;
  padding:10px 12px;
  border-radius:10px;
  transition:transform .18s ease, background-color .18s ease, color .18s ease;
  display:inline-block;
  white-space:nowrap;
}

.nav-links a:hover{
  background:rgba(42,157,143,0.14);
  transform:translateY(-1px);
}

.nav-cta{
  display:flex;
  align-items:center;
  gap:10px;
  flex:0 0 auto;
}

.phone-link{
  text-decoration:none;
  color:var(--blue);
  font-weight:800;
  padding:10px 12px;
  border-radius:10px;
  border:2px solid rgba(0,53,122,0.12);
  transition:.18s ease;
  white-space:nowrap;
}

.phone-link:hover{
  background:rgba(42,157,143,0.12);
  border-color:rgba(42,157,143,0.35);
}

.nav-btn{
  text-decoration:none;
  background:var(--blue);
  color:#fff;
  font-weight:800;
  padding:10px 12px;
  border-radius:10px;
  transition:transform .18s ease, background-color .18s ease;
  white-space:nowrap;
}

.nav-btn:hover{
  background:var(--teal);
  transform:translateY(-1px);
}

.menu-toggle{
  display:none;
  font-size:28px;
  cursor:pointer;
  color:var(--blue);
  user-select:none;
  padding:8px 10px;
  border-radius:10px;
  transition:background-color .18s ease;
}

.menu-toggle:hover{background:rgba(0,0,0,0.04);}

/* ===== Mobile-only menu items ===== */
.mobile-only { display: none; }

/* Contact card button alignment */
.contact-card{
  display:flex;
  flex-direction:column;
}
.contact-card .contact-btn{
  margin-top:auto;
}


/* ===== Page header / hero ===== */
.page-hero{
  text-align:center;
  padding:70px 20px;
  background:linear-gradient(135deg,var(--teal),var(--blue));
  color:#fff;
}

.page-hero h1{
  font-family:'Chewy',cursive;
  font-size:2.7rem;
  margin-bottom:10px;
  letter-spacing:1px;
}

.page-hero p{
  max-width:820px;
  margin:0 auto;
  font-size:1.1rem;
  opacity:.95;
}

.hero-cta-row{
  display:flex;
  gap:12px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:22px;
}

.btn{
  display:inline-block;
  padding:14px 22px;
  border-radius:10px;
  font-weight:800;
  text-decoration:none;
  transition:transform .18s ease, background-color .18s ease, color .18s ease, border-color .18s ease;
  white-space:nowrap;
}

.btn-primary{
  background:#fff;
  color:var(--blue);
}

.btn-primary:hover{
  background:var(--teal);
  color:#fff;
  transform:translateY(-1px);
}

.btn-secondary{
  background:transparent;
  color:#fff;
  border:2px solid rgba(255,255,255,0.7);
}

.btn-secondary:hover{
  background:rgba(255,255,255,0.15);
  border-color:rgba(255,255,255,0.95);
  transform:translateY(-1px);
}

/* ===== Shared Sections ===== */
section{
  max-width:1000px;
  margin:50px auto;
  padding:40px 30px;
  background:#fff;
  border-radius:14px;
  box-shadow:0 2px 8px rgba(0,0,0,0.08);
}

section h2{
  color:var(--blue);
  font-size:1.8rem;
  margin-bottom:14px;
  text-align:center;
}

section p{
  font-size:1.05rem;
  color:#444;
  text-align:center;
}

.info-list{
  list-style:none;
  margin-top:18px;
  padding:0;
}

.info-list li{
  background:rgba(42,157,143,0.10);
  padding:12px 16px;
  margin:10px 0;
  border-radius:10px;
  font-size:1rem;
}

.info-list li:hover{
  background:rgba(42,157,143,0.16);
}

/* Contact cards */
#contact{
  background:var(--gray);
}

.contact-grid{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:18px;
  margin:22px 0;
}

.contact-card{
  background:#fff;
  padding:18px;
  border-radius:12px;
  box-shadow:0 3px 8px rgba(0,0,0,0.08);
  width:260px;
}

.contact-card h3{
  color:var(--blue);
  margin-bottom:8px;
  font-size:1.15rem;
  text-align:center;
}

.contact-card p{
  color:#111;
  font-size:1rem;
  margin-bottom:10px;
  text-align:center;
}

.contact-btn{
  display:inline-block;
  width:100%;
  padding:10px 14px;
  background:var(--blue);
  color:#fff;
  font-weight:800;
  border:none;
  border-radius:10px;
  cursor:pointer;
  transition:transform .18s ease, background-color .18s ease;
}

.contact-btn:hover{
  background:var(--teal);
  transform:translateY(-1px);
}

.map-embed{
  width:100%;
  max-width:650px;
  height:350px;
  border:0;
  border-radius:14px;
  margin:18px auto 0;
  display:block;
}

/* Blog */
.blog-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:16px;
}

.blog-card{
  grid-column:span 12;
  background:#fff;
  border:1px solid rgba(0,0,0,0.06);
  border-radius:14px;
  padding:18px;
}

.blog-card h3{
  color:var(--blue);
  margin-bottom:8px;
}

.blog-meta{
  font-size:.95rem;
  color:#555;
  margin-bottom:12px;
}

/* Footer */
footer{
  text-align:center;
  padding:28px 10px;
  background:var(--blue);
  color:#fff;
  font-size:.92rem;
  margin-top:50px;
}

footer a{color:var(--teal);text-decoration:none;}
footer a:hover{text-decoration:underline;}

/* ===== Mobile ===== */
@media (max-width: 900px){
  nav{padding:0 14px;}
  .phone-link{display:none;}
}

@media (max-width: 768px){
  .menu-toggle{display:block;}
  .nav-cta { display: none; }      /* hide desktop CTA on phones */
  .mobile-only { display: block; } /* show Calendly inside menu */
  .menu-toggle{ margin-left:auto; }
  .nav-cta{gap:8px;}
  .nav-btn{padding:10px 12px;}
  .nav-links{
    display:none;
    flex-direction:column;
    align-items:stretch;
    position:absolute;
    top:70px; /* matches nav height */
    left:0;
    width:100%;
    background:var(--white);
    padding:10px 0;
    border-top:2px solid var(--teal);
  }
  .nav-links.active{display:flex;}
  .nav-links li{width:100%;}
  .nav-links a{
    width:100%;
    text-align:center;
    padding:14px 12px;
    border-radius:0;
  }
  section{padding:34px 18px;margin:34px 14px;}
  .page-hero h1{font-size:2.35rem;}
}