@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=DM+Sans:wght@300;400;500;600;700&display=swap');
:root {
--rojo:       #E61E3A;   
--rojo2:      #ff2a4b;   
--burdeo:     #9b1c2e;   
--black:      #030303;   
--dark:       #0d0d0f;   
--dark2:      #151518;   
--dark-hover: #1c1c20;   
--white:      #ffffff;
--light:      #e4e4e7;
--muted:      #8a8a93;
--border:     rgba(255,255,255,0.06); 
--border-hlt: rgba(230,30,58,0.3); 
--nav-h:      85px;
--r:          2px;       
--trans:      .4s cubic-bezier(0.16, 1, 0.3, 1);
--shadow:     0 20px 40px rgba(0,0,0,0.5);
--glow:       0 0 20px rgba(230,30,58,0.4);
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; background:var(--black); }
body { 
font-family:'DM Sans',-apple-system,sans-serif; 
color:var(--light); 
background:var(--dark); 
overflow-x:hidden; 
line-height:1.7; 
-webkit-font-smoothing: antialiased;
}
img  { max-width:100%; display:block; }
a    { text-decoration:none; }
ul   { list-style:none; }
button, input, textarea, select { font-family:inherit; }
.container { max-width:1300px; margin:0 auto; padding:0 5%; }
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--black); }
::-webkit-scrollbar-thumb { background: var(--dark-hover); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--rojo); }
::selection { background: var(--rojo); color: var(--white); }
.stag {
font-size:12px; font-weight:700; letter-spacing:4px;
text-transform:uppercase; color:var(--rojo);
margin-bottom:1.2rem; display:flex; align-items:center; gap:12px;
}
.stag::before { content:''; width:40px; height:2px; background:var(--rojo); flex-shrink:0; }
.stitle {
font-family:'Bebas Neue', sans-serif;
font-size:clamp(45px, 6vw, 85px);
letter-spacing:1px; margin-bottom:1.5rem; line-height:0.95;
color: var(--white);
text-transform: uppercase;
}
.sdesc { font-size:17px; color:var(--muted); line-height:1.8; font-weight:400; max-width: 600px; }
.rev { opacity:0; transform:translateY(40px); transition:opacity .8s var(--trans), transform .8s var(--trans); }
.rev.on { opacity:1; transform:translateY(0); }
.d1 { transition-delay:.15s; } .d2 { transition-delay:.3s; }
.d3 { transition-delay:.45s; } .d4 { transition-delay:.6s; }
.btn-r {
display:inline-flex; align-items:center; justify-content:center; gap:10px;
background:var(--rojo); color:var(--white);
padding:18px 40px; border-radius:0; 
font-size:14px; font-weight:700; letter-spacing:1px; text-transform:uppercase;
border:1px solid transparent;
transition:all var(--trans); position:relative; overflow:hidden; z-index:1;
}
.btn-r::before {
content:''; position:absolute; top:0; left:-100%; width:100%; height:100%;
background:var(--rojo2); transition:all var(--trans); z-index:-1;
}
.btn-r:hover::before { left:0; }
.btn-r:hover { transform:translateY(-2px); box-shadow:var(--glow); }
.btn-o {
display:inline-flex; align-items:center; justify-content:center; gap:10px;
background:transparent; color:var(--white);
padding:18px 40px; border-radius:0;
border:1px solid rgba(255,255,255,0.2);
font-size:14px; font-weight:700; letter-spacing:1px; text-transform:uppercase;
transition:all var(--trans);
}
.btn-o:hover { border-color:var(--rojo); background:rgba(230,30,58,0.1); color:var(--white); }
.btn-d {
background:var(--white); color:var(--black); border:none; padding:18px 40px;
font-size:14px; font-weight:700; text-transform:uppercase; letter-spacing:1px;
transition:all var(--trans); display:inline-block;
}
.btn-d:hover { background:var(--light); transform:translateY(-2px); box-shadow:0 10px 20px rgba(255,255,255,0.1); }
#nav {
position:fixed; top:0; left:0; right:0; z-index:1000;
height:var(--nav-h);
display:flex; align-items:center; justify-content:space-between;
padding:0 4%;
background:transparent;
border-bottom:1px solid transparent;
transition:all var(--trans);
}
#nav.scrolled { 
background:rgba(5,5,5,0.85); 
backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
border-bottom-color:var(--border); 
}
.nav-logo { display:flex; align-items:center; gap:12px; }
.nav-logo img { height:40px; width:auto; border-radius:1px; }
.nav-logo-txt { display:flex; flex-direction:column; line-height:1; }
.nav-logo-txt .n1 { font-family:'Bebas Neue',sans-serif; font-size:24px; letter-spacing:3px; color:var(--white); }
.nav-logo-txt .n2 { font-size:9px; font-weight:700; letter-spacing:3px; color:var(--rojo); text-transform:uppercase; }
.nav-links { display:flex; align-items:center; gap:2.5rem; }
.nav-links a { 
color:rgba(255,255,255,0.6); font-size:12px; font-weight:700; 
letter-spacing:1.5px; text-transform:uppercase; 
transition:color var(--trans); position:relative; 
}
.nav-links a::after {
content:''; position:absolute; bottom:-6px; left:0; width:0; height:2px; background:var(--rojo); transition:width var(--trans);
}
.nav-links a:hover { color:var(--white); }
.nav-links a:hover::after { width:100%; }
.nav-cta { 
background:var(--rojo) !important; color:var(--white) !important; 
padding:12px 28px; font-weight:700 !important; border:1px solid var(--rojo); 
}
.nav-cta::after { display:none; }
.nav-cta:hover { background:transparent !important; color:var(--rojo) !important; }
.hamburger { display:none; flex-direction:column; gap:6px; cursor:pointer; background:none; border:none; padding:4px; z-index:1001; }
.hamburger span { width:28px; height:2px; background:var(--white); display:block; transition:all .3s; }
.hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(6px,6px); background:var(--rojo); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); background:var(--rojo); }
.mob-menu {
display:none; position:fixed; top:0; inset-inline:0; height:100vh;
background:rgba(5,5,5,0.98); backdrop-filter:blur(20px); flex-direction:column;
padding:120px 5% 2rem; z-index:999; justify-content:flex-start; align-items:center; gap:2rem;
opacity:0; transition:opacity .3s; pointer-events:none;
}
.mob-menu.open { display:flex; opacity:1; pointer-events:auto; }
.mob-menu a { 
color:var(--white); font-family:'Bebas Neue', sans-serif; font-size:42px; 
text-transform:uppercase; letter-spacing:2px; transition:color var(--trans); 
}
.mob-menu a:hover { color:var(--rojo); }
.mob-menu a:last-child { color:var(--rojo); margin-top:2rem; font-size:24px; font-family:'DM Sans', sans-serif; font-weight:700; }
#hero {
min-height:800px; height:100vh;
position:relative; display:flex; align-items:center; overflow:hidden;
border-bottom:1px solid var(--border);
padding-top: calc(var(--nav-h) + 20px);
padding-bottom: 60px;
}
.hero-bg {
position:absolute; inset:0;
background:url('../fotos/hero1.jpeg') center/cover no-repeat;
filter: grayscale(20%) contrast(1.1);
transform:scale(1.05); animation:slowZoom 20s infinite alternate;
}
@keyframes slowZoom { from {transform:scale(1.05)} to {transform:scale(1.1)} }
.hero-overlay {
position:absolute; inset:0; z-index:1;
background:linear-gradient(to right, rgba(5,5,5,0.95) 0%, rgba(5,5,5,0.7) 50%, rgba(5,5,5,0.4) 100%),
radial-gradient(circle at top right, rgba(230,30,58,0.15), transparent 50%);
}
.hero-grid {
position:absolute; inset:0; z-index:2;
background-image:
linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px),
linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px);
background-size:60px 60px;
opacity:0.4;
}
.hero-accent-bar {
position:absolute; left:0; top:0; bottom:0; width:8px;
background:var(--rojo);
z-index:3; box-shadow:0 0 30px rgba(230,30,58,0.5);
}
.hero-c {
position:relative; z-index:4;
padding:0 5%; margin-top:40px; max-width:1200px;
}
.hero-badge {
display:inline-flex; align-items:center; gap:10px;
background:rgba(230,30,58,0.1); border:1px solid var(--border-hlt);
color:var(--white); padding:8px 20px;
font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase;
margin-bottom:2rem; backdrop-filter:blur(4px);
animation:fadeUp .8s ease both;
}
.hero-badge::before { content:''; width:8px; height:8px; background:var(--rojo); border-radius:0; animation:blink 2s infinite; }
@keyframes blink { 0%,100%{opacity:1;box-shadow:0 0 5px var(--rojo)} 50%{opacity:.3;box-shadow:none} }
.hero-title {
font-family:'Bebas Neue', sans-serif;
font-size:clamp(48px, 7vw, 100px);
line-height:.9; letter-spacing:0px; color:var(--white);
animation:fadeUp .8s .15s ease both;
text-shadow: 0 10px 30px rgba(0,0,0,0.8);
margin-bottom:0.5rem;
}
.hero-title .acc { color:transparent; -webkit-text-stroke:2px var(--rojo); }
.hero-subtitle {
font-family:'Bebas Neue', sans-serif;
font-size:clamp(24px, 3vw, 36px);
color:var(--white); letter-spacing:1px;
margin:2rem 0 1.5rem; line-height:1.2;
animation:fadeUp .8s .25s ease both;
}
.hero-sub {
font-size:clamp(16px, 1.8vw, 20px); color:rgba(255,255,255,.7);
max-width:550px; line-height:1.7; margin:1rem 0 2rem; font-weight:400;
animation:fadeUp .8s .3s ease both;
}
.hero-features {
list-style:none; padding:0; margin:1.5rem 0 3rem; max-width:550px;
animation:fadeUp .8s .35s ease both;
}
.hero-features li {
color:rgba(255,255,255,.8); font-size:clamp(14px, 1.6vw, 18px);
margin:0.8rem 0; line-height:1.6; display:flex; align-items:center; gap:12px;
font-weight:400;
}
.hero-features li::before {
content:'✔'; color:var(--rojo); font-weight:700; font-size:1.1em; flex-shrink:0;
}
.hero-btns { display:flex; gap:1.5rem; flex-wrap:wrap; animation:fadeUp .8s .45s ease both; }
.hero-scroll {
position:absolute; bottom:2rem; right:5%;
display:flex; align-items:center; gap:15px;
color:var(--muted); font-size:10px; letter-spacing:4px; text-transform:uppercase; font-weight:700;
z-index:4; animation:fadeUp .8s .9s ease both; transform:rotate(90deg) translateY(-20px); transform-origin:right center;
}
.scroll-line { width:80px; height:1px; background:rgba(255,255,255,0.2); position:relative; overflow:hidden;}
.scroll-line::after {
content:''; position:absolute; top:0; left:0; width:100%; height:100%; background:var(--rojo);
animation:scrollA 2s infinite; transform-origin:left;
}
@keyframes scrollA { 0%{transform:scaleX(0);transform-origin:left} 50%{transform:scaleX(1);transform-origin:left} 51%{transform:scaleX(1);transform-origin:right} 100%{transform:scaleX(0);transform-origin:right} }
.hero-stats {
position:absolute; bottom:0; left:0; right:120px;
display:grid; grid-template-columns:repeat(4,1fr); gap:1px; z-index:5;
animation:fadeUp .8s .6s ease both; border-top:1px solid var(--border); border-right:1px solid var(--border);
background:rgba(255,255,255,0.05); 
}
.hstat {
background:rgba(5,5,5,0.4); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
padding:30px; text-align:left; border-right:1px solid var(--border);
transition:all var(--trans);
}
.hstat:hover { background:rgba(230,30,58,0.1); border-color:var(--border-hlt); }
.snum { font-family:'Bebas Neue',sans-serif; font-size:48px; color:var(--white); line-height:1; margin-bottom:5px;}
.snum span { color:var(--rojo); }
.slbl { font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:2px; font-weight:700;}
@keyframes fadeUp { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }
#nosotros { padding:9rem 5%; background:var(--black); position:relative; }
.about-wrap { display:grid; grid-template-columns:1fr 1fr; gap:6rem; align-items:center; max-width:1300px; margin:0 auto; }
.about-img-col { position:relative; width:100%; }
.about-img-container {
width:90%; height:auto; aspect-ratio:4/5; margin:0 auto 0 0;
background-color:#0d0d0f; display:flex; align-items:center; justify-content:center;
box-shadow:20px 20px 0 var(--dark2); transition:all .5s;
}
.about-img-logo {
width:85%; height:85%; object-fit:contain; display:block;
}
.about-img-col:hover .about-img-container { box-shadow:20px 20px 0 var(--rojo); }
.about-badge {
position:absolute; bottom:-30px; right:0; z-index:2;
background:var(--black); border:1px solid var(--border);
padding:30px; text-align:left;
box-shadow:var(--shadow); display:flex; gap:20px; align-items:center;
}
.about-badge::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--rojo); }
.about-badge .big { font-family:'Bebas Neue',sans-serif; font-size:70px; color:var(--white); line-height:1; }
.about-badge .small { font-size:12px; font-weight:700; color:var(--muted); text-transform:uppercase; letter-spacing:2px; }
.afeats { display:grid; grid-template-columns:1fr 1fr; gap:2rem; margin-top:3rem; }
.af { display:flex; gap:15px; align-items:flex-start; }
.af-i { color:var(--rojo); font-size:24px; font-weight:300; line-height:1;}
.af h4 { font-size:15px; font-weight:700; margin-bottom:5px; color:var(--white); letter-spacing:1px; text-transform:uppercase;}
.af p  { font-size:14px; color:var(--muted); line-height:1.6; }
#servicios { padding:9rem 5%; background:var(--dark); border-top:1px solid var(--border); }
.srv-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:30px; margin-top:4rem; }
.srv {
background:var(--dark2); padding:50px 40px;
position:relative; overflow:hidden; border:1px solid var(--border);
transition:all var(--trans); cursor:default;
}
.srv::after {
content:''; position:absolute; left:0; top:0; bottom:0; width:3px;
background:var(--rojo); transform:scaleY(0); transform-origin:bottom; transition:transform .35s;
}
.srv:hover { background:var(--dark-hover); transform:translateY(-10px); border-color:var(--border-hlt); box-shadow:var(--glow); }
.srv:hover::after { transform:scaleY(1); }
.srv-n { font-family:'Bebas Neue',sans-serif; font-size:90px; color:rgba(255,255,255,0.03); position:absolute; top:-10px; right:10px; line-height:1; pointer-events:none; transition:color .3s; }
.srv:hover .srv-n { color:rgba(230,30,58,0.1); }
.srv-i { font-size:32px; margin-bottom:1.5rem; color:var(--white);}
.srv h3 { font-size:20px; font-weight:700; color:var(--white); margin-bottom:1rem; text-transform:uppercase; letter-spacing:1px;}
.srv > p { font-size:15px; color:var(--muted); line-height:1.7; margin-bottom:2rem; }
.srv-b li { font-size:14px; color:var(--light); padding:4px 0; display:flex; gap:10px; align-items:center;}
.srv-b li::before { content:'—'; color:var(--rojo); font-weight:bolder; }
#proyectos { padding:9rem 5%; background:var(--black); }
.fbar { display:flex; gap:1rem; flex-wrap:wrap; margin:2rem 0 3rem; }
.fbtn {
padding:10px 25px; border-radius:0; border:1px solid var(--border);
background:transparent; font-size:12px; font-weight:700; cursor:pointer;
transition:all var(--trans); font-family:'DM Sans',sans-serif; color:var(--muted);
text-transform:uppercase; letter-spacing:2px;
}
.fbtn.active, .fbtn:hover { background:var(--rojo); border-color:var(--rojo); color:var(--white); }
.pgrid { 
column-count: 3; 
column-gap: 20px; 
}
.pcard { 
display: inline-block; 
width: 100%;
margin-bottom: 20px;
position: relative; 
overflow: hidden; 
cursor: pointer; 
background: var(--dark2); 
border: 1px solid var(--border); 
break-inside: avoid;
}
.pimg { 
width: 100%; 
height: auto; 
display: block;
transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1); 
filter: grayscale(20%); 
}
.pcard:hover .pimg { transform: scale(1.05); filter: grayscale(0); }
@media (max-width: 1024px) { .pgrid { column-count: 2; } }
@media (max-width: 768px) { .pgrid { column-count: 1; } }
.pcard:hover .pimg { transform:scale(1.08); filter:grayscale(0); }
.pov {
position:absolute; inset:0;
background:linear-gradient(to top, rgba(5,5,5,0.95) 0%, transparent 60%);
display:flex; flex-direction:column; justify-content:flex-end;
padding:2rem; opacity:0; transition:opacity .4s, transform .4s; transform:translateY(20px);
}
.pcard:hover .pov { opacity:1; transform:translateY(0); }
.pcat  { font-size:11px; color:var(--rojo); text-transform:uppercase; letter-spacing:2px; font-weight:700; margin-bottom:5px; }
.pname { font-size:22px; font-weight:700; color:var(--white); margin-bottom:5px; text-transform:uppercase;}
.pmeta { font-size:13px; color:var(--muted); }
#galeria { padding:9rem 5%; background:var(--dark); border-top:1px solid var(--border); }
.gal-grid { display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:280px; gap:8px; margin-top:3.5rem; }
.gi { position:relative; overflow:hidden; cursor:pointer; background:var(--dark2);}
.gi.gw { grid-column:span 2; }
.gi.gt { grid-row:span 2; }
.gi-img { width:100%; height:100%; object-fit:cover; transition:transform .8s cubic-bezier(0.16, 1, 0.3, 1); filter:grayscale(20%); }
.gi:hover .gi-img { transform:scale(1.06); filter:grayscale(0); }
.gi-ov { position:absolute; inset:0; background:rgba(230,30,58,0.7); display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity .3s; }
.gi:hover .gi-ov { opacity:1; }
.gi-ov span { font-size:30px; color:var(--white); font-weight:bolder; }
.gph { width:100%; height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px; color:var(--muted); }
.gph .ico { font-size:30px; }
.gph p { font-size:12px; text-align:center; line-height:1.5; padding:0 1rem; font-family:monospace;}
#lb { display:none; position:fixed; inset:0; z-index:9999; background:rgba(3,3,3,0.98); align-items:center; justify-content:center; backdrop-filter:blur(5px); }
#lb.open { display:flex; }
#lb img { max-width:90vw; max-height:85vh; object-fit:contain; border:2px solid var(--border); box-shadow:var(--shadow);}
#lb-x { position:absolute; top:2rem; right:2.5rem; color:var(--white); font-size:28px; cursor:pointer; background:none; border:none; opacity:.5; transition:opacity .2s; }
#lb-x:hover { opacity:1; color:var(--rojo); }
#lb-p, #lb-n { position:absolute; top:50%; transform:translateY(-50%); background:var(--dark2); border:1px solid var(--border); color:var(--white); font-size:20px; width:56px; height:56px; border-radius:0; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all .2s; }
#lb-p { left:2rem; } #lb-n { right:2rem; }
#lb-p:hover, #lb-n:hover { background:var(--rojo); border-color:var(--rojo); }
#lb-cnt { position:absolute; bottom:2rem; left:50%; transform:translateX(-50%); color:var(--muted); font-size:13px; letter-spacing:2px; font-weight:700;}
#proceso { padding:9rem 5%; background:var(--black); border-top:1px solid var(--border); }
.psteps { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; margin-top:5rem; position:relative; }
.psteps::before { content:''; position:absolute; top:35px; left:10%; right:10%; height:1px; background:var(--border); z-index:0; }
.psteps::after { content:''; position:absolute; top:35px; left:10%; right:10%; height:1px; background:var(--rojo); z-index:0; transform:scaleX(0); transform-origin:left; transition:transform 1s; }
.psteps:hover::after { transform:scaleX(1); }
.ps { text-align:left; padding:0 2rem; position:relative; z-index:1; }
.ps-c { width:70px; height:70px; background:var(--dark); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; margin-bottom:2rem; font-family:'Bebas Neue',sans-serif; font-size:32px; color:var(--muted); transition:all .3s; }
.ps:hover .ps-c { background:var(--rojo); color:var(--white); border-color:var(--rojo); box-shadow:var(--glow); transform:translateY(-5px);}
.ps h3 { font-size:18px; font-weight:700; margin-bottom:.8rem; text-transform:uppercase; color:var(--white); letter-spacing:1px;}
.ps p  { font-size:14px; color:var(--muted); line-height:1.7; }
#testimonios { padding:9rem 5%; background:var(--dark); }
.tgrid-scroll {
display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
margin-top:3rem;
}
.tc {
background:var(--dark2); padding:40px; border:1px solid var(--border);
opacity:1; transition:all .3s ease;
position:relative;
}
.tc::before { content:'"'; position:absolute; top:20px; right:30px; font-size:120px; font-family:'Bebas Neue',sans-serif; color:rgba(255,255,255,0.03); line-height:1; }
.tc:hover { background:var(--dark-hover); border-color:var(--border-hlt); transform:translateY(-5px);}
.tc blockquote { color:var(--light); font-size:16px; line-height:1.8; margin-bottom:2rem; position:relative; z-index:1;}
.tc .tstars { color:var(--rojo); font-size:16px; margin-bottom:1.5rem; letter-spacing:2px; }
.tc .tauth { display:flex; gap:15px; align-items:center; }
.tc .tav {
width:46px; height:46px; background:var(--black); border:1px solid var(--border);
display:flex; align-items:center; justify-content:center;
color:var(--white); font-weight:700; font-size:14px; flex-shrink:0; letter-spacing:1px;
}
.tc .tauth h4 { color:var(--white); font-size:15px; margin-bottom:2px; font-weight:700; text-transform:uppercase;}
.tc .tauth p { color:var(--muted); font-size:13px; }
.add-testimonial-section {
margin-top:5rem; padding:50px; background:var(--black);
border:1px solid var(--border); border-left:4px solid var(--rojo);
}
.add-testimonial-section h3 {
font-family:'Bebas Neue',sans-serif; font-size:36px;
color:var(--white); margin-bottom:2rem; letter-spacing:1px;
}
.testimonial-form { display:flex; flex-direction:column; gap:2rem; }
.tf-row { display:grid; grid-template-columns:1fr 1fr; gap:2rem; }
.testimonial-form input,
.testimonial-form textarea {
background:var(--dark2); border:1px solid var(--border); color:var(--white);
padding:16px 20px; border-radius:0; font-family:inherit; font-size:15px;
transition:all .3s;
}
.testimonial-form input:focus,
.testimonial-form textarea:focus { outline:none; border-color:var(--rojo); background:var(--black); box-shadow:inset 4px 0 0 var(--rojo); }
.star-rating-group label { color:var(--white); font-size:14px; font-weight:700; text-transform:uppercase; letter-spacing:1px; display:block; margin-bottom:1rem;}
.star-rating { display:flex; gap:1.5rem; flex-wrap:wrap; }
.star-rating label { display:flex; align-items:center; gap:8px; font-size:14px; color:var(--muted); cursor:pointer; }
.star-rating input[type="radio"] { accent-color:var(--rojo); width:16px; height:16px; cursor:pointer;}
.star-rating label:hover { color:var(--white); }
#cta-band {
background:url('../fotos/hero1.jpeg') center/cover no-repeat;
padding:7rem 5%; position:relative; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:3rem;
border-top:1px solid var(--border); border-bottom:1px solid var(--border);
}
#cta-band::before { content:''; position:absolute; inset:0; background:rgba(230,30,58,0.92); }
#cta-band::after { content:''; position:absolute; inset:0; background-image:linear-gradient(rgba(0,0,0,0.1) 1px, transparent 1px), linear-gradient(90deg, rgba(0,0,0,0.1) 1px, transparent 1px); background-size:30px 30px; }
.cta-txt, .btn-d { position:relative; z-index:1; }
.cta-txt h2 { font-family:'Bebas Neue',sans-serif; font-size:clamp(45px,6vw,80px); color:var(--white); line-height:0.95; letter-spacing:1px; }
.cta-txt p  { font-size:18px; color:rgba(255,255,255,.8); margin-top:1rem; font-weight:500;}
#contacto { padding:9rem 5%; background:var(--black); }
.cwrap { display:grid; grid-template-columns:1fr 1fr; gap:6rem; max-width:1300px; margin:3rem auto 0; }
.ci h3 { font-size:24px; font-weight:700; margin-bottom:2rem; color:var(--white); text-transform:uppercase; letter-spacing:1px;}
.citem { display:flex; gap:20px; align-items:flex-start; margin-bottom:2rem; }
.cico { width:54px; height:54px; background:var(--dark2); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; color:var(--rojo); }
.citem h4 { font-size:13px; font-weight:700; margin-bottom:5px; color:var(--white); text-transform:uppercase; letter-spacing:2px;}
.citem p, .citem a { font-size:15px; color:var(--muted); line-height:1.6;}
.citem a:hover { color:var(--rojo); }
.wa-btn { display:inline-flex; align-items:center; gap:12px; border:1px solid #25D366; color:#25D366; padding:16px 30px; font-size:14px; font-weight:700; text-transform:uppercase; letter-spacing:1px; margin-top:1rem; transition:all .3s; }
.wa-btn:hover { background:#25D366; color:var(--black); box-shadow:0 0 20px rgba(37,211,102,0.3); transform:translateY(-2px);}
.map-box { margin-top:3rem; border:1px solid var(--border); filter:grayscale(100%) contrast(1.2); transition:filter .5s; }
.map-box:hover { filter:grayscale(0); }
.fstack { display:flex; flex-direction:column; gap:1.5rem; }
.fg { display:flex; flex-direction:column; gap:8px; }
.fg label { font-size:12px; font-weight:700; letter-spacing:1px; color:var(--muted); text-transform:uppercase;}
.fg input, .fg textarea, .fg select {
padding:16px 20px; border:1px solid var(--border); border-radius:0;
font-size:15px; transition:all .3s; background:var(--dark2); color:var(--white);
font-family:inherit;
}
.fg input:focus, .fg textarea:focus, .fg select:focus { outline:none; border-color:var(--rojo); background:var(--black); box-shadow:inset 4px 0 0 var(--rojo);}
.fg-row { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; }
.fok { display:none; padding:20px; background:rgba(37,211,102,0.1); border:1px solid #25D366; color:#25D366; font-size:14px; font-weight:600; }
.sbtn { background:var(--white); color:var(--black); border:none; padding:18px 40px; font-size:14px; font-weight:700; cursor:pointer; transition:all .3s; text-transform:uppercase; letter-spacing:1px; align-self:flex-start;}
.sbtn:hover { background:var(--rojo); color:var(--white); box-shadow:var(--glow); transform:translateY(-2px); }
footer { background:var(--dark); border-top:1px solid var(--border); padding:6rem 5% 2rem; }
.fgrid { display:grid; grid-template-columns:2.5fr 1fr 1fr 1fr; gap:4rem; padding-bottom:4rem; border-bottom:1px solid rgba(255,255,255,.05); }
.fbrand .logo-wrap { display:flex; align-items:center; gap:15px; margin-bottom:1.5rem; }
.fbrand .logo-wrap img { height:48px; filter:grayscale(100%); transition:filter .3s;}
.fbrand:hover .logo-wrap img { filter:grayscale(0); }
.fbrand .logo-txt .t1 { font-family:'Bebas Neue',sans-serif; font-size:28px; letter-spacing:3px; color:var(--white); line-height:1; }
.fbrand .logo-txt .t2 { font-size:10px; font-weight:700; letter-spacing:3px; color:var(--rojo); text-transform:uppercase; }
.fbrand p { font-size:14px; line-height:1.8; max-width:300px; color:var(--muted);}
.fsocs { display:flex; gap:10px; margin-top:2rem; }
.fsoc { width:42px; height:42px; border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--muted); font-size:14px; font-weight:700; transition:all .3s; }
.fsoc:hover { border-color:var(--rojo); background:var(--rojo); color:var(--white); }
.fcol h4 { font-size:13px; font-weight:700; color:var(--white); text-transform:uppercase; letter-spacing:2px; margin-bottom:1.5rem; }
.fcol ul { display:flex; flex-direction:column; gap:1rem; }
.fcol a { color:var(--muted); font-size:14px; transition:color .3s; }
.fcol a:hover { color:var(--white); padding-left:5px; }
.fbot { padding-top:2rem; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; font-size:13px; color:var(--muted);}
.fbot .acc { color:var(--white); font-weight:bold; }
@media (max-width:1024px) {
.nav-links { gap:1.8rem; }
.nav-links a { font-size:11px; }
.hero-title { font-size:clamp(44px, 6.5vw, 90px); line-height:.95; }
.hero-subtitle { font-size:clamp(18px, 2.8vw, 28px); }
.hero-sub { font-size:clamp(14px, 1.6vw, 18px); }
.pgrid { grid-template-columns:repeat(2,1fr); }
.pcard.wide { grid-column:span 1; }
.fgrid { grid-template-columns:1fr 1fr; }
.gal-grid { grid-template-columns:repeat(3,1fr); }
.gi.gw { grid-column:span 2; }
.psteps::before, .psteps::after { display:none; }
.psteps { grid-template-columns:repeat(2,1fr); gap:3rem; }
.hero-stats { grid-template-columns:repeat(2,1fr); right:0; border-right:none;}
.hstat { border-bottom:1px solid var(--border); }
}
@media (max-width:900px) {
.nav-logo-txt .n1 { font-size:16px; letter-spacing:2px; }
.nav-logo-txt .n2 { font-size:7px; letter-spacing:2px; }
.nav-links { gap:0.9rem; }
.nav-links a { font-size:9px; letter-spacing:1px; }
.nav-cta { padding:8px 16px !important; font-size:9px !important; letter-spacing:0.5px; }
}
@media (max-width:768px) {
.nav-logo-txt .n1 { font-size:15px; letter-spacing:1.5px; }
.nav-logo-txt .n2 { font-size:6px; }
.nav-links { gap:0.6rem; }
.nav-links a { font-size:8px; }
.nav-cta { padding:6px 12px !important; font-size:8px !important; }
.hero-badge { padding:5px 12px; font-size:8px; margin-bottom:0.6rem; }
.hero-title { font-size:clamp(28px, 6vw, 50px); line-height:1; margin-bottom:0.2rem; }
.hero-subtitle { font-size:clamp(13px, 2vw, 20px); margin:0.5rem 0 0.5rem; }
.hero-sub { font-size:clamp(12px, 1.3vw, 15px); margin:0.4rem 0 0.8rem; line-height:1.4; }
.about-wrap, .cwrap { grid-template-columns:1fr; gap:4rem; }
.about-img-container { width:100%; }
.about-badge { right: 0; left: auto; bottom: -10px; padding: 15px 20px; gap: 15px; }
.about-badge .big { font-size: 40px; }
.about-badge .small { font-size: 10px; }
.pgrid { grid-template-columns:1fr; }
.tgrid-scroll { grid-template-columns:1fr; }
.gal-grid { grid-template-columns:repeat(2,1fr); grid-auto-rows:200px; }
.gi.gw, .gi.gt { grid-column:span 1; grid-row:span 1; }
.psteps { grid-template-columns:1fr; }
.fgrid { grid-template-columns:1fr; gap:3rem; }
.afeats { grid-template-columns:1fr; }
.fg-row { grid-template-columns:1fr; }
.sbtn { width:100%; }
#lb-p { left:.5rem; } #lb-n { right:.5rem; }
.stitle { font-size:45px; }
}
@media (max-width:640px) {
.nav-links, .nav-cta { display:none; }
.hamburger { display:flex; }
.hero-features { margin:0.8rem 0 1.5rem; }
.hero-features li { font-size:clamp(12px, 1.3vw, 15px); margin:0.5rem 0; gap:8px; }
.hero-btns { gap:0.8rem; margin-bottom:1.5rem; }
.about-wrap, .cwrap { grid-template-columns:1fr; gap:4rem; }
.about-img-container { width:100%; }
.about-badge { 
right: 0; left: auto; bottom: -10px; 
padding: 15px 20px; gap: 15px; 
}
.about-badge .big { font-size: 40px; }
.about-badge .small { font-size: 10px; }
.pgrid { grid-template-columns:1fr; }
.tgrid-scroll { grid-template-columns:1fr; }
.gal-grid { grid-template-columns:repeat(2,1fr); grid-auto-rows:200px; }
.gi.gw, .gi.gt { grid-column:span 1; grid-row:span 1; }
.psteps { grid-template-columns:1fr; }
.fgrid { grid-template-columns:1fr; gap:3rem; }
.afeats { grid-template-columns:1fr; }
.fg-row { grid-template-columns:1fr; }
.sbtn { width:100%; }
#lb-p { left:.5rem; } #lb-n { right:.5rem; }
.stitle { font-size:45px; }
}
@media (max-width:480px) {
.hero-c { margin-top:15px; }
.hero-scroll { display:none; }
.hero-badge { padding:6px 12px; font-size:8px; margin-bottom:0.6rem; }
.hero-title { font-size:clamp(24px, 6.5vw, 44px); line-height:1; margin-bottom:0.2rem; }
.hero-subtitle { font-size:clamp(13px, 2vw, 18px); margin:0.5rem 0 0.5rem; }
.hero-sub { font-size:12px; margin:0.4rem 0 0.8rem; line-height:1.4; }
.hero-features { margin:0.6rem 0 1.2rem; }
.hero-features li { font-size:11px; margin:0.4rem 0; gap:6px; }
.hero-btns { gap:0.6rem; }
.hero-btns a { padding:8px 12px; font-size:11px; }
}
