:root{
  --bg:#fbf8f1; --fg:#1f2a24; --muted:#5d6b62; --card:#ffffff;
  --border:#e6e1d4; --soft:#f3efe4;
  --primary:#2f8a4a; --primary-fg:#fdfcf5;
  --sky:#3169b8; --accent:#dcefd9;
  --grad-warm:linear-gradient(135deg,#f7f1df 0%,#f1e8c9 100%);
  --grad-leaf:linear-gradient(135deg,#2f8a4a 0%,#3169b8 100%);
  --shadow-soft:0 20px 60px -20px rgba(49,105,184,.22);
  --shadow-warm:0 30px 80px -30px rgba(47,138,74,.35);
  --radius:1rem;
}
*{box-sizing:border-box;border-color:var(--border)}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--fg);font-family:"Inter",system-ui,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:"Fraunces",Georgia,serif;letter-spacing:-.02em;font-weight:600;margin:0}
p{margin:0}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
em.grad{font-style:normal;background:var(--grad-leaf);-webkit-background-clip:text;background-clip:text;color:transparent}
em.sky{font-style:normal;color:var(--sky)}
.muted{color:var(--muted)}
.small{font-size:.78rem}
.strong{font-weight:600}
.container{max-width:1180px;margin:0 auto;padding:0 1.5rem}
.eyebrow{display:inline-block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.22em;color:var(--primary)}
.lead{font-size:1.1rem;color:var(--muted);line-height:1.7;max-width:36rem}
.section{padding:6rem 0}
.section-head{max-width:42rem;margin-bottom:3.5rem}
.section-head.center{margin-inline:auto;text-align:center}
.section-head h2{font-size:clamp(2rem,3.6vw,3rem);margin:.75rem 0 1rem;line-height:1.1}
.bg-soft{
  background-color:var(--soft);
  background-image:url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='2' cy='2' r='1' fill='%232f8a4a' fill-opacity='0.08'/%3E%3C/svg%3E");
  background-size: 24px 24px;
}

/* nav */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(10px);background:rgba(251,248,241,.85);border-bottom:1px solid var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem}
.brand img{height:44px;width:auto}
.nav-links{display:none;gap:2rem;font-size:.9rem;font-weight:500;color:var(--muted)}
.nav-links a:hover{color:var(--primary)}
@media(min-width:860px){.nav-links{display:flex}}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border-radius:999px;font-weight:600;cursor:pointer;border:0;transition:transform .2s,opacity .2s,border-color .2s,color .2s,background .2s;text-align:center}
.btn-sm{padding:.6rem 1.2rem;font-size:.85rem}
.btn-lg{padding:1rem 1.75rem;font-size:1rem}
.btn-primary{background:var(--primary);color:var(--primary-fg);box-shadow:var(--shadow-warm)}
.btn-primary:hover{transform:scale(1.02);opacity:.95}
.btn-outline{background:transparent;border:2px solid rgba(31,42,36,.15);color:var(--fg)}
.btn-outline:hover{border-color:var(--primary);color:var(--primary)}
.full{width:100%}

/* hero */
.hero{position:relative;overflow:hidden;background:linear-gradient(rgba(251,248,241,0.88), rgba(251,248,241,0.88)), url('images/background.png') center/cover no-repeat}
.hero-blob{position:absolute;top:-8rem;right:-8rem;width:480px;height:480px;border-radius:50%;background:var(--grad-leaf);opacity:.28;filter:blur(80px)}
.hero-grid{display:grid;gap:3rem;padding:5rem 0 7rem;align-items:center}
@media(min-width:960px){.hero-grid{padding:8rem 0 10rem}}
.hero-copy{text-align:center; display:flex; flex-direction:column; align-items:center}
.chip{display:inline-flex;align-items:center;gap:.5rem;background:var(--accent);color:#225a30;padding:.4rem 1rem;border-radius:999px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em}
.chip .dot{width:.5rem;height:.5rem;border-radius:50%;background:var(--primary)}
.hero h1{font-size:clamp(2.6rem,5vw,4.5rem);line-height:1.02;margin:1.5rem 0; max-width:48rem}
.hero .lead{margin-top:1.25rem; margin-inline:auto}
.actions{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem;margin-top:2rem}
.hero-checks{display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem;margin-top:1.5rem;color:var(--muted);font-size:.9rem}
.hero-art{position:relative}
.hero-img{position:relative;border-radius:2rem;overflow:hidden;box-shadow:var(--shadow-warm);aspect-ratio:4/5}
.hero-img img{width:100%;height:100%;object-fit:cover}
.hero-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(31,42,36,.3),transparent 60%)}
.hero-card{position:absolute;bottom:-1.5rem;left:-1.5rem;background:var(--card);border:1px solid var(--border);border-radius:1.25rem;padding:1.1rem 1.25rem;box-shadow:var(--shadow-soft);display:flex;align-items:center;gap:.85rem;max-width:260px}
.hero-card-icon{width:42px;height:42px;border-radius:50%;background:var(--grad-leaf);color:#fff;display:grid;place-items:center;font-size:1.1rem}

/* stats */
.stats{
  border-block:1px solid var(--border);
  background-color:var(--card);
  background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M54.627 0l1.373 1.373-54.627 54.627-1.373-1.373L54.627 0zM24.627 0l1.373 1.373-24.627 24.627-1.373-1.373L24.627 0zM84.627 0l1.373 1.373-84.627 84.627-1.373-1.373L84.627 0z' fill='%231f2a24' fill-opacity='0.02' fill-rule='evenodd'/%3E%3C/svg%3E");
}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;padding:3rem 1.5rem;text-align:center}
@media(min-width:760px){.stats-grid{grid-template-columns:repeat(4,1fr)}}
.stat-v{font-family:"Fraunces",serif;font-size:clamp(2.2rem,4vw,3rem);font-weight:600;color:var(--primary)}

/* sobre */
.sobre-grid{display:grid;gap:3rem;align-items:center}
@media(min-width:960px){.sobre-grid{grid-template-columns:1fr 1fr;gap:4rem}}
.sobre-img img{width:100%;height:auto;border-radius:1.5rem;box-shadow:var(--shadow-warm);object-fit:cover;aspect-ratio:4/3}
.sobre-grid h2{font-size:clamp(2rem,3.6vw,3rem);margin-top:.75rem;line-height:1.1;margin-bottom:1.25rem}
.sobre-text p{font-size:1.1rem;color:var(--muted);line-height:1.7;margin-bottom:1.25rem}
.sobre-text blockquote{margin:0;border-left:4px solid var(--primary);padding-left:1.5rem;font-family:"Fraunces",serif;font-style:italic;font-size:1.3rem;color:var(--fg)}

/* services */
.services-grid{display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.service{background:var(--card);border:1px solid var(--border);border-radius:1.25rem;padding:1.75rem;transition:transform .3s,box-shadow .3s,border-color .3s}
.service:hover{transform:translateY(-4px);border-color:rgba(47,138,74,.4);box-shadow:var(--shadow-soft)}
.service-icon{width:48px;height:48px;border-radius:.85rem;background:var(--accent);color:var(--primary);display:grid;place-items:center;font-size:1.25rem;margin-bottom:1.1rem;transition:all .3s}
.service:hover .service-icon{background:var(--primary);color:#fff}
.service h3{font-size:1.2rem;font-family:"Inter",sans-serif;font-weight:600;margin-bottom:.4rem;letter-spacing:0}
.service p{color:var(--muted);line-height:1.6}

/* modalidades */
.modal-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.modal-card{background:var(--card);border:1px solid var(--border);border-radius:1.5rem;padding:2rem;transition:box-shadow .3s}
.modal-card:hover{box-shadow:var(--shadow-warm)}
.modal-icon{font-size:2rem;color:var(--primary);margin-bottom:1.5rem}
.modal-card h3{font-size:1.5rem;margin-bottom:.75rem}
.modal-card p{color:var(--muted)}

/* agendar */
.agendar-grid{display:grid;gap:3rem;align-items:start}
@media(min-width:960px){.agendar-grid{grid-template-columns:5fr 7fr}}
.agendar-grid h2{font-size:clamp(2rem,3.6vw,3rem);margin:.75rem 0 1rem;line-height:1.1}
.checks{list-style:none;padding:0;margin-top:1.25rem;color:var(--muted);font-size:.95rem}
.checks li{margin-bottom:.6rem}
.card{background:var(--card);border:1px solid var(--border);border-radius:1.5rem;padding:2rem;box-shadow:var(--shadow-soft)}
.form .field{margin-bottom:1rem;display:flex;flex-direction:column}
.form .row{display:grid;gap:1rem;grid-template-columns:1fr 1fr}
@media(max-width:560px){.form .row{grid-template-columns:1fr}}
.form label{font-size:.85rem;font-weight:600;margin-bottom:.4rem}
.form input,.form select,.form textarea{font:inherit;border:1px solid var(--border);background:#fff;padding:.7rem .9rem;border-radius:.75rem;color:var(--fg);transition:border-color .2s,box-shadow .2s}
.form input:focus,.form select:focus,.form textarea:focus{outline:0;border-color:var(--primary);box-shadow:0 0 0 3px rgba(47,138,74,.15)}
.form .err{color:#b8323c;font-size:.78rem;margin-top:.3rem;min-height:1em}
.form button{margin-top:.5rem}

/* gallery */
.gallery{display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}
@media(min-width:680px){.gallery{grid-template-columns:repeat(3,1fr)}}
@media(min-width:980px){.gallery{grid-template-columns:repeat(4,1fr)}}
.gallery-item{position:relative;border-radius:1.25rem;overflow:hidden;cursor:pointer;background:var(--soft);aspect-ratio:4/3;border:0;padding:0}
.gallery-item.big{grid-column:span 2;grid-row:span 2;aspect-ratio:1/1}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery-item:hover img{transform:scale(1.06)}
.gallery-item .lbl{position:absolute;inset:auto 0 0 0;padding:.85rem 1rem;color:#fff;font-size:.85rem;font-weight:500;background:linear-gradient(to top,rgba(0,0,0,.55),transparent);opacity:0;transition:opacity .3s}
.gallery-item:hover .lbl{opacity:1}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(251,248,241,.96);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:2rem}
.lightbox[hidden]{display:none}
.lightbox img{max-height:80vh;max-width:90vw;object-fit:contain;border-radius:.75rem;box-shadow:0 30px 80px -20px rgba(0,0,0,.4)}
.lb-close,.lb-nav{position:absolute;width:46px;height:46px;border-radius:50%;background:#fff;border:1px solid var(--border);font-size:1.3rem;cursor:pointer;display:grid;place-items:center;transition:background .2s}
.lb-close{top:1.25rem;right:1.25rem}
.lb-prev{left:1.5rem;top:50%;transform:translateY(-50%)}
.lb-next{right:1.5rem;top:50%;transform:translateY(-50%)}
.lb-close:hover,.lb-nav:hover{background:var(--soft)}
.lb-caption{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);background:#fff;border:1px solid var(--border);border-radius:999px;padding:.5rem 1.2rem;font-size:.85rem;font-weight:500}

/* cta */
.cta{position:relative;overflow:hidden;padding:6rem 0;color:#fdfcf5}
.cta-bg{position:absolute;inset:0;background:var(--grad-leaf)}
.cta-bg::after{content:"";position:absolute;inset:0;opacity:.2;background-image:radial-gradient(circle at 20% 20%,#fff 1px,transparent 1px);background-size:32px 32px}
.cta-grid{position:relative;display:grid;gap:3rem;align-items:center}
@media(min-width:880px){.cta-grid{grid-template-columns:1fr 1fr}}
.cta-copy h2{font-size:clamp(2rem,3.6vw,3rem);line-height:1.1}
.cta-copy p{margin-top:1.25rem;opacity:.92;font-size:1.05rem}
.contact-card{color:var(--fg);padding:2rem}
.contact-card h3{font-size:1.5rem;margin-bottom:1.25rem}
.contact-row{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}
.contact-row .ci{width:44px;height:44px;border-radius:.85rem;background:var(--accent);color:var(--primary);display:grid;place-items:center;font-size:1.1rem;flex-shrink:0;transition:all .2s}
a.contact-row:hover .ci{background:var(--primary);color:#fff}

/* footer */
.footer{background:#1c2620;color:rgba(253,252,245,.7);padding:3rem 0}
.footer-inner{display:flex;flex-direction:column;gap:1.25rem;align-items:center;justify-content:space-between;text-align:center}
@media(min-width:720px){.footer-inner{flex-direction:row;text-align:right}}
.footer-logo{height:48px;filter:brightness(0) invert(1);opacity:.9}
.footer p{font-size:.85rem}

/* whatsapp float */
.whatsapp-float{position:fixed;bottom:2rem;right:2rem;width:60px;height:60px;background:#25d366;color:#fff;border-radius:50%;display:grid;place-items:center;box-shadow:0 10px 30px -10px rgba(37,211,102,.6);z-index:90;transition:transform .3s,box-shadow .3s}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 15px 40px -10px rgba(37,211,102,.8)}
.whatsapp-float svg{width:34px;height:34px;fill:currentColor}

/* footer overrides */
.developed-by{font-size:.85rem;margin-top:.5rem;opacity:.8}
.developed-by a{font-weight:600;text-decoration:underline}
