:root{ --bg:#f8fafc; --text:#0f172a; --muted:#475569; --card:#ffffff; --accent:#22c55e; --accent2:#16a34a; --shadow:0 10px 30px rgba(0,0,0,.08); --radius:22px; --max:1100px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{ margin:0; font-family:system-ui,-apple-system,Segoe UI,Roboto,Poppins,Arial,sans-serif; background:var(--bg); color:var(--text); line-height:1.6;
}
a{color:inherit}
.container{max-width:var(--max); margin:0 auto; padding:0 20px;}
.topbar{ position:sticky; top:0; z-index:50; background:rgba(15,23,42,.92); backdrop-filter: blur(10px); color:#fff; border-bottom:1px solid rgba(255,255,255,.08);
}
.topbar .inner{ display:flex; align-items:center; justify-content:space-between; padding:14px 0; gap:14px;
}
.brand{ display:flex; flex-direction:column; gap:2px;
}
.brand strong{font-size:16px; letter-spacing:.2px}
.brand span{font-size:12px; opacity:.85}
.nav{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; justify-content:flex-end;
}
.nav a{ text-decoration:none; font-weight:600; font-size:13px; opacity:.92;
}
.nav a:hover{opacity:1; text-decoration:underline}
.pill{ display:inline-flex; align-items:center; gap:10px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12); padding:10px 14px; border-radius:999px; text-decoration:none; font-weight:700; font-size:13px;
}
.pill:hover{background:rgba(255,255,255,.12)}
.hero{ position:relative; color:#fff; background: radial-gradient(1200px 600px at 20% 10%, rgba(34,197,94,.35), transparent 55%), radial-gradient(900px 520px at 85% 35%, rgba(56,189,248,.18), transparent 55%), linear-gradient(180deg, rgba(15,23,42,1), rgba(15,23,42,.92)); overflow:hidden;
}
.hero .wrap{ padding:72px 0 54px; display:grid; grid-template-columns: 1.15fr .85fr; gap:30px; align-items:center;
}
.kicker{ display:inline-flex; align-items:center; gap:10px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.14); border-radius:999px; padding:8px 12px; font-weight:700; font-size:12px; letter-spacing:.2px; width:max-content;
}
h1{ margin:14px 0 12px; font-size:46px; line-height:1.06; letter-spacing:-.6px;
}
.hero p{ margin:0 0 22px; color:rgba(255,255,255,.86); font-size:16px; max-width:58ch;
}
.actions{display:flex; gap:12px; flex-wrap:wrap; align-items:center}
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:10px; padding:14px 18px; border-radius:999px; font-weight:800; text-decoration:none; border:1px solid transparent; transition:transform .12s ease, background .12s ease, border .12s ease;
}
.btn:active{transform:translateY(1px)}
.btn.primary{background:var(--accent); color:#052e16;}
.btn.primary:hover{background:var(--accent2)}
.btn.ghost{ background:transparent; border-color:rgba(255,255,255,.22); color:#fff;
}
.btn.ghost:hover{background:rgba(255,255,255,.08)}
.hero-card{ background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14); border-radius:var(--radius); box-shadow:0 18px 40px rgba(0,0,0,.25); padding:20px;
}
.hero-card h3{margin:0 0 10px; font-size:16px}
.hero-card ul{margin:0; padding-left:18px; color:rgba(255,255,255,.86)}
.hero-card li{margin:8px 0}
.badges{display:flex; gap:10px; flex-wrap:wrap; margin-top:14px}
.badge{ font-size:12px; font-weight:800; padding:8px 12px; border-radius:999px; background:rgba(34,197,94,.16); border:1px solid rgba(34,197,94,.28); color:#dcfce7;
}
.section{padding:62px 0;}
.section h2{ margin:0 0 12px; font-size:32px; letter-spacing:-.3px;
}
.section p.lead{margin:0 0 26px; color:var(--muted); max-width:70ch}
.grid{ display:grid; grid-template-columns:repeat(12,1fr); gap:18px;
}
.card{ background:var(--card); border-radius:var(--radius); box-shadow:var(--shadow); border:1px solid rgba(15,23,42,.06); padding:20px;
}
.card h3{margin:0 0 8px}
.card p{margin:0; color:var(--muted)}
.service{grid-column:span 6;}
@media (min-width:920px){ .service{grid-column:span 3;} }
.feature{grid-column:span 12;}
@media (min-width:920px){ .feature{grid-column:span 4;} }
.split{ display:grid; grid-template-columns:1fr; gap:18px;
}
@media (min-width:920px){ .split{grid-template-columns:1.2fr .8fr;} }
.callout{ background:linear-gradient(135deg, rgba(34,197,94,.14), rgba(56,189,248,.10)); border:1px solid rgba(15,23,42,.08);
}
.small{font-size:13px; color:var(--muted)}
.list{margin:10px 0 0; padding-left:18px; color:var(--muted)}
.list li{margin:8px 0}
.kpi{ display:flex; gap:12px; flex-wrap:wrap; margin-top:14px
}
.kpi .item{ background:rgba(15,23,42,.04); border:1px solid rgba(15,23,42,.07); border-radius:999px; padding:10px 12px; font-weight:800; font-size:12px; color:var(--text)
}
.footer{ background:#0f172a; color:#fff; padding:34px 0; margin-top:30px;
}
.footer a{color:#fff; opacity:.9}
.footer a:hover{opacity:1}
.footer .cols{ display:grid; gap:18px; grid-template-columns:1fr;
}
@media (min-width:920px){ .footer .cols{grid-template-columns:1.4fr .6fr .6fr;} }
hr.sep{ border:none; border-top:1px solid rgba(255,255,255,.12); margin:18px 0 14px;
}
.fine{font-size:12px; opacity:.85}
.whatsapp{ position:fixed; bottom:18px; right:18px; display:inline-flex; align-items:center; gap:10px; background:#25D366; color:#062d16; font-weight:900; text-decoration:none; padding:12px 14px; border-radius:999px; box-shadow:0 14px 34px rgba(0,0,0,.22);
}
.whatsapp:hover{filter:brightness(0.96)}
.note{ background:#fff; border:1px dashed rgba(15,23,42,.18); border-radius:14px; padding:12px 14px; color:var(--muted); font-size:13px;
} /* ===== Gallery ===== */
.gallery-grid{ display:grid; grid-template-columns:repeat(auto-fit, minmax(280px, 1fr)); gap:18px;
}
.g-item{ display:block; border-radius:18px; overflow:hidden; background:#fff; box-shadow:var(--shadow); border:1px solid rgba(15,23,42,.06);
}
.g-item img{ width:100%; height:260px; object-fit:cover; display:block; transition:transform .18s ease;
}
.g-item:hover img{transform:scale(1.03)}
@media (min-width:920px){ .g-item img{ width:100%; height:260px; object-fit:cover; display:block; transition:transform .18s ease;
}
} /* ===== Testimonials ===== */
.testimonials{background:linear-gradient(180deg, rgba(15,23,42,.02), rgba(15,23,42,0));}
.t-grid{ display:grid; grid-template-columns:repeat(12,1fr); gap:18px;
}
.t-card{ grid-column:span 12; background:#fff; border-radius:22px; box-shadow:var(--shadow); border:1px solid rgba(15,23,42,.06); padding:18px;
}
@media (min-width:920px){ .t-card{grid-column:span 4;} }
.t-quote{margin:10px 0 0; color:var(--muted);}
.t-name{margin-top:10px; font-weight:900; color:var(--text);}
.stars{color:#fbbf24; font-size:16px; letter-spacing:1px; font-weight:900} /* ===== Brand Button ===== */
.brand-button{ display:inline-block; padding:8px 16px; background:#16a34a; color:white !important; border-radius:8px; font-weight:800; letter-spacing:.5px; text-decoration:none; transition:.2s ease;
}
.brand-button:hover{ background:#15803d; transform:translateY(-1px);
} /* Reviews improvement */
.review-stars{ color:#fbbf24; font-size:22px; letter-spacing:2px; font-weight:900; display:inline-block; margin-bottom:8px;
} /* ===== Mobile Call Bar ===== */
.callbar{ position:fixed; left:0; right:0; bottom:0; z-index:9999; padding:10px 14px calc(10px + env(safe-area-inset-bottom)); background:rgba(15,23,42,.92); backdrop-filter: blur(10px); border-top:1px solid rgba(255,255,255,.10); display:none;
}
.callbar .inner{ max-width:1100px; margin:0 auto; display:flex; gap:10px;
}
.callbar a{ flex:1; display:flex; align-items:center; justify-content:center; gap:10px; padding:14px 14px; border-radius:14px; font-weight:900; text-decoration:none; letter-spacing:.2px;
}
.callbar .call{ background:#22c55e; color:#052e16;
}
.callbar .call:active{transform:translateY(1px)}
.callbar .hint{ flex:0 0 auto; display:flex; align-items:center; justify-content:center; padding:14px 12px; border-radius:14px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12); color:rgba(255,255,255,.92); font-weight:800; font-size:12px;
}
@media (max-width: 900px){ .callbar{display:block;} body{padding-bottom:76px;}
}
