:root{
  --bg:#f6f8fb; --card:#ffffff; --ink:#0b2a4a; --muted:#526579;
  --brand:#1463a8; --brand2:#0b2a4a; --line:#d9e4f2;
  --shadow: 0 18px 40px rgba(11,42,74,.10);
  --radius: 18px; --radius2: 26px;
}
*{box-sizing:border-box} html,body{margin:0;padding:0}
body{font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; background:var(--bg); color:var(--ink); line-height:1.45}
a{color:inherit} .container{max-width:1120px;margin:0 auto;padding:0 18px}
.section{padding:64px 0} @media (max-width:760px){.section{padding:44px 0}}
@keyframes glowPulse{0%,100%{box-shadow:0 16px 36px rgba(20,99,168,.30),0 0 0 rgba(20,99,168,0)}50%{box-shadow:0 20px 44px rgba(20,99,168,.44),0 0 0 10px rgba(20,99,168,.08)}}
.topbar{position:sticky;top:0;z-index:50;background:rgba(246,248,251,.82);backdrop-filter:blur(14px);border-bottom:1px solid rgba(217,228,242,.8)}
.topbar-inner{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:18px;height:76px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--ink)}
.brand img{width:52px;height:52px;object-fit:contain}
.brand-title{font-weight:800;font-size:16px;white-space:nowrap;line-height:1.05}
.brand-title strong{font-weight:900}
.brand-sub{font-weight:700;font-size:13px;color:var(--muted);margin-top:2px}
.nav{justify-self:center;display:flex;gap:18px;align-items:center;flex-wrap:nowrap}
.nav a{text-decoration:none;color:var(--ink);font-weight:650;font-size:14px;padding:10px 10px;border-radius:12px;opacity:.95;white-space:nowrap}
.nav a:hover{background:#fff;box-shadow:0 10px 22px rgba(11,42,74,.08)}
@media (max-width:980px){.nav{display:none}}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:13px 15px;border-radius:14px;border:1px solid var(--line);background:#fff;box-shadow:0 12px 26px rgba(11,42,74,.10);text-decoration:none;font-weight:900}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:linear-gradient(135deg,var(--brand2),var(--brand));color:#fff;border-color:transparent;animation:glowPulse 2.6s ease-in-out infinite}
.btn-ghost{background:#fff} .btn-sm{padding:10px 12px;font-size:14px} .btn-wide{padding:14px 16px;font-size:15px}
.hero{padding:38px 0 10px}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:26px;align-items:stretch}
@media (max-width:980px){.hero-grid{grid-template-columns:1fr;gap:18px}}
.hero-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius2);box-shadow:var(--shadow);padding:22px;overflow:hidden}
.kicker{display:flex;flex-wrap:wrap;gap:10px;align-items:center;color:var(--brand);font-weight:900;letter-spacing:.2px}
.kicker .pill{display:inline-flex;align-items:center;gap:8px;background:#eaf2fb;border:1px solid #d6e3f2;padding:8px 10px;border-radius:999px;font-size:13px}
h1{font-size:44px;line-height:1.05;margin:12px 0 10px;letter-spacing:-.8px}
@media (max-width:760px){h1{font-size:34px}}
.sub{color:var(--muted);font-size:16px;margin:0 0 18px}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}
.trust-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.badge{display:inline-flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line);background:#fff;border-radius:14px;color:var(--ink);font-weight:800;font-size:14px}
.badge small{display:block;font-weight:650;color:var(--muted);margin-left:2px}
.hero-right{display:flex;flex-direction:column;gap:14px}
.gallery-hero{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.gallery-hero .big{grid-column:1/-1}
.figure{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--line);background:#fff;min-height:160px}
.figure img{width:100%;height:100%;object-fit:cover;display:block}
.figure .cap{position:absolute;left:12px;bottom:12px;background:rgba(11,42,74,.85);color:#fff;padding:8px 10px;border-radius:999px;font-weight:900;font-size:12px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media (max-width:980px){.grid-3{grid-template-columns:1fr 1fr}}
@media (max-width:620px){.grid-3{grid-template-columns:1fr}}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 14px 32px rgba(11,42,74,.08);padding:18px}
.card h3{margin:0 0 8px;font-size:16px} .card p{margin:0;color:var(--muted)}
.section-title{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:18px}
.section-title h2{margin:0;font-size:28px;letter-spacing:-.4px} .section-title p{margin:0;color:var(--muted);max-width:60ch}
.split{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:stretch}
@media (max-width:980px){.split{grid-template-columns:1fr}}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media (max-width:980px){.gallery{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.gallery{grid-template-columns:1fr}}
.tile{border-radius:18px;overflow:hidden;border:1px solid var(--line);background:#fff;cursor:pointer;min-height:190px}
.tile img{width:100%;height:100%;object-fit:cover;display:block} .tile:hover{transform:translateY(-2px)}
.note{background:#fff;border:1px dashed #c7d9ee;border-radius:var(--radius);padding:14px;color:var(--muted)}
.map{width:100%;height:360px;border:0;border-radius:18px;overflow:hidden;box-shadow:0 14px 32px rgba(11,42,74,.08);border:1px solid var(--line)}
.footer{padding:34px 0 90px;border-top:1px solid rgba(217,228,242,.9);color:var(--muted)} .footer strong{color:var(--ink)}
.sticky-actions{position:fixed;right:18px;bottom:18px;z-index:60;display:flex;flex-direction:column;gap:10px}
@media (max-width:760px){.sticky-actions{right:12px;bottom:76px}}
.fab{width:58px;height:58px;border-radius:18px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line);background:#fff;box-shadow:0 18px 36px rgba(11,42,74,.18);text-decoration:none;font-weight:900}
.fab.primary{background:linear-gradient(135deg,var(--brand2),var(--brand));color:#fff;border-color:transparent;animation:glowPulse 2.6s ease-in-out infinite}
.mobile-bar{position:fixed;left:0;right:0;bottom:0;z-index:70;display:none;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);border-top:1px solid rgba(217,228,242,.9);padding:10px 12px}
.mobile-bar .row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media (max-width:760px){.mobile-bar{display:block}}
.modal{position:fixed;inset:0;background:rgba(11,42,74,.80);display:none;z-index:100;align-items:center;justify-content:center;padding:18px}
.modal.open{display:flex}
.modal .box{max-width:980px;width:100%;background:#0b0f14;border-radius:22px;overflow:hidden;border:1px solid rgba(255,255,255,.12)}
.modal img{width:100%;height:auto;display:block}
.modal .meta{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;color:#fff;font-weight:900}
.modal button{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.14);color:#fff;border-radius:12px;padding:8px 10px;font-weight:900;cursor:pointer}

/* Added content */
.sublead{margin:10px 0 0;color:var(--muted);max-width:70ch;font-weight:650}
.stars{margin:0 0 10px;color:#d4a017;font-weight:900;letter-spacing:1px}
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{display:inline-flex;align-items:center;padding:10px 12px;border:1px solid var(--line);background:#fff;border-radius:999px;font-weight:800;color:var(--ink);font-size:13px}

/* Brand text in navbar */
.brand{display:flex;align-items:center;gap:12px}
.brand img{width:54px;height:54px}
.brand{min-width:0}
.brand-text{font-size:16px;line-height:1.1;color:#0b1d3a;white-space:nowrap;min-width:0;overflow:hidden;text-overflow:ellipsis}
.brand-text strong{font-weight:800}
@media (max-width:520px){
  /* En mobile siempre mostrar el nombre (antes se ocultaba) */
  .brand-text{display:block;font-size:14px;max-width:180px}
  .brand img{width:48px;height:48px}
}

/* WhatsApp: todos los botones verdes para mejor contraste */
.btn-whatsapp{background:#25D366;color:#fff;border-color:transparent}
.btn-whatsapp:hover{filter:brightness(.95)}
a[href*="wa.me"].btn,
a[href*="api.whatsapp.com"].btn{background:#25D366;color:#fff;border-color:transparent}
a[href*="wa.me"].btn:hover,
a[href*="api.whatsapp.com"].btn:hover{filter:brightness(.95)}

.fab.whatsapp{background:#25D366;color:#fff;border-color:transparent}
.fab.whatsapp:hover{filter:brightness(.95)}

/* Work gallery: grilla prolija (sin huecos en desktop) */
.gallery.gallery-work{display:grid;grid-template-columns:repeat(2, minmax(0,1fr));gap:16px}
@media (min-width: 720px){
  .gallery.gallery-work{grid-template-columns:repeat(3,1fr)}
}
@media (min-width: 1024px){
  .gallery.gallery-work{grid-template-columns:repeat(4,1fr)}
}

@media (max-width: 980px){.topbar-inner{grid-template-columns:auto auto;grid-template-rows:auto auto;height:auto;padding:10px 0}.nav{grid-column:1/-1;justify-self:center;flex-wrap:wrap;justify-content:center;padding:8px 0}.top-actions{justify-self:end}}
@media (max-width: 720px){.gallery.gallery-work{grid-template-columns:repeat(2, minmax(0,1fr))}}
@media (max-width: 480px){.gallery.gallery-work{grid-template-columns:1fr}.brand img{width:46px;height:46px}}


/* --- Reviews spotlight (hero) --- */
.reviews-spotlight .card__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}
.reviews-spotlight .link{ font-weight:700; }
.mini-reviews{ display:grid; gap:10px; }
.mini-review{
  padding:10px 12px;
  border:1px solid rgba(15,23,42,.08);
  border-radius:14px;
  background: rgba(255,255,255,.6);
}
.mini-review__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:6px;
  font-size:14px;
}
.mini-review p{
  margin:0;
  color: rgba(15,23,42,.78);
  font-size:14px;
  line-height:1.35;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

/* --- Compact the main reviews section so it doesn't eat the page --- */
#resenas .grid-3{ gap:14px; }
#resenas .review{
  padding:14px;
}
#resenas .review p{
  margin-top:8px;
  font-size:14px;
  line-height:1.45;
  display:-webkit-box;
  -webkit-line-clamp:5;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
@media (max-width: 720px){
  #resenas .review{ padding:12px; }
  #resenas .review p{ -webkit-line-clamp:4; }
}
