*{
margin:0;
padding:0;
box-sizing:border-box;
}

:root{

--gold:#d4af37;
--gold-soft:#b08d57;
--black:#050505;
--wa:#1f9d54;

}

html{

scroll-behavior:smooth;
scroll-padding-top:90px;

}

body{

background:var(--black);
font-family:Segoe UI,sans-serif;
color:white;
overflow-x:hidden;

}

/* LOADER */

#loader{

position:fixed;

inset:0;

background:black;

display:flex;

justify-content:center;

align-items:center;

z-index:99999;

transition:

opacity .9s ease,

transform .9s ease;

}

#loader img{

width:min(540px,78vw);

transform:scale(.25);

animation:

loaderZoom 1.8s ease forwards;

}

@keyframes loaderZoom{

0%{

opacity:0;

transform:scale(.25);

}

40%{

opacity:1;

transform:scale(.75);

}

100%{

opacity:1;

transform:scale(1);

}

}

/* NAVBAR */

#navbar{

position:fixed;

top:0;

left:0;

width:100%;

height:67px;

background:rgba(5,5,5,.92);

border-bottom:1px solid rgba(212,175,55,.15);

z-index:9999;

}

nav{

height:75px;

display:flex;

justify-content:center;

align-items:center;

padding:0 3%;

position:relative;

}

.left,
.right{

display:flex;

align-items:center;

gap:25px;

flex:1;

}

.left{

justify-content:flex-end;

padding-right:70px;

}

.right{

justify-content:flex-start;

padding-left:70px;

}

.logo img{

width:180px;

margin-top:18px;

}

.nav-btn{

padding:10px 16px;

border:1px solid rgba(212,175,55,.35);

background:rgba(0,0,0,.20);

text-decoration:none;

color:var(--gold);

transition:.25s;

}

.nav-btn:hover{

background:rgba(212,175,55,.12);

box-shadow:

0 0 18px rgba(212,175,55,.20);

transform:translateY(-2px);

}

/* HERO */

.hero{

height:100vh;

display:flex;

align-items:center;

position:relative;

overflow:hidden;

}

.hero-bg{

position:absolute;

width:100%;

height:100%;

object-fit:cover;

transform:scale(1.03);

}

.hero-overlay{

position:absolute;

inset:0;

background:

linear-gradient(

90deg,

rgba(0,0,0,.84),

rgba(0,0,0,.45),

rgba(0,0,0,.12)

);

}

.hero-content{

position:relative;

z-index:3;

margin-left:7%;

margin-top:95px;

max-width:620px;

padding:50px;

background:rgba(0,0,0,.72);

border-left:4px solid var(--gold);

}

.hero-content h1{

font-size:3rem;

margin-bottom:18px;

}

/* BOTONES */

.cta{

display:flex;

gap:15px;

margin-top:28px;

flex-wrap:wrap;

}

.cta a{

padding:14px 24px;

border:1px solid var(--gold);

text-decoration:none;

color:white;

transition:.25s;

}

.cta a:hover{

background:rgba(212,175,55,.10);

}

.wa-link{

border-color:#25D366!important;

background:transparent;

}

.wa-link:hover{

background:rgba(37,211,102,.12)!important;

border-color:#25D366!important;

box-shadow:

0 0 18px rgba(37,211,102,.18);

}

/* SECCIONES */

.section{

min-height:85vh;

padding:140px 7%;

display:flex;

align-items:center;

position:relative;

background-size:cover;

background-position:center;

overflow:hidden;

}

.reverse{

justify-content:flex-end;

}

.overlay{

position:absolute;

inset:0;

background:

linear-gradient(

90deg,

rgba(0,0,0,.82),

rgba(0,0,0,.40),

rgba(0,0,0,.10)

);

}

.content-box{

position:relative;

z-index:3;

max-width:720px;

padding:50px;

background:rgba(0,0,0,.62);

border-left:4px solid var(--gold);

}

.cards{

display:flex;

flex-wrap:wrap;

gap:12px;

margin-top:22px;

}

.cards span{

padding:10px 18px;

border:1px solid var(--gold-soft);

}

/* LISTA */

.service-list{

margin-top:35px;

list-style:none;

display:grid;

gap:15px;

}

.service-list li{

padding-bottom:12px;

border-bottom:1px solid rgba(212,175,55,.12);

}

/* SEPARADORES */

.separator-block{

padding:150px 20px;

background:black;

display:flex;

justify-content:center;

align-items:center;

}

.separator-inner{

width:min(900px,95%);

text-align:center;

}

.separator-line{

height:1px;

max-width:500px;

margin:auto;

background:

linear-gradient(

90deg,

transparent,

var(--gold),

transparent

);

}

.separator-block p{

padding:45px 25px;

font-size:1.1rem;

line-height:1.9;

}

/* FOOTER */

footer{

padding-top:140px;

background:black;

}

.footer-grid{

display:grid;

grid-template-columns:

repeat(auto-fit,minmax(250px,1fr));

gap:35px;

padding:60px 7%;

}

.footer-box{

padding:40px;

border:1px solid rgba(212,175,55,.20);

background:rgba(255,255,255,.02);

}

.phone-wrapper{

margin:20px 0;

}

.phone-link{

display:inline-block;

}

.phone-img{

height:36px;
width:auto;
max-width:100%;

display:block;

user-select:none;
-webkit-user-drag:none;

object-fit:contain;

}
.footer-logo{

width:180px;

margin-bottom:25px;

}

.ig-icon{

width:18px;

margin-right:6px;

vertical-align:middle;

}

iframe{

width:100%;

height:320px;

border:0;

margin-top:40px;

}

.copy{

padding:35px;

text-align:center;

}

/* WHATSAPP */

.floating-wa{

position:fixed;

right:20px;

bottom:20px;

z-index:9999;

transition:.25s;

}

.floating-wa:hover{

transform:scale(1.12);

filter:brightness(1.15);

}

.floating-wa img{

width:62px;

}

/* MOVIL */

#menuBtn{

display:none;

}

#mobileMenu{

position:fixed;

top:0;

right:-100%;

width:300px;

height:100vh;

background:#0a0a0a;

padding:110px 30px;

display:flex;

flex-direction:column;

gap:18px;

transition:.35s;

z-index:99999;

}

.mobile-btn{

padding:14px;

border:1px solid rgba(212,175,55,.35);

text-decoration:none;

color:var(--gold);

}

#closeMenu{

position:absolute;

top:25px;

right:25px;

background:none;

border:none;

font-size:34px;

color:white;

}

@media(max-width:992px){

.left,
.right{

display:none;

}

#menuBtn{

display:block;

position:absolute;

right:20px;

background:none;

border:none;

font-size:34px;

color:var(--gold);

}

.logo img{

width:150px;

margin-top:12px;

}

.hero-content{

margin:130px 25px 0;

padding:35px;

}

.hero-content h1{

font-size:2.2rem;

}

.section{

padding:120px 25px;

min-height:auto;

}

.separator-block{

padding:120px 25px;

}

.phone-img{

width:170px;

}

}