:root{
  --accent:#fff; --accent-2:#f6d36d; --dark:#1a202c;
  --text:#374151; --muted:#6b7280; --bg:#ffffff;
  --shadow:0 8px 24px rgba(0,0,0,.08); --radius:16px; --container:1180px;
}
*{box-sizing:border-box} html,body{margin:0;padding:0}
body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif;color:var(--text);background:#fafafa;line-height:1.6}
h1,h2,h3,h4{font-family:Montserrat,Inter,sans-serif;color:#1a202c}
h4 {font-size: 21px;     margin: 20px 0;}
a{color:inherit;text-decoration:none}
.container{max-width:var(--container);margin:0 auto;padding:0 20px}
.btn{display:inline-block;padding:12px 20px;border-radius:999px;background:#111;color:#fff;font-weight:600;letter-spacing:.3px;transition:all .2s ease;border:2px solid #111}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow)}
.btn.alt{background:var(--accent);border-color:var(--accent);color:#111}
.btn.ghost{background:transparent;color:#111;border-color:#111}

/* Header overlay + mobile nav */
header{position:fixed;top:0;left:0;right:0;height:76px;background:transparent;border-bottom:none;transition:all .25s ease;z-index:60}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand img{height:34px;vertical-align:middle;transition:height .25s ease}
nav ul{display:flex;gap:28px;list-style:none;margin:0;padding:0}
nav a{font-weight:600;color:#fff;opacity:.95; font-size: 14px} nav a:hover{opacity:1}
.nav-toggle{display:none}
.hamb{display:none;font-size:22px;padding:8px 12px;cursor:pointer}
@media (max-width:900px){
  .hamb{display:block}
  nav ul{position:fixed;inset:76px 0 auto 0;background:#1a202c;display:grid;gap:0;padding:16px;transform:translateY(-120%);transition:transform .25s ease}
  .nav-toggle:checked ~ nav ul{transform:translateY(0); padding: 50px}
  nav a{color:#fff}
}
header.scrolled{background:var(--dark);box-shadow:0 4px 18px rgba(0,0,0,.25)}
header.scrolled .nav{height:60px} header.scrolled .brand img{height:28px}

/* Hero slider */
.hero.slider{min-height:100vh;padding:0;position:relative;color:#fff}
.hero.slider .slides{position:relative;height:100vh;overflow:hidden}
.hero.slider .slide{position:absolute;inset:0;display:grid;place-items:center;visibility:hidden;opacity:0;transform:scale(1.02);transition:opacity .6s ease, transform 1.2s ease, visibility 0s linear .6s}
.hero.slider .slide.active{visibility:visible;opacity:1;transform:scale(1);transition-delay:0s}
.hero.slider .slide .bg{position:absolute;inset:0;width:100%;object-fit:cover}
.hero.slider .slide::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,32,44,.75),rgba(26,32,44,.6))}
.hero.slider .slide .inner{position:relative;z-index:1;text-align:center;padding:0 20px;max-width:980px}
.hero.slider .slide h1 {
    font-size: clamp(30px, 6vw, 50px);
    line-height: 1.5;
    color: #fff;
    margin: 0 0 14px;
    max-width: 70%;
}
.hero.slider .slide p{color:#e5e7eb;font-size:clamp(16px,2.2vw,21px);margin:0 0 24px}
.hero.slider .controls{position:absolute;left:0;right:0;bottom:18px;display:flex;align-items:center;justify-content:center;gap:14px;z-index:3}
.hero.slider .pp{position:static;width:44px;height:44px;border-radius:999px;border:0;background:rgba(0,0,0,.25);color:#fff;cursor:pointer;display:grid;place-items:center}
.hero.slider .dots{display:flex;gap:10px}
.hero.slider .dot {
    width: 12px;
    height: 17px;
    border-radius: 0 25% 0;
    background: rgba(255, 255, 255, .5);
    border: 2px solid rgba(255, 255, 255, .9);
    cursor: pointer;
    transition: transform .2s ease, background .2s ease;
}
.hero.slider .dot.active{background:var(--accent);transform:scale(1.05)}

/* Secciones */
section{padding: 3em 0}

section:not(.hero){scroll-margin-top:76px}
.split{display:grid;grid-template-columns:1fr 1fr;gap:28px;}
.kpi{background:var(--accent);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.counter{font-family:Montserrat,Inter,sans-serif;font-weight:800;font-size:34px;color:#111}
.muted{color:#6b7280}
.who{background:#fff;border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}

.features{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:40px 0}
.feature{background:#fff;border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);display:grid;grid-template-columns:48px 1fr;gap:16px;align-items:start}
.feature i{background:#111;color:#fff;width:48px;height:48px;display:grid;place-items:center;border-radius:14px}

.section-head{text-align:center;margin-bottom:26px}
.section-eyebrow{font-size:12px;letter-spacing:.25em;text-transform:uppercase;color:var(--muted)}
.section-title{font-size:26px;margin:6px 0 8px}
.section-sub{color:var(--muted);max-width:650px;margin:0 auto}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}
.card img{width:100%;height:190px;object-fit:cover}
.card-body{padding:18px}
.card h3{margin:0 0 8px;font-size:18px}
.card p{margin:0 0 10px;color:var(--muted)}
.meta{font-size:12px;color:#9ca3af}
.progress{height:8px;background:#f3f4f6;border-radius:999px;overflow:hidden;margin:12px 0}
.progress > span{display:block;height:100%;width:0;background:var(--accent);transition:width .6s ease}

.donors{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.donor{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;display:grid;grid-template-columns:56px 1fr;gap:14px;align-items:center}
.avatar{width:56px;height:56px;border-radius:50%;object-fit:cover}
.donor .name{font-weight:700}

.strip{background:var(--accent-2);padding:38px 0}
.strip .flex{display:grid;grid-template-columns:1.2fr 1fr;gap:28px;align-items:center}
.strip img{border-radius:var(--radius);width:100%;height:260px;object-fit:cover;box-shadow:var(--shadow)}
.strip .box{background:#fff;border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}

.news{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.news .item{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.news .item img{width:100%;height:160px;object-fit:cover}
.news .item .p{padding:14px}

/* CTA */
.cta{background:var(--accent-2);position:relative}
.cta:before{content:"";position:absolute;inset:0;background:url('../img/cta-bg.jpg') center/cover no-repeat;mix-blend:multiply;opacity:.45}
.cta .wrap{position:relative}
.cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:center}
.form{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}
.form .field{display:grid;gap:8px;margin:12px 0}
.form input,.form textarea{width:100%;padding:12px 14px;border:1px solid #e5e7eb;border-radius:12px;font:inherit}
.form textarea{min-height:108px;resize:vertical}

/* Footer */
footer{background:#0f172a;color:#cbd5e1}
.copyright{padding:18px 0;font-size:12px;color:#94a3b8;text-align:center}

/* Responsive */
@media (max-width:1100px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .news{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr}
  .strip .flex{grid-template-columns:1fr}
}
@media (max-width:780px){
  .features{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .donors{grid-template-columns:1fr 1fr}
  .news{grid-template-columns:1fr}
  .cta-grid{grid-template-columns:1fr}
  .hero{min-height:60vh}
}
/* === Typewriter  === */
.hero .inner p.typewriter {
  position: relative;

}

/* Cursor parpadeante al final del texto */
@keyframes caret-blink { 0%,40% {opacity:1} 50%,100% {opacity:0} }
.hero .inner p.typewriter::after {
  content: "";
  position: absolute;
  right: -2px;          
  top: 0.15em;
  width: 1px;
  height: 1em;
  background: currentColor;
  animation: caret-blink 1s steps(1) infinite;
}
.hero .inner p.typewriter.done::after { display: none; }


.hero .inner p b,
.hero .inner p strong {
  position: relative;
  display: inline-block;
  padding-bottom: 2px;
  overflow: visible;    
}


.hero .inner p .hand-underline {
  position: absolute;
  left: 0;
  bottom: -2px;       
  width: 100%;
  height: 12px;
  pointer-events: none;
  overflow: visible;
}
.hero.slider .slide .inner.typing-left { 
  text-align: left !important; 
}

.hero.slider .slide .inner { 
  text-align: left !important;
}


.hero .inner p.typewriter{
  position: relative;
  display: inline-block; 
}


@keyframes caret-blink { 0%,40% {opacity:1} 50%,100% {opacity:0} }
.hero .inner p.typewriter::after{
  content:"";
  position:absolute;
  right:-2px;          
  top:0.15em;
  width:1px;
  height:1em;
  background: currentColor;
  animation: caret-blink 1s steps(1) infinite;
}


.hero .inner p b,
.hero .inner p strong{
  position: relative;
  display: inline-block;
  padding-bottom: 2px;
  overflow: visible;  
}


.hero .inner p .hand-underline{
  position: absolute;
  left: 0;
  bottom: -2px;        
  width: 100%;
  height: 12px;
  pointer-events: none;
  overflow: visible;
}

.hero.slider .slide .inner{
  width: 100%;
  max-width: var(--container) !important; /* coincide con el header */
  margin: 0 auto;                         /* centra el bloque de 1180px */
  padding: 0 20px;                        /* mismo gutter que .container */
  text-align: left !important;            /* alinea h1, p y botones a la izq */
  display: grid;                          /* orden vertical prolijo */
  gap: 12px;
  justify-items: start;                   /* botones alineados a la izq */
}

.hero.slider .slide .inner{
  width: 100%;
  max-width: var(--container, 1180px); /* igual que tu header */
  margin: 0 auto;
  padding: 0 20px;                   
  text-align: left !important;
  display: grid;
  gap: 12px;
  justify-items: start;              
}


.hero .inner p.typewriter{
  position: relative;
  display: inline-block; 
}

@keyframes caret-blink { 0%,40% {opacity:1} 50%,100% {opacity:0} }
.hero .inner p.typewriter::after{
    content: "";
    position: absolute;
    right: -8px;
    top: 0.3em;
    width: 2px;
    height: 1em;
    background: currentColor;
    animation: caret-blink 1s steps(1) infinite;
}
}


.hero .inner p b,
.hero .inner p strong{
  position: relative;
  display: inline-block;
  padding-bottom: 2px;
  overflow: visible;
}
.hero .inner p .hand-underline{
  position: absolute;
  left: 0; bottom: -2px;
  width: 100%; height: 12px;
  pointer-events: none; overflow: visible;
}
p.typewriter {
    min-height: 40px;
}

.hero.slider .slide .inner .btn.alt.cta-delay{
  opacity: 0;
  transform: translateY(6px);
  pointer-events: none;
  transition: opacity .35s ease, transform .35s ease;
}
.hero.slider .slide .inner .btn.alt.cta-delay.show{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
h1.title{
    text-align: center;
    font-size: 3.5rem;
    font-weight: normal;
}

.hero.slider .pp{
  position: relative;
  --progress: 0;                    /* 0..1 */
  --loader-thickness: 3px;          /* grosor del borde/progreso */
  --progress-color: currentColor;   /* color del progreso (hereda del texto) */
  --track-color: rgba(255,255,255,.25); /* color de pista */
}


.hero.slider .pp::before,
.hero.slider .pp::after{
  content:"";
  position:absolute;
  inset: 0;                         /* ocupa todo el botón */
  border-radius: inherit;           /* respeta tu radius */
  pointer-events: none;
  padding: var(--loader-thickness);

  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
}

.hero.slider .pp::before{
  background: conic-gradient(var(--track-color) 1turn, var(--track-color) 0);
}

.hero.slider .pp::after{
  background: conic-gradient(var(--progress-color) calc(var(--progress)*1turn),
                             transparent 0);
  transition: background .08s linear; /* suaviza el avance */
}

.focus-grid{
  display: grid;
  gap: 24px;
  grid-template-columns: repeat(4, 1fr);   /* 4 en una fila (desktop) */
}


@media (max-width: 1024px){
  .focus-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px){
  .focus-grid{ grid-template-columns: 1fr; }
}


.focus-card{
  background: #fff;
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 16px;
  padding: 24px;
  box-shadow: 0 8px 24px rgba(0,0,0,.06);
}

.focus-card h2{
  font-size: clamp(18px, 2.4vw, 22px);
  line-height: 1.2;
  margin: 0 0 10px;
  font-weight: 700;
}
.focus-card p{
  margin: 0;
  color: #3b3b3b;
}


.reveal{
  opacity: 0;
  transform: translateY(28px);
  will-change: opacity, transform;
}
.reveal.in{
  opacity: 1;
  transform: translateY(0);
  transition: opacity .6s ease, transform .6s ease;
}



.metodo{padding:clamp(32px,5vw,72px) 0}
.metodo-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(220px,1fr));
  gap:clamp(12px,2vw,24px);
  align-items:stretch;
}
.metodo-card{
  background:var(--card-bg);
  border:1px solid var(--card-border);
  border-radius:14px;
  padding:20px;
  text-align:center;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:96px;
  box-shadow:0 2px 8px rgba(0,0,0,.04);
}
.metodo-card p {font-weight: normal}
.metodo-card h3{
  margin:0;
  font-size:clamp(16px,1.1vw,18px);
  font-weight:600;
}


@media (max-width: 1024px){
  .metodo-grid{grid-template-columns:repeat(2,minmax(220px,1fr))}
}
@media (max-width: 640px){
  .metodo-grid{grid-template-columns:1fr}
}



.metodo{
 
  --metodo-bg:url('metodo-bg.png');
  background-image:
    radial-gradient(120% 140% at 50% 20%,
      rgba(26,32,44,0) 0%,
      rgba(26,32,44,0.45) 38%,
      rgba(26,32,44,0.78) 68%,
      #1a202c 100%),
    var(--metodo-bg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  padding: clamp(40px, 6vw, 96px) 0;
}


.metodo-grid{ position: relative; z-index: 1; }



.metodo{
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background-color:#1a202c; /* fallback */
  padding: clamp(48px, 7vw, 110px) 0;
}
.metodo::before{
  content:"";
  position:absolute; inset:0;
  background-image:
    url('noise.png'),
    radial-gradient(120% 140% at 50% 30%,
      rgba(26,32,44,0) 0%,
      rgba(26,32,44,0.55) 30%,
      rgba(18,22,30,0.85) 58%,
      #1a202c 86%),
    radial-gradient(85% 65% at 0% 0%,
      rgba(0,0,0,.38) 0%,
      rgba(0,0,0,0) 65%),
    radial-gradient(85% 65% at 100% 100%,
      rgba(0,0,0,.38) 0%,
      rgba(0,0,0,0) 65%),
    linear-gradient(180deg,
      rgba(12,14,18,.7) 0%,
      rgba(15,18,24,.9) 55%,
      #1a202c 100%),
    url('metodo-bg.png');
  background-repeat: repeat, no-repeat, no-repeat, no-repeat, no-repeat, no-repeat;
  background-size: 256px 256px, cover, cover, cover, cover, cover;
  background-position: center;
  background-blend-mode: soft-light, multiply, multiply, multiply, multiply, normal;
  opacity:.98;
  z-index:0;
  pointer-events:none;
}

.metodo-grid{ position:relative; z-index:1; }



.metodo{ background-color:#121720; }
.metodo::before{
  background-image:
    radial-gradient(110% 120% at 50% 35%,
      rgba(255,255,255,0.18) 0%,
      rgba(255,255,255,0.06) 22%,
      rgba(255,255,255,0.00) 46%),
    url('noise.png'),
    radial-gradient(120% 140% at 50% 30%,
      rgba(26,32,44,0.00) 0%,
      rgba(26,32,44,0.48) 34%,
      rgba(18,22,30,0.82) 60%,
      #1a202c 88%),
    radial-gradient(85% 65% at 0% 0%,
      rgba(0,0,0,.32) 0%,
      rgba(0,0,0,0) 60%),
    radial-gradient(85% 65% at 100% 100%,
      rgba(0,0,0,.32) 0%,
      rgba(0,0,0,0) 60%),
    linear-gradient(180deg,
      rgba(12,14,18,.64) 0%,
      rgba(15,18,24,.86) 55%,
      #1a202c 100%),
    url('metodo-bg.png');
  background-repeat: no-repeat, repeat, no-repeat, no-repeat, no-repeat, no-repeat, no-repeat;
  background-size: cover, 256px 256px, cover, cover, cover, cover, cover;
  background-position: center;
  background-blend-mode: screen, soft-light, multiply, multiply, multiply, multiply, normal;
  opacity: .98;
}



.metodo{
  background:#1a202c !important;
  position: relative;
  isolation: isolate;
  overflow: hidden;
  padding: clamp(48px, 7vw, 110px) 0;
}
.metodo::before{
  content:"";
  position:absolute; inset:0;
  background-image: url('noise.png');
  background-repeat: repeat;
  background-size: 256px 256px;
  background-position: center;

  opacity: 1;
  z-index:0;
  pointer-events:none;
}
.metodo-grid{ position:relative; z-index:1; }



#metodo .metodo-card{
  box-shadow: none !important;
  transition: box-shadow .25s ease-in;
}
#metodo .metodo-card:hover,
#metodo .metodo-card:focus-within{

  box-shadow: 0 2px 10px rgba(0,0,0,1);
}



#metodo .metodo-card{
  box-shadow: none; 
  transition: box-shadow .25s ease-in;
  will-change: box-shadow;
}
#metodo .metodo-card:hover,
#metodo .metodo-card:focus-visible,
#metodo .metodo-card:focus-within{
  box-shadow: 0 2px 10px rgba(0,0,0,1) !important;
}
#metodo h1.title, #metodo h3, #metodo p { color: #fff; }




#metodo{ background:#1a202c; position:relative; isolation:isolate; overflow:hidden; }
#metodo::before{
  content:""; position:absolute; inset:0;

  background-repeat:repeat;
  background-size:256px 256px;
  pointer-events:none; z-index:0; opacity:1;
}
#metodo .metodo-grid{ position:relative; z-index:1; }


#metodo .metodo-card{
  box-shadow:none; transition:box-shadow .25s ease-in;
}
#metodo .metodo-card:hover,
#metodo .metodo-card:focus-visible,
#metodo .metodo-card:focus-within{
  box-shadow:0 2px 10px rgba(0,0,0,1);
}


#metodo .title{
  margin:0 0 clamp(20px,3vw,36px);
  font-size: clamp(24px, 3.2vw, 40px);
  line-height:1.1;
}
#metodo .type-caret{
  display:inline-block;
  width:.55ch; height:1em;
  margin-left:2px; vertical-align:-.1em;
  border-right:2px solid currentColor;
  animation:caret-blink 1s steps(1) infinite;
}
#metodo .type-caret.done{ animation:none; border-right-color:transparent; }
@keyframes caret-blink { 0%, 49% { opacity: 1; } 50%, 100% { opacity: 0; } }
\n

#metodo .type-caret.hold{
  opacity: 0;
  animation: none;
  border-right-color: transparent;
}



#metodo .type-caret.auto-hide{
  animation-iteration-count: 5;
  animation-fill-mode: forwards; /* keeps final opacity:0 from keyframes */
}



#metodo .metodo-card{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:10px;
}
#metodo .metodo-card i.fa-solid{
  color:#fff; 
  font-size: clamp(28px, 2.6vw, 40px);
  line-height:1;
  margin-bottom: 4px;
  transition: transform .25s ease-in;
  transition: scale .25s ease-in;
}
#metodo .metodo-card:hover i.fa-solid,
#metodo .metodo-card:focus-within i.fa-solid{
  
  scale: 1.2;
}
#metodo .metodo-card h3{
  margin: 0;
}




#metodo{ background:#1a202c; position:relative; isolation:isolate; overflow:hidden; }
#metodo::before{
  content:""; position:absolute; inset:0;
  
  background-repeat:repeat;
  background-size:256px 256px;
  pointer-events:none; z-index:0; opacity:1;
}
#metodo .metodo-grid{ position:relative; z-index:1; }


#metodo .metodo-card{
  box-shadow:none; transition:box-shadow .25s ease-in;
}
#metodo .metodo-card:hover,
#metodo .metodo-card:focus-visible,
#metodo .metodo-card:focus-within{
  box-shadow:0 2px 10px rgba(0,0,0,1);
}


#metodo .title{
  margin:0 0 clamp(20px,3vw, 60px);
  font-size: 3.5rem;
  line-height:1.1;
}
#metodo .type-caret{
  display:inline-block;
  width:.55ch; height:1em;
  margin-left:2px; vertical-align:-.1em;
  border-right:2px solid currentColor;
  animation:caret-blink 1s steps(1) infinite;
}
#metodo .type-caret.done{ animation:none; border-right-color:transparent; }
@keyframes caret-blink { 0%, 49% { opacity: 1; } 50%, 100% { opacity: 0; } }
\n

#metodo .type-caret.hold{
  opacity: 0;
  animation: none;
  border-right-color: transparent;
}



#metodo .type-caret.auto-hide{
  animation-iteration-count: 5;
  animation-fill-mode: forwards; 
}



#metodo .metodo-card{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:10px;
}
#metodo .metodo-card i.fa-solid{
  color:#fff;
  font-size: clamp(28px, 2.6vw, 40px);
  line-height:1;
  margin-bottom: 4px;
  transition: transform .25s ease-in;
  transition: scale .25s ease-in;
}
#metodo .metodo-card:hover i.fa-solid,
#metodo .metodo-card:focus-within i.fa-solid{
  transform: translateY(-1px);
  transform: scale(1.2);
}
#metodo .metodo-card h3{
  margin: 0;
}



#trusted-logos{ padding: clamp(36px, 6vw, 72px) 0; }
#trusted-logos .title{ text-align:center; margin:0 0 clamp(16px,3vw,28px); }


#trusted-logos .trusted-shell{
  position:relative;
  max-width: var(--container);
  margin: 0 auto;
  overflow: hidden;
}


#trusted-logos .trusted-viewport{
  --navPad: 0px; /* 36px botón + ~20px aire */
  overflow: hidden;
  padding-inline: var(--navPad);
}


#trusted-logos .trusted-track{
  --gap: 24px;
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: calc((100% - (var(--gap) * 4)) / 5);
  gap: var(--gap);
  align-items: center;
  transform: translateX(0);
  transition: transform .4s ease;
  will-change: transform;
}

#trusted-logos .trusted-item{
  display:flex; align-items:center; justify-content:center;
  height:110px; padding:10px 16px; border-radius:12px;

}
#trusted-logos .trusted-item img{
  max-width:200px; max-height:80px; object-fit:contain;
  filter:none !important; opacity:1 !important; transition:none;
}
.container.values-grid h4 span {    line-height: normal;
    color: #8BBEB2;
    font-size: 44px;}


#trusted-logos .trusted-nav{
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    border-radius: 50%;
    border: 1px solid rgba(0, 0, 0, .1);
    background: #fff;
    display: flex
;
    align-items: center;
    justify-content: center;
    font-size: 15px;
    cursor: pointer;
    z-index: 3;
}
.trusted-viewport {

    margin: 0 auto;
    max-width: 95%;
}
#trusted-logos .trusted-nav.prev{ left:10px; }
#trusted-logos .trusted-nav.next{ right:10px; }


#trusted-logos .trusted-dots{ display:flex; gap:8px; justify-content:center; margin-top:16px; }
#trusted-logos .trusted-dots button{ width:8px; height:12px; border-radius:0 25% 0; border:none; background:#d1d5db; cursor:pointer; }
#trusted-logos .trusted-dots button[aria-current="true"]{ background:var(--dark); }

/* Responsive: 4/3/2 items visibles */
@media (max-width:1199.98px){ #trusted-logos .trusted-track{ grid-auto-columns: calc((100% - (var(--gap) * 3)) / 4); } }
@media (max-width:991.98px){  #trusted-logos .trusted-track{ grid-auto-columns: calc((100% - (var(--gap) * 2)) / 3); } }
@media (max-width:767.98px){
  #trusted-logos .trusted-track{ grid-auto-columns: calc((100% - var(--gap)) / 2); }
  #trusted-logos .trusted-nav{ display:none; } /* móvil: swipe */
}

/* ==== Footer (layout + redes) ==== */
.footer {
  padding: 36px 0;
  text-align: center;
  font-size: 14px;
margin: 4em 0 0}
.footer-grid {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 24px;
  align-items: start;
}
.footer-brand img {
  height: 30px;
  display: block;
}
.footer-contact address {
  margin: 0 0 6px;
  font-style: normal;
  line-height: 1.7;
  color: #cbd5e1;
}
.footer-contact a {
  color: #e5e7eb;
  text-decoration: underline;
}
.footer-social .social {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 999px;
  margin-right: 8px;
  background: #0b1221;
  color: #cbd5e1;
  border: 1px solid rgba(255, 255, 255, 0.08);
}
.footer-social .social:hover {
  background: #111827;
  color: #fff;
}


#trusted-logos .trusted-viewport {
  overflow: hidden;
}

#trusted-logos .trusted-nav[disabled] {
  opacity: .35;
  pointer-events: none;
}



.subhero {
  background: #1a202c;
  color: #fff;
  padding: clamp(72px, 12vw, 140px) 0 clamp(36px, 6vw, 64px) !important;
  position: relative;
  overflow: hidden;
}
.subhero .title {
  margin: 0;
  text-align: left;
  font-size: clamp(32px, 5vw, 56px);
  color: #fff;
}
.subhero .lead {
  color: #e5e7eb;
  max-width: 820px;
  margin-top: 10px;
  font-weight: 100;
}
.subhero b { font-weight:bold }

/* Valores */
.values-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 18px;
}
.value-card {
  background: var(--dark);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 16px;
  padding: 18px;
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
      display: initial;
  gap: 8px;
}
.value-card i { font-size: 22px; color: #fff; }
.value-card h3 { margin: 0; font-size: 16px; }
.value-card p { margin: 0; color: #ffffff; font-size: 14px; }
.value-card em { color: #fff; }
.value-card h4 {color: #fff;     height: 11vh;     font-size: 20px;}
/* Equipo */
.team-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
.team-card {
  background: #fff;
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 16px;
  box-shadow: 0 8px 24px rgba(0,0,0,.06);
  overflow: hidden;
  text-align: center;
  padding-bottom: 12px;
}
.team-card img {
  width: 100%;
  max-width: 300px;
  height: 300px;
  object-fit: cover;
  display: block;
  margin: 30px auto 0;
}
.team-card h4 { margin: 12px 0 0; }
.team-card p { margin: 2px 0 8px; color: #6b7280; }
.team-card .links a { color: #0a66c2; text-decoration: underline; font-size: 14px; }

/* Responsivo interiores */
@media (max-width: 1100px) { .values-grid { grid-template-columns: repeat(3,1fr); } }
@media (max-width: 700px)  { .values-grid { grid-template-columns: 1fr; } .team-grid { grid-template-columns: 1fr; } }
/* Icono + texto en links de LinkedIn (team) */
.team-card .links a{
  display:inline-flex; align-items:center; gap:8px; text-decoration: none;
}
subhero b { color: white}
.team-card .links a .fa-linkedin-in{ font-size:16px; line-height:1; }

.subhero{
  background-color:#1a202c;           
  position:relative; isolation:isolate; overflow:hidden;
}
.subhero::before{
  content:""; position:absolute; inset:0;
  background-image:url('noise.png');
  background-repeat:repeat;
  background-size:256px 256px;
  opacity:.9; pointer-events:none; z-index:0;
}
.subhero .container{ position:relative; z-index:1; }

/* Servicios */
.service-block { margin-top: 4em; margin-bottom: 48px;     text-align: justify; }
.service-title { text-align: center; align-items:center; gap:12px; margin: 45px 0 ; }
.service-title i { font-size: 22px; color:#1a202c; }
.service-text { }

.feature-wrap { margin-top: 18px; }
.feature-title { margin: 45px 0 ; text-align: center;}
.features-list { list-style: none; padding: 0; margin: 0; display:grid; gap:30px; }
.features-list li {
  background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:12px;
  padding:12px 14px; box-shadow:0 6px 16px rgba(0,0,0,.05); display:flex; gap:10px; align-items:flex-start;
}
.features-list i { color:#8BBEB2; margin-top:2px; }

.module-title { margin: 45px 0 ; text-align: center; }
.modules-grid { display:grid; grid-template-columns: repeat(4,1fr); gap:50px; color: white}
.module-card {
  background:#1a202c; border:1px solid rgba(0,0,0,.06); border-radius:14px; padding:16px;
  box-shadow:0 8px 22px rgba(0,0,0,.06); display:grid; gap:6px;
}
.module-card i { font-size:22px; color:#fff; }
.module-card h4 { color:#fff; }

.eval-grid { display:grid; grid-template-columns:1fr 1fr; gap:50px; }
.eval-card {
  background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:14px; padding:16px;
  box-shadow:0 8px 22px rgba(0,0,0,.06);
}
p.service-cta {
    text-align: center;
    margin: 50px 0;
}
.eval-card .checks{ list-style:none; padding:0; margin:8px 0 0; display:grid; gap:8px; }
.eval-card .checks li{ display:flex; gap:10px; align-items:flex-start; }
.eval-card .checks i{ color:#8BBEB2; margin-top:2px; }


.reveal{ opacity:0; transform: translateY(14px); transition: all .48s ease; }
.reveal.in{ opacity:1; transform:none; text-align:left; }

@media (max-width: 1100px){
  .modules-grid{ grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 700px){
  .modules-grid{ grid-template-columns: 1fr; }
  .eval-grid{ grid-template-columns: 1fr; }
}
.features-list{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px 24px;         
  align-items: start;
}

/* Mobile: una sola columna */
@media (max-width: 700px){
  .features-list{
    grid-template-columns: 1fr;
  }
}
  /* ===== Nuestra Experiencia ===== */


.experiencia-rubros { margin-top: 18px; }
.experiencia-rubros li { align-items: center; }


.accordion { margin-top: 16px; }
.accordion-item + .accordion-item { margin-top: 12px; }

.accordion-header{
  width:100%;
  display:flex; justify-content:space-between; align-items:center;
  padding:16px 18px;
  font-weight:700;
  border-radius:12px;
  background:#f6f7f9;           
  border:1px solid rgba(0,0,0,.06);
  transition: background .2s ease, border-color .2s ease;
}
.accordion-header[aria-expanded="true"]{
  background:#fff; border-color:rgba(0,0,0,.12);
}
.accordion-header .acc-icon{
  font-size:22px; line-height:1; width:24px; text-align:center;
}

.accordion-panel{ padding: 10px 6px 4px; }
.accordion-panel ul{ margin:0; padding:8px 12px 10px; }
.accordion-panel .cols-2{ columns:2; column-gap:28px; }
.accordion-panel li{ break-inside:avoid; margin:6px 0; }

@media (max-width:700px){
  .accordion-panel .cols-2{ columns:1; }
}




.experiencia-rubros { margin-top: 18px; }

/* Tabs */
.tabs {
  display: grid;
  grid-auto-flow: column;
  gap: 10px;
  align-items: center;
  justify-content: start;
  margin: 18px 0 14px;
}
.tab {
  position: relative;
  padding: 10px 14px;
  border-radius: 10px;
  background: #f6f7f9;
  border: 1px solid rgba(0,0,0,.06);
  font-weight: 700;
  line-height: 1.1;
  transition: background .2s ease, box-shadow .2s ease, border-color .2s ease, transform .04s ease;
  cursor: pointer;
}
.tab:hover { background: #fff; border-color: rgba(0,0,0,.12); }
.tab:active { transform: translateY(1px); }

.tab.is-active {
  background: #ffffff;
  border-color: rgba(0,0,0,.16);
  box-shadow: 0 8px 20px rgba(0,0,0,.06);
}

/* Panels */
.tab-panels {
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.06);
  background: #fff;
  padding: 16px 16px 6px;
}
.tab-panel[hidden] { display: none !important; }
.tab-panel.is-active { animation: panelIn .22s ease both; }
@keyframes panelIn { from {opacity:0; transform: translateY(6px);} to {opacity:1; transform:none;} }

/* Listas en 2 columnas */
.tab-panel .cols-2 {
  columns: 2;
  column-gap: 28px;
  margin: 0;
  padding: 0 6px 10px;
  list-style: none;
}
.tab-panel .cols-2 li {
  break-inside: avoid;
  margin: 6px 0;
  padding-left: 0;
}

/* Responsive */
@media (max-width: 960px){
  .tabs { grid-auto-flow: row; grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 700px){
  .tab-panel .cols-2 { columns: 1; }
}

/* ===== Nuestra Experiencia: Tabs + paneles ===== */
.tabs{
  display:flex; flex-wrap:wrap; gap:10px;
  margin: 18px 0 0;
}
.tab{
  appearance:none; border:none; cursor:pointer;
  padding:10px 14px; border-radius:5px 5px 0 0;
  background:#f6f7f9; border:1px solid rgba(0,0,0,.06);
  font-weight:700; line-height:1.1;
  transition: background .2s ease, border-color .2s ease, box-shadow .2s ease, transform .04s ease;
}
.tab:hover{ background:#fff; border-color:rgba(0,0,0,.12); }
.tab:active{ transform:translateY(1px); }
.tab.is-active{
  background:#fff; border-color:rgba(0,0,0,.16);
  box-shadow: var(--shadow);
}

/* Mini contador */
.tab .badge{
  display:inline-flex; align-items:center; justify-content:center;
  min-width: 22px; height: 22px; padding: 0 6px;
  margin-left: 8px;
  border-radius:999px; font-size:12px; font-weight:700;
  background:#111; color:#fff;
}

/* Panel contenedor */
.tab-panels{
  border-radius:14px; border:1px solid rgba(0,0,0,.06);
  background:#fff; padding:16px 16px 6px;
}
.tab-panel[hidden]{ display:none !important; }
.tab-panel.is-active{ animation: panelIn .22s ease both; }
@keyframes panelIn { from{opacity:0; transform:translateY(6px)} to{opacity:1; transform:none} }

/* Listas en 2 columnas (desktop) */
.tab-panel .cols-2{
  columns:2; column-gap:28px;
  margin:0; padding:0 6px 10px; list-style:none;
}
.tab-panel .cols-2 li{ break-inside:avoid; margin:6px 0; }

/* Responsive */
@media (max-width:960px){ .tabs{ gap:8px; } }
@media (max-width:700px){ .tab-panel .cols-2{ columns:1; } }


.experiencia-rubros { margin-top: 18px; }

/* ===== Tabs estilo barra (oscuro) ===== */
:root{
  --tabs-accent: var(--primary, #8BBEB2); 
  --tabs-dark: #0f0f10;
  --tabs-dark-2: #1b1c1e;
  --tabs-border: rgba(255,255,255,.12);
  --card-shadow: 0 10px 24px rgba(0,0,0,.12);
}


.tabs--bar{
  position: relative;
  display: flex; gap: 0; flex-wrap: nowrap;
 
  border: 1px solid var(--tabs-border);
  border-bottom: none;
  border-radius: 10px 10px 0 0;
  overflow: hidden;
}


.tabs--bar .tab{
  appearance: none; border: none; cursor: pointer;
  padding: 20px;
  font-weight: 700; color: #e8e9ea;
  background: var(--dark);
  border-right: 1px solid var(--tabs-border);
  transition: background .15s ease, color .15s ease;
  font-family: Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif;
  margin: 0 5px 0 0;
}
.tabs--bar .tab:last-child{ border-right: none; }
.tabs--bar .tab:hover{ background:#111214; }


.tabs--bar .tab.is-active{
  background: #ffffff;
  color: #111;
  position: relative;
}


/* mini contador */
.tabs--bar .tab .badge{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:20px; height:20px; padding:0 6px; margin-left:8px;
  border-radius:999px; font-size:12px; font-weight:700;
  background:#111; color:#fff;
}
.tabs--bar .tab.is-active .badge{ background: var(--tabs-accent); color:#fff; }


.tab-panels{
  background:#fff; border:1px solid rgba(0,0,0,.06);
  border-top: none;
  border-radius: 0 10px 10px 10px;
  padding: 3em;
  box-shadow: var(--card-shadow);
}
.tab-panel[hidden]{ display:none!important; }
.tab-panel.is-active{ animation: panelIn .18s ease both; }
@keyframes panelIn{ from{opacity:0; transform:translateY(6px)} to{opacity:1; transform:none} }

/* listas en 2 columnas dentro del panel */
.tab-panel .cols-2{
  columns: 2; column-gap: 28px;
  margin: 0; padding: 0 6px 10px; list-style: disc inside;
}
.tab-panel .cols-2 li{ break-inside: avoid; margin: 6px 0; }

/* responsive */
@media (max-width: 960px){
  .tabs--bar{ overflow-x: auto; border-radius: 10px 10px 0 0; }
  .tabs--bar .tab{ white-space: nowrap; }
}
@media (max-width: 700px){
  .tab-panel .cols-2{ columns: 1; }
}
/* === Experiencia: Rubros a 3 columnas (desktop) === */
.features-list.experiencia-rubros{
  grid-template-columns: repeat(3, minmax(0, 1fr));
}


@media (max-width: 900px){

  .tabs-experiencia.tabs--bar{
    display: block;
    border-radius: 10px 10px 0 0;
    overflow: hidden;
  }

  .tabs-experiencia.tabs--bar .tab{
    display: block;
    width: 100%;
    border-right: none;
    border-bottom: 1px solid var(--tabs-border);
    padding: 14px 16px;
    white-space: normal;           
    text-align: left;
    border-radius: 0;
  }
  .tabs-experiencia.tabs--bar .tab:last-child{ border-bottom:none; }


  .tabs-experiencia.tabs--bar .tab.is-active::before{
    content:"";
    position:absolute;
    left:0; top:0; bottom:0; width:4px;  
    background: var(--tabs-accent);
  }


  .tabs-experiencia.tabs--bar + .tab-panels{
    border-radius: 0 0 10px 10px;
    padding: 16px 14px 8px;
  }
}

/* Columnas de las listas dentro de cada tab (1 col en móvil) */
@media (max-width: 700px){
  .tab-panels .tab-panel .cols-2{ columns: 1; }
}

/* === Rubros atendidos: 3 cols desktop, 2 cols responsive === */
/* Desktop */
.features-list.experiencia-rubros{
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

/* ≤900px: 2 columnas */
@media (max-width: 900px){
  .features-list.experiencia-rubros{
    grid-template-columns: repeat(1, minmax(0, 1fr)) !important;
  }
}

/* ===== Menú responsive (hamburguesa) ===== */
@media (max-width: 900px){

  header .nav{ position: relative; z-index: 1001; }


  header .hamb{
    display: inline-flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    padding: 10px 12px;
    border-radius: 8px;
    user-select: none;
  }


  .nav-toggle{
    position: absolute;
    opacity: 0;
    pointer-events: none;
  }


  header nav{
    max-height: 0;
    overflow: hidden;
    transition: max-height .3s ease;
    background: #ffffff;          
    border: 1px solid rgba(0,0,0,.08);
    border-radius: 10px;
    margin-top: 10px;
  }


  .nav-toggle:checked ~ nav{
    max-height: 100%;               
  }


  header nav ul{
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 10px;
  }
  header nav a{
    display: block;
    padding: 12px 10px;
    border-radius: 8px;
  }
  header nav a:hover{
    background: rgba(0,0,0,.04);
  }


  .sticky-cta, .topbar, .cta-fixed{ z-index: 1000; }  /* si tienes esa clase */
}


@media (max-width: 900px){

  header .hamb{ position: relative; z-index: 1003; }


  header .nav { position: relative; z-index: 1001; } 
  header .nav + nav,
  header nav{
    position: fixed;
    inset: 0;               
    width: 100vw;
    height: 100vh;
    background: #ffffff;
    transform: translateY(-100%); 
    opacity: 0;
    pointer-events: none;
    transition: transform .32s ease, opacity .2s ease;
    margin: 0;
    border: 0;
    border-radius: 0;
    padding: 80px 20px 24px;  
    z-index: 1002;
    overflow: auto;          
  }

  /* Al activar el checkbox: mostrar overlay */
  .nav-toggle:checked ~ nav{
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
  }

  /* Lista vertical y táctil */
  header nav ul{
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 0;
    margin: 0;
  }
  header nav li{ list-style: none; }
  header nav a{
    display: block;
    padding: 14px 12px;
    border-radius: 10px;
  }
  header nav a:hover{ background: rgba(0,0,0,.05); }


  body:has(.nav-toggle:checked){ overflow: hidden; }
}

/* ===== Menú móvil fullscreen (overlay oscuro) ===== */
@media (max-width: 900px){

  header nav{
    position: fixed !important;
    inset: 0 !important;            
    width: 100vw;
    height: 100vh;                  
    height: 100dvh;                
    background: #1a202c;            
    color: #fff;
    margin: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    padding: 80px 20px 24px;       
    overflow: auto;                  
    transform: translateY(-100%);   
    opacity: 0;
    pointer-events: none;
    transition: transform .32s ease, opacity .2s ease;
    z-index: 9998;                   
  }


  .nav-toggle:checked ~ nav{
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
  }


  header nav ul{
    display: flex; flex-direction: column; gap: 10px;
    padding: 0; margin: 0;
  }
  header nav li{ list-style: none; }
  header nav a{
    display: block;
    color: #fff !important;
    padding: 14px 12px;
    border-radius: 10px;
  }
  header nav a:hover{ background: rgba(255,255,255,.08); }


  header .hamb{ position: relative; z-index: 9999; }


  body:has(.nav-toggle:checked){ overflow: hidden; }
}




@media (max-width: 900px){

  body .subhero{

    padding: calc(76px + 44px) 0 36px !important;
  }

  .subhero .title{
    font-size: clamp(28px, 7vw, 40px);
    line-height: 1.15;
    margin: 0 0 6px;
  }
  .subhero .lead{
    font-size: 15px;
  }
}


@media (max-width: 900px){
  section h1.title{
    font-size: clamp(22px, 7vw, 28px);
    line-height: 1.2;
    margin: 0 0 35px;
  }
  section {
    padding: 2em 0;
}
.container {
   
    padding: 0 35px;
}
}


@media (max-width: 900px){
  h1.title {
    max-width: 100%;
}
  .footer .footer-grid{
    display: grid;
    grid-template-columns: 1fr;     
    grid-auto-rows: auto;
    gap: 16px;
    text-align: center;
    justify-items: center;
  }


  .footer .footer-brand{
    order: 1;                      
    width: 100%;
    display: flex;
    justify-content: center;
  }
  .footer .footer-brand img{
    max-width: 200px;             
    height: auto;
  }


  .footer .footer-contact{
    order: 2;
    max-width: 520px;
  }
  .footer .footer-contact address{
    margin: 0 auto 10px;
    text-align: center;
    line-height: 1.5;
  }
  .footer .footer-contact a{ display: inline-block; }


  .footer .footer-social{
    order: 3;
    display: flex !important;
    gap: 10px;
    justify-content: center;
    align-items: center;
    position: static !important;  
    inset: auto !important;
    transform: none !important;
  }
  .footer .footer-social .social{
    width: 38px; height: 38px;
    display: inline-flex;
    align-items: center; justify-content: center;
    border-radius: 50%;
    background: rgba(255,255,255,.08);
    color: #fff;
  }
  .hero.slider .slide .bg {
    
    height: 100%;
}
.hero.slider .slide .inner {
   
    padding: 0 35px;
}
.hero.slider .slide h1 {

    max-width: 100%;
}
#trusted-logos .trusted-track {
    --gap: 0px;}
    .trusted-viewport {
  
    max-width: 100%;
}
#trusted-logos .title {

    padding: 0 35px;
}
ul.trusted-track {
    padding: 0;
}
#trusted-logos .trusted-item {

    padding: 10px 0px;

}
#trusted-logos {
    padding: clamp(36px, 6vw, 72px) 35px;
}
}


.footer .footer-grid{ row-gap: 18px; }
.footer .footer-social .social:hover{ background: rgba(255,255,255,.15); }


.hero .inner p.typewriter{
  position: relative;
  display: inline-block;     
  vertical-align: bottom;
}
.hero .inner p.typewriter::after{
  top: auto !important;      
  bottom: 0.05em !important; 
  height: 1em !important;    
  right: -2px;               
}


.hero .inner p.typewriter{
  display: inline;              
}

.hero .inner p.typewriter::after{
  content: "";
 
  position: static !important;
  top: auto !important;
  bottom: auto !important;
  right: auto !important;

  display: inline-block;
  width: 2px;
  height: 0.95em;               
  margin-left: 3px;              
  background: currentColor;      
  vertical-align: -0.08em;      
  animation: tw-blink 1s steps(1, end) infinite;
}

@keyframes tw-blink {
  0%, 49% { opacity: 1; }
  50%, 100% { opacity: 0; }
}


header nav a{
  font-weight: 400 !important;   
  color: #ababab;
}


header nav a:hover,
header nav a:focus{
  font-weight: 600;
}


header nav a.active,
header nav a[aria-current="page"]{
  font-weight: 900 !important;  
  color: #fff;
}

header nav a:hover {
    color: #fff;
}

/* ===== Necesitas apoyo: layout ===== */

/* Grid superior: 2 columnas (izq Hablemos / der Cómo trabajamos) */
.support-grid{
  display: grid;
  grid-template-columns: 1.25fr 1fr;
  gap: 24px;
  align-items: start;
  margin-bottom: 3em;
}
.support-grid .bullets{ margin: 8px 0 12px; padding-left: 18px; }
.support-grid .bullets li{ margin: 4px 0; }

/* Cards inferiores: mismo look de value-card, solo distribuimos */
.contact-cards{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
@media (max-width: 900px){
  .support-grid{
    grid-template-columns: 1fr;     /* apila en móvil */
    gap: 18px;
  }
  .contact-cards{
    grid-template-columns: 1fr;     /* 1 por fila en móvil */
  }
}

.contact-cards article.value-card.reveal.in {
    padding: 50px;
}
article.value-card.reveal.in h3 {
    color: white;
}
  .features-list.experiencia-rubros{list-style:none;margin:0;padding:0}
  .features-list.experiencia-rubros li{
    display:flex;align-items:center;gap:.5rem;line-height:1.3;min-height: 70px;
  }
  .features-list.experiencia-rubros .rubros-icon{
    width:28px;height:28px;flex:0 0 24px;object-fit:contain;
  }

  .ph-constel .node { cursor: grab; }
  .ph-constel .node.dragging { cursor: grabbing; }
  .ph-constel .node .cellular { will-change: transform; }

  .ph-constel .node.dragging .cellular { animation-play-state: paused; }
 
  .ph-constel { user-select: none; -webkit-user-select: none; -ms-user-select: none; }
    .ph-constel .node{ cursor: grab; touch-action: none; pointer-events: all; }
  .ph-constel .node.dragging{ cursor: grabbing; }
  .ph-constel .node .cellular{ will-change: transform; }
  .ph-constel .node.dragging .cellular{ animation-play-state: paused; }
  .ph-constel{ user-select: none; -webkit-user-select: none; -ms-user-select: none; }
    .ph-constel .node{ cursor: grab; touch-action: none; }
  .ph-constel .node.dragging{ cursor: grabbing; }

.ph-constel,
  .ph-constel svg,
  .ph-constel .node{
    touch-action: none;             
    -webkit-user-select: none;
    user-select: none;
  }
  .ph-constel .node { pointer-events: all; cursor: grab; }
  .ph-constel .node.dragging { cursor: grabbing; }
  .ph-constel .node text { pointer-events: none; } 


  @media (max-width: 640px){
    .ph-constel .frame{
      aspect-ratio: 1/1 !important            
    }
    .ph-constel svg{
      transform: scale(1.25);    
      transform-origin: center;
    }

    .ph-constel .node text{ font-size: 14px; }

    .ph-constel .spoke, .ph-constel .spark{ stroke-width:3; }
  }


  @media (min-width: 641px) and (max-width: 900px){
    .ph-constel .frame{ aspect-ratio: 4/3; }
    .ph-constel svg{ transform: scale(1.12); transform-origin: center; }
  }


  .ph-constel { overscroll-behavior: contain; }