:root{
  --navy:#151f45;--yellow:#f3d14b;--green:#70bf7b;--coral:#de515a;--blue:#7097fb;--purple:#8c5baf;
  --cream:#fbfaf6;--ink:#1c2547;--grey:#5c6480;--line:#e7e6ee;--font:'Poppins',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--cream);color:var(--ink);line-height:1.65;overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--font);line-height:1.14;color:var(--navy);font-weight:800}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1140px;margin:0 auto;padding:0 22px}
.eyebrow{font-weight:700;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--coral);margin-bottom:13px;display:block}
.center{text-align:center}

/* Animaciones */
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-18px)}}
@keyframes floatX{0%,100%{transform:translate(0,0)}50%{transform:translate(12px,-14px)}}
@keyframes bob{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-10px) rotate(1deg)}}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 15px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes drawLine{from{width:0}to{width:100%}}
@keyframes bounceArrow{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}

.deco{position:absolute;border-radius:50%;z-index:0;pointer-events:none;opacity:.45}

/* Botones */
.btn{font-weight:700;font-size:.96rem;padding:13px 26px;border-radius:50px;display:inline-flex;align-items:center;gap:8px;cursor:pointer;border:none;transition:transform .2s,box-shadow .2s,background .2s;position:relative;z-index:2}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 8px 22px rgba(112,151,251,.35)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(112,151,251,.5)}
.btn-dona{background:var(--coral);color:#fff;box-shadow:0 8px 22px rgba(222,81,90,.32)}
.btn-dona:hover{transform:translateY(-3px);background:#c8424b}
.btn-ghost{background:#fff;color:var(--navy);border:2px solid var(--line)}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue)}
.btn-yellow{background:var(--yellow);color:var(--navy)}
.btn-yellow:hover{transform:translateY(-3px)}

/* Header */
header{position:sticky;top:0;z-index:100;background:rgba(251,250,246,.94);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px;gap:18px}
.logo{font-weight:800;font-size:1.45rem;letter-spacing:-.02em;display:flex;align-items:center;gap:9px}
.logo .s{color:var(--coral)}
.nav-menu{display:flex;align-items:center;gap:22px}
.nav-menu>li{list-style:none;position:relative}
.nav-menu>li>a{font-weight:500;font-size:.93rem;color:var(--ink);padding:8px 0;display:inline-flex;align-items:center;gap:5px;transition:color .2s}
.nav-menu>li>a:hover,.nav-menu>li>a.active{color:var(--blue)}
.nav-menu>li>a.active{font-weight:700}
.nav-menu .ar{font-size:.6rem;opacity:.6}
.submenu{position:absolute;top:100%;left:-16px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:8px;min-width:240px;box-shadow:0 18px 40px rgba(21,31,69,.12);opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s}
.nav-menu>li:hover .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.submenu a{display:block;padding:10px 14px;border-radius:9px;font-size:.89rem;color:var(--ink)}
.submenu a:hover{background:var(--cream);color:var(--blue)}
.nav-right{display:flex;align-items:center;gap:10px}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
.burger span{width:24px;height:2.5px;background:var(--navy);border-radius:3px}

/* Hero home */
.hero{position:relative;padding:64px 0 76px;overflow:hidden}
.hero .deco.d1{width:180px;height:180px;background:var(--yellow);top:-40px;left:-60px;animation:float 9s ease-in-out infinite}
.hero .deco.d2{width:110px;height:110px;background:var(--green);bottom:40px;right:-40px;animation:floatX 11s ease-in-out infinite}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.hero h1{font-size:clamp(2.2rem,5.4vw,4rem);font-weight:800;letter-spacing:-.02em}
.hero h1 .hl{position:relative;color:var(--blue)}
.hero h1 .hl:after{content:"";position:absolute;left:0;bottom:6px;height:13px;background:var(--yellow);z-index:-1;border-radius:4px;width:0;animation:drawLine 1s ease .5s forwards}
.hero p.lead{font-size:1.12rem;color:var(--grey);margin:20px 0 28px;max-width:500px}
.hero-cta{display:flex;gap:13px;flex-wrap:wrap}
.scroll-hint{margin-top:30px;display:inline-flex;align-items:center;gap:8px;color:var(--grey);font-size:.84rem;font-weight:500}
.scroll-hint .arr{animation:bounceArrow 1.6s ease-in-out infinite}
.hero-art{position:relative}
.hero-art .photo{border-radius:26px;box-shadow:0 28px 60px rgba(21,31,69,.18);position:relative;z-index:2;animation:bob 6s ease-in-out infinite}
.blob{position:absolute;border-radius:50%;z-index:1}
.blob.b1{width:110px;height:110px;background:var(--green);top:-24px;right:28px;opacity:.85;animation:float 7s ease-in-out infinite}
.blob.b2{width:74px;height:74px;background:var(--coral);bottom:28px;left:-24px;opacity:.85;animation:float 8s ease-in-out infinite .6s}
.hero-tag{position:absolute;z-index:3;bottom:22px;right:-12px;background:#fff;border-radius:16px;padding:13px 17px;box-shadow:0 14px 34px rgba(21,31,69,.16);display:flex;align-items:center;gap:11px;animation:float 5s ease-in-out infinite 1s}
.hero-tag b{font-size:1.45rem;color:var(--purple);line-height:1}
.hero-tag span{font-size:.76rem;color:var(--grey);line-height:1.2}

/* Page hero (internas) */
.phero{position:relative;padding:56px 0;background:var(--navy);color:#fff;overflow:hidden;text-align:center}
.phero .deco.p1{width:150px;height:150px;background:var(--coral);top:-40px;right:8%;opacity:.25;animation:float 8s ease-in-out infinite}
.phero .deco.p2{width:90px;height:90px;background:var(--green);bottom:-30px;left:12%;opacity:.25;animation:floatX 9s ease-in-out infinite}
.phero .wrap{position:relative;z-index:2}
.phero .eyebrow{color:var(--yellow)}
.phero h1{color:#fff;font-size:clamp(2rem,4.6vw,3rem)}
.phero p{color:rgba(255,255,255,.82);max-width:620px;margin:14px auto 0}

/* Marquee */
.strip{background:var(--navy);color:#fff;padding:15px 0;overflow:hidden;white-space:nowrap}
.marquee{display:inline-flex;gap:46px;animation:marquee 24s linear infinite;will-change:transform}
.marquee:hover{animation-play-state:paused}
.marquee span{font-weight:600;font-size:.98rem;display:inline-flex;align-items:center;gap:9px}
.marquee b{color:var(--yellow)}

/* Secciones */
.sec{padding:78px 0;position:relative;overflow:hidden}
.sec-sm{padding:56px 0}
.sec-head{max-width:660px;margin:0 auto 44px;text-align:center;position:relative;z-index:2}
.sec-head h2{font-size:clamp(1.8rem,4.2vw,2.7rem);font-weight:800;letter-spacing:-.02em}
.sec-head p{color:var(--grey);margin-top:13px;font-size:1.02rem}

/* Qué es */
.about-grid{position:relative;z-index:2;display:grid;grid-template-columns:.9fr 1.1fr;gap:46px;align-items:center}
.about-grid .imgwrap{position:relative}
.about-grid img{border-radius:22px;box-shadow:0 22px 50px rgba(21,31,69,.16)}
.about-grid .dot{position:absolute;width:84px;height:84px;border-radius:50%;background:var(--yellow);bottom:-22px;right:-16px;z-index:-1;animation:float 7s ease-in-out infinite}
.about-grid h2{font-size:clamp(1.7rem,3.8vw,2.5rem);margin-bottom:8px}
.about-grid .sub{font-weight:600;font-style:italic;color:var(--purple);font-size:1.15rem;margin-bottom:15px}
.about-grid p{color:var(--grey);font-size:1.02rem}

/* Pilares */
.pill-grid{position:relative;z-index:2;display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pill{background:#fff;border-radius:20px;padding:28px 24px;border:1px solid var(--line);transition:transform .25s,box-shadow .25s}
.pill:hover{transform:translateY(-7px);box-shadow:0 20px 44px rgba(21,31,69,.12)}
.pill .chip{width:54px;height:54px;border-radius:15px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:15px;transition:transform .3s}
.pill:hover .chip{transform:rotate(-8deg) scale(1.1)}
.pill h3{font-size:1.22rem;font-weight:700;margin-bottom:7px}
.pill p{color:var(--grey);font-size:.93rem}
.c-coral{background:rgba(222,81,90,.15)}.c-blue{background:rgba(112,151,251,.15)}.c-green{background:rgba(112,191,123,.15)}
.c-yellow{background:rgba(243,209,75,.22)}.c-purple{background:rgba(140,91,175,.15)}.c-navy{background:rgba(21,31,69,.1)}

/* Programas */
.prog-grid{position:relative;z-index:2;display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.prog{display:flex;border-radius:22px;overflow:hidden;background:#fff;border:1px solid var(--line);transition:transform .25s,box-shadow .25s}
.prog:hover{transform:translateY(-6px);box-shadow:0 22px 48px rgba(21,31,69,.13)}
.prog .bar{width:8px;flex-shrink:0}
.prog .pbody{padding:26px 28px}
.prog h3{font-size:1.32rem;font-weight:700;margin-bottom:9px}
.prog p{color:var(--grey);font-size:.94rem;margin-bottom:13px}
.prog a{font-weight:600;font-size:.9rem;color:var(--blue);display:inline-flex;align-items:center;gap:6px;transition:gap .2s}
.prog a:hover{gap:11px}

/* Bloque detalle (festival, nasa) */
.detail{background:#fff;border:1px solid var(--line);border-radius:24px;padding:40px;margin-bottom:30px;position:relative;z-index:2}
.detail h3{font-size:1.5rem;margin-bottom:6px}
.detail .tag{display:inline-block;font-weight:700;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;padding:5px 12px;border-radius:50px;margin-bottom:14px}
.detail p{color:var(--grey);margin-bottom:14px}
.facts{display:flex;flex-wrap:wrap;gap:14px;margin:18px 0}
.fact{background:var(--cream);border:1px solid var(--line);border-radius:14px;padding:12px 16px;min-width:120px}
.fact b{display:block;font-size:1.05rem;color:var(--navy)}
.fact span{font-size:.78rem;color:var(--grey);text-transform:uppercase;letter-spacing:.06em}
.chk{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:9px 22px;margin:8px 0 4px}
.chk li{display:flex;align-items:flex-start;gap:9px;font-size:.95rem;color:var(--ink)}
.chk li:before{content:"✓";color:var(--green);font-weight:800;flex-shrink:0}
.phase-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:10px}
.phase{background:var(--cream);border:1px solid var(--line);border-radius:14px;padding:16px 14px;text-align:center}
.phase b{display:block;width:30px;height:30px;line-height:30px;border-radius:50%;background:var(--blue);color:#fff;margin:0 auto 8px;font-size:.9rem}
.phase span{font-size:.84rem;font-weight:600;color:var(--navy)}

/* Editions */
.ed-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:8px}
.ed{background:var(--cream);border:1px solid var(--line);border-radius:18px;padding:24px}
.ed h4{font-size:1.2rem;margin-bottom:4px}
.ed .yr{font-weight:700;color:var(--coral);font-size:.85rem;margin-bottom:12px}
.ed .mini{display:flex;gap:18px;margin-bottom:12px}
.ed .mini div b{font-size:1.5rem;color:var(--purple);display:block;line-height:1}
.ed .mini div span{font-size:.76rem;color:var(--grey)}
.ed p{font-size:.9rem;color:var(--grey)}

/* Conv (Sé parte del cambio) - SIN animación */
.conv{position:relative;z-index:2;background:linear-gradient(120deg,var(--purple),var(--blue));border-radius:26px;padding:48px;color:#fff}
.conv-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center}
.conv h2{color:#fff;font-size:clamp(1.6rem,3.4vw,2.3rem)}
.conv p{opacity:.92;margin:13px 0 20px}
.conv-list{list-style:none;display:flex;flex-direction:column;gap:10px}
.conv-list li{background:rgba(255,255,255,.16);border-radius:12px;padding:13px 17px;font-weight:600;display:flex;align-items:center;gap:10px}

/* Impacto */
.impact{position:relative;z-index:2;background:var(--navy);color:#fff;border-radius:30px;margin:0 22px;padding:64px 0;overflow:hidden}
.impact .deco.di1{width:150px;height:150px;background:var(--coral);top:-40px;right:60px;opacity:.22;animation:float 8s ease-in-out infinite}
.impact .deco.di2{width:100px;height:100px;background:var(--green);bottom:-30px;left:80px;opacity:.22;animation:floatX 9s ease-in-out infinite}
.impact .wrap{max-width:1080px;position:relative;z-index:2}
.impact .sec-head h2,.impact .sec-head p{color:#fff}
.impact .sec-head p{opacity:.82}
.imp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;text-align:center}
.imp b{font-size:2.8rem;font-weight:800;display:block;line-height:1}
.imp:nth-child(1) b{color:var(--yellow)}.imp:nth-child(2) b{color:var(--green)}
.imp:nth-child(3) b{color:var(--blue)}.imp:nth-child(4) b{color:var(--coral)}
.imp span{font-size:.9rem;opacity:.85;display:block;margin-top:7px}

/* Testimonios */
.test-grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:22px}
.test{background:#fff;border:1px solid var(--line);border-radius:22px;padding:30px;position:relative;transition:transform .25s}
.test:hover{transform:translateY(-5px)}
.test .mark{font-size:3.2rem;font-weight:800;color:var(--yellow);position:absolute;top:16px;right:26px;line-height:1}
.test p{font-size:1.02rem;color:var(--ink);margin-bottom:16px;font-style:italic}
.test .who{display:flex;align-items:center;gap:12px}
.test .who img{width:48px;height:48px;border-radius:50%;object-fit:cover;border:3px solid var(--green)}
.test .who b{display:block;font-weight:700;color:var(--navy);line-height:1.2}
.test .who span{font-size:.82rem;color:var(--grey)}

/* Aliados */
.aliados-row{display:flex;justify-content:center;align-items:center;gap:42px;flex-wrap:wrap;margin-top:26px;position:relative;z-index:2}
.aliados-row img{height:60px;opacity:.7;transition:opacity .25s,transform .25s}
.aliados-row img:hover{opacity:1;transform:scale(1.07)}

/* Dona */
.dona{position:relative;z-index:2;text-align:center;background:var(--yellow);border-radius:30px;margin:0 22px;padding:58px 22px;overflow:hidden}
.dona .deco.dd1{width:110px;height:110px;background:var(--coral);top:-28px;left:40px;opacity:.4;animation:float 7s ease-in-out infinite}
.dona .deco.dd2{width:84px;height:84px;background:var(--blue);bottom:-22px;right:60px;opacity:.4;animation:floatX 8s ease-in-out infinite}
.dona h2{font-size:clamp(1.8rem,4.2vw,2.7rem);max-width:660px;margin:0 auto 12px;position:relative;z-index:2}
.dona p{color:var(--navy);opacity:.8;max-width:500px;margin:0 auto 24px;font-size:1.04rem;position:relative;z-index:2}

/* Contacto */
.contact-grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:start}
.contact-grid h2{font-size:clamp(1.7rem,3.8vw,2.4rem);margin-bottom:9px}
.contact-grid .lead{color:var(--grey);margin-bottom:22px}
.cform{display:flex;flex-direction:column;gap:13px}
.cform label{font-weight:600;font-size:.86rem;color:var(--navy);margin-bottom:-6px}
.cform input,.cform textarea{padding:13px 17px;border-radius:13px;border:2px solid var(--line);font-family:var(--font);font-size:.94rem;width:100%}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--green)}
.cform textarea{resize:vertical;min-height:92px}
.wa-btn{background:#25d366;color:#fff;font-weight:700;font-size:1rem;border:none;border-radius:50px;padding:14px 26px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:9px;transition:transform .2s,box-shadow .2s}
.wa-btn:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(37,211,102,.4)}
.infobox{background:#fff;border:1px solid var(--line);border-radius:18px;padding:22px;margin-bottom:20px}
.infobox .row{display:flex;align-items:center;gap:13px;margin-bottom:13px}
.infobox .row:last-child{margin-bottom:0}
.infobox .ic{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.infobox .row b{display:block;font-size:.92rem;color:var(--navy)}
.infobox .row span{font-size:.84rem;color:var(--grey)}
.social-title{font-weight:700;color:var(--navy);margin-bottom:13px}
.social-grid{display:flex;gap:13px;flex-wrap:wrap}
.social-grid a{width:54px;height:54px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:#fff;transition:transform .22s,box-shadow .22s}
.social-grid a:hover{transform:translateY(-4px) rotate(-6deg);box-shadow:0 12px 26px rgba(21,31,69,.2)}
.sg-wa{background:#25d366}.sg-ig{background:linear-gradient(45deg,#f09433,#dc2743,#bc1888)}.sg-fb{background:#1877f2}.sg-tt{background:#010101}

/* Newsletter */
.news{text-align:center;padding:64px 0}
.news h2{font-size:1.8rem;margin-bottom:9px}
.news p{color:var(--grey);margin-bottom:22px}
.news form{display:flex;gap:11px;max-width:470px;margin:0 auto;flex-wrap:wrap;justify-content:center}
.news input{flex:1;min-width:210px;padding:13px 19px;border-radius:50px;border:2px solid var(--line);font-family:var(--font);font-size:.93rem}
.news input:focus{outline:none;border-color:var(--blue)}

/* Footer */
footer{background:var(--navy);color:#fff;padding:54px 0 26px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:34px;margin-bottom:34px}
.foot-grid h4{font-size:1.02rem;margin-bottom:15px;color:var(--yellow)}
.foot-grid a,.foot-grid p{display:block;color:rgba(255,255,255,.78);font-size:.89rem;margin-bottom:9px}
.foot-grid a:hover{color:#fff}
.foot-logo{font-size:1.45rem;font-weight:800;margin-bottom:11px}
.foot-logo .s{color:var(--coral)}
.socials{display:flex;gap:11px;margin-top:8px}
.socials a{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.05rem;color:#fff;transition:transform .2s}
.socials a:hover{transform:translateY(-3px)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:20px;text-align:center;color:rgba(255,255,255,.6);font-size:.8rem}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s,transform .6s}
.reveal.show{opacity:1;transform:none}

.wa{position:fixed;bottom:20px;right:20px;z-index:95;background:#25d366;width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.7rem;animation:pulse 2.2s infinite;transition:transform .2s}
.wa:hover{transform:scale(1.1)}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .nav-menu{gap:16px}
  .hero-grid{gap:34px}
  .phase-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:900px){
  .nav-menu,.nav-right .btn-ghost{display:none}
  .burger{display:flex}
  .nav-menu.open{display:flex;flex-direction:column;align-items:flex-start;position:absolute;top:72px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);padding:16px 22px;gap:4px;box-shadow:0 20px 40px rgba(21,31,69,.1)}
  .nav-menu.open>li{width:100%}
  .nav-menu.open .submenu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;padding:2px 0 6px 16px;min-width:0}
  .hero-grid,.about-grid,.conv-grid,.contact-grid{grid-template-columns:1fr;gap:34px}
  .hero-art{max-width:400px;margin:0 auto;order:-1}
  .pill-grid{grid-template-columns:1fr 1fr}
  .prog-grid,.test-grid,.ed-grid{grid-template-columns:1fr}
  .imp-grid{grid-template-columns:1fr 1fr;gap:30px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .conv{padding:36px 28px}
  .detail{padding:30px 24px}
}
@media(max-width:600px){
  .wrap{padding:0 18px}
  .sec{padding:52px 0}
  .sec-sm{padding:42px 0}
  .hero{padding:40px 0 52px}
  .hero h1{font-size:1.95rem}
  .hero p.lead{font-size:1rem}
  .hero-cta{gap:10px}
  .hero-cta .btn{flex:1;justify-content:center;min-width:140px;font-size:.9rem;padding:12px 16px}
  .pill-grid,.imp-grid,.foot-grid,.phase-grid,.chk{grid-template-columns:1fr}
  .imp b{font-size:2.4rem}
  .impact,.dona,.conv{margin:0 14px}
  .impact{padding:48px 0}
  .dona{padding:46px 18px}
  .dona .btn{width:auto;font-size:.96rem;padding:12px 26px}
  .conv{padding:30px 22px}
  .detail{padding:24px 18px}
  .facts{gap:10px}.fact{min-width:calc(50% - 5px);flex:1}
  .hero-tag{right:6px;bottom:12px;padding:11px 14px}
  .hero-tag b{font-size:1.25rem}
  .social-grid a{width:50px;height:50px;font-size:1.3rem}
  .sec-head{margin-bottom:34px}
  .ed .mini{gap:14px}
  .phero{padding:42px 0}
}

/* ===== AJUSTES v4: logo, misión/visión, timeline, galería, reseñas, equipo ===== */
.logo img{height:36px;width:auto;display:block}
.foot-logo{display:flex;align-items:center;gap:9px}
.foot-logo img{height:40px;width:auto}

.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;position:relative;z-index:2}
.mv{background:#fff;border:1px solid var(--line);border-radius:22px;padding:34px;position:relative;overflow:hidden}
.mv:before{content:"";position:absolute;top:0;left:0;width:100%;height:6px}
.mv.m1:before{background:var(--coral)}.mv.m2:before{background:var(--blue)}
.mv .ic{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;margin-bottom:16px}
.mv h3{font-size:1.45rem;margin-bottom:10px}
.mv p{color:var(--grey)}

.tl-h{display:flex;overflow-x:auto;padding:24px 0 12px;position:relative;z-index:2}
.tl-h .node{min-width:225px;flex:1;padding:0 16px;position:relative}
.tl-h .node:before{content:"";position:absolute;top:13px;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--coral),var(--blue))}
.tl-h .node:first-child:before{left:50%}
.tl-h .node:last-child:before{right:50%}
.tl-h .dot{position:relative;z-index:2;width:26px;height:26px;border-radius:50%;border:4px solid var(--cream);margin:0 auto 16px;box-shadow:0 0 0 2px var(--line)}
.tl-h .yr{font-weight:800;color:var(--coral);font-size:1.05rem;text-align:center}
.tl-h h4{font-size:1.02rem;text-align:center;margin:4px 0 6px}
.tl-h p{font-size:.85rem;color:var(--grey);text-align:center}

.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;position:relative;z-index:2}
.gitem{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:3/2}
.gitem img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gitem:hover img{transform:scale(1.08)}
.gitem figcaption{position:absolute;left:0;right:0;bottom:0;padding:28px 16px 12px;color:#fff;font-weight:600;font-size:.88rem;background:linear-gradient(transparent,rgba(8,4,23,.82))}

.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;position:relative;z-index:2}
.review{background:#fff;border:1px solid var(--line);border-radius:20px;padding:28px;display:flex;flex-direction:column}
.review .stars{color:#f3b800;font-size:1.05rem;letter-spacing:2px;margin-bottom:12px}
.review p{color:var(--ink);font-size:.93rem;margin-bottom:16px;flex:1}
.review .by{display:flex;align-items:center;gap:11px}
.review .av{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.05rem;flex-shrink:0}
.review .by b{display:block;font-size:.9rem;color:var(--navy)}
.review .by span{font-size:.76rem;color:var(--grey)}

.team-feature{display:grid;grid-template-columns:1fr 1fr;gap:22px;position:relative;z-index:2}
.team-feature figure{border-radius:22px;overflow:hidden;position:relative;margin:0}
.team-feature img{width:100%;height:100%;object-fit:cover;aspect-ratio:3/2;display:block}
.team-feature figcaption{position:absolute;left:0;right:0;bottom:0;padding:26px 18px 14px;color:#fff;font-weight:600;font-size:.92rem;background:linear-gradient(transparent,rgba(8,4,23,.8))}

.socials a svg{width:18px;height:18px}
.social-grid a svg{width:26px;height:26px}

@media(max-width:900px){
  .mv-grid,.gallery,.reviews,.team-feature{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .mv-grid,.reviews,.team-feature{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr 1fr;gap:10px}
  .mv{padding:26px}
  .tl-h .node{min-width:190px}
}

/* ===== AJUSTES v5: header solo logo, timeline cards, equipo, chips, fixes ===== */
.logo img{height:46px}                 /* logo solo, un poco más grande */
.wa-btn svg{width:20px;height:20px}    /* fix: SVG no debe agrandarse */
.infobox .ic svg{width:22px;height:22px}
.social-grid a svg{width:26px;height:26px}
.socials a svg{width:18px;height:18px}

/* Timeline horizontal en tarjetas */
.tl2{display:flex;gap:18px;overflow-x:auto;padding:6px 2px 20px;position:relative;z-index:2;scroll-snap-type:x proximity}
.tl2 .c{min-width:290px;max-width:310px;flex:0 0 auto;background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px;border-top:5px solid var(--coral);scroll-snap-align:start;box-shadow:0 8px 26px rgba(21,31,69,.05)}
.tl2 .c .yr{font-weight:800;font-size:1.12rem;margin-bottom:3px;color:var(--navy)}
.tl2 .c h4{font-size:1.02rem;margin-bottom:12px;color:var(--coral)}
.tl2 .c ul{list-style:none;display:flex;flex-direction:column;gap:7px}
.tl2 .c li{font-size:.85rem;color:var(--grey);padding-left:15px;position:relative;line-height:1.5}
.tl2 .c li:before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:50%;background:currentColor;color:inherit}
.tl2 .c li{}
.tl2 .c li::before{background:#c9c6da}

/* Equipo */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative;z-index:2}
.tm{text-align:center}
.tm .ph{width:160px;height:160px;border-radius:50%;margin:0 auto 14px;overflow:hidden;display:flex;align-items:flex-end;justify-content:center}
.tm .ph img{width:108%;height:108%;object-fit:cover;object-position:top center}
.tm b{display:block;color:var(--navy);font-size:1.02rem;line-height:1.2}
.tm span{font-size:.85rem;color:var(--grey)}

/* Aliados en chips */
.ally-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:26px;position:relative;z-index:2}
.ally-chips span{background:#fff;border:1px solid var(--line);border-radius:50px;padding:10px 22px;font-weight:600;color:var(--navy);font-size:.9rem}

/* Dona más pequeño (sobre todo móvil) */
.nav-right .btn-dona{padding:11px 22px}
@media(max-width:900px){.nav-right .btn-dona{padding:9px 15px;font-size:.85rem}}
@media(max-width:600px){
  .nav-right .btn-dona{padding:8px 13px;font-size:.8rem}
  .team-grid{grid-template-columns:1fr 1fr;gap:18px}
  .tm .ph{width:130px;height:130px}
  .tl2 .c{min-width:250px}
}

/* ===== AJUSTES v5: logo solo, dona pequeña, timeline tarjetas, equipo, chips ===== */
.logo img{height:46px;width:auto}
.btn-dona{font-size:.9rem;padding:11px 22px}
.nav-right .btn-dona{font-size:.82rem;padding:8px 16px}

.tlc{display:flex;gap:18px;overflow-x:auto;padding:6px 2px 20px;scroll-snap-type:x mandatory;position:relative;z-index:2}
.tlc::-webkit-scrollbar{height:8px}
.tlc::-webkit-scrollbar-thumb{background:var(--line);border-radius:50px}
.tlc .node{flex:0 0 300px;max-width:300px;background:#fff;border:1px solid var(--line);border-radius:20px;padding:0 0 22px;overflow:hidden;scroll-snap-align:start}
.tlc .node .top{height:7px}
.tlc .node .in{padding:22px 24px 0}
.tlc .yr{font-weight:800;font-size:1.3rem;color:var(--navy);line-height:1}
.tlc .yr small{display:block;font-size:.72rem;letter-spacing:.04em;text-transform:uppercase;color:var(--coral);margin-top:6px;font-weight:700}
.tlc h4{font-size:1.05rem;margin:12px 0 10px}
.tlc ul{list-style:none;display:flex;flex-direction:column;gap:7px}
.tlc li{font-size:.85rem;color:var(--grey);padding-left:16px;position:relative}
.tlc li:before{content:"";position:absolute;left:0;top:8px;width:7px;height:7px;border-radius:50%;background:var(--blue)}
.tl-hint{text-align:center;color:var(--grey);font-size:.82rem;margin-top:2px}

.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative;z-index:2}
.tm{text-align:center}
.tm .pic{width:170px;height:170px;border-radius:50%;margin:0 auto 14px;overflow:hidden;display:flex;align-items:flex-end;justify-content:center}
.tm .pic img{width:98%;height:auto;object-fit:contain;object-position:bottom}
.tm b{display:block;color:var(--navy);font-size:1rem}
.tm span{font-size:.83rem;color:var(--grey)}

.ally-chips{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:24px;position:relative;z-index:2}
.ally-chips span{background:#fff;border:1px solid var(--line);border-radius:50px;padding:12px 26px;font-weight:600;color:var(--navy)}

.who .ini{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.1rem;flex-shrink:0}

@media(max-width:900px){.team-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){
  .logo img{height:40px}
  .nav-right .btn-dona{font-size:.74rem;padding:7px 12px}
  .team-grid{grid-template-columns:1fr 1fr;gap:18px}
  .tm .pic{width:130px;height:130px}
  .tlc .node{flex-basis:260px}
}

/* ===== Carrusel de aliados ===== */
@keyframes allyScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ally-track-wrap{overflow:hidden;margin-top:26px;position:relative;z-index:2;-webkit-mask-image:linear-gradient(to right,transparent 0%,#000 8%,#000 92%,transparent 100%);mask-image:linear-gradient(to right,transparent 0%,#000 8%,#000 92%,transparent 100%)}
.ally-track{display:flex;align-items:center;gap:40px;width:max-content;animation:allyScroll 34s linear infinite;will-change:transform}
.ally-track:hover{animation-play-state:paused}
.ally-track img{height:52px;width:120px;object-fit:contain;opacity:.7;transition:opacity .25s,transform .25s;flex:0 0 auto}
.ally-track img:hover{opacity:1;transform:scale(1.07)}
@media(max-width:600px){.ally-track{gap:28px}.ally-track img{height:44px;width:96px}}
