:root{
  --sand:#f5f2ec;
  --paper:#ffffff;
  --sage:#dde7dc;
  --ink:#22312c;
  --muted:#5f6c66;
  --line:#e7e3dc;
  --green:#2f9969;
  --green-dark:#237b55;
  --shadow:0 24px 60px rgba(34,49,44,.10);
  --shadow-soft:0 14px 34px rgba(34,49,44,.08);
  --radius-xl:28px;
  --radius-lg:22px;
  --radius-md:16px;
  --max:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at 0% 0%, rgba(255,255,255,.8), transparent 28%),
    radial-gradient(circle at 100% 100%, rgba(47,153,105,.08), transparent 24%),
    var(--sand);
  line-height:1.5;
}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}

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

.topbar{
  position:sticky; top:0; z-index:50;
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  background:rgba(245,242,236,.78);
  border-bottom:1px solid rgba(255,255,255,.6);
}
.topbar-inner{
  min-height:78px;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
}
.brand{
  display:flex;align-items:center;gap:10px;
  font-size:1.5rem;font-weight:800;letter-spacing:-.03em;
}
.brand .paw{font-size:1.25rem}
.nav{display:flex;gap:10px;flex-wrap:wrap}
.nav a{
  padding:11px 14px;border-radius:999px;font-weight:600;color:#33433d;
  transition:background .18s ease, transform .18s ease, box-shadow .18s ease;
}
.nav a:hover,.nav a.active{
  background:rgba(255,255,255,.82);box-shadow:var(--shadow-soft);transform:translateY(-1px);
}

.page{padding:30px 0 90px}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .75s ease, transform .75s ease}
.reveal.show{opacity:1;transform:none}

.hero{
  display:grid;grid-template-columns:1.04fr .96fr;gap:22px;align-items:stretch;
}
.hero-copy,.hero-visual{
  background:rgba(255,255,255,.72);
  border:1px solid rgba(255,255,255,.74);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow);
}
.hero-copy{padding:34px}
.kicker{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 13px;border-radius:999px;
  background:rgba(47,153,105,.12);color:var(--green-dark);
  font-size:.86rem;font-weight:800;letter-spacing:.02em;text-transform:uppercase;
}
.hero h1{
  margin:18px 0 14px;font-size:clamp(2.8rem,5vw,4.7rem);line-height:1.02;letter-spacing:-.05em;
}
.hero p{
  margin:0 0 18px;color:var(--muted);font-size:1.12rem;max-width:33rem;
}
.review-pill{
  display:inline-flex;align-items:center;gap:8px;
  margin:6px 0 24px;padding:10px 14px;border-radius:999px;
  background:#fff;box-shadow:var(--shadow-soft);font-weight:700;color:#394742
}
.actions{display:flex;gap:12px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:54px;padding:0 20px;border-radius:999px;
  font-weight:800;font-size:1rem;transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:linear-gradient(135deg,var(--green),var(--green-dark));color:#fff;box-shadow:0 18px 36px rgba(47,153,105,.28)}
.btn-secondary{background:#fff;color:var(--ink);box-shadow:var(--shadow-soft)}

.hero-visual{
  padding:18px;
  display:grid;
  grid-template-columns:1.1fr .9fr;
  grid-template-rows:1fr 1fr;
  gap:14px;
}
.hero-main{
  grid-row:1 / span 2;
  position:relative;
  overflow:hidden;
  border-radius:24px;
  min-height:620px;
}
.hero-main img,.hero-side img,.new-client-photo img,.service-card img,.gallery-card img{width:100%;height:100%;object-fit:cover}
.hero-main::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.18), transparent 32%);
}
.hero-main-badge{
  position:absolute;left:16px;bottom:16px;z-index:2;
  background:rgba(255,255,255,.92);padding:10px 14px;border-radius:999px;box-shadow:var(--shadow-soft);font-weight:700
}
.hero-side{
  overflow:hidden;border-radius:22px;min-height:303px;
}

.new-client{
  margin-top:24px;
  background:rgba(255,255,255,.82);
  border:1px solid rgba(255,255,255,.78);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow);
  padding:18px;
  display:grid;grid-template-columns:1.15fr .85fr;gap:18px;align-items:stretch;
}
.new-client-copy{padding:14px 10px 14px 14px}
.new-client h2{margin:4px 0 10px;font-size:2.2rem;letter-spacing:-.04em}
.new-client p{margin:0 0 14px;font-size:1.05rem;color:var(--muted)}
.new-client ul{margin:0;padding-left:20px;color:#47534e;font-size:1.05rem;line-height:1.7}
.new-client-photo{border-radius:22px;overflow:hidden;min-height:320px;background:#efe9df}
.new-client-photo img{object-position:center top}

.section{margin-top:34px}
.section-head{display:flex;justify-content:space-between;align-items:end;gap:18px;margin-bottom:18px}
.section-head h2{margin:0;font-size:clamp(2rem,4vw,3.1rem);letter-spacing:-.045em}
.section-head p{margin:0;max-width:38rem;color:var(--muted);font-size:1.05rem}

.services-grid{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;
}
.service-card{
  background:rgba(255,255,255,.92);border:1px solid rgba(255,255,255,.72);
  border-radius:24px;overflow:hidden;box-shadow:var(--shadow-soft);
  transition:transform .22s ease, box-shadow .22s ease;
}
.service-card:hover{transform:translateY(-6px);box-shadow:0 24px 54px rgba(34,49,44,.14)}
.service-media{aspect-ratio:4/3;overflow:hidden}
.service-body{padding:18px}
.service-body h3{margin:0 0 8px;font-size:1.7rem;letter-spacing:-.04em}
.service-body p{margin:0;color:var(--muted);font-size:1rem}
.service-link{display:inline-flex;align-items:center;gap:8px;margin-top:14px;font-weight:800;color:var(--green-dark)}

.gallery-grid{
  display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px;
}
.gallery-card{
  aspect-ratio:1/1;
  border-radius:22px;overflow:hidden;box-shadow:var(--shadow-soft);
  transition:transform .22s ease, box-shadow .22s ease;
}
.gallery-card:hover{transform:translateY(-6px) scale(1.01);box-shadow:0 24px 54px rgba(34,49,44,.14)}

.cta-panel{
  margin-top:34px;
  background:linear-gradient(135deg, rgba(255,255,255,.92), rgba(221,231,220,.88));
  border-radius:30px;padding:30px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.7);
  display:grid;grid-template-columns:1.1fr .9fr;gap:18px;align-items:center;
}
.cta-panel h2{margin:0 0 10px;font-size:2.4rem;letter-spacing:-.05em}
.cta-panel p{margin:0;color:var(--muted);font-size:1.08rem}
.info-list{display:grid;gap:12px}
.info-item{
  background:#fff;border-radius:18px;padding:16px 18px;box-shadow:var(--shadow-soft)
}
.info-item strong{display:block;margin-bottom:4px}

.hero-panel{
  background:rgba(255,255,255,.82);
  border:1px solid rgba(255,255,255,.72);
  border-radius:var(--radius-xl);box-shadow:var(--shadow);padding:34px
}
.hero-panel h1{margin:16px 0 14px;font-size:clamp(2.6rem,4.4vw,4.2rem);line-height:1.04;letter-spacing:-.045em}
.hero-panel p{margin:0;color:var(--muted);font-size:1.08rem}
.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.tile{
  background:rgba(255,255,255,.92);border:1px solid rgba(255,255,255,.72);border-radius:24px;padding:24px;box-shadow:var(--shadow-soft)
}
.tile h3{margin:0 0 10px;font-size:1.6rem;letter-spacing:-.04em}
.tile p{margin:0;color:var(--muted)}
.contact-box{display:grid;gap:14px}
.contact-chip{
  display:flex;gap:12px;align-items:flex-start;background:#fff;border-radius:18px;padding:16px 18px;box-shadow:var(--shadow-soft)
}
.contact-chip .icon{font-size:1.3rem;line-height:1.2}

.float-call{
  position:fixed;right:20px;bottom:20px;z-index:80;
  display:inline-flex;align-items:center;justify-content:center;gap:12px;
  min-height:60px;padding:0 24px;border-radius:999px;
  color:#fff;background:linear-gradient(135deg,var(--green),var(--green-dark));
  box-shadow:0 18px 38px rgba(47,153,105,.36);
  font-weight:800;font-size:1.08rem;animation:pulse 2.8s ease-in-out infinite
}
.float-call:hover{transform:translateY(-2px);box-shadow:0 24px 44px rgba(47,153,105,.42)}
@keyframes pulse{
  0%,100%{box-shadow:0 18px 38px rgba(47,153,105,.36)}
  50%{box-shadow:0 22px 46px rgba(47,153,105,.5)}
}

.footer{
  padding:16px 0 84px;color:#67746e;font-size:.95rem
}

@media (max-width: 1080px){
  .hero,.new-client,.cta-panel,.grid-2,.grid-3,.services-grid,.gallery-grid{grid-template-columns:1fr 1fr}
  .hero-main{min-height:520px}
}
@media (max-width: 860px){
  .nav{display:none}
  .hero,.new-client,.cta-panel,.grid-2,.grid-3,.services-grid,.gallery-grid{grid-template-columns:1fr}
  .hero-main{min-height:500px}
  .hero-visual{grid-template-columns:1fr;grid-template-rows:auto}
  .hero-main{grid-row:auto}
  .new-client-photo{min-height:260px}
}
@media (max-width: 640px){
  .container{padding:0 16px}
  .topbar-inner{min-height:72px}
  .brand{font-size:1.28rem}
  .hero-copy,.hero-panel{padding:24px}
  .new-client{padding:14px}
  .new-client h2{font-size:1.8rem}
  .section-head{display:block}
  .section-head p{margin-top:8px}
  .float-call{left:14px;right:14px;bottom:14px}
}
