*{list-style:none;text-decoration:none;margin:0;padding:0;}
iframe{display:block;border:none;}

.os-animation{opacity:0;}
.os-animation.animated{opacity:1;}

 *:focus { outline: none; } 

.texto20{ color: white; font-size: 14px;}

.home-hero{position:relative;width:100%;display:flex;flex-direction:column;align-items:center;overflow:hidden;padding-top:80px;padding-bottom:80px;}
.home-bg{position:absolute;inset:0;background:url('../imagenes/fondo.jpg') center center/cover no-repeat;z-index:1;will-change:transform;}
.home-content{position:relative;width:100%;min-height:120vh;display:flex;justify-content:center;align-items:center;padding:0 2%;z-index:2;}
.home-text{width:96vw;max-width:1980px;height:auto;display:block;position:relative;z-index:2;}

.home-shape{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) scale(1);width:100%;max-width:1288px;height:auto;z-index:3;pointer-events:none;will-change:transform,opacity;
opacity:0;transition:opacity 4s ease, transform .3s ease;}


@media(max-width:900px){
.home-hero{padding-top:100px;padding-bottom:70px;}
.home-content{min-height:60vh;}
.home-text{width:95vw;}
.home-shape{width:100%;max-width:700px;}
}

.services-section{position:relative;width:100%;display:flex;justify-content:center;padding:40px 0 0;z-index:4;}
.services-grid{width:98%;display:grid;grid-template-columns:repeat(5,1fr);gap:24px;padding-top:40px;}

.service-card{position:relative;min-height:400px;padding:26px 26px 30px;border:2px solid rgba(255,255,255,.7);background-size:cover;background-position:center;display:flex;flex-direction:column;justify-content:space-between;overflow:visible;transition:box-shadow .35s ease;z-index:1;}
.service-card:nth-child(1){background-image:url('../imagenes/h1.jpg');}
.service-card:nth-child(2){background-image:url('../imagenes/h2.jpg');}
.service-card:nth-child(3){background-image:url('../imagenes/h3.jpg');}
.service-card:nth-child(4){background-image:url('../imagenes/h4.jpg');}
.service-card:nth-child(5){background-image:url('../imagenes/h5.jpg');}

.service-card:before{content:'';position:absolute;inset:0;background:rgba(0,0,0,.35);z-index:1;transition:background .4s ease;pointer-events:none;}
.service-card:hover:before{background:rgba(0,0,0,.85);}
.service-card:hover{box-shadow:0 0px 0px rgba(0,0,0,.85);}

.service-card{
opacity:0;
transform:translateX(-40px);
transition:opacity .9s ease, transform .9s ease;
will-change:opacity,transform;
}

.service-card.reveal{
opacity:1;
transform:translateX(0);
}

.service-top{position:absolute;top:-52px;left:0;z-index:10;display:flex;align-items:center;gap:12px;font-size:16px;font-weight:300;pointer-events:none; text-transform: uppercase;}
.service-top p{margin:0;}
.service-top h2{margin:0;font-size:16px;font-weight:400;color:#fff;line-height:1;}


.service-number{width:38px;height:38px;border:2px solid rgba(255,255,255,.85);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;background:transparent;}

.service-inner{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;padding:26px;gap:12px;}

.service-btn{width:164px;display:block;transition:transform .25s ease;}
.service-card:hover .service-btn{transform:translateX(6px);}

.service-card h3{position:relative;z-index:2;font-size:clamp(35px,1.8vw,50px);line-height:1.05;font-weight:400;letter-spacing:-1px;color:#fff;margin:0;}
.service-card h3 span{color:#3360ef;}

.service-card:nth-child(1) .service-inner{justify-content:flex-end;align-items:flex-start;text-align:left;}
.service-card:nth-child(2) .service-inner{justify-content:center;align-items:center;text-align:center;}
.service-card:nth-child(3) .service-inner{justify-content:flex-start;align-items:flex-start;text-align:left;}
.service-card:nth-child(4) .service-inner{justify-content:flex-end;align-items:flex-start;text-align:left;}
.service-card:nth-child(5) .service-inner{justify-content:flex-start;align-items:flex-start;text-align:left;}

@media(max-width:1500px){
.services-grid{grid-template-columns:repeat(3,1fr);}
.service-card{margin-bottom:60px;}
}

@media(max-width:900px){
.services-section{padding:25px 0 0;}
.services-grid{width:80%;grid-template-columns:1fr;gap:18px;padding-top:26px;}
.service-card{min-height:400px;padding:22px;}
.service-top{top:12px;left:12px;font-size:14px;z-index:10;}
.service-number{width:34px;height:34px;font-size:16px;}
.service-top h2{font-size:14px;}
.service-card h3{font-size:9vw;line-height:.95;}
.service-card:nth-child(1) .service-inner,
.service-card:nth-child(2) .service-inner,
.service-card:nth-child(3) .service-inner,
.service-card:nth-child(4) .service-inner,
.service-card:nth-child(5) .service-inner{justify-content:center;align-items:center;text-align:center;}.service-card{margin-bottom:10px;}
}





/* ========= SC Hero Section (scientific.html) ========= */
.sc-hero-section { position: relative; width: 100%; min-height: 100vh; overflow: hidden; display: flex; flex-direction: column; background-color: #0d1a2e; padding-top: 200px; }
.sc-hero-bg-wrap { position: absolute; inset: 0; z-index: 1; overflow: hidden; }
.sc-hero-bg-static { position: absolute; inset: -20px; width: calc(100% + 40px); height: calc(100% + 40px); object-fit: cover; object-position: center; z-index: 1; }
.sc-hero-bg-drift { position: absolute; inset: -50px; width: calc(100% + 100px); height: calc(100% + 100px); z-index: 2; overflow: hidden; animation: scFloatDrift 20s ease-in-out infinite; }
.sc-hero-bg-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center 30%; animation: scBreathScale 12s ease-in-out infinite; transform-origin: center center; }
@keyframes scBreathScale { 0%, 100% { transform: scale3d(1.05, 1.05, 1); } 50% { transform: scale3d(1.12, 1.12, 1); } }
@keyframes scFloatDrift { 0%, 100% { transform: translate3d(0, 0, 0); } 33% { transform: translate3d(15px, -12px, 0); } 66% { transform: translate3d(-12px, 15px, 0); } }
.sc-hero-overlay { position: absolute; inset: 0; z-index: 3; background: linear-gradient(180deg, rgba(10,15,35,0.55) 0%, rgba(10,15,35,0.3) 50%, rgba(10,15,35,0.78) 100%); }
/* sc1.png: logo derecho, top-right, debajo del header, margen derecho igual al del menú */
.sc-hero-brand { position: absolute; top: 180px; right: 2vw; z-index: 6; }
.sc-hero-logo { height: 36px; width: auto; object-fit: contain; }
/* Headline enorme transparente - 96% ancho - delgado y elegante */
.sc-hero-spacer { flex: 1; min-height: 20px; }
.sc-hero-headline-wrap { position: relative; z-index: 5; width: 100%; display: flex; align-items: center; justify-content: center; pointer-events: none; }
.sc-hero-headline { width: 96vw; max-width: 96vw; text-align: center; font-size: clamp(5.5rem, 13vw, 13.5rem); font-weight: 300; letter-spacing: -0.04em; line-height: 1; color: rgba(255,255,255,0.16); pointer-events: none; white-space: nowrap; overflow: hidden; }
/* sc2.png: flecha izquierda, debajo del headline, margen izquierdo igual al logo header */
.sc-hero-arrow-row { position: relative; z-index: 5; width: 96%; max-width: 1400px; margin: 0.5rem auto 0; }
.sc-hero-arrow-left { display: inline-block; }
.sc-hero-arrow-icon { width: 58px; height: 58px; object-fit: contain; opacity: 0.75; }
/* Texto lead + botón colocados al centro pero con texto alineado a la izquierda */
.sc-hero-content { position: relative; z-index: 5; display: flex; align-items: center; justify-content: center; padding: 2.5rem 2vw; width: 96%; max-width: 1400px; margin: 0 auto; }
.sc-hero-body { display: flex; flex-direction: column; gap: 2rem; max-width: 680px; text-align: left; align-items: flex-start; }
.sc-hero-lead { font-size: clamp(1.4rem, 2.6vw, 2.2rem); font-weight: 600; line-height: 1.35; color: #ffffff; letter-spacing: -0.02em; }
.sc-hero-btn { display: inline-flex; align-items: center; gap: 0.75rem; background-color: transparent; color: #ffffff; border: 1px solid rgba(255,255,255,0.45); padding: 0.75rem 1.8rem; border-radius: 100px; font-size: 0.95rem; font-weight: 500; text-decoration: none; cursor: pointer; transition: border-color 0.3s ease; width: fit-content; }
.sc-hero-btn svg { width: 14px; height: 14px; stroke-width: 2; transition: transform 0.3s ease; }
.sc-hero-btn:hover svg { transform: translate(4px, -4px); }
/* Dos columnas abajo con mayor separación */
.sc-hero-footer-cols { position: relative; z-index: 5; width: 96%; max-width: 1400px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 10rem; padding: 2.5rem 0 3.5rem; border-top: 1px solid rgba(255,255,255,0.15); }
.sc-hero-footer-col p { font-size: clamp(0.9rem, 1.2vw, 1.05rem); line-height: 1.65; color: rgba(255,255,255,0.72); font-weight: 400; }
@media (max-width: 900px) { .sc-hero-headline { font-size: clamp(3rem, 12vw, 6rem); } .sc-hero-lead { font-size: clamp(1.2rem, 4vw, 1.6rem); } .sc-hero-footer-cols { gap: 4rem; } }
@media (max-width: 600px) { .sc-hero-headline { font-size: clamp(2.2rem, 14vw, 4rem); white-space: normal; color: rgba(255, 255, 255, 0.60); } .sc-hero-footer-cols { grid-template-columns: 1fr; gap: 1.5rem; text-align: center; } .sc-hero-brand { top: 140px; right: 4%; } .sc-hero-body { max-width: 100%; text-align: center; align-items: center; } .sc-hero-content { justify-content: center; } }
/* ======================================================= */
.sc-header-divider { border-bottom: 1px solid rgba(255, 255, 255, 0.15); }



/* ============================ CONTACTO PAGE (scoped to body.con-page / .con-* classes) ======================================================= */
body.con-page{background:#cccccc;}
/* --- Header dark overrides (only on contacto) --- */
.con-hero-header{border-bottom:1px solid rgba(53,59,74,.2);}
.con-hero-header .con-hero-text{color:#353b4a;}
.con-hero-header .con-hero-span{color:#3f6cff;}
/* ---- Main section: flex column, full page width ---- */
.con-section{width:100%;min-height:100vh;background:#cccccc;display:flex;flex-direction:column;padding:150px 5% 80px;box-sizing:border-box;}
/* ---- TOP ROW: label | heading ---- */
.con-top-row{width:100%;display:grid;grid-template-columns:240px 1fr;align-items:start;column-gap:7%;margin-bottom:6rem;}
/* Left cell */
.con-top-left{display:flex;flex-direction:column;gap:3rem;padding-top:.3rem;}
.con-label{font-size:.85rem;font-weight:600;letter-spacing:.02em;color:#353b4a;text-transform:none;}
/* Vertical divider */
.con-top-divider{display:none;}
/* Right cell: big heading */
.con-top-right{width:100%;max-width:920px;margin-left:auto;padding-top:0;}
.con-heading{font-size:clamp(1.7rem,3.1vw,3.2rem);font-weight:700;line-height:1.2;color:#05091d;letter-spacing:-.055em;}
.con-heading-blue{color:#3f6cff;}
/* ---- Arrow ---- */
.con-arrow-wrap{display:inline-block;margin-top:2rem;}
.con-arrow-img{width:88px;height:88px;object-fit:contain;opacity:1;animation:conArrowFloat 3.5s ease-in-out infinite;}

@keyframes conArrowFloat{
0%,100%{transform:translate(0,0);}
50%{transform:translate(6px,6px);}
}

/* ---- CTA button ---- */
.con-btn{display:inline-flex;align-items:center;gap:.65rem;border:1.5px solid #353b4a;color:#353b4a;background:transparent;padding:.78rem 1.7rem;border-radius:100px;font-size:.95rem;font-weight:500;text-decoration:none;width:fit-content;margin-top:2.3rem;}
.con-btn svg{width:14px;height:14px;stroke-width:2;transition:transform .25s ease;}
.con-btn:hover svg{transform:translate(4px,-4px);}
/* ---- FORM AREA ---- */
.con-form-area{width:100%;padding-top:3rem;border-top:1px solid rgba(53,59,74,.22);}
.con-form-subtitle{width:100%;max-width:920px;margin-left:auto;padding-left:0;font-size:clamp(1rem,1vw,1rem);line-height:1.65;color:#040814;opacity:.9;margin-bottom:4rem;}
.con-form{display:flex;flex-direction:column;width:100%;}
/* Each field row */
.con-field{position:relative;width:100%;margin-bottom:1rem;}
.con-input{width:100%;background:transparent;border:none;outline:none;font-family:inherit;font-size:clamp(3rem,6vw,5.5rem);font-weight:300;letter-spacing:-.055em;color:#05091d;padding:.45rem 0 .4rem;line-height:1;resize:none;overflow:hidden;display:block;box-sizing:border-box;}
/* Placeholder = inactive */
.con-input::placeholder{color:rgba(53,59,74,.12);}
/* On focus placeholder fades further */
.con-input:focus::placeholder{color:rgba(53,59,74,.05);}
/* Bottom divider per field */
.con-field-line{width:100%;height:1px;background:rgba(53,59,74,.25);transition:background .3s ease,height .3s ease;}
.con-field:focus-within .con-field-line{background:#353b4a;height:1.5px;}
/* Textarea auto-size */
.con-textarea{min-height:1.2em;overflow:hidden;}
/* Submit row */
.con-form-bottom{display:flex;justify-content:flex-end;margin-top:3.5rem;}
/* Submit button */
.con-submit-btn{display:inline-flex;align-items:center;gap:.65rem;border:1.5px solid #353b4a;color:#353b4a;background:transparent;padding:.9rem 1.9rem;border-radius:100px;font-family:inherit;font-size:1rem;font-weight:500;cursor:pointer;white-space:nowrap;}
.con-submit-btn svg{width:14px;height:14px;stroke-width:2;transition:transform .25s ease;}
.con-submit-btn:hover svg{transform:translate(4px,-4px);}
/* Success */
.con-success{margin-top:1.5rem;padding:1rem 1.5rem;color:#353b4a;font-size:1rem;border-radius:0px;}

/* ---- Responsive ---- */
@media(max-width:1100px){
.con-top-row{grid-template-columns:180px 1fr;column-gap:5%;}
.con-heading{font-size:clamp(2rem,5vw,3.4rem);}
.con-input{font-size:clamp(2.3rem,7vw,4.5rem);}
}

@media(max-width:900px){
.con-section{padding:130px 5% 60px;}
.con-top-row{grid-template-columns:1fr;gap:2rem;margin-bottom:4rem;}
.con-top-right{max-width:100%;margin-left:0;}
.con-heading{font-size:clamp(1.7rem,6vw,2.6rem);}
.con-form-subtitle{margin-left:0;max-width:100%;}
.con-input{font-size:clamp(2rem,8vw,3.2rem);}
.con-arrow-wrap{display:inline-block;margin-top:0rem;}
.con-arrow-img{width:70px;height:70px;}

.con-top-right{max-width:100%;margin-left:0;text-align:center;display:flex;flex-direction:column;align-items:center;}
.con-heading{text-align:center;}
.con-form-subtitle{max-width:100%;margin-left:0;text-align:center;}

.con-form-bottom{justify-content:center;}

.con-submit-btn{width:auto;min-width:unset;}    
    
}


@media(max-width:600px){
.con-section{padding:110px 5% 50px;}
.con-heading{font-size:clamp(1.5rem,8vw,2.1rem);}
.con-input{font-size:clamp(1.6rem,10vw,2.5rem);}
.con-submit-btn{justify-content:center;}
.con-arrow-img{width:55px;height:55px;}
}

/* ================================================================ END CONTACTO ================================================================ */




.scientific-section-container { position: relative; width: 100%; height: 100vh; overflow: hidden; background-color: #f4f4f4; }
.scientific-bg-image-wrapper { position: absolute; top: 0; left: 0; width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; z-index: 1; overflow: hidden; pointer-events: none; animation: floatDrift 18s ease-in-out infinite; }
#scientific-bg-image { max-width: 95%; max-height: 85%; object-fit: contain; opacity: 0.95; animation: breathScale 11s ease-in-out infinite; transform-origin: center center; }
@keyframes breathScale { 0%, 100% { transform: scale3d(0.98, 0.98, 1); } 50% { transform: scale3d(1.12, 1.12, 1); } }
@keyframes floatDrift { 0%, 100% { transform: translate3d(0, 0, 0) rotate(0deg); } 33% { transform: translate3d(16px, -12px, 0) rotate(0.4deg); } 66% { transform: translate3d(-12px, 14px, 0) rotate(-0.3deg); } }

.scientific-hero { position: relative; width: 100%; height: 100vh; display: flex; flex-direction: column; justify-content: center; align-items: center; z-index: 2; padding: 2rem; text-align: center; }
.scientific-headline-container { position: relative; display: flex; flex-direction: column; align-items: center; gap: 2rem; max-width: 90%; transform: translateY(-5vh); }
.scientific-headline { font-size: clamp(6rem, 9vw, 8rem); font-weight: 700; letter-spacing: -0.04em; line-height: 1.05; color: rgba(11, 30, 230, 0.78); mix-blend-mode: multiply; pointer-events: none; }
.scientific-info-btn { display: inline-flex; align-items: center; justify-content: center; gap: 0.75rem; background-color: #ffffff; color: #0f0fab; border: 1px solid rgba(0, 0, 0, 0.05); padding: 0.8rem 1.8rem; border-radius: 100px; font-size: 0.95rem; font-weight: 500; text-decoration: none; box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05); cursor: pointer; transition: box-shadow 0.3s ease, background-color 0.3s ease; z-index: 3; }
.scientific-info-btn:hover { box-shadow: 0 8px 22px rgba(0, 0, 0, 0.08); }
.scientific-info-btn svg { width: 14px; height: 14px; transition: transform 0.3s ease; }
.scientific-info-btn:hover svg { transform: translate(2px, -2px); }
.scientific-bottom-banner { position: absolute; bottom: 0; left: 0; width: 100%; background-color: #0018a8; color: #ffffff; padding: 2.2rem 5rem; display: grid; grid-template-columns: auto 1fr; align-items: center; gap: 4rem; z-index: 5; border-top: 1px solid rgba(255, 255, 255, 0.1); }
.scientific-banner-arrow { display: flex; align-items: center; justify-content: center; }
.scientific-banner-arrow img { width: 48px; height: 48px; object-fit: contain; mix-blend-mode: screen; animation: pulseArrow 2s infinite ease-in-out; }
.scientific-banner-content { font-size: clamp(1rem, 1.5vw, 1.25rem); line-height: 1.6; font-weight: 400; letter-spacing: -0.01em; opacity: 0.9; }
.scientific-banner-content strong { font-weight: 700; opacity: 1; }
.scientific-banner-content p { margin-bottom: 0.4rem; }
.scientific-banner-content p:last-child { margin-bottom: 0; }

@keyframes fadeInDown { from { opacity: 0; transform: translateY(-30px); } to { opacity: 1; transform: translateY(0); } }
@keyframes fadeInUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } }
@keyframes slideUp { from { transform: translateY(100%); } to { opacity: 1; transform: translateY(0); } }
@keyframes pulseArrow { 0%, 100% { transform: translateX(0); opacity: 0.8; } 50% { transform: translateX(6px); opacity: 1; } }


.scientific-section-containernueva { width: 100%; background-color: #0018a8; color: #ffffff; padding: 3rem 0; display: flex; justify-content: center; border-top: 1px solid rgba(255, 255, 255, 0.1); }
.scientific-container-nueva { width: 96vw; max-width: 1980px; margin: 0 auto; display: grid; grid-template-columns: auto 1fr; align-items: center; gap: 4rem; }
@media (max-width: 900px) { 
    .scientific-bottom-banner { grid-template-columns: auto 1fr; gap: 2.5rem; padding: 1.8rem 3rem; } 
    .scientific-banner-arrow img { width: 38px; height: 38px; } 
    .scientific-container-nueva { gap: 2.5rem; }
}
@media (max-width: 600px) {
    .scientific-headline-container { transform: translateY(-8vh); } .scientific-bottom-banner { grid-template-columns: 1fr; gap: 1rem; padding: 1.25rem 1.5rem; text-align: center; } .scientific-banner-arrow { justify-content: center; } .scientific-banner-arrow img { width: 32px; height: 32px; } 
    .scientific-banner-content { font-size: 0.95rem; } 
    .scientific-container-nueva { grid-template-columns: 1fr; gap: 1rem; text-align: center; }
}



.entradas-section { background:url('../imagenes/fondo.jpg') center center/cover no-repeat; padding: 6rem 0 8rem; color: #ffffff; overflow: hidden; display: flex; justify-content: center; width: 100%; }
.entradas-container { width: 90vw; max-width: 1980px; margin: 0 auto; }
.entradas-header { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2.5rem; align-items: flex-start; margin-bottom: 5rem; }
.entradas-header-right { grid-column: span 2; }
.entradas-header-number { font-size: clamp(3rem, 7vw, 5.5rem); font-weight: 700; color: #3d66ff; line-height: 0.8; display: block; }
.entradas-header-text { font-size: clamp(1.6rem, 2.8vw, 2.6rem); font-weight: 300; line-height: 1.35; letter-spacing: -0.02em; color: rgba(255, 255, 255, 0.95); }
.entradas-highlight { color: #3d66ff; font-weight: 600; }
.entradas-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2.5rem; }
.entradas-card { display: flex; flex-direction: column; height: 100%; max-width: 535px; width: 100%; }
.entradas-card-image-container { display: block; position: relative; width: 100%; aspect-ratio: 343 / 228; border-radius: 16px; }
.entradas-card-image { width: 100%; height: 100%; object-fit: cover; clip-path: url(#entradas-clip); display: block; }
.entradas-card-border { position: absolute; top: 0; left: 0; width: 100%; height: 100%; pointer-events: none; overflow: visible; }
.entradas-card-border path { stroke: #3d66ff; stroke-width: 2; transition: stroke 0.3s ease, stroke-width 0.3s ease; }
.entradas-card:hover .entradas-card-border path { stroke: #5d7cff; stroke-width: 2.5; }
.entradas-plus-btn { position: absolute; bottom: 0px; left: 0px; width: 44px; height: 44px; border-radius: 50%; background-color: #2b50f6; color: #ffffff; border: 0; font-size: 1.5rem; font-weight: 500; display: flex; align-items: center; justify-content: center; cursor: pointer; z-index: 3; transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275), background-color 0.3s ease; }
.entradas-card:hover .entradas-plus-btn { transform: scale(1.15) rotate(90deg); background-color: #1e3dbe; }
.entradas-card-footer { margin-top: 1.8rem; display: grid; grid-template-columns: auto 1fr; align-items: flex-start; gap: 1.2rem; }
.entradas-card-number { font-size: 1.1rem; font-weight: 500; color: rgba(255, 255, 255, 0.4); line-height: 1.3; }
.entradas-card-info { display: flex; flex-direction: column; gap: 0.3rem; }
.entradas-card-title { font-size: 1.15rem; font-weight: 700; color: #ffffff; line-height: 1.35; }
.entradas-card-subtitle { font-size: 1.15rem; font-weight: 400; color: rgba(255, 255, 255, 0.65); line-height: 1.35; }
.entradas-card-action { margin-top: 1.6rem; }
.entradas-info-btn { display: inline-flex; align-items: center; justify-content: center; gap: 0.6rem; background-color: transparent; color: #ffffff; border: 1px solid rgba(255, 255, 255, 0.25); padding: 0.55rem 1.4rem; border-radius: 100px; font-size: 0.88rem; font-weight: 500; text-decoration: none; cursor: pointer; transition: background-color 0.3s ease, border-color 0.3s ease, color 0.3s ease, transform 0.3s ease; }
.entradas-info-btn svg { width: 12px; height: 12px; fill: none; stroke: currentColor; stroke-width: 2.5; transition: transform 0.3s ease; }
.entradas-info-btn:hover svg { transform: translate(2px, -2px); }

@media (max-width: 1100px) { 
    .entradas-grid { grid-template-columns: repeat(2, 1fr); gap: 2rem; }
}

@media (max-width: 768px) { 
    .entradas-section { padding: 4.5rem 5% 5rem; } 
    .entradas-header { grid-template-columns: 1fr; gap: 1rem; margin-bottom: 3.5rem; text-align: center; } 
    .entradas-header-right { grid-column: auto; } .entradas-header-number { text-align: center; line-height: 1; } 
    .entradas-grid { grid-template-columns: 1fr; gap: 3.5rem; justify-items: center; } .entradas-card { align-items: center; max-width: 535px; } 
    .entradas-card-image-container { max-width: 535px; width: 100%; } 
    .entradas-card-footer { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 0.6rem; width: 100%; } 
    .entradas-card-action { display: flex; justify-content: center; width: 100%; } 
}

/* Proyectos */
.proyectos-section { background-color: #020516; padding: 6rem 0 6rem; width: 100%; overflow: hidden; display: flex; justify-content: center; font-family: "TikTok Sans", sans-serif; border-bottom: 1px solid rgba(255, 255, 255, 0.25); }
.proyectos-container { width: 96vw; max-width: 1980px; margin: 0 auto; display: flex; flex-direction: column; gap: 3rem; }
.proyectos-svg-wrap { width: 100%; }
.proyectos-svg { width: 100%; height: auto; display: block; filter: brightness(1.3); }
.proyectos-bottom-row { display: flex; justify-content: space-between; align-items: flex-end; width: 100%; }
.proyectos-heading { font-size: clamp(2rem, 3.5vw, 3.2rem); font-weight: 300; line-height: 1.25; color: #ffffff; margin: 0; letter-spacing: -0.02em; }
.proyectos-action { display: flex; align-items: center; }
.proyectos-btn { display: inline-flex; align-items: center; justify-content: center; gap: 0.6rem; background-color: transparent; color: #ffffff; border: 1px solid rgba(255, 255, 255, 0.25); padding: 0.6rem 1.6rem; border-radius: 100px; font-size: 0.9rem; font-weight: 400; text-decoration: none; cursor: pointer; transition: border-color 0.3s ease, color 0.3s ease; }
.proyectos-btn svg { width: 12px; height: 12px; fill: none; stroke: currentColor; stroke-width: 2.5; transition: transform 0.3s ease; }
.proyectos-btn:hover { border-color: rgba(255, 255, 255, 0.5); }
.proyectos-btn:hover svg { transform: translate(2px, -2px); }




/* foot */
.emaly-footer { background-color: #020516; color: #ffffff; padding: 5rem 0 4rem; font-family: "TikTok Sans", sans-serif; display: flex; justify-content: center; width: 100%; }
.emaly-footer-container { width: 96vw; max-width: 1980px; margin: 0 auto; display: flex; flex-direction: column; gap: 4rem; background-color: #040814; }
.emaly-footer-top { display: grid; grid-template-columns: 1fr 2fr; align-items: flex-start; gap: 4rem; }
.emaly-footer-logo-wrap { display: flex; align-items: center; }
.emaly-footer-logo { max-width: 150px; height: auto; }
.emaly-footer-form { display: flex; flex-direction: column; width: 100%; }
.emaly-footer-label { font-size: 1.15rem; font-weight: 300; color: #353b4a; margin-bottom: 1.5rem; letter-spacing: -0.01em; }
.emaly-footer-label-highlight { color: #ffffff; font-weight: 500; }
.emaly-footer-input-row { width: 100%; margin-bottom: 1.5rem; }
.emaly-footer-input { width: 100%; background: transparent; border: none; border-bottom: 1px solid rgba(255, 255, 255, 0.5); padding: 0.8rem 0; color: #ffffff; font-size: 1.1rem; font-family: inherit; outline: none; transition: border-bottom-color 0.3s ease; }
.emaly-footer-input:focus { border-bottom-color: #2b50f6; }
.emaly-footer-btn-row { display: flex; justify-content: flex-end; width: 100%; }
.emaly-footer-submit-btn { display: inline-flex; align-items: center; justify-content: center; gap: 0.6rem; background-color: transparent; color: #ffffff; border: 1px solid rgba(255, 255, 255, 0.25); padding: 0.55rem 1.4rem; border-radius: 100px; font-size: 0.88rem; font-weight: 500; cursor: pointer; font-family: inherit; transition: background-color 0.3s ease, border-color 0.3s ease; }
.emaly-footer-submit-btn:hover { border-color: rgba(255, 255, 255, 0.5); }
.emaly-footer-submit-btn svg { width: 12px; height: 12px; fill: none; stroke: currentColor; stroke-width: 2.5; transition: transform 0.3s ease; }
.emaly-footer-submit-btn:hover svg { transform: translate(2px, -2px); }
.emaly-footer-middle { display: grid; grid-template-columns: 1fr 2fr; gap: 4rem; }
.emaly-footer-middle-content { grid-column: 2; display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; }
.emaly-footer-address h5 { font-size: 1.15rem; font-weight: 700; color: #ffffff; margin-bottom: 0.8rem; }
.emaly-footer-address p { font-size: 1rem; font-weight: 400; color: #ffffff; line-height: 1.6; margin: 0 0 0.4rem; }
.emaly-footer-address a { color: inherit; text-decoration: none; transition: color 0.3s ease; }
.emaly-footer-address a:hover { color: #3360ef; }
.emaly-footer-socials { display: flex; flex-direction: column; gap: 1.2rem; }
.emaly-footer-socials-text { font-size: 1rem; font-weight: 400; color: #ffffff; line-height: 1.4; }
.emaly-footer-social-icons { display: flex; align-items: center; gap: 1.5rem; }
.emaly-footer-social-icons a { color: rgba(255, 255, 255, 0.8); transition: color 0.3s ease, transform 0.3s ease; display: flex; align-items: center; justify-content: center; }
.emaly-footer-social-icons a:hover { color: #2b50f6; transform: translateY(-2px); }
.emaly-footer-social-img { height: 20px; width: auto; opacity: 0.8; transition: opacity 0.3s ease; } .emaly-footer-social-icons a:hover .emaly-footer-social-img { opacity: 1; }
.emaly-footer-bottom { display: grid; grid-template-columns: 1fr 2fr; align-items: flex-start; gap: 4rem; border-top: 1px solid rgba(255, 255, 255, 0.1); padding-top: 3rem; }
.emaly-footer-copyright p { font-size: 0.9rem; color: #ffffff; margin: 0; }
.emaly-footer-bottom-nav { display: grid; grid-template-columns: repeat(3, 1fr) auto; gap: 3rem; align-items: flex-start; }
.emaly-footer-nav-col { display: flex; flex-direction: column; gap: 0.8rem; }
.emaly-footer-nav-col a { font-size: 0.95rem; color: #353b4a; text-decoration: none; transition: color 0.3s ease; }
.emaly-footer-nav-col a:hover { color: #3360ef; }
.emaly-footer-link-highlight { color: #2b50f6 !important; font-weight: 600; }
.emaly-footer-link-white { color: #ffffff !important; }
.emaly-footer-back-to-top { display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 50%; border: 1px solid rgba(255, 255, 255, 0.2); color: rgba(255, 255, 255, 0.6); transition: all 0.3s ease; text-decoration: none; }
.emaly-footer-back-to-top:hover { border-color: #2b50f6; color: #ffffff; background-color: #2b50f6; transform: translateY(-3px); }
.emaly-footer-back-to-top svg { width: 16px; height: 16px; fill: none; stroke: currentColor; stroke-width: 2.5; }

@media (max-width: 1024px) {
  .emaly-footer-top, .emaly-footer-middle, .emaly-footer-bottom { grid-template-columns: 1fr; gap: 2.5rem; }
  .emaly-footer-middle-content { grid-column: 1; grid-template-columns: 1fr 1fr; gap: 3rem; }
  .emaly-footer-bottom-nav { grid-template-columns: repeat(3, 1fr) auto; gap: 2rem; }
}

@media (max-width: 768px) {
  .proyectos-section { padding: 4rem 5% 4rem; }
  .proyectos-container { gap: 2rem; }
  .proyectos-bottom-row { flex-direction: column; align-items: center; text-align: center; gap: 2.2rem; }

  .emaly-footer { padding: 4rem 5% 3rem; }
  .emaly-footer-container { gap: 3rem; }
  .emaly-footer-top { text-align: center; justify-items: center; }
  .emaly-footer-form { align-items: center; }
  .emaly-footer-btn-row { justify-content: center; }
  .emaly-footer-middle-content { grid-template-columns: 1fr; text-align: center; justify-items: center; }
  .emaly-footer-socials { align-items: center; }
  .emaly-footer-bottom { text-align: center; justify-items: center; }
  .emaly-footer-bottom-nav { grid-template-columns: 1fr; gap: 2rem; text-align: center; justify-items: center; width: 100%; order: 1; }
  .emaly-footer-nav-col { align-items: center; }
  .emaly-footer-copyright { order: 2; }
}
