
:root{
  --primary:#ff5037;
  --primary-dark:#df442f;
  --primary-soft:#fff1ee;
  --dark:#16212b;
  --text:#253241;
  --muted:#697480;
  --line:#e4e9ef;
  --shadow:0 14px 40px rgba(22,33,43,.08);
  --radius:24px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,Arial,Helvetica,sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top right, rgba(255,80,55,.08), transparent 28%),
    linear-gradient(180deg,#fbfcfe 0%, #f4f7fb 100%);
  line-height:1.6;
}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.container{width:min(calc(100% - 2rem),var(--max));margin:auto}
.topbar{
  background:var(--dark);
  color:#fff;
  font-size:.92rem;
}
.topbar .container{
  display:flex;justify-content:space-between;align-items:center;
  gap:1rem;flex-wrap:wrap;padding:.8rem 0;
}
.topbar .meta{display:flex;gap:1rem 1.4rem;flex-wrap:wrap}
.topbar a,.topbar span{opacity:.94}
header{
  position:sticky;top:0;z-index:60;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(22,33,43,.06);
}
.nav{
  min-height:82px;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
}
.brand{display:flex;flex-direction:column;gap:.1rem}
.brand strong{color:var(--dark);letter-spacing:.08em;font-size:1.08rem}
.brand span{color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.16em}
.nav-links{display:flex;align-items:center;gap:1.15rem}
.nav-links a{font-weight:600;color:#334150;position:relative}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:-.38rem;width:0;height:2px;background:var(--primary);transition:.25s ease
}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.btn,.btn-ghost{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.95rem 1.24rem;border-radius:999px;font-weight:700;transition:.25s ease
}
.btn{background:linear-gradient(135deg,var(--primary) 0%, #ff6d58 100%);color:#fff;box-shadow:0 14px 26px rgba(255,80,55,.22)}
.btn:hover{transform:translateY(-1px)}
.btn-ghost{background:#fff;border:1px solid var(--line);color:var(--dark)}
.menu-btn{
  display:none;width:48px;height:48px;border-radius:14px;border:1px solid var(--line);
  background:#fff;color:var(--dark);font-size:1.1rem;cursor:pointer
}
.hero{padding:4.6rem 0 3.1rem}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:2rem;align-items:center}
.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;padding:.45rem .82rem;border-radius:999px;
  background:var(--primary-soft);color:var(--primary-dark);border:1px solid rgba(255,80,55,.14);
  font-weight:800;font-size:.8rem;text-transform:uppercase;letter-spacing:.08em
}
h1{
  margin:1rem 0 1rem;font-size:clamp(2.35rem,5vw,4.4rem);
  line-height:1.03;letter-spacing:-.05em;color:var(--dark);max-width:13ch
}
.lead{margin:0 0 1.5rem;color:var(--muted);font-size:1.05rem;max-width:66ch}
.hero-actions{display:flex;gap:.9rem;flex-wrap:wrap;margin:0 0 1.4rem}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem}
.stat{
  background:rgba(255,255,255,.88);border:1px solid var(--line);border-radius:18px;
  padding:1rem;box-shadow:var(--shadow)
}
.stat strong{display:block;font-size:1.12rem;color:var(--dark);margin-bottom:.25rem}
.stat span{color:var(--muted);font-size:.93rem}
.visual-card{
  background:linear-gradient(180deg,#fff 0%, #f7f9fc 100%);
  border:1px solid var(--line);border-radius:28px;padding:1rem;box-shadow:var(--shadow)
}
.visual{
  min-height:500px;border-radius:22px;overflow:hidden;position:relative;
  background:
    linear-gradient(180deg, rgba(22,33,43,.12), rgba(22,33,43,.04)),
    url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 900'%3E%3Cdefs%3E%3ClinearGradient id='bg' x1='0' y1='0' x2='1' y2='1'%3E%3Cstop offset='0' stop-color='%23fff7f5'/%3E%3Cstop offset='1' stop-color='%23ffe7e2'/%3E%3C/linearGradient%3E%3C/defs%3E%3Crect width='1200' height='900' fill='url(%23bg)'/%3E%3Crect x='120' y='120' width='960' height='650' rx='26' fill='%23ffffff'/%3E%3Crect x='170' y='185' width='395' height='405' rx='22' fill='%23fff1ee' stroke='%23ffd0c8'/%3E%3Crect x='225' y='240' width='170' height='22' rx='11' fill='%23ff5037'/%3E%3Crect x='225' y='286' width='270' height='14' rx='7' fill='%23f0c0b8'/%3E%3Crect x='225' y='320' width='240' height='14' rx='7' fill='%23f0c0b8'/%3E%3Crect x='225' y='378' width='125' height='125' rx='18' fill='%23ff5037'/%3E%3Crect x='375' y='383' width='145' height='16' rx='8' fill='%23e4d0cc'/%3E%3Crect x='375' y='416' width='118' height='14' rx='7' fill='%23eddeda'/%3E%3Crect x='375' y='447' width='135' height='14' rx='7' fill='%23eddeda'/%3E%3Crect x='655' y='180' width='270' height='430' rx='24' fill='%23283441'/%3E%3Crect x='708' y='248' width='160' height='18' rx='9' fill='%23ff6d5a'/%3E%3Crect x='708' y='286' width='130' height='10' rx='5' fill='%23576979'/%3E%3Crect x='708' y='312' width='145' height='10' rx='5' fill='%23576979'/%3E%3Crect x='165' y='650' width='365' height='52' rx='18' fill='%23f5f7fa' stroke='%23e5e9ef'/%3E%3Crect x='680' y='662' width='220' height='40' rx='20' fill='%23ff5037'/%3E%3C/svg%3E");
  background-size:cover;background-position:center
}
.visual-note{
  position:absolute;left:1rem;bottom:1rem;max-width:330px;background:rgba(255,255,255,.88);
  border:1px solid rgba(22,33,43,.08);border-radius:18px;padding:1rem;backdrop-filter:blur(10px);box-shadow:var(--shadow)
}
.visual-note strong{display:block;margin-bottom:.3rem;color:var(--dark)}
.visual-note span{color:var(--muted);font-size:.93rem}
.page-hero{padding:3.4rem 0 2rem}
.page-hero-box{background:linear-gradient(135deg,#fff 0%, #fff4f1 100%);border:1px solid var(--line);border-radius:28px;padding:2rem;box-shadow:var(--shadow)}
.page-hero h1{max-width:none;font-size:clamp(2rem,4vw,3.4rem);margin:.6rem 0}
.breadcrumb{color:var(--muted);font-size:.95rem}
section{padding:1rem 0 4rem}
.section-head{
  display:flex;justify-content:space-between;align-items:end;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem
}
.section-head h2{margin:0;font-size:clamp(1.7rem,3vw,2.6rem);letter-spacing:-.04em;color:var(--dark)}
.section-head p{margin:0;color:var(--muted);max-width:60ch}
.grid-4,.grid-3,.grid-2{display:grid;gap:1rem}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem;box-shadow:var(--shadow)
}
.service-card{transition:.25s ease}
.service-card:hover{transform:translateY(-4px)}
.icon{
  width:52px;height:52px;border-radius:16px;display:grid;place-items:center;margin-bottom:1rem;
  font-weight:800;font-size:1.15rem;background:var(--primary-soft);color:var(--primary-dark)
}
.card h3{margin:0 0 .5rem;color:var(--dark);font-size:1.08rem}
.card p{margin:0;color:var(--muted)}
.card ul{margin:.8rem 0 0;padding-left:1.1rem;color:var(--muted)}
.card li{margin:.35rem 0}
.cta-section{
  text-align:center;background:linear-gradient(135deg,var(--dark) 0%, #293441 100%);
  color:#fff;border-radius:26px;padding:2rem;box-shadow:var(--shadow)
}
.cta-section h2{margin:0 0 .55rem;font-size:clamp(1.6rem,3vw,2.4rem)}
.cta-section p{margin:0 0 1rem;color:rgba(255,255,255,.82);max-width:58ch;margin-inline:auto}
.check-list{list-style:none;padding:0;margin:0;display:grid;gap:.8rem}
.check-list li{display:flex;gap:.75rem;align-items:flex-start;color:var(--text)}
.check-list li::before{
  content:"✓";width:24px;height:24px;flex:0 0 24px;display:grid;place-items:center;border-radius:50%;
  background:var(--primary-soft);color:var(--primary-dark);font-weight:800;margin-top:.05rem
}
.inline-links{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1rem}
.legal-list{display:grid;gap:.42rem}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.info-list{display:grid;gap:.9rem}
.info-item{background:#f4f7fa;border:1px solid var(--line);border-radius:18px;padding:1rem}
.info-item strong{display:block;margin-bottom:.25rem;color:var(--dark)}
.info-item span,.info-item a{color:var(--muted)}
form{display:grid;gap:.9rem}
.input-row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
input,textarea{
  width:100%;padding:1rem;font:inherit;color:var(--text);background:#fff;border:1px solid var(--line);
  border-radius:16px;outline:none
}
input:focus,textarea:focus{border-color:rgba(255,80,55,.45);box-shadow:0 0 0 4px rgba(255,80,55,.08)}
textarea{min-height:150px;resize:vertical}
.small{font-size:.92rem;color:var(--muted)}
footer{margin-top:1rem;background:var(--dark);color:#fff;padding:2rem 0 2.4rem}
.footer-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}
footer h3{margin-top:0}
footer p,footer a,footer span{color:rgba(255,255,255,.8)}
.whatsapp-float{
  position:fixed;right:20px;bottom:20px;width:60px;height:60px;border-radius:50%;background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 8px 20px rgba(0,0,0,.25);z-index:120
}
.call-mobile{display:none}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease, transform .6s ease}
.reveal.visible{opacity:1;transform:none}
@media (max-width:1080px){.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:980px){
  .hero-grid,.grid-4,.grid-3,.grid-2,.contact-grid,.footer-grid,.input-row,.hero-stats{grid-template-columns:1fr}
  .nav-links,.nav .btn.desktop{display:none}
  .menu-btn{display:grid;place-items:center}
  .nav{position:relative}
  .nav-links.open{
    display:flex;position:absolute;left:0;right:0;top:82px;background:#fff;border:1px solid var(--line);
    border-radius:20px;box-shadow:var(--shadow);padding:1rem;flex-direction:column;align-items:flex-start
  }
  .visual{min-height:390px}
  h1{max-width:none}
  .call-mobile{display:inline-flex;position:fixed;left:20px;bottom:20px;z-index:120}
}
