:root{
  --terracotta: #C65D3B;
  --terracotta-deep: #A9472A;
  --olive: #6B8A47;
  --sand: #F3E9DE;
  --cream: #FFF8F2;
  --text: #2B2B2B;
  --muted: #6F6F6F;
  --card: #FFFDFB;
  --radius: 12px;
  --shadow: 0 8px 28px rgba(15,15,15,0.06);
  --max-width: 1100px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  font-family: Inter, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  margin:0;
  line-height:1.6;
  color:var(--text);
  background: linear-gradient(180deg,var(--cream),var(--sand));
  -webkit-font-smoothing:antialiased;
}

.container{max-width:var(--max-width);margin:0 auto;padding:1.25rem}

/* header */
.site-header{
  position:sticky; top:0; z-index:60;
  background:rgba(255,250,247,0.86);
  backdrop-filter: blur(6px);
  border-bottom:1px solid rgba(0,0,0,0.04);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand{display:flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--text);font-weight:700}
.brand .logo{font-size:1.1rem}
.nav{display:flex;gap:1rem;align-items:center}
.nav a{color:var(--text);text-decoration:none;padding:.35rem .5rem;border-radius:8px;font-weight:500}
.nav a:hover{opacity:.9}
.cta{background:var(--terracotta);color:#fff;padding:.45rem .7rem;border-radius:8px}
.nav-toggle{display:none;border:0;background:transparent;font-size:1.1rem}

/* hero */
.hero{padding:3rem 0}
.hero-grid{display:grid;grid-template-columns:1fr 420px;gap:1.5rem;align-items:center}
.hero h1{font-family: 'Playfair Display', serif; font-size:clamp(1.6rem,3.8vw,2.6rem);margin:0 0 .5rem}
.lead{color:var(--muted);margin:0 0 1rem}
.hero-image{width:100%;height:auto;border-radius:16px;box-shadow:var(--shadow);border:1px solid rgba(0,0,0,0.03)}
.btn{display:inline-block;border-radius:999px;padding:.6rem 1rem;text-decoration:none;font-weight:600}
.btn-primary{background:var(--terracotta);color:#fff}
.btn-ghost{background:transparent;border:1px solid rgba(0,0,0,0.06);color:var(--text)}
.actions{margin-top:1rem}


/* about */
.about {
  padding: 2.5rem 0;
}

.about-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 0.9fr); /* text : image ratio */
  gap: 2rem;
  align-items: start;
}

.about-photo {
  justify-self: end;
  max-width: 500px;
  width: 100%;
}

.about-photo img {
  display: block;
  width: 100%;
  max-width: 500px;
  height: auto;
  border-radius: 12px;
  box-shadow: var(--shadow);
}

.meta-list {
  margin-top: .6rem;
  padding-left: 1rem;
  color: var(--muted);
}

/* responsive: stack on mobile */
@media (max-width: 980px) {
  .about-grid {
    grid-template-columns: 1fr;
  }
  .about-photo {
    justify-self: center;
    margin-top: 1.5rem;
  }
}



.numbers {
  padding: 1.5rem 0 3rem;  /* slightly less top, a bit more bottom */
}



.numbers-grid h2{margin-bottom:1rem}
.num-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}
.num-card{background:linear-gradient(180deg,#fff,#fff7f2);padding:1.25rem;border-radius:12px;border:1px solid rgba(0,0,0,0.03);text-align:center;box-shadow:var(--shadow)}
.num{font-size:2rem;font-weight:700;color:var(--terracotta-deep)}
.num-label{margin-top:.5rem;color:var(--muted);font-weight:600}

/* testimonials */
.test-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;margin-top:1rem}
.testi{background:linear-gradient(180deg,#fff,#fff6f3);padding:1rem;border-radius:12px;border-left:4px solid var(--olive);font-style:normal}
.testi cite{display:block;margin-top:.6rem;color:var(--muted);font-style:normal;font-weight:600}

/* gallery */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: .8rem;
  margin-top: 1rem;
}

.gallery-grid a {
  display: block;
}

.gallery-grid a img {
  width: 100%;
  height: 300px;
  object-fit: cover;
  border-radius: 12px;
  cursor: zoom-in;
  display: block;
}


/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 320px;gap:1rem;align-items:start}
.contact-form input, .contact-form textarea{width:100%;padding:.6rem;border-radius:8px;border:1px solid rgba(0,0,0,0.08);margin-bottom:.6rem}
.contact-info{background:var(--card);padding:1rem;border-radius:12px;border:1px solid rgba(0,0,0,0.03)}

/* whatsapp floating */
.whatsapp-button{
  position:fixed;right:18px;bottom:18px;z-index:80;
  background:linear-gradient(180deg,var(--olive),var(--terracotta));
  color:#fff;padding:.9rem .95rem;border-radius:999px;display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 30px rgba(0,0,0,0.18);text-decoration:none;font-weight:700;font-size:1.05rem;
}

/* footer */
.site-footer{padding:2rem 0;color:var(--muted);text-align:center}

/* responsive */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width:680px){
  .nav{display:none;position:absolute;right:1rem;top:64px;background:var(--cream);padding:.75rem;border-radius:8px;box-shadow:var(--shadow)}
  .nav.open{display:flex;flex-direction:column;align-items:flex-end}
  .nav-toggle{display:block}
}

/* fade-in animation */
.fade-in{opacity:0;transform:translateY(12px);transition:opacity .75s ease-out, transform .75s ease-out}
.fade-in.visible{opacity:1;transform:none}

/* accessibility focus */
button:focus, a:focus, input:focus, textarea:focus{outline:3px solid rgba(182,125,102,0.18);outline-offset:3px}

/* utilities */
.muted{color:var(--muted)}


.btn.btn-primary {
  /* your existing primary button styles */
}
/* types */
.types {
  padding: 3rem 0 2rem;          /* balanced top/bottom */
  background: var(--cream);
}

.types-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr)); /* 3 columns on desktop */
  gap: 1.25rem;
  margin-top: 1.5rem;
}

.type-card {
  background: var(--card);
  padding: 1.1rem 1.25rem;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,0.03);
  box-shadow: var(--shadow);
  text-align: center;
}

.types .muted {
  margin-top: .25rem;
  color: var(--muted);
}

/* Types grid responsiveness */
@media (max-width: 980px) {
  .types-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));  /* 2 columns on tablet */
  }
}
@media (max-width: 640px) {
  .types-grid {
    grid-template-columns: 1fr;                        /* 1 column on mobile */
  }
}
