.contact-grid{
display:grid;
grid-template-columns:2fr 1fr;
gap:40px;
}

.form-card{
background:#101010;
padding:35px;
border-radius:10px;
border:1px solid #222;
}

.row{
display:grid;
grid-template-columns:1fr 1fr;
gap:15px;
margin-bottom:15px;
}

input,select,textarea{
width:100%;
padding:10px;
background:#0c0c0c;
border:1px solid #333;
color:white;
border-radius:5px;
margin-top:6px;
}

.side{
display:flex;
flex-direction:column;
gap:25px;
}

.info-card,
.hours-card,
.map-card{
background:#101010;
padding:25px;
border-radius:10px;
border:1px solid #222;
}

.map-card iframe{
width:100%;
height:250px;
border:0;
}

.page-hero{

padding:120px 0 80px;

background:

radial-gradient(circle at 15% 10%, rgba(212,175,55,.15), transparent 45%),
radial-gradient(circle at 85% 0%, rgba(212,175,55,.10), transparent 40%),
linear-gradient(#0b0b0c,#0b0b0c);

border-bottom:1px solid rgba(255,255,255,.05);

}

.page-hero h1{

font-size:48px;
font-family:'Cinzel',serif;
letter-spacing:.5px;

text-shadow:0 10px 40px rgba(0,0,0,.8);

margin-bottom:12px;

}

.page-hero p{

font-size:18px;

color:#b8b8b8;

max-width:650px;

line-height:1.7;

}

.form-box{

background:rgba(20,20,20,.75);

border:1px solid rgba(255,255,255,.08);

border-radius:16px;

padding:40px;

backdrop-filter:blur(14px);

box-shadow:
0 30px 80px rgba(0,0,0,.8),
0 0 60px rgba(212,175,55,.05);

transition:.35s;

}

.form-box:hover{

transform:translateY(-6px);

border-color:#d4af37;

}

.info-box{

background:rgba(20,20,20,.7);

border:1px solid rgba(255,255,255,.08);

border-radius:14px;

padding:28px;

backdrop-filter:blur(10px);

transition:.35s;

}

.info-box:hover{

border-color:#d4af37;

transform:translateY(-4px);

box-shadow:0 25px 60px rgba(0,0,0,.6);

}

.gold-divider{

width:120px;
height:2px;

background:#d4af37;

margin:22px 0 0;

box-shadow:0 0 15px rgba(212,175,55,.5);

}

input,
textarea,
select{

background:#121212;

border:1px solid #2a2a2a;

border-radius:8px;

color:#fff;

padding:12px;

transition:.25s;

}

input:focus,
textarea:focus,
select:focus{

border-color:#d4af37;

outline:none;

box-shadow:0 0 0 2px rgba(212,175,55,.15);

}

/* ========================
TARJETA DATOS RÁPIDOS PRO
======================== */

.info-card{
background:rgba(20,20,20,.7);
border:1px solid rgba(255,255,255,.08);
border-radius:14px;
padding:32px;
backdrop-filter:blur(10px);
transition:.35s;
}

.info-card:hover{
border-color:#d4af37;
transform:translateY(-6px);
box-shadow:0 25px 60px rgba(0,0,0,.6);
}

.info-card h3{
font-family:'Cinzel',serif;
margin-bottom:20px;
}

/* lista */

.info-list{
display:flex;
flex-direction:column;
gap:16px;
margin-bottom:25px;
}

.info-item{
display:flex;
gap:12px;
align-items:flex-start;
color:#bbb;
}

.info-item span{
font-size:18px;
}

.info-item b{
display:block;
color:#fff;
font-size:14px;
}

.info-item p{
font-size:14px;
color:#aaa;
margin-top:2px;
}

/* botones */

.info-actions{
display:flex;
flex-wrap:wrap;
gap:12px;
}

/* ========================
BLOQUE FINAL CONTACTO
======================== */

.final-box{
margin-top:30px;
padding-top:25px;
border-top:1px solid rgba(255,255,255,.08);
display:flex;
flex-direction:column;
gap:18px;
}

/* checkbox elegante */

.check{
display:flex;
align-items:center;
gap:12px;
cursor:pointer;
color:#bbb;
font-size:14px;
}

.check input{
accent-color:#d4af37;
width:16px;
height:16px;
}

/* acciones */

.final-actions{
display:flex;
align-items:center;
gap:18px;
flex-wrap:wrap;
margin-top:10px;
}

.tip{
font-size:13px;
color:#888;
max-width:420px;
}

/* =========================
LAYOUT CONTACTO
========================= */

.contact-layout{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:60px;
  margin-top:60px;
}

/* responsive */

@media(max-width:900px){
  .contact-layout{
    grid-template-columns:1fr;
  }
}


/* =========================
TARJETAS DERECHA
========================= */

.info-card{
  background:rgba(20,20,20,.7);
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  padding:30px;
  backdrop-filter:blur(8px);
  margin-bottom:25px;
  transition:.35s;
}

.info-card:hover{
  border-color:#d4af37;
  transform:translateY(-6px);
  box-shadow:0 25px 60px rgba(0,0,0,.6);
}

.info-card h3{
  font-family:'Cinzel',serif;
  margin-bottom:20px;
}


/* info items */

.info-item{
  display:flex;
  gap:14px;
  margin-bottom:18px;
}

.icon{
  font-size:20px;
  color:#d4af37;
}

.info-item b{
  display:block;
}

.info-item p{
  color:#bbb;
  margin:2px 0 0;
}


/* botones */

.info-actions{
  display:flex;
  gap:12px;
  margin-top:15px;
  flex-wrap:wrap;
}


/* =========================
MAPA
========================= */

.map-card{
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
}

.map-card iframe{
  width:100%;
  height:260px;
  border:0;
}

* ========================
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;

}