@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;600&family=Playfair+Display:wght@700&display=swap');

:root {
  --primary:#2563eb;
  --secondary:#1e40af;
  --accent:#f59e0b;
  --bg:#f9f8f6;
  --surface:#fff;
  --text:#1a1a2e;
  --muted:#6b7280;
  --radius:16px;
  --shadow:0 4px 24px rgba(0,0,0,.10);
  --transition:all .3s cubic-bezier(.4,0,.2,1);
}

/* Global resets & typography */
*,
*::before,
*::after{
  box-sizing:border-box;
  margin:0;
  padding:0;
}
html{
  scroll-behavior:smooth;
}
body{
  font-family:'Inter',sans-serif;
  font-size:clamp(1rem,1vw + .5rem,1.125rem);
  line-height:1.6;
  color:var(--text);
  background:var(--bg);
}
h1,h2,h3,h4{
  font-family:'Playfair Display',serif;
  margin-bottom:.5em;
}
h1{
  font-size:clamp(2.5rem,4vw,4rem);
  line-height:1.2;
  color:#fff;
}
h2{
  font-size:clamp(2rem,3vw,3rem);
}
h3{
  font-size:clamp(1.5rem,2.5vw,2rem);
}

/* Layout helpers */
.container{
  max-width:1200px;
  margin:auto;
  padding:0 1rem;
}
.flex-between{
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.grid-3{
  display:grid;
  gap:1.5rem;
  grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
}
.grid-2{
  display:grid;
  gap:1.5rem;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
}

/* Navbar */
.navbar{
  position:sticky;
  top:0;
  z-index:1000;
  background:rgba(255,255,255,0.85);
  backdrop-filter:blur(10px);
}
.navbar .nav-list{
  display:flex;
  gap:1.5rem;
  list-style:none;
}
.navbar .nav-list a{
  position:relative;
  color:var(--text);
  text-decoration:none;
  font-weight:600;
}
.navbar .nav-list a::after{
  content:'';
  position:absolute;
  left:0;
  bottom:-2px;
  width:100%;
  height:2px;
  background:var(--primary);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .3s ease;
}
.navbar .nav-list a:hover::after{
  transform:scaleX(1);
}

/* Hero */
.hero-section{
  position:relative;
  background-size:cover;
  background-position:center;
  min-height:80vh;
  display:flex;
  align-items:center;
  color:#fff;
}
.hero-section .overlay{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,0.4);
}
.hero-content{
  position:relative;
  z-index:2;
  text-align:center;
  max-width:800px;
  margin:auto;
}
.hero-content p{
  margin:1rem 0 2rem;
  font-size:clamp(1rem,1.5vw,1.25rem);
}

/* Buttons */
.btn{
  display:inline-block;
  padding:.75rem 1.5rem;
  font-weight:600;
  text-decoration:none;
  color:#fff;
  transition:var(--transition);
}
.pill{
  border-radius:999px;
}
.btn.primary{
  background:linear-gradient(135deg,var(--primary),var(--accent));
}
.btn.secondary{
  background:linear-gradient(135deg,var(--secondary),var(--accent));
}
.btn:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow);
  filter:brightness(1.08);
}

/* Cards */
.card{
  background:var(--surface);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
  transition:var(--transition);
}
.card img{
  width:100%;
  display:block;
}
.card h3{
  margin:1rem;
}
.card p{
  margin:0 1rem 1rem;
}
.card:hover{
  transform:translateY(-6px);
}

/* Testimonial cards */
.testimonial-card{
  background:var(--surface);
  border-radius:var(--radius);
  padding:1.5rem;
  box-shadow:var(--shadow);
  transition:var(--transition);
}
.testimonial-card:hover{
  transform:translateY(-4px);
}

/* CTA Card */
.cta-card{
  display:block;
  background:linear-gradient(135deg,var(--secondary),var(--accent));
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
  text-decoration:none;
  color:#fff;
  transition:var(--transition);
}
.cta-card:hover{
  transform:translateY(-4px);
}
.cta-content{
  padding:1.5rem;
}

/* Forms */
input,
textarea{
  width:100%;
  padding:.75rem;
  border:1px solid var(--muted);
  border-radius:var(--radius);
  background:var(--surface);
  font-family:inherit;
  margin-bottom:.75rem;
  transition:var(--transition);
}
input:focus,
textarea:focus{
  outline:none;
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(37,99,235,.3);
}

/* Sections */
.section{
  padding:4rem 0;
}
.about-section .about-image img{
  width:100%;
  border-radius:var(--radius);
}
.contact-section .contact-info a{
  color:inherit;
  text-decoration:underline;
}

/* Footer */
.footer{
  background:var(--text);
  color:#fff;
  padding:3rem 0 1rem;
}
.footer a{
  color:#fff;
  text-decoration:none;
}
.footer h4{
  margin-bottom:.5rem;
}
.footer-col{
  margin-bottom:1.5rem;
}
.footer-bottom{
  text-align:center;
  padding-top:1rem;
  font-size:.875rem;
  border-top:1px solid rgba(255,255,255,.1);
}

/* Reveal animation */
@keyframes fadeInUp{
  from{
    opacity:0;
    transform:translateY(20px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}
.reveal{
  opacity:0;
  transform:translateY(20px);
  transition:var(--transition);
}
.reveal.active{
  opacity:1;
  transform:none;
  animation:fadeInUp .6s ease forwards;
}

/* Responsive tweaks */
@media (max-width:768px){
  .navbar .nav-list{
    flex-direction:column;
    background:var(--surface);
    position:absolute;
    top:100%;
    right:0;
    left:0;
    padding:1rem;
    display:none;
  }
  .navbar .nav-list.show{
    display:flex;
  }
  .hero-section{
    min-height:60vh;
  }
}
@media (max-width:480px){
  .hero-content h1{
    font-size:clamp(2rem,6vw,2.5rem);
  }
}