.page-hero{
padding:100px 0;
text-align:center;
}

.steps{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:35px;
margin-top:50px;
}

.step{
background:#101010;
padding:30px;
border-radius:10px;
border:1px solid #222;
transition:.35s;
}

.step:hover{
transform:translateY(-6px);
border-color:#d4af37;
}

.num{
font-size:26px;
color:#d4af37;
margin-bottom:12px;
}

/* TARJETA PERFIL */

.profile-card{
perspective:1200px;
max-width:320px;
margin:auto;
}

.card-inner{
position:relative;
width:100%;
height:420px;
transition:transform .8s;
transform-style:preserve-3d;
}

.profile-card:hover .card-inner{
transform:rotateY(180deg);
}

.card-front,
.card-back{
position:absolute;
width:100%;
height:100%;
backface-visibility:hidden;

background:rgba(20,20,20,.8);
border:1px solid rgba(255,255,255,.08);

border-radius:14px;
padding:30px;
text-align:center;

backdrop-filter:blur(10px);

display:flex;
flex-direction:column;
justify-content:center;
align-items:center;
}

.card-back{
transform:rotateY(180deg);
}

.photo img{
width:120px;
height:120px;
border-radius:50%;
object-fit:cover;
margin-bottom:15px;

border:2px solid #d4af37;
}

.card-front h3{
font-family:'Cinzel',serif;
margin-bottom:5px;
}

.card-front p{
color:#aaa;
font-size:14px;
margin-bottom:20px;
}

/* botón flip */

.flip-btn{
margin-top:15px;
background:#d4af37;
border:none;
color:#111;
padding:10px 18px;
border-radius:6px;
cursor:pointer;
font-weight:600;
}

.flip-btn.back{
background:transparent;
border:1px solid #d4af37;
color:#d4af37;
}

/* info reverso */

.card-back h3{
margin-bottom:20px;
font-family:'Cinzel',serif;
}

.info{
display:flex;
flex-direction:column;
gap:12px;
margin-bottom:20px;
}

.info span{
font-size:12px;
color:#888;
}

.info b{
display:block;
font-size:14px;
}

.cards{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:30px;
margin-top:50px;
}

.card{
background:rgba(20,20,20,.7);
border:1px solid rgba(255,255,255,.08);
border-radius:14px;
padding:35px;
transition:.35s;
backdrop-filter:blur(8px);
position:relative;
}

.card:hover{
transform:translateY(-8px);
border-color:#d4af37;
box-shadow:0 25px 60px rgba(0,0,0,.6);
}

.card .tag{
font-size:12px;
color:#d4af37;
letter-spacing:1px;
margin-bottom:10px;
text-transform:uppercase;
}

.card h3{
font-family:'Cinzel',serif;
margin-bottom:10px;
}

.card p{
color:#aaa;
font-size:15px;
}

.two{
display:grid;
grid-template-columns:1fr 1fr;
gap:60px;
margin-top:70px;
}

.box{
background:rgba(20,20,20,.7);
border:1px solid rgba(255,255,255,.08);
border-radius:14px;
padding:40px;
backdrop-filter:blur(8px);
transition:.35s;
}

.box:hover{
border-color:#d4af37;
transform:translateY(-6px);
box-shadow:0 25px 60px rgba(0,0,0,.6);
}

.box h2{
font-family:'Cinzel',serif;
margin-bottom:15px;
}

.list{
margin-top:20px;
}

.li{
padding:10px 0;
border-bottom:1px solid rgba(255,255,255,.05);
color:#bbb;
}

.li::before{
content:"✔";
color:#d4af37;
margin-right:10px;
}

.badge{
display:flex;
align-items:center;
gap:10px;
padding:12px 14px;
margin-bottom:10px;

background:rgba(255,255,255,.04);
border:1px solid rgba(255,255,255,.08);
border-radius:8px;

transition:.3s;
}

.badge:hover{
border-color:#d4af37;
transform:translateX(6px);
}

@media (max-width:900px){

.cards{
grid-template-columns:1fr;
}

.two{
grid-template-columns:1fr;
}

}

.hero-grid{
display:grid;
grid-template-columns:1fr 420px;
gap:80px;
align-items:center;
margin-top:80px;
}

.page-hero h1{
font-size:46px;
font-family:'Cinzel',serif;
margin-bottom:15px;
}

.page-hero p{
color:#aaa;
font-size:18px;
line-height:1.6;
max-width:600px;
margin-bottom:25px;
}

.cta{
display:flex;
gap:15px;
margin-bottom:25px;
flex-wrap:wrap;
}

.meta{
display:flex;
gap:40px;
margin-top:15px;
}

.meta-item span{
display:block;
font-size:12px;
color:#888;
}

.meta-item b{
font-size:16px;
}

.profile-card{
display:flex;
justify-content:center;
}

@media (max-width:900px){

.hero-grid{
grid-template-columns:1fr;
text-align:center;
}

.cta{
justify-content:center;
}

.meta{
justify-content:center;
}

}

.profile-card{

width:320px;
height:420px;
perspective:1200px;
margin:auto;

}

.card-inner{

width:100%;
height:100%;
position:relative;

transform-style:preserve-3d;
transition:transform .8s ease;

}

.profile-card.flip .card-inner{
transform:rotateY(180deg);
}

.card-front,
.card-back{

position:absolute;
width:100%;
height:100%;

background:rgba(20,20,20,.7);
border:1px solid rgba(255,255,255,.08);

border-radius:14px;

display:flex;
flex-direction:column;
justify-content:center;
align-items:center;

padding:40px;

backdrop-filter:blur(8px);

backface-visibility:hidden;

}

.card-back{
transform:rotateY(180deg);
}

.card-front h3{
font-family:'Cinzel',serif;
text-align:center;
line-height:1.3;
margin:10px 0;
}

.card-front p{
color:#aaa;
text-align:center;
}

.flip-btn{

margin-top:20px;

padding:10px 18px;

background:#d4af37;
color:#111;

border:none;
border-radius:6px;

cursor:pointer;

font-weight:600;

}

.lic-badge{

border:2px solid #d4af37;
color:#d4af37;

padding:6px 12px;
border-radius:40px;

font-size:12px;

margin-bottom:10px;

}

/* ========================
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;

}

/* =========================
   RECONOCIMIENTOS PREMIUM
========================= */

.awards{
background:#0b0b0c;
border-top:1px solid rgba(212,175,55,.15);
}

/* DESTACADO */

.award-feature{

display:flex;
align-items:center;
gap:30px;

background:linear-gradient(
145deg,
rgba(212,175,55,.15),
rgba(212,175,55,.05)
);

border:1px solid rgba(212,175,55,.3);

padding:35px;
border-radius:16px;

margin-bottom:60px;

box-shadow:0 20px 60px rgba(0,0,0,.7);

}

.award-medal{

font-size:56px;
filter:drop-shadow(0 0 10px rgba(212,175,55,.6));

}

.award-text h3{

font-family:'Cinzel',serif;
color:#d4af37;
font-size:24px;
margin-bottom:8px;

}

.award-text p{
color:#ccc;
margin-bottom:8px;
}

.award-year{
color:#d4af37;
font-weight:600;
}

/* GRID */

.award-grid{

display:grid;
grid-template-columns:repeat(4,1fr);
gap:25px;

}

/* TARJETAS */

.award-card{

background:#111;

border:1px solid rgba(255,255,255,.08);

border-radius:14px;

padding:25px;

text-align:center;

transition:.35s;

position:relative;
overflow:hidden;

}

.award-card:hover{

border-color:#d4af37;

transform:translateY(-8px);

box-shadow:0 25px 60px rgba(0,0,0,.8);

}

/* ICONO */

.award-card .icon{

font-size:34px;
margin-bottom:12px;
color:#d4af37;

}

/* TITULO */

.award-card h4{

font-family:'Cinzel',serif;
font-size:17px;
color:#fff;
margin-bottom:6px;

}

/* TEXTO */

.award-card p{

font-size:14px;
color:#aaa;
margin-bottom:8px;

}

/* AÑO */

.award-card span{

color:#d4af37;
font-size:13px;
font-weight:600;

}

/* RESPONSIVE */

@media (max-width:900px){

.award-feature{
flex-direction:column;
text-align:center;
}

.award-grid{
grid-template-columns:1fr 1fr;
}

}

@media (max-width:500px){

.award-grid{
grid-template-columns:1fr;
}

}


/* =========================
   GALERÍA DE DIPLOMAS
========================= */

.diplomas{
background:#0b0b0c;
border-top:1px solid rgba(212,175,55,.15);
}

.diploma-grid{

display:grid;
grid-template-columns:repeat(3,1fr);
gap:25px;

}

.diploma{

width:100%;
border-radius:12px;

cursor:pointer;

border:1px solid rgba(255,255,255,.1);

transition:.35s;

background:#111;

}

.diploma:hover{

transform:scale(1.03);

border-color:#d4af37;

box-shadow:0 20px 50px rgba(0,0,0,.8);

}

/* MODAL */

.modal{

display:none;

position:fixed;
z-index:9999;

padding-top:60px;

left:0;
top:0;

width:100%;
height:100%;

background:rgba(0,0,0,.95);

}

.modal-content{

margin:auto;
display:block;

max-width:90%;
max-height:85%;

border-radius:8px;

box-shadow:0 0 40px rgba(0,0,0,.9);

}

/* BOTÓN CERRAR */

.close{

position:absolute;

top:20px;
right:40px;

color:#fff;
font-size:40px;

cursor:pointer;

}

/* RESPONSIVE */

@media (max-width:900px){

.diploma-grid{
grid-template-columns:1fr 1fr;
}

}

@media (max-width:500px){

.diploma-grid{
grid-template-columns:1fr;
}

}

