*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--orange:#E85D26;--orange-light:#FFE4D6;--orange-pale:#FFF8F4;--yellow:#F5C842;--dark:#1A0F08;--muted:#7A5C4A;--border:rgba(232,93,38,0.15);--white:#FFFFFF;--cream:#FFFAF7}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--dark);overflow-x:hidden}

.top-bar{background:var(--orange);color:var(--white);text-align:center;padding:0.55rem;font-size:0.72rem;letter-spacing:0.1em}
.top-bar strong{color:var(--yellow)}

nav{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 2rem;background:var(--white);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}
.nav-logo{font-family:'Fraunces',serif;font-size:1.3rem;font-weight:700;color:var(--dark);text-decoration:none}
.nav-logo span{color:var(--orange)}
.nav-cta{font-size:0.75rem;font-weight:500;letter-spacing:0.08em;color:var(--white);background:var(--orange);padding:0.65rem 1.5rem;text-decoration:none;border-radius:4px;transition:background 0.2s}
.nav-cta:hover{background:var(--dark)}

#hero{background:var(--orange-light);padding:4.5rem 2rem;display:grid;grid-template-columns:1fr;gap:3rem;align-items:center}
.hero-tag{display:inline-flex;align-items:center;gap:0.5rem;font-size:0.7rem;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;color:var(--orange);background:rgba(232,93,38,0.1);padding:0.4rem 1rem;border-radius:20px;margin-bottom:1.2rem}
.hero-title{font-family:'Fraunces',serif;font-size:clamp(2.5rem,7vw,5rem);font-weight:900;line-height:1;margin-bottom:1.2rem;color:var(--dark)}
.hero-title span{color:var(--orange);font-style:italic}
.hero-desc{font-size:0.95rem;font-weight:300;color:var(--muted);max-width:440px;line-height:1.85;margin-bottom:2rem}
.hero-cta-group{display:flex;gap:1rem;flex-wrap:wrap}
.btn-orange{font-size:0.82rem;font-weight:500;color:var(--white);background:var(--orange);padding:1rem 2.2rem;text-decoration:none;border-radius:4px;transition:background 0.2s;display:inline-flex;align-items:center;gap:0.5rem}
.btn-orange:hover{background:var(--dark)}
.btn-outline{font-size:0.82rem;font-weight:400;color:var(--orange);border:1.5px solid var(--orange);padding:1rem 2rem;text-decoration:none;border-radius:4px;transition:all 0.2s;display:inline-block}
.btn-outline:hover{background:var(--orange);color:var(--white)}
.hero-stats{display:flex;gap:2rem;margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--border);flex-wrap:wrap}
.stat-num{font-family:'Fraunces',serif;font-size:1.8rem;font-weight:700;color:var(--orange)}
.stat-label{font-size:0.7rem;color:var(--muted);margin-top:0.1rem}

#catalogo{padding:5rem 2rem;background:var(--white)}
.section-tag{font-size:0.7rem;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;color:var(--orange);margin-bottom:0.8rem}
.section-title{font-family:'Fraunces',serif;font-size:clamp(1.8rem,4vw,3rem);font-weight:700;margin-bottom:3rem;color:var(--dark)}
.section-title span{color:var(--orange);font-style:italic}
.catalogo-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.catalogo-card{border:1px solid var(--border);border-radius:8px;overflow:hidden;transition:transform 0.2s,box-shadow 0.2s;background:var(--cream)}
.catalogo-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(232,93,38,0.12)}
.catalogo-img{height:140px;display:flex;align-items:center;justify-content:center;font-size:3.5rem}
.catalogo-img.c1{background:linear-gradient(135deg,#FFE4D6,#FFCBB5)}
.catalogo-img.c2{background:linear-gradient(135deg,#FFF3CC,#FFE680)}
.catalogo-img.c3{background:linear-gradient(135deg,#D6EAFF,#B3D4FF)}
.catalogo-img.c4{background:linear-gradient(135deg,#D6F5D6,#B3E6B3)}
.catalogo-body{padding:1rem}
.catalogo-name{font-family:'Fraunces',serif;font-size:1rem;font-weight:700;margin-bottom:0.3rem}
.catalogo-desc{font-size:0.78rem;color:var(--muted);margin-bottom:0.8rem;line-height:1.6}
.catalogo-price{font-size:0.82rem;font-weight:500;color:var(--orange);margin-bottom:0.8rem}
.btn-catalogo{font-size:0.72rem;font-weight:500;color:var(--orange);border:1px solid var(--orange);padding:0.5rem 1rem;border-radius:4px;text-decoration:none;transition:all 0.2s;display:inline-block;width:100%;text-align:center}
.btn-catalogo:hover{background:var(--orange);color:var(--white)}

#como{padding:5rem 2rem;background:var(--orange-pale)}
.como-steps{display:flex;flex-direction:column;gap:1rem;margin-top:2rem;max-width:600px}
.como-step{display:flex;align-items:flex-start;gap:1.2rem;background:var(--white);padding:1.5rem;border-radius:8px;border-left:4px solid var(--orange)}
.como-num{font-family:'Fraunces',serif;font-size:2rem;font-weight:900;color:var(--orange);line-height:1;flex-shrink:0}
.como-title{font-family:'Fraunces',serif;font-size:1rem;font-weight:700;margin-bottom:0.3rem}
.como-desc{font-size:0.82rem;color:var(--muted);line-height:1.6}

#trabajos{padding:5rem 2rem;background:var(--white)}
.trabajos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:2rem}
.trabajo-item{aspect-ratio:1;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:2.5rem}
.trabajo-item:nth-child(1){background:linear-gradient(135deg,#FFE4D6,#FFCBB5)}
.trabajo-item:nth-child(2){background:linear-gradient(135deg,#FFF3CC,#FFE680)}
.trabajo-item:nth-child(3){background:linear-gradient(135deg,#D6EAFF,#B3D4FF)}
.trabajo-item:nth-child(4){background:linear-gradient(135deg,#D6F5D6,#B3E6B3)}
.trabajo-item:nth-child(5){background:linear-gradient(135deg,#FFD6F5,#FFB3E6)}
.trabajo-item:nth-child(6){background:linear-gradient(135deg,#FFE4D6,#F5C842)}

#cta-final{background:var(--orange);padding:4.5rem 2rem;text-align:center}
#cta-final h2{font-family:'Fraunces',serif;font-size:clamp(2rem,5vw,3.5rem);font-weight:900;color:var(--white);margin-bottom:1rem}
#cta-final p{font-size:0.95rem;color:rgba(255,255,255,0.75);margin-bottom:2rem;font-weight:300}
.btn-white{font-size:0.85rem;font-weight:500;color:var(--orange);background:var(--white);padding:1.1rem 3rem;text-decoration:none;border-radius:4px;transition:background 0.2s;display:inline-block}
.btn-white:hover{background:var(--yellow)}

footer{background:var(--dark);padding:1.5rem 2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-logo{font-family:'Fraunces',serif;font-size:1.1rem;font-weight:700;color:var(--white)}
.footer-logo span{color:var(--orange)}
footer p{font-size:0.7rem;color:rgba(255,255,255,0.3)}
.footer-links{display:flex;gap:1.5rem}
.footer-links a{font-size:0.7rem;color:rgba(255,255,255,0.3);text-decoration:none;transition:color 0.2s}
.footer-links a:hover{color:var(--orange)}

#wa-float{position:fixed;bottom:1.8rem;right:1.8rem;z-index:999;width:58px;height:58px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,0.4);transition:transform 0.2s;text-decoration:none}
#wa-float:hover{transform:scale(1.1)}
#wa-float::before{content:'';position:absolute;inset:-4px;border-radius:50%;border:2px solid rgba(37,211,102,0.3);animation:wa-pulse 2s ease-out infinite}
@keyframes wa-pulse{0%{transform:scale(1);opacity:0.8}100%{transform:scale(1.5);opacity:0}}

@media(min-width:768px){
  nav,#catalogo,#como,#trabajos,#cta-final,footer{padding-left:4rem;padding-right:4rem}
  #hero{grid-template-columns:1fr 1fr;padding:5rem 4rem}
  .catalogo-grid{grid-template-columns:repeat(4,1fr)}
}