/* ============================================================
   AISA GROUP — Páginas interiores (pages.css)
   Estilos específicos de página. Complementa styles.css.
   Reutiliza las variables :root globales (--ink, --paper, etc.).
   ============================================================ */

/* ---------- Page hero (sin imagen, fondo tinta) ---------- */
.page-hero{
  background:var(--ink); color:var(--white); overflow:hidden;
  padding:clamp(128px,18vh,200px) 0 clamp(56px,9vh,110px);
  position:relative;
}
.page-hero::after{
  content:''; position:absolute; inset:0; z-index:0; opacity:.06; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.page-hero::before{
  content:''; position:absolute; z-index:0; right:-10%; top:50%; transform:translateY(-50%);
  width:min(620px,60vw); aspect-ratio:1; pointer-events:none; opacity:.10;
  background:url("aisa-mark.svg") no-repeat center/contain;
}
@media(max-width:760px){ .page-hero::before{ right:-30%; opacity:.07; } }
.page-hero .wrap{ position:relative; z-index:1; }
.page-hero .eyebrow{ margin-bottom:30px; }
.page-hero .eyebrow .num{ color:var(--gray-400); }
.page-hero .eyebrow .over{ color:var(--gray-400); }
.page-hero .eyebrow .ln{ background:var(--line-inv); }
.page-hero__title{
  font-family:var(--display); font-weight:500;
  font-size:clamp(44px,9vw,140px); line-height:.92; letter-spacing:-0.02em;
  max-width:16ch; text-wrap:balance;
}
.page-hero__intro{
  font-family:var(--display); font-style:italic; font-size:clamp(20px,2.4vw,32px);
  line-height:1.3; max-width:40ch; margin-top:clamp(26px,4vh,46px);
  color:var(--gray-300);
  border-top:1px solid var(--line-inv); padding-top:26px; text-wrap:pretty;
}
.page-hero__stats{
  display:grid; grid-template-columns:repeat(2,1fr); gap:1px;
  background:var(--line-inv); border-top:1px solid var(--line-inv); border-bottom:1px solid var(--line-inv);
  margin-top:clamp(40px,6vh,70px);
}
@media(min-width:780px){ .page-hero__stats{ grid-template-columns:repeat(4,1fr); } }
.page-hero__stats .stat{ background:var(--ink); }

/* ---------- EQUIPO — filtro por área ---------- */
.team__filter{
  display:flex; flex-wrap:wrap; gap:10px;
  margin-top:clamp(28px,4vh,48px);
}
.tf{
  font-family:var(--util); font-size:13px; letter-spacing:.01em;
  padding:9px 16px; border-radius:999px; cursor:pointer;
  color:var(--gray-700); background:var(--paper);
  border:1px solid var(--line-strong);
  transition:color .3s var(--ease), background .3s var(--ease), border-color .3s var(--ease), transform .3s var(--ease);
}
.tf:hover{ border-color:var(--accent); color:var(--ink); transform:translateY(-1px); }
.tf.is-active{ color:var(--white); background:var(--ink); border-color:var(--ink); }
.member.is-hidden{ display:none; }

/* ---------- EQUIPO — grid de miembros ---------- */
.team{ margin-top:clamp(28px,4vh,40px); }
.team__grid{
  display:grid; grid-template-columns:1fr; gap:1px;
  background:var(--line); border:1px solid var(--line);
  counter-reset:member;
}
@media(min-width:620px){ .team__grid{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:1040px){ .team__grid{ grid-template-columns:repeat(4,1fr); } }
.member{ position:relative; background:var(--paper); display:flex; flex-direction:column; counter-increment:member; transition:background .45s var(--ease); }
.member:hover{ background:var(--white); }
.member__photo{ position:relative; aspect-ratio:4/5; overflow:hidden; background:var(--charcoal); }
.member__photo img{ width:100%; height:100%; object-fit:cover; filter:grayscale(1) contrast(1.06) brightness(.96); transition:transform .9s var(--ease), filter .6s var(--ease); }
.member:hover .member__photo img{ transform:scale(1.06); filter:grayscale(0) contrast(1.04) brightness(1.02); }
.member.has-info{ cursor:pointer; }
.member__more{ margin-top:auto; padding-top:16px; font-family:var(--util); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--gray-500); display:inline-flex; align-items:center; gap:9px; opacity:0; transform:translateY(6px); transition:opacity .4s var(--ease), transform .4s var(--ease), color .4s var(--ease); }
.member__more .ar{ transition:transform .4s var(--ease); }
.member:hover .member__more{ opacity:1; transform:none; color:var(--ink); }
.member:hover .member__more .ar{ transform:translateX(5px); }
.member__photo::after{
  content:counter(member,decimal-leading-zero); position:absolute; top:14px; left:16px; z-index:2;
  font-family:var(--mono); font-size:11px; letter-spacing:.1em; color:var(--white);
  opacity:.85; mix-blend-mode:difference;
}
.member__photo::before{
  content:''; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(to top, rgba(11,11,12,.5), rgba(11,11,12,0) 45%);
  opacity:0; transition:opacity .5s var(--ease);
}
.member:hover .member__photo::before{ opacity:1; }
.member__body{ padding:clamp(22px,2.4vw,30px); display:flex; flex-direction:column; gap:8px; flex:1; }
.member__role{ font-family:var(--util); font-weight:600; font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--gray-500); display:flex; align-items:center; gap:10px; }
.member__role::before{ content:''; width:18px; height:1px; background:var(--gray-400); flex:none; }
.member__name{ font-family:var(--display); font-size:clamp(24px,2.4vw,30px); line-height:1.02; }
.member__bio{ font-family:var(--util); font-size:13px; line-height:1.58; color:var(--gray-700); margin-top:6px; }

/* shared closing CTA band */
.cta-band{ background:var(--paper-2); }
.cta-band__inner{ display:grid; gap:28px; max-width:64ch; }
.cta-band h2{ font-size:clamp(34px,5.6vw,76px); line-height:.98; text-wrap:balance; }
.cta-band p{ color:var(--gray-700); max-width:52ch; font-size:clamp(18px,2vw,22px); text-wrap:pretty; }

/* ---------- PRENSA — destacado + grid ---------- */
.press-featured{
  display:grid; grid-template-columns:1fr; gap:0;
  border:1px solid var(--line); margin-top:clamp(40px,6vh,70px);
  background:var(--paper); overflow:hidden; transition:background .4s var(--ease);
}
.press-featured:hover{ background:var(--white); }
@media(min-width:880px){ .press-featured{ grid-template-columns:1.05fr .95fr; } }
.press-featured__media{ position:relative; overflow:hidden; background:var(--charcoal); min-height:300px; }
.press-featured__media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:grayscale(1) contrast(1.06) brightness(.94); transition:transform .9s var(--ease), filter .7s var(--ease); }
.press-featured:hover .press-featured__media img{ transform:scale(1.04); filter:grayscale(0) contrast(1.02) brightness(1); }
.press-featured__body{ padding:clamp(34px,4vw,64px); display:flex; flex-direction:column; }
.press-meta{ display:flex; flex-wrap:wrap; gap:10px 18px; font-family:var(--util); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--gray-500); }
.press-meta .outlet{ color:var(--ink); }
.press-featured__body h3{ font-size:clamp(30px,3.6vw,52px); line-height:1.02; margin:22px 0 16px; }
.press-featured__body p{ color:var(--gray-700); max-width:52ch; }
.press-featured__body .more{ margin-top:auto; padding-top:26px; font-family:var(--util); font-size:12px; letter-spacing:.1em; text-transform:uppercase; display:flex; gap:10px; align-items:center; }
.press-featured__body .more .ar{ transition:transform .4s var(--ease); }
.press-featured:hover .more .ar{ transform:translateX(8px); }

.press-grid{
  display:grid; grid-template-columns:1fr; gap:1px;
  background:var(--line); border:1px solid var(--line); border-top:0;
}
@media(min-width:680px){ .press-grid{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:1040px){ .press-grid{ grid-template-columns:repeat(3,1fr); } }
.press-card{ position:relative; background:var(--paper); padding:clamp(26px,3vw,38px); display:flex; flex-direction:column; min-height:300px; transition:background .45s var(--ease); overflow:hidden; }
.press-card::before{ content:''; position:absolute; left:0; top:0; bottom:0; width:2px; background:var(--ink); transform:scaleY(0); transform-origin:top; transition:transform .5s var(--ease); }
.press-card:hover{ background:var(--white); }
.press-card:hover::before{ transform:scaleY(1); }
.press-card h4{ font-size:clamp(22px,2.2vw,28px); line-height:1.06; margin:20px 0 14px; transition:transform .45s var(--ease); }
.press-card:hover h4{ transform:translateX(6px); }
.press-card p{ font-family:var(--util); font-size:13.5px; line-height:1.55; color:var(--gray-700); }
.press-card .more{ margin-top:auto; padding-top:22px; font-family:var(--util); font-size:11.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--gray-500); display:flex; align-items:center; justify-content:space-between; }
.press-card .more::after{ content:'→'; font-size:14px; opacity:0; transform:translateX(-8px); transition:opacity .4s var(--ease), transform .4s var(--ease); }
.press-card:hover .more::after{ opacity:1; transform:none; }
.press-card.has-info, .press-featured.has-info{ cursor:pointer; }

/* ── Noticias: tarjetas editoriales con imagen (rejilla rica) ─────── */
.press-card--img{ padding:0; background:var(--paper); border:1px solid rgba(11,11,12,.09); overflow:hidden; transition:box-shadow .55s var(--ease), transform .55s var(--ease), border-color .55s var(--ease); }
.press-card--img::before{ display:none; }
.press-card--img:hover{ transform:translateY(-5px); box-shadow:0 30px 60px -24px rgba(11,11,12,.26); border-color:rgba(11,11,12,.14); background:var(--paper); }
.press-card__media{ aspect-ratio:3/2; overflow:hidden; background:#ECEAE3; }
.press-card__media img{ width:100%; height:100%; object-fit:cover; transition:transform 1.2s var(--ease); }
.press-card--img:hover .press-card__media img{ transform:scale(1.06); }
.press-card__body{ display:flex; flex-direction:column; flex:1; }
.press-card--img .press-card__body{ padding:24px 26px 26px; }
.press-card__eyebrow{ display:flex; align-items:center; gap:11px; margin-bottom:14px; font-family:var(--util); font-size:10.5px; letter-spacing:.15em; text-transform:uppercase; }
.press-card__eyebrow .cat{ color:var(--accent); font-weight:600; }
.press-card__eyebrow .sep{ width:16px; height:1px; background:rgba(11,11,12,.22); }
.press-card__eyebrow .date{ color:var(--gray-500); }
.press-card--img h4{ font-size:clamp(20px,1.75vw,25px); line-height:1.1; margin:0 0 12px; }
.press-card--img:hover h4{ color:var(--accent); transform:none; }
.press-card--img p{ font-family:var(--util); font-size:13.5px; line-height:1.55; color:var(--gray-700); margin:0 0 20px; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.press-card--img .more{ margin-top:auto; font-family:var(--util); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink); display:inline-flex; align-items:center; gap:9px; opacity:.85; }
.press-card--img .more::after{ content:none; }
.press-card--img .more .ar{ transition:transform .4s var(--ease); }
.press-card--img:hover .more .ar{ transform:translateX(7px); }
.press-card--img:hover .more{ opacity:1; }

/* ── Noticias: ticker "En vivo" ─────────────────────────────────── */
.news-ticker{ display:flex; align-items:center; gap:18px; margin:6px 0 30px; padding:9px 8px 9px 16px; border:1px solid rgba(11,11,12,.1); border-radius:999px; background:rgba(252,251,249,.72); -webkit-backdrop-filter:blur(12px) saturate(1.4); backdrop-filter:blur(12px) saturate(1.4); box-shadow:0 10px 34px rgba(11,11,12,.06); overflow:hidden; }
.news-ticker__live{ display:inline-flex; align-items:center; gap:9px; flex-shrink:0; white-space:nowrap; padding-right:16px; border-right:1px solid rgba(11,11,12,.12); font-family:var(--util); font-size:10.5px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--ink); }
.news-ticker__dot{ width:8px; height:8px; border-radius:50%; background:#c0392b; animation:tickerPulse 1.8s infinite; }
.news-ticker__dot--ok{ background:var(--hub-accent,#3f8f86); animation-duration:2.6s; }
@keyframes tickerPulse{ 0%{ box-shadow:0 0 0 0 rgba(192,57,43,.45);} 70%{ box-shadow:0 0 0 7px rgba(192,57,43,0);} 100%{ box-shadow:0 0 0 0 rgba(192,57,43,0);} }
.news-ticker__viewport{ flex:1; min-width:0; display:flex; align-items:center; overflow:hidden; transform:translateZ(0); }
@media(hover:hover) and (pointer:fine){ .news-ticker__viewport{ -webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent); mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent); } }
.news-ticker__track{ display:inline-flex; align-items:center; gap:44px; white-space:nowrap; will-change:transform; animation:tickerScroll 40s linear infinite; }
@media(hover:hover) and (pointer:fine){ .news-ticker:hover .news-ticker__track{ animation-play-state:paused; } }
.news-ticker__track span{ font-family:var(--util); font-size:12.5px; color:var(--gray-700); display:inline-flex; align-items:center; gap:9px; }
.news-ticker__track .tk-dot{ color:var(--accent); font-size:14px; }
@keyframes tickerScroll{ from{ transform:translate3d(0,0,0);} to{ transform:translate3d(-50%,0,0);} }
.news-ticker__status{ display:none; flex-shrink:0; align-items:center; gap:8px; padding-left:16px; border-left:1px solid rgba(11,11,12,.12); font-family:var(--util); font-size:9.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--gray-500); }
@media(min-width:900px){ .news-ticker__status{ display:inline-flex; } }
@media(max-width:640px){
  .news-ticker{ gap:10px; padding:7px 6px 7px 12px; margin:4px 0 22px; }
  .news-ticker__live{ font-size:9px; letter-spacing:.12em; gap:6px; padding-right:10px; }
  .news-ticker__dot{ width:6px; height:6px; }
  .news-ticker__track{ gap:28px; animation-duration:30s; }
  .news-ticker__track span{ font-size:11.5px; }
}

/* ── Noticias: filtros por categoría ────────────────────────────── */
.news-filters{ display:flex; flex-wrap:wrap; gap:9px; margin:0 0 36px; }
.news-filters__chip{ font-family:var(--util); font-size:11px; letter-spacing:.08em; text-transform:uppercase; padding:9px 16px; border:1px solid rgba(11,11,12,.16); border-radius:999px; background:transparent; color:var(--gray-700); cursor:pointer; transition:background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease); }
.news-filters__chip:hover{ border-color:var(--ink); color:var(--ink); }
.news-filters__chip.is-active{ background:var(--ink); color:var(--paper); border-color:var(--ink); }

/* ---------- CARRERAS — beneficios / proceso / vacantes ---------- */
.benefits{
  display:grid; grid-template-columns:1fr; gap:1px;
  background:var(--line); border:1px solid var(--line); margin-top:clamp(36px,5vh,60px);
}
@media(min-width:680px){ .benefits{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:1040px){ .benefits{ grid-template-columns:repeat(4,1fr); } }
.benefit{ background:var(--paper); padding:clamp(28px,3vw,40px); display:flex; flex-direction:column; gap:14px; min-height:220px; }
.benefit .bn{ font-family:var(--mono); font-size:12px; color:var(--gray-400); }
.benefit h4{ font-size:clamp(23px,2.4vw,30px); }
.benefit p{ font-family:var(--util); font-size:13.5px; line-height:1.55; color:var(--gray-700); margin-top:auto; }

.steps{ margin-top:clamp(36px,5vh,60px); border-top:1px solid var(--line); }
.step{ display:grid; grid-template-columns:1fr; gap:8px; padding:clamp(26px,3.4vw,44px) 0; border-bottom:1px solid var(--line); align-items:start; }
@media(min-width:760px){ .step{ grid-template-columns:120px 200px 1fr; gap:48px; align-items:baseline; } }
.step__num{ font-family:var(--display); font-weight:500; font-size:clamp(34px,4vw,58px); line-height:1; color:var(--ink); }
.step__name{ font-family:var(--util); font-weight:600; font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:var(--gray-500); }
.step p{ color:var(--gray-700); max-width:54ch; font-size:clamp(17px,1.8vw,21px); line-height:1.45; }

.roles{ margin-top:clamp(36px,5vh,60px); border-top:1px solid var(--line); }
.role{
  position:relative; display:grid; grid-template-columns:1fr; gap:14px;
  padding:clamp(24px,3vw,38px) 0; border-bottom:1px solid var(--line);
  align-items:center; transition:padding-left .45s var(--ease), background .45s var(--ease);
}
.role::before{ content:''; position:absolute; left:0; top:0; bottom:0; width:0; background:var(--ink); transition:width .45s var(--ease); }
.role:hover{ padding-left:24px; }
.role:hover::before{ width:3px; }
@media(min-width:820px){ .role{ grid-template-columns:1.4fr 1fr 1fr auto; gap:40px; } }
.role__title{ font-family:var(--display); font-size:clamp(26px,2.8vw,40px); line-height:1.02; transition:transform .45s var(--ease); }
.role__meta{ font-family:var(--util); font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--gray-500); }
.role__meta b{ display:block; font-weight:600; color:var(--ink); letter-spacing:.1em; font-size:11px; margin-bottom:4px; }
.role__cta{ justify-self:start; display:flex; flex-direction:column; align-items:flex-start; gap:12px; }
@media(min-width:820px){ .role__cta{ justify-self:end; align-items:flex-end; } }
.role__open{ font-family:var(--util); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--gray-500); display:inline-flex; align-items:center; gap:8px; opacity:0; transform:translateY(4px); transition:opacity .4s var(--ease), transform .4s var(--ease), color .4s var(--ease); }
.role__open .ar{ transition:transform .4s var(--ease); }
.role:hover .role__open{ opacity:1; transform:none; color:var(--ink); }
.role:hover .role__open .ar{ transform:translateX(5px); }

/* ---------- VACANTES — estado vacío ---------- */
.jobs-empty{ margin-top:clamp(36px,5vh,60px); border-top:1px solid var(--line); padding:clamp(40px,7vh,80px) 0 clamp(20px,4vh,40px); max-width:680px; }
.jobs-empty__lead{ font-family:var(--display,'Cormorant Garamond',Georgia,serif); font-size:clamp(26px,3.4vw,38px); line-height:1.12; color:var(--ink); margin:0 0 16px; }
.jobs-empty__sub{ font-size:clamp(16px,1.5vw,18px); line-height:1.65; color:var(--gray-700); margin:0 0 30px; }
.jobs-empty__cta{ display:inline-flex; align-items:center; gap:10px; }
.jobs-empty__cta .ar{ transition:transform .3s var(--ease); }
.jobs-empty__cta:hover .ar{ transform:translateX(5px); }

/* ---------- LEGAL — columna de lectura ---------- */
.legal{ background:var(--paper); }
.legal__wrap{ max-width:760px; margin:0 auto; padding:0 var(--mx); }
.legal__updated{ font-family:var(--util); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--gray-500); margin:18px 0 0; }
.legal__body{ margin-top:clamp(34px,5vh,58px); border-top:1px solid var(--line); padding-top:clamp(30px,4vh,50px); }
.legal__body p{ color:var(--gray-700); font-size:18px; line-height:1.7; margin-bottom:20px; }
.legal__body h3{ font-family:var(--display); font-size:clamp(24px,2.6vw,34px); line-height:1.1; margin:42px 0 16px; }
.legal__body ul{ list-style:none; margin:0 0 22px; padding:0; }
.legal__body li{ position:relative; color:var(--gray-700); font-size:18px; line-height:1.6; padding-left:26px; margin-bottom:12px; }
.legal__body li::before{ content:''; position:absolute; left:0; top:.72em; width:10px; height:1px; background:var(--gray-400); }
.legal__body strong{ color:var(--ink); font-weight:600; }
.legal__body em{ color:var(--gray-500); }
.legal__body a{ border-bottom:1px solid var(--line-strong); transition:border-color .3s var(--ease); }
.legal__body a:hover{ border-color:var(--ink); }

/* ============================================================
   SOSTENIBILIDAD — Ejes ESG (acordeón), Impacto, Simulador, Certs
   ============================================================ */

/* --- Impacto: variante de 3 columnas --- */
@media(min-width:780px){ .stat-row--3{ grid-template-columns:repeat(3,1fr); } }
.stat .count{ font-variant-numeric:tabular-nums; }

/* --- Ejes ESG: acordeón interactivo --- */
.esg{ margin-top:clamp(36px,5vh,60px); border-top:1px solid var(--line); }
.esg__item{ border-bottom:1px solid var(--line); }
.esg__head{ width:100%; display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:22px; padding:clamp(22px,3vw,34px) 0; background:none; border:0; cursor:pointer; text-align:left; transition:padding-left .45s var(--ease); }
.esg__head:hover{ padding-left:14px; }
.esg__num{ font-family:var(--mono); font-size:12px; letter-spacing:.04em; color:var(--gray-400); transition:color .4s var(--ease); }
.esg__title{ font-family:var(--display); font-weight:400; font-size:clamp(26px,3.4vw,46px); line-height:1.02; color:var(--ink); transition:color .4s var(--ease); }
.esg__ic{ position:relative; width:18px; height:18px; flex:none; }
.esg__ic::before, .esg__ic::after{ content:''; position:absolute; background:var(--gray-500); transition:transform .4s var(--ease), background .4s var(--ease); }
.esg__ic::before{ left:0; top:50%; width:18px; height:1.5px; transform:translateY(-50%); }
.esg__ic::after{ left:50%; top:0; width:1.5px; height:18px; transform:translateX(-50%); }
.esg__item.is-open .esg__ic::after{ transform:translateX(-50%) scaleY(0); }
.esg__item.is-open .esg__num{ color:var(--accent); }
.esg__item.is-open .esg__title{ color:var(--accent); }
.esg__item.is-open .esg__ic::before{ background:var(--accent); }
.esg__panel{ max-height:0; overflow:hidden; transition:max-height .5s var(--ease), opacity .4s var(--ease); opacity:0; }
.esg__item.is-open .esg__panel{ max-height:340px; opacity:1; }
.esg__panel p{ font-family:var(--util); font-size:clamp(15px,1.7vw,18px); line-height:1.6; color:var(--gray-700); max-width:62ch; padding:0 0 clamp(24px,3vw,34px) 40px; margin:0; }
@media(max-width:600px){ .esg__panel p{ padding-left:0; } .esg__head{ gap:16px; } }

/* --- Simulador de impacto energético (glass claro) --- */
.sim{ margin-top:clamp(36px,5vh,60px); }
.sim__panel{ display:grid; gap:1px; background:var(--line); border:1px solid var(--line); border-radius:22px; overflow:hidden; }
@media(min-width:900px){ .sim__panel{ grid-template-columns:5fr 7fr; } }
.sim__controls{ background:var(--paper); padding:clamp(28px,3.2vw,44px); display:flex; flex-direction:column; }
.sim__lbl{ font-family:var(--util); font-weight:600; font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--gray-500); margin-bottom:14px; }
.sim__scenarios{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:26px; }
.sim__sc{ flex:1; min-width:130px; padding:12px 14px; border:1px solid var(--line-strong); background:var(--paper-2); border-radius:11px; font-family:var(--util); font-weight:600; font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--gray-700); cursor:pointer; transition:background .35s var(--ease), color .35s var(--ease), border-color .35s var(--ease); }
.sim__sc:hover{ border-color:var(--ink); color:var(--ink); }
.sim__sc.is-active{ background:var(--ink); color:var(--white); border-color:var(--ink); }
.sim__desc{ background:var(--paper-2); border:1px solid var(--line); border-radius:14px; padding:20px 22px; margin-bottom:28px; min-height:150px; }
.sim__desc h4{ font-family:var(--display); font-size:clamp(20px,2.2vw,26px); line-height:1.05; margin:0 0 6px; }
.sim__loc{ display:block; font-family:var(--util); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--accent); margin-bottom:12px; }
.sim__desc p{ font-family:var(--util); font-size:13.5px; line-height:1.55; color:var(--gray-700); margin:0; }
.sim__range{ -webkit-appearance:none; appearance:none; width:100%; height:3px; background:var(--line-strong); border-radius:3px; outline:none; cursor:pointer; margin:4px 0 0; }
.sim__range::-webkit-slider-thumb{ -webkit-appearance:none; appearance:none; width:22px; height:22px; border-radius:50%; background:var(--accent); border:3px solid var(--paper); box-shadow:0 1px 8px rgba(0,0,0,.18); cursor:pointer; transition:transform .2s var(--ease); }
.sim__range::-webkit-slider-thumb:hover{ transform:scale(1.12); }
.sim__range::-moz-range-thumb{ width:22px; height:22px; border-radius:50%; background:var(--accent); border:3px solid var(--paper); cursor:pointer; }
.sim__mw{ margin-top:18px; text-align:right; font-family:var(--display); font-weight:500; font-size:clamp(34px,4vw,52px); line-height:1; color:var(--accent); }
.sim__mw i{ font-family:var(--util); font-style:normal; font-size:.32em; font-weight:600; letter-spacing:.04em; color:var(--gray-500); margin-left:4px; }
.sim__out{ background:var(--paper); display:flex; flex-direction:column; }
/* --- Escena animada: sol + bosque --- */
.sim__viz{ position:relative; height:132px; overflow:hidden; background:linear-gradient(180deg,#fbf6ec 0%, #f7f1e6 42%, var(--paper) 100%); border-bottom:1px solid var(--line); }
.sim__sun{ position:absolute; top:20px; right:30px; width:34px; height:34px; border-radius:50%; background:radial-gradient(circle at 38% 36%, #F2D79A, var(--accent) 78%); opacity:calc(.42 + .58*var(--lit,.05)); transform:scale(calc(.82 + .26*var(--lit,.05))); box-shadow:0 0 calc(10px + 34px*var(--lit,.05)) rgba(176,141,87,calc(.25 + .45*var(--lit,.05))); transition:opacity .55s var(--ease), transform .55s var(--ease), box-shadow .55s var(--ease); }
.sim__sun::after{ content:''; position:absolute; inset:-12px; border-radius:50%; background:radial-gradient(circle, rgba(176,141,87,.28), transparent 62%); animation:simSun 7s ease-in-out infinite; }
@keyframes simSun{ 0%,100%{ transform:scale(1); opacity:.7; } 50%{ transform:scale(1.18); opacity:1; } }
.sim__ground{ position:absolute; left:0; right:0; bottom:0; height:14px; background:linear-gradient(180deg, rgba(176,141,87,.10), rgba(0,0,0,.04)); border-top:1px solid var(--line); }
.sim__forest{ position:absolute; left:0; right:0; bottom:13px; height:96px; display:flex; align-items:flex-end; justify-content:space-between; gap:2px; padding:0 clamp(16px,3vw,30px); }
.tree{ flex:1 1 0; display:flex; align-items:flex-end; justify-content:center; transform:translateY(8px) scale(.5); opacity:.22; transform-origin:bottom center; transition:transform .55s var(--ease), opacity .55s var(--ease); transition-delay:calc(var(--i,0)*16ms); }
.tree.is-on{ transform:translateY(0) scale(1); opacity:1; }
.tree svg{ width:clamp(11px,1.5vw,18px); height:auto; display:block; }
.tree .tree__leaf{ fill:var(--line-strong); transition:fill .55s var(--ease); transition-delay:calc(var(--i,0)*16ms); }
.tree.is-on .tree__leaf{ fill:var(--accent); }
.tree .tree__trunk{ fill:var(--gray-400); transition:fill .55s var(--ease); }
.tree.is-on .tree__trunk{ fill:#7a5a32; }
/* --- Métricas --- */
.sim__grid{ flex:1; display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line); }
.sim__metric{ position:relative; background:var(--paper); padding:clamp(20px,2.5vw,32px); display:flex; flex-direction:column; gap:12px; min-height:120px; transition:background .35s var(--ease); }
.sim__metric:hover{ background:#fbf8f2; }
.sim__mlbl{ display:flex; align-items:center; gap:8px; font-family:var(--util); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--gray-700); }
.sim__ic{ flex:none; color:var(--accent); }
.sim__mval{ margin-top:auto; font-family:var(--display); font-weight:500; font-size:clamp(30px,3.6vw,50px); line-height:1; color:var(--ink); font-variant-numeric:tabular-nums; }
.sim__mval i{ font-family:var(--util); font-style:normal; font-size:.3em; font-weight:600; letter-spacing:.03em; color:var(--accent); }
.sim__note{ margin-top:18px; font-family:var(--util); font-size:12px; color:var(--gray-500); display:flex; align-items:center; gap:9px; }
.sim__note::before{ content:''; width:16px; height:1px; background:var(--gray-400); flex:none; }
@media (prefers-reduced-motion:reduce){ .sim__sun::after{ animation:none; } .tree{ transition:none; } }

/* ===== Apply modal — file dropzone ===== */
.filedrop-field i{ font-style:normal; color:var(--gray-500); font-weight:400; }
.filedrop{ position:relative; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; text-align:center; padding:26px 20px; border:1.5px dashed var(--line-strong); border-radius:14px; background:var(--paper); color:var(--gray-700); cursor:pointer; transition:border-color .3s var(--ease), background .3s var(--ease), color .3s var(--ease); }
.filedrop:hover{ border-color:var(--accent); color:var(--ink); background:#fbf8f2; }
.filedrop.is-drag{ border-color:var(--accent); background:var(--accent-soft); color:var(--ink); }
.filedrop input[type=file]{ position:absolute; inset:0; width:100%; height:100%; opacity:0; cursor:pointer; }
.filedrop__ic{ color:var(--accent); }
.filedrop__txt{ font-family:var(--util); font-size:13px; line-height:1.4; }
.filedrop__txt b{ font-weight:600; color:var(--ink); }
.filelist{ list-style:none; margin:12px 0 0; padding:0; display:flex; flex-direction:column; gap:8px; }
.filelist__item{ display:flex; align-items:center; gap:10px; padding:10px 12px; background:var(--paper-2); border:1px solid var(--line); border-radius:10px; animation:fileIn .35s var(--ease) both; }
.filelist__item svg{ color:var(--accent); flex:none; }
.filelist__name{ flex:1; min-width:0; font-family:var(--util); font-size:12.5px; color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.filelist__size{ font-family:var(--mono,var(--util)); font-size:11px; color:var(--gray-500); flex:none; }
.filelist__x{ flex:none; width:22px; height:22px; border:none; background:transparent; color:var(--gray-500); font-size:13px; cursor:pointer; border-radius:50%; transition:background .25s var(--ease), color .25s var(--ease); }
.filelist__x:hover{ background:var(--line); color:var(--ink); }
@keyframes fileIn{ from{ opacity:0; transform:translateY(6px); } to{ opacity:1; transform:none; } }

/* --- Certificaciones: marquee monocromo --- */
.certs{ background:var(--paper-2); border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:clamp(34px,4vw,52px) 0; overflow:hidden; }
.certs__cap{ display:block; text-align:center; font-family:var(--util); font-weight:600; font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--gray-500); margin-bottom:26px; padding:0 var(--mx); }
.certs__viewport{ overflow:hidden; transform:translateZ(0); }
@media(hover:hover) and (pointer:fine){ .certs__viewport{ -webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent); mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent); } }
.certs__track{ display:inline-flex; align-items:center; white-space:nowrap; gap:36px; }
@media(prefers-reduced-motion:no-preference){ .certs__track{ animation:certsScroll 32s linear infinite; } }
@keyframes certsScroll{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
.certs__item{ font-family:var(--display); font-weight:400; font-size:clamp(24px,3vw,40px); color:var(--ink); opacity:.55; transition:opacity .4s var(--ease); }
.certs__item:hover{ opacity:1; }
.certs__sep{ color:var(--accent); font-size:24px; }

/* ---------- Consultas de prensa / Media inquiries ---------- */
.press-cta-wrap{ background:var(--paper); padding:clamp(16px,3vh,36px) 0 clamp(72px,12vh,140px); }
.press-cta{ position:relative; overflow:hidden; background:var(--ink); color:var(--paper); border-radius:18px; padding:clamp(50px,8.5vh,98px) clamp(26px,6vw,90px); text-align:center; box-shadow:0 50px 95px -52px rgba(11,11,12,.55); }
.press-cta__glow{ position:absolute; top:-46%; left:50%; transform:translateX(-50%); width:82%; height:128%; background:radial-gradient(circle, rgba(176,141,87,.24), transparent 62%); pointer-events:none; }
.press-cta__inner{ position:relative; max-width:680px; margin:0 auto; }
.press-cta__eyebrow{ display:inline-block; font-family:var(--util); font-size:11.5px; letter-spacing:.24em; text-transform:uppercase; color:var(--accent); margin-bottom:clamp(16px,3vh,26px); }
.press-cta__title{ font-family:var(--display); font-weight:500; font-size:clamp(32px,4.6vw,60px); line-height:1.05; letter-spacing:-.015em; color:var(--paper); margin:0; text-wrap:balance; }
.press-cta__title em{ font-style:italic; color:var(--accent); }
.press-cta__sub{ max-width:520px; margin:clamp(18px,3vh,26px) auto 0; font-family:var(--body); font-size:clamp(16px,1.4vw,18px); line-height:1.65; color:rgba(252,251,249,.62); }
.press-cta__mail{ display:inline-flex; align-items:center; gap:14px; margin-top:clamp(28px,5vh,44px); padding:14px 16px 14px 26px; border:1px solid rgba(252,251,249,.22); border-radius:100px; font-family:var(--display); font-size:clamp(18px,2vw,25px); color:var(--paper); transition:background .4s var(--ease), color .4s var(--ease), border-color .4s var(--ease), transform .4s var(--ease); }
.press-cta__mail:hover{ background:var(--accent); border-color:var(--accent); color:var(--ink); transform:translateY(-2px); }
.press-cta__ic{ display:inline-flex; opacity:.85; }
.press-cta__ar{ display:inline-flex; width:34px; height:34px; align-items:center; justify-content:center; border-radius:50%; background:rgba(252,251,249,.1); transition:background .4s var(--ease), transform .4s var(--ease); }
.press-cta__mail:hover .press-cta__ar{ background:rgba(11,11,12,.16); transform:translateX(3px); }
@media(max-width:560px){ .press-cta__mail{ font-size:16px; padding:12px 12px 12px 18px; gap:9px; max-width:100%; } .press-cta__addr{ font-size:14px; } .press-cta__ar{ width:30px; height:30px; } }
