:root{
  --wine:#6f1842;
  --plum:#552070;
  --rose:#f7e8ee;
  --rose-2:#fff6f8;
  --gold:#b99563;
  --ink:#261a24;
  --muted:#6f6570;
  --line:#ead9e2;
  --white:#ffffff;
  --shadow:0 22px 60px rgba(83,32,72,.14);
  --radius:28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Arial, Helvetica, sans-serif;
  background:var(--white);
  color:var(--ink);
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1160px,92%);margin:0 auto}
.section{padding:88px 0}
.site-header{
  position:sticky;
  top:0;
  z-index:20;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(185,149,99,.22);
}
.nav{
  width:min(1160px,92%);
  margin:0 auto;
  min-height:82px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:22px;
}
.brand{display:flex;align-items:center;gap:14px;min-width:260px}
.brand-logo{
  width:70px;
  height:52px;
  object-fit:contain;
  border-radius:14px;
  background:#fff;
  box-shadow:0 12px 30px rgba(83,32,72,.08);
}
.brand strong{display:block;font-size:1rem;color:var(--wine);letter-spacing:.02em}
.brand small{display:block;color:var(--muted);font-size:.76rem;margin-top:3px}
.nav-links{display:flex;align-items:center;gap:8px}
.nav-links a{
  padding:10px 14px;
  border-radius:999px;
  color:#4b3d48;
  font-weight:700;
  font-size:.92rem;
}
.nav-links a:hover{background:var(--rose);color:var(--wine)}
.menu-btn{display:none;background:none;border:0;width:42px;height:42px;cursor:pointer}
.menu-btn span{display:block;height:2px;background:var(--wine);margin:7px 0;border-radius:5px}
.hero{position:relative;overflow:hidden;padding-top:72px;background:linear-gradient(135deg,#fff 0%,#fff9fa 54%,#fbedf4 100%)}
.soft-shape{position:absolute;border-radius:50%;filter:blur(0);opacity:.55;pointer-events:none}
.shape-one{width:420px;height:420px;background:#f7dce7;right:-130px;top:40px}
.shape-two{width:240px;height:240px;background:#efe2c7;left:-70px;bottom:20px}
.hero-grid{position:relative;display:grid;grid-template-columns:1.02fr .88fr;gap:48px;align-items:center}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:var(--wine);
  text-transform:uppercase;
  letter-spacing:.16em;
  font-weight:800;
  font-size:.78rem;
  margin:0 0 14px;
}
.eyebrow:before{content:"";width:28px;height:1px;background:var(--gold)}
h1,h2,h3,p{margin-top:0}
h1{font-size:clamp(2.7rem,7vw,5.7rem);line-height:.95;margin-bottom:14px;color:var(--wine);letter-spacing:-.055em}
.hero-copy h2{font-size:clamp(1.5rem,3vw,2.55rem);line-height:1.05;color:var(--plum);margin-bottom:20px}
.lead{font-size:1.16rem;line-height:1.85;color:#524550;max-width:720px;margin-bottom:28px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:26px}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  padding:14px 22px;
  border-radius:999px;
  font-weight:800;
  transition:.25s ease;
  border:1px solid transparent;
}
.btn.primary{background:linear-gradient(135deg,var(--wine),var(--plum));color:#fff;box-shadow:0 14px 30px rgba(111,24,66,.22)}
.btn.secondary{background:#fff;color:var(--wine);border-color:var(--line)}
.btn:hover{transform:translateY(-2px)}
.hero-contact,.phone-box{
  width:fit-content;
  display:flex;
  align-items:center;
  gap:13px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:20px;
  padding:13px 18px;
  box-shadow:0 14px 40px rgba(83,32,72,.08);
}
.hero-contact span,.phone-box span{color:var(--muted);font-size:.88rem;font-weight:700}
.hero-contact strong,.phone-box strong{font-size:1.2rem;color:var(--wine);letter-spacing:.03em}
.hero-photo-card{
  background:#fff;
  padding:18px;
  border-radius:34px;
  border:1px solid rgba(185,149,99,.26);
  box-shadow:var(--shadow);
}
.photo-frame{
  background:#fff7f9;
  border-radius:26px;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:390px;
}
.photo-frame img{width:100%;height:auto;object-fit:contain;border-radius:24px}
.photo-caption{display:flex;align-items:center;gap:14px;margin-top:16px;padding:10px 8px 2px}
.photo-caption img{width:82px;height:58px;object-fit:contain;border-radius:12px;background:#fff}
.photo-caption strong{display:block;color:var(--wine)}
.photo-caption span{display:block;color:var(--muted);font-size:.9rem;margin-top:3px}
.split{display:grid;grid-template-columns:.82fr 1.18fr;gap:42px;align-items:start}
h2{font-size:clamp(2rem,4vw,3.3rem);line-height:1.08;color:var(--wine);letter-spacing:-.035em}
.panel,.highlight-card,.contact-card,.closing-card,.credential-card,.distance-box{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.text-panel{padding:34px;font-size:1.05rem;line-height:1.85;color:#524550}
.service-highlight{background:linear-gradient(180deg,#fff 0%,#fff7f9 100%)}
.highlight-card{display:grid;grid-template-columns:auto 1fr auto;gap:28px;align-items:center;padding:34px}
.highlight-icon{width:74px;height:74px;border-radius:24px;background:var(--rose);display:grid;place-items:center;font-size:2.4rem;color:var(--wine)}
.highlight-card p{line-height:1.75;color:#564752}
.section-title{text-align:center;max-width:780px;margin:0 auto 34px}
.section-title .eyebrow:before{display:none}
.section-title p{line-height:1.7;color:var(--muted)}
.topics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.topics-grid article{
  min-height:138px;
  padding:22px;
  border-radius:24px;
  background:linear-gradient(135deg,#fff 0%,#fff7fa 100%);
  border:1px solid var(--line);
  box-shadow:0 12px 35px rgba(83,32,72,.08);
}
.topics-grid span{display:inline-flex;width:34px;height:34px;align-items:center;justify-content:center;border-radius:50%;background:var(--rose);color:var(--wine);font-size:.82rem;font-weight:900;margin-bottom:15px}
.topics-grid h3{font-size:1.02rem;line-height:1.35;margin:0;color:#2b2028}
.distance{background:#fff9fb}
.distance-box{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center;padding:38px;background:linear-gradient(135deg,#fff 0%,#fff8fb 100%)}
.distance-box p{line-height:1.8;color:#564752}
.distance-list{display:grid;gap:14px}
.distance-list div{padding:18px;border-radius:20px;background:#fff;border:1px solid var(--line)}
.distance-list strong{display:block;color:var(--wine);margin-bottom:5px}
.distance-list span{color:var(--muted)}
.cedulas{background:#fff}
.credentials-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:34px;align-items:center}
.credentials-grid p{line-height:1.75;color:var(--muted)}
.credential-card{padding:22px;text-align:center;background:linear-gradient(135deg,#fff 0%,#fff6fb 100%)}
.credential-card img{width:100%;height:auto;object-fit:contain;border-radius:16px;margin:0 auto 14px}
.credential-card p{margin:0;color:var(--wine);font-weight:900;font-size:1.18rem}
.contact{background:linear-gradient(135deg,#fff 0%,#fff6f9 100%)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:stretch}
.contact-card,.closing-card{padding:36px}
.contact-card p,.closing-card p{line-height:1.8;color:#564752}
.phone-box{margin:24px 0;width:100%;justify-content:space-between}
.full{width:100%}
.closing-card{background:linear-gradient(135deg,#fff 0%,#fdf1f6 100%);display:flex;flex-direction:column;justify-content:center}
.closing-card img{width:220px;height:auto;object-fit:contain;margin-bottom:22px;border-radius:18px;background:#fff}
.footer{padding:32px 0;background:#2a1726;color:#fff}
.footer-grid{display:flex;align-items:center;justify-content:space-between;gap:22px}
.footer-logo{width:130px;height:auto;object-fit:contain;background:#fff;border-radius:16px;margin-bottom:10px}
.footer a{color:#fff;text-decoration:underline}
.whatsapp{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:30;
  background:#25d366;
  color:#fff;
  font-weight:900;
  padding:15px 19px;
  border-radius:999px;
  box-shadow:0 16px 40px rgba(37,211,102,.36);
}
@media(max-width:920px){
  .menu-btn{display:block}
  .nav-links{position:absolute;left:4%;right:4%;top:82px;background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);padding:14px;display:none;flex-direction:column;align-items:stretch}
  .nav-links.open{display:flex}
  .nav-links a{padding:14px 16px}
  .hero-grid,.split,.distance-box,.credentials-grid,.contact-grid{grid-template-columns:1fr}
  .topics-grid{grid-template-columns:repeat(2,1fr)}
  .highlight-card{grid-template-columns:1fr;text-align:left}
  .footer-grid{flex-direction:column;align-items:flex-start}
}
@media(max-width:560px){
  .section{padding:62px 0}
  .brand{min-width:auto}
  .brand-logo{width:58px;height:44px}
  .brand strong{font-size:.9rem}
  .brand small{font-size:.68rem}
  .hero{padding-top:50px}
  .hero-actions{display:grid}
  .btn{width:100%}
  .hero-contact{width:100%;justify-content:space-between}
  .topics-grid{grid-template-columns:1fr}
  .text-panel,.highlight-card,.distance-box,.contact-card,.closing-card{padding:26px}
  .photo-frame{min-height:260px}
  .phone-box{display:grid;gap:6px}
}
