/* =========================
ANIMACIÓN SUAVE
========================= */

.fade-up{
opacity:0;
transform:translateY(40px);
transition:all .8s ease;
}

.fade-up.visible{
opacity:1;
transform:translateY(0);
}


/* =========================
PASOS
========================= */

.step{
padding:26px;
border-radius:12px;
margin-bottom:20px;

background:rgba(255,255,255,0.04);
border:1px solid rgba(255,255,255,0.08);

backdrop-filter: blur(8px);

transition:all .35s ease;
}

.step:hover{
transform:translateY(-4px);
border-color:#d4af37;
box-shadow:0 10px 30px rgba(0,0,0,.35);
}


/* número */

.num{
font-size:28px;
font-weight:700;
font-family:'Cinzel',serif;
color:#d4af37;

margin-bottom:6px;

transition:transform .3s ease;
}

.step:hover .num{
transform:scale(1.1);
}


/* =========================
BADGES
========================= */

.badge{
display:flex;
gap:12px;
padding:14px;
border-radius:10px;

background:rgba(255,255,255,0.03);
border:1px solid rgba(255,255,255,0.08);

transition:all .3s ease;
}

.badge:hover{
transform:translateX(6px);
border-color:#d4af37;
}


/* =========================
BOTONES
========================= */

.btn{
transition:all .25s ease;
}

.btn:hover{
transform:translateY(-2px);
box-shadow:0 8px 20px rgba(0,0,0,.3);
}

.page-hero{
padding:120px 0 80px;
text-align:center;
position:relative;
}

.page-hero h1{
font-size:46px;
font-family:'Cinzel',serif;
margin-bottom:15px;
}

.page-hero p{
color:#aaa;
font-size:18px;
max-width:600px;
margin:auto;
}

.page-hero::after{
content:"";
display:block;
width:120px;
height:2px;
background:#d4af37;
margin:30px auto 0;
box-shadow:0 0 12px #d4af37;
}

.steps{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:30px;
margin-top:50px;
}

.step{
padding:35px;
border-radius:14px;
background:rgba(20,20,20,.7);
border:1px solid rgba(255,255,255,.08);
backdrop-filter:blur(8px);
transition:.35s;
position:relative;
}

.step:hover{
transform:translateY(-8px);
border-color:#d4af37;
box-shadow:0 20px 60px rgba(0,0,0,.6);
}

.num{
font-size:38px;
font-family:'Cinzel',serif;
color:#d4af37;
margin-bottom:10px;
}

@media (max-width:900px){

.steps{
grid-template-columns:1fr 1fr;
}

}

@media (max-width:600px){

.steps{
grid-template-columns:1fr;
}

}

.two{
display:grid;
grid-template-columns:1fr 1fr;
gap:60px;
margin-top:60px;
}

.panel-box{
padding:40px;
border-radius:14px;

background:rgba(20,20,20,.7);
border:1px solid rgba(255,255,255,.08);

backdrop-filter:blur(10px);

transition:.35s;
}

.panel-box:hover{
border-color:#d4af37;
transform:translateY(-6px);
box-shadow:0 20px 60px rgba(0,0,0,.6);
}

.list{
margin:20px 0;
}

.li{
padding:10px 0;
border-bottom:1px solid rgba(255,255,255,.05);
color:#bbb;
}

.top-glint{
position:absolute;
top:0;
left:0;
width:100%;
height:200px;

background:linear-gradient(
120deg,
transparent,
rgba(212,175,55,.08),
transparent
);

animation:glintMove 8s infinite linear;
}

@keyframes glintMove{

0%{
transform:translateX(-100%);
}

100%{
transform:translateX(100%);
}

}

.step::before{

content:"";
position:absolute;
inset:0;

background:linear-gradient(
120deg,
transparent,
rgba(212,175,55,.08),
transparent
);

opacity:0;
transition:.4s;

}

.step:hover::before{
opacity:1;
}


.quick{
display:flex;
justify-content:center;
align-items:center;
gap:16px;
margin-top:30px;
flex-wrap:wrap;
}

.quick .btn{
padding:12px 22px;
font-size:15px;
border-radius:8px;
}

.page-hero{
padding:140px 0 100px;
text-align:center;
display:flex;
justify-content:center;
align-items:center;
flex-direction:column;
}

.page-hero h1{
font-size:48px;
letter-spacing:1px;
margin-bottom:10px;
}

.page-hero p{
font-size:18px;
color:#aaa;
max-width:600px;
margin:auto;
}

* ========================
FOOTER PRO
======================== */

.footer{

margin-top:120px;

background:linear-gradient(
180deg,
#0b0b0c,
#060606
);

border-top:1px solid rgba(212,175,55,.2);

padding-top:70px;

}

/* contenedor */

.footer .wrap{
max-width:1200px;
margin:auto;
padding:0 20px;
}

/* grid */

.footer-grid{

display:grid;
grid-template-columns:2fr 1fr 1fr;

gap:60px;

}

/* línea dorada */

.footer::before{

content:"";

display:block;

width:120px;
height:2px;

background:#d4af37;

margin:0 auto 40px auto;

opacity:.6;

}

/* logo */

.footer-logo{

font-family:'Cinzel',serif;
font-size:20px;

color:#fff;

margin-bottom:15px;

}

/* texto */

.footer-text{

color:#aaa;
font-size:14px;

line-height:1.6;

margin-bottom:15px;

}

/* meta */

.footer-meta{

color:#777;
font-size:13px;

}

/* títulos */

.footer-col h4{

color:#d4af37;

margin-bottom:15px;

font-size:15px;

}

/* links */

.footer-col a{

display:block;

color:#bbb;

text-decoration:none;

margin-bottom:10px;

font-size:14px;

transition:.25s;

}

.footer-col a:hover{

color:#d4af37;
transform:translateX(4px);

}

/* ciudad */

.footer-city{

margin-top:15px;
color:#777;
font-size:13px;

}

/* bottom */

.footer-bottom{

margin-top:50px;

border-top:1px solid rgba(255,255,255,.06);

padding:25px 0;

display:flex;
justify-content:space-between;

font-size:13px;

color:#777;

}

/* créditos */

.credits b{

color:#d4af37;
font-weight:600;
letter-spacing:.5px;

}

@media (max-width:900px){

.footer-grid{
grid-template-columns:1fr;
text-align:center;
gap:40px;
}

.footer-bottom{
flex-direction:column;
gap:10px;
text-align:center;
}

}

/* TARJETA DESARROLLADOR */

.dev-card{

margin-top:25px;

background:rgba(20,20,20,.6);
border:1px solid rgba(255,255,255,.08);

border-radius:12px;

padding:20px;

max-width:320px;

backdrop-filter:blur(10px);

transition:.35s;

}

.dev-card:hover{

border-color:#d4af37;

transform:translateY(-4px);

box-shadow:0 20px 50px rgba(0,0,0,.6);

}

/* titulo */

.dev-title{

font-size:12px;

color:#888;

margin-bottom:5px;

}

/* nombre */

.dev-name{

font-family:'Cinzel',serif;

font-size:18px;

color:#d4af37;

margin-bottom:10px;

}

/* descripción */

.dev-desc{

font-size:13px;

color:#aaa;

line-height:1.5;

margin-bottom:12px;

}

/* links */

.dev-links{

display:flex;

gap:15px;

}

.dev-links a{

color:#bbb;

text-decoration:none;

font-size:13px;

transition:.25s;

}

.dev-links a:hover{

color:#d4af37;

}