/* ===== FONTS ===== */
@font-face { font-family:'Groza'; src:url('assets/fonts/Groza-Regular.ttf') format('truetype'); font-weight:400; }
@font-face { font-family:'Groza'; src:url('assets/fonts/Groza-SemiBold.ttf') format('truetype'); font-weight:600; }
@font-face { font-family:'Groza'; src:url('assets/fonts/Groza-Bold.ttf') format('truetype'); font-weight:700; }
@font-face { font-family:'Groza'; src:url('assets/fonts/Groza-ExtraBold.ttf') format('truetype'); font-weight:800; }
@font-face { font-family:'Geon'; src:url('assets/fonts/Geon-Light.otf') format('opentype'); font-weight:300; }
@font-face { font-family:'Geon'; src:url('assets/fonts/Geon-Regular.otf') format('opentype'); font-weight:400; }
@font-face { font-family:'Geon'; src:url('assets/fonts/Geon-Medium.otf') format('opentype'); font-weight:500; }
@font-face { font-family:'Geon'; src:url('assets/fonts/Geon-Bold.otf') format('opentype'); font-weight:700; }

/* ===== VARIABLES ===== */
:root {
  --dark:        #1A2533;
  --dark-deep:   #101820;
  --dark-mid:    #243040;
  --lime:        #C8D44E;
  --lime-hover:  #d4e054;
  --green:       #1D8549;
  --green-light: #83C59E;
  --orange:      #BA4C17;
  --stone:       #BAC1B8;
  --white:       #FFFFFF;
  --muted:       #6B7280;
  --radius:      10px;
}

/* ===== RESET ===== */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body { font-family:'Geon','Helvetica Neue',Arial,sans-serif; color:var(--dark); background:#fff; overflow-x:hidden; }
img { max-width:100%; display:block; }
a { text-decoration:none; }

/* ===== SCROLL REVEAL ===== */
[data-reveal] {
  opacity:0;
  transform:translateY(36px);
  transition:opacity .7s ease, transform .7s ease;
}
[data-reveal="left"] { transform:translateX(-36px); }
[data-reveal="right"] { transform:translateX(36px); }
[data-reveal].revealed { opacity:1; transform:translate(0); }

/* ===== NAVBAR ===== */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:1.1rem 6%;
  display:flex; align-items:center; justify-content:space-between;
  transition:background .4s, box-shadow .4s, backdrop-filter .4s;
}
.navbar.scrolled {
  background:rgba(26,37,51,.94);
  backdrop-filter:blur(12px);
  box-shadow:0 2px 32px rgba(0,0,0,.35);
}
.navbar-logo img { height:40px; width:auto; }
.nav-links { display:flex; align-items:center; gap:2.2rem; list-style:none; }
.nav-links a {
  color:rgba(255,255,255,.78); font-family:'Geon',sans-serif;
  font-weight:500; font-size:.88rem; letter-spacing:.04em;
  transition:color .2s; position:relative;
}
.nav-links a::after {
  content:''; position:absolute; bottom:-3px; left:0; right:0;
  height:1px; background:var(--lime); transform:scaleX(0);
  transition:transform .25s ease; transform-origin:left;
}
.nav-links a:hover { color:var(--lime); }
.nav-links a:hover::after { transform:scaleX(1); }
.btn-nav {
  background:var(--lime); color:var(--dark) !important;
  padding:.5rem 1.3rem; border-radius:5px;
  font-weight:700 !important; font-size:.82rem !important;
  letter-spacing:.07em !important; text-transform:uppercase;
  transition:background .2s, transform .2s !important;
}
.btn-nav:hover { background:var(--lime-hover) !important; transform:translateY(-2px) !important; }
.btn-nav::after { display:none !important; }
.btn-nav-app {
  background:var(--green); color:#fff !important;
  padding:.5rem 1.3rem; border-radius:5px;
  font-weight:700 !important; font-size:.82rem !important;
  letter-spacing:.07em !important; text-transform:uppercase;
  transition:background .2s, transform .2s !important;
}
.btn-nav-app:hover { background:#1a9a54 !important; transform:translateY(-2px) !important; }
.btn-nav-app::after { display:none !important; }

/* ===== HERO ===== */
.hero {
  min-height:100vh; position:relative; overflow:hidden;
  background:var(--dark);
  display:flex; align-items:center; justify-content:center;
}
#heroCanvas {
  position:absolute; inset:0; width:100%; height:100%; z-index:0;
}
.hero-overlay {
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(160deg, rgba(10,18,28,.55) 0%, rgba(26,37,51,.7) 60%, rgba(10,18,28,.85) 100%);
}
.hero-intro {
  position:absolute; inset:0; z-index:3;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  pointer-events:none;
}
.hero-intro-logo {
  width:clamp(130px,16vw,210px);
  will-change:transform, opacity;
  filter:drop-shadow(0 0 40px rgba(200,212,78,.25));
}
.hero-intro-slogan {
  font-family:'Geon',sans-serif; font-weight:300;
  font-size:clamp(.9rem,1.4vw,1.15rem); color:rgba(255,255,255,.72);
  text-align:center; margin-top:1.4rem;
  max-width:520px; line-height:1.7; padding:0 1.5rem;
  letter-spacing:.04em;
  will-change:opacity;
}
.hero-scroll {
  position:absolute; bottom:2.5rem; left:50%; transform:translateX(-50%);
  z-index:4; display:flex; flex-direction:column; align-items:center; gap:.5rem;
  color:rgba(255,255,255,.35); font-size:.68rem; letter-spacing:.16em; text-transform:uppercase;
}
.scroll-bar {
  width:1px; height:40px;
  background:linear-gradient(to bottom, transparent, var(--lime));
  animation:scrollPulse 2.2s ease-in-out infinite;
}
@keyframes scrollPulse {
  0%,100%{opacity:.25; transform:scaleY(.6);}
  50%{opacity:1; transform:scaleY(1);}
}

/* ===== STATS STRIP ===== */
.stats-strip {
  background:var(--dark-mid);
  border-top:1px solid rgba(200,212,78,.08);
  border-bottom:1px solid rgba(200,212,78,.08);
  display:grid; grid-template-columns:repeat(4,1fr);
  position:relative; overflow:hidden;
}
.stats-strip::before {
  content:''; position:absolute; inset:0;
  background:
    linear-gradient(rgba(200,212,78,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(200,212,78,.03) 1px, transparent 1px);
  background-size:48px 48px;
  animation:gridShift 18s linear infinite;
}
@keyframes gridShift { 0%{background-position:0 0;} 100%{background-position:48px 48px;} }
.stat-block {
  padding:1.4rem 1.2rem; text-align:center; position:relative;
  border-right:1px solid rgba(255,255,255,.06);
  transition:background .3s;
}
.stat-block:last-child { border-right:none; }
.stat-block:hover { background:rgba(200,212,78,.06); }
a.stat-block {
  color:inherit; text-decoration:none; cursor:pointer; display:block;
}
a.stat-block:hover { background:rgba(200,212,78,.1); }
.stat-n {
  font-family:'Geon',sans-serif; font-weight:700;
  font-size:clamp(1.4rem,2.3vw,2rem); color:var(--lime);
  line-height:1; letter-spacing:-.02em;
}
.stat-l {
  font-family:'Geon',sans-serif; font-size:.68rem;
  color:rgba(255,255,255,.42); margin-top:.35rem;
  letter-spacing:.1em; text-transform:uppercase;
}
.stat-bar {
  height:2px; background:var(--lime); margin:.8rem auto 0;
  width:0; transition:width 1.2s ease; border-radius:1px;
  max-width:40px;
}
.stat-block.revealed .stat-bar { width:100%; }

/* ===== SECTION BASE ===== */
.section { padding:6rem 6%; }
.label {
  font-family:'Geon',sans-serif; font-weight:500; font-size:.72rem;
  letter-spacing:.22em; text-transform:uppercase; color:var(--green); margin-bottom:.9rem;
}
.title {
  font-family:'Geon',sans-serif; font-weight:700;
  font-size:clamp(1.9rem,3.2vw,2.8rem); line-height:1.15;
  margin-bottom:1.4rem; letter-spacing:-.02em;
}
.body-text {
  font-family:'Geon',sans-serif; font-weight:400;
  font-size:1rem; line-height:1.8; color:var(--muted); max-width:580px;
}
.container { max-width:1200px; margin:0 auto; }

/* ===== NOSOTROS ===== */
.about { background:#fff; }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.about-photo { border-radius:var(--radius); overflow:hidden; aspect-ratio:4/3; position:relative; }
.about-photo img { width:100%; height:100%; object-fit:cover; object-position:center 55%; display:block; transition:transform .6s ease; }
.about-photo:hover img { transform:scale(1.04); }
.about-photo::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(to top, #1A2533 0%, rgba(26,37,51,.5) 30%, rgba(26,37,51,0) 60%);
  pointer-events:none;
}
.about-stats { display:flex; gap:3rem; margin-top:2.5rem; }
.astat-n { font-family:'Geon',sans-serif; font-weight:700; font-size:2rem; color:var(--green); line-height:1; }
.astat-l { font-family:'Geon',sans-serif; font-size:.76rem; color:var(--muted); margin-top:.3rem; letter-spacing:.06em; }

/* TEAM */
.team-section { margin-top:4.5rem; padding-top:3.5rem; border-top:1px solid #eee; }
.team-label { font-family:'Geon',sans-serif; font-weight:500; font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--green); margin-bottom:2rem; }
.team-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; }
.team-card { text-align:center; }
.team-avatar { border-radius:var(--radius); overflow:hidden; aspect-ratio:3/4; margin-bottom:.75rem; }
.team-avatar img { width:100%; height:100%; object-fit:cover; object-position:center 18%; display:block; transition:transform .4s; }
.team-card:hover .team-avatar img { transform:scale(1.05); }
.team-name { font-family:'Geon',sans-serif; font-weight:600; font-size:.9rem; color:var(--dark); }
.team-role { font-family:'Geon',sans-serif; font-weight:400; font-size:.76rem; color:var(--muted); margin-top:.15rem; }

/* FIELD STRIP */
.field-strip { height:360px; overflow:hidden; position:relative; }
.field-strip img { width:100%; height:100%; object-fit:cover; object-position:center 65%; display:block; transition:transform 12s ease; }
.field-strip:hover img { transform:scale(1.06); }
.field-strip-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to right, rgba(16,24,32,.7) 0%, transparent 65%);
  display:flex; align-items:center; padding:0 6%;
}
.field-strip-text {
  font-family:'Geon',sans-serif; font-weight:300; font-size:1.4rem;
  color:rgba(255,255,255,.9); max-width:420px; line-height:1.55;
}
.field-strip-text strong { color:var(--lime); font-weight:600; }

/* ===== SERVICIOS ===== */
.services { background:var(--dark); position:relative; overflow:hidden; }
.services::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(200,212,78,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(200,212,78,.035) 1px, transparent 1px);
  background-size:72px 72px;
  animation:gridShift 25s linear infinite;
}
.services .label { color:var(--lime); }
.services .title { color:#fff; }
.svc-grid { display:flex; flex-wrap:wrap; justify-content:center; gap:1.4rem; margin-top:3.5rem; position:relative; z-index:1; }
.svc-card {
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.09);
  border-radius:var(--radius); padding:1.8rem;
  transition:background .3s, border-color .3s, transform .35s, box-shadow .35s;
  position:relative; overflow:hidden;
  display:flex; flex-direction:column;
  flex: 0 0 calc(25% - 1.05rem);
}
.svc-card:hover {
  background:rgba(200,212,78,.07); border-color:rgba(200,212,78,.3);
  transform:translateY(-6px); box-shadow:0 20px 50px rgba(0,0,0,.4);
}
/* Imagen de fondo en hover */
.svc-card-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  opacity:0; transition:opacity .35s ease;
  border-radius:var(--radius); z-index:0;
  filter:blur(2px);
}
.svc-card:hover .svc-card-bg { opacity:.20; }
.svc-card-bg.fading { opacity:0 !important; transition:opacity .25s ease !important; }
.svc-card[data-svc-folder="Asesoramiento y Seguimiento"] .svc-card-bg { background-position:left center; }
.svc-card > *:not(.svc-card-bg) { position:relative; z-index:1; }
.svc-icon {
  width:46px; height:46px; background:rgba(200,212,78,.12); border-radius:9px;
  display:flex; align-items:center; justify-content:center; margin-bottom:1.2rem;
  transition:background .3s;
}
.svc-card:hover .svc-icon { background:rgba(200,212,78,.22); }
.svc-icon svg { width:24px; height:24px; stroke:var(--lime); fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.svc-cat { font-family:'Geon',sans-serif; font-size:.63rem; letter-spacing:.16em; text-transform:uppercase; color:var(--lime); opacity:.6; margin-bottom:.55rem; }
.svc-name { font-family:'Geon',sans-serif; font-weight:700; font-size:.95rem; color:#fff; margin-bottom:.5rem; }
.svc-desc { font-family:'Geon',sans-serif; font-size:.82rem; line-height:1.65; color:rgba(255,255,255,.68); flex:1; }
.svc-tags { display:flex; flex-wrap:wrap; gap:.3rem; margin-top:.9rem; min-height:2rem; align-items:flex-start; }
.svc-tag { font-family:'Geon',sans-serif; font-size:.62rem; color:rgba(255,255,255,.38); background:rgba(255,255,255,.06); padding:.14rem .52rem; border-radius:20px; }

/* ===== METODOLOGIA ===== */
.method { background:#f5f6f3; }
.method-steps { margin-top:4rem; }
.method-phase-label {
  font-family:'Geon',sans-serif; font-size:.7rem;
  letter-spacing:.2em; text-transform:uppercase; color:var(--green);
  border-top:1px solid rgba(29,133,73,.2); padding-top:1.2rem;
  text-align:center; margin-top:2.5rem;
}
.method-phase-label:first-child { margin-top:0; }
.method-phase-label:not(.phase-mid)::before {
  content:''; display:block; width:2px; height:1.4rem;
  background:rgba(29,133,73,.3); margin:0 auto .7rem;
}
.method-phase-label.phase-mid::before {
  content:''; display:block; width:2px; height:1.4rem;
  background:rgba(29,133,73,.3); margin:0 auto .7rem;
}
.phase-row {
  display:grid; grid-template-columns:repeat(4,1fr); gap:2rem;
  position:relative; margin-top:2.5rem;
}
.phase-row::before {
  content:''; position:absolute;
  top:29px; left:calc(12.5% + 22px); right:calc(12.5% + 22px);
  height:2px; background:linear-gradient(90deg, var(--lime), var(--green));
}
/* Gradiente diferenciado por etapa */
.phase-row:first-of-type::before { background:linear-gradient(90deg, var(--lime), #6bbf8a); }
.phase-row:last-of-type::before  { background:linear-gradient(90deg, #6bbf8a, #1a5ca8); }
.step { text-align:center; padding:0 1rem; }
.step-num {
  width:58px; height:58px; border-radius:50%;
  background:var(--dark); color:var(--lime);
  font-family:'Groza',sans-serif; font-weight:800; font-size:1.25rem;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 1.4rem; position:relative; z-index:1;
  box-shadow:0 0 0 6px #f5f6f3, 0 0 0 7px rgba(29,133,73,.2);
  transition:transform .3s, box-shadow .3s;
}
.step:hover .step-num {
  transform:scale(1.1);
  box-shadow:0 0 0 6px #f5f6f3, 0 0 0 7px var(--green), 0 6px 20px rgba(29,133,73,.3);
}
.step-tag { font-family:'Geon',sans-serif; font-weight:700; font-size:.68rem; letter-spacing:.15em; text-transform:uppercase; color:var(--green); margin-bottom:.4rem; }
.step-title { font-family:'Geon',sans-serif; font-weight:700; font-size:1.05rem; color:var(--dark); margin-bottom:.5rem; }
.step-desc { font-family:'Geon',sans-serif; font-size:.83rem; line-height:1.62; color:var(--muted); }

/* ===== NUESTROS NUMEROS ===== */
.numeros { background:#fff; }
.num-loader { font-family:'Geon',sans-serif; color:var(--muted); font-size:.85rem; margin-top:3rem; text-align:center; }
.num-slicer { display:flex; gap:.45rem; flex-wrap:wrap; margin-top:2.5rem; }
.slicer-btn {
  font-family:'Geon',sans-serif; font-size:.72rem; letter-spacing:.1em;
  text-transform:uppercase; padding:.42rem 1.15rem; border-radius:50px;
  border:1.5px solid rgba(24,39,51,.15); background:transparent;
  color:var(--dark); cursor:pointer; transition:all .2s;
}
.slicer-btn:hover { border-color:var(--green); color:var(--green); }
.slicer-btn.active { background:var(--green); color:#fff; border-color:var(--green); }
.num-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; margin-top:2.2rem; }
.num-card {
  background:#f9fafb; border-radius:16px; padding:2rem 1.6rem 1.8rem;
  border:1px solid #eee; transition:transform .3s, box-shadow .3s;
  position:relative; overflow:hidden;
}
.num-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:var(--card-c, #d1d5db); transition:background .4s;
}
.num-card:hover { transform:translateY(-4px); box-shadow:0 16px 40px rgba(0,0,0,.08); }
.num-card-lbl {
  font-family:'Geon',sans-serif; font-size:.68rem; letter-spacing:.16em;
  text-transform:uppercase; color:var(--muted); margin-bottom:1rem;
}
/* Gauge SVG */
.gauge-wrap { display:flex; flex-direction:column; align-items:center; }
.gauge-svg { width:100%; max-width:200px; display:block; overflow:visible; }
.gauge-arc {
  transition:stroke-dashoffset 1.4s cubic-bezier(.22,.61,.36,1), stroke .4s;
}
.gauge-val {
  font-family:'Geon',sans-serif; font-weight:700;
  font-size:2rem; line-height:1; color:var(--dark);
  text-align:center; margin-top:-.5rem;
}
.gauge-status {
  font-family:'Geon',sans-serif; font-size:.78rem; font-weight:600;
  text-align:center; margin-top:.25rem;
}
.num-chart-box {
  margin-top:2.5rem; background:#f9fafb; border-radius:16px;
  padding:1.8rem 1.6rem 1rem; border:1px solid #eee;
}
.num-chart-ttl {
  font-family:'Geon',sans-serif; font-weight:600; font-size:.9rem;
  color:var(--dark); margin-bottom:1rem; letter-spacing:.03em;
}

/* ===== TECNOLOGIA ===== */
.tech { background:var(--dark); position:relative; overflow:hidden; }
.tech::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse 80% 60% at 50% 100%, rgba(29,133,73,.12) 0%, transparent 70%);
}
.tech .label { color:var(--lime); }
.tech .title { color:#fff; }
.tech-intro { font-family:'Geon',sans-serif; font-weight:300; font-size:1.05rem; color:rgba(255,255,255,.55); line-height:1.8; max-width:620px; margin-bottom:3.5rem; }
.tech-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; position:relative; z-index:1; }
.tech-card {
  background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08);
  border-radius:12px; padding:2rem;
  transition:background .3s, border-color .3s, transform .35s;
  display:flex; gap:1.2rem; align-items:flex-start;
}
.tech-card:hover {
  background:rgba(200,212,78,.06); border-color:rgba(200,212,78,.25);
  transform:translateY(-4px);
}
.tech-icon {
  width:48px; height:48px; background:rgba(200,212,78,.1); border-radius:10px;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  transition:background .3s;
}
.tech-card:hover .tech-icon { background:rgba(200,212,78,.2); }
.tech-icon svg { width:22px; height:22px; stroke:var(--lime); fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.tech-name { font-family:'Geon',sans-serif; font-weight:700; font-size:.9rem; color:#fff; margin-bottom:.4rem; }
.tech-desc { font-family:'Geon',sans-serif; font-size:.8rem; line-height:1.65; color:rgba(255,255,255,.45); }

/* ===== VISION ===== */
.vision { background:var(--dark-deep); text-align:center; position:relative; overflow:hidden; }
.vision::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse 60% 70% at 50% 50%, rgba(200,212,78,.07) 0%, transparent 70%);
  animation:visionPulse 6s ease-in-out infinite;
}
@keyframes visionPulse { 0%,100%{opacity:.6;} 50%{opacity:1;} }
.vision .label { color:var(--lime); }
.vision-quote {
  font-family:'Geon',sans-serif; font-weight:700;
  font-size:clamp(1.8rem,3.1vw,2.8rem); line-height:1.22; color:#fff; margin-bottom:1.8rem;
  position:relative; z-index:1;
}
.vision-quote em { color:var(--lime); font-style:normal; }
.vision-text {
  font-family:'Geon',sans-serif; font-weight:300; font-size:.98rem;
  line-height:1.82; color:rgba(255,255,255,.5); max-width:680px;
  margin:0 auto; position:relative; z-index:1;
}

/* ===== LOCATION ===== */
.location { background:#fff; }
.loc-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.map-frame { background:var(--stone); border-radius:var(--radius); overflow:hidden; aspect-ratio:4/3; }
.map-frame iframe { width:100%; height:100%; border:none; }
.loc-items { display:flex; flex-direction:column; gap:1.6rem; margin-top:2rem; }
.loc-item { display:flex; gap:1rem; align-items:flex-start; }
.loc-icon {
  width:40px; height:40px; background:rgba(29,133,73,.1); border-radius:8px;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  transition:background .3s, transform .3s;
}
.loc-item:hover .loc-icon { background:rgba(29,133,73,.2); transform:scale(1.08); }
.loc-icon svg { width:20px; height:20px; stroke:var(--green); fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.loc-text strong { display:block; font-family:'Geon',sans-serif; font-weight:700; font-size:.88rem; color:var(--dark); margin-bottom:.2rem; }
.loc-text span { font-family:'Geon',sans-serif; font-size:.85rem; color:var(--muted); }

/* ===== FOOTER ===== */
footer { background:var(--dark-deep); padding:3.5rem 6% 2rem; }
.footer-top { display:flex; justify-content:space-between; align-items:flex-start; padding-bottom:2rem; border-bottom:1px solid rgba(255,255,255,.08); margin-bottom:2rem; }
.footer-logo img { height:34px; }
.footer-links { display:flex; gap:2rem; }
.footer-links a { color:rgba(255,255,255,.38); font-family:'Geon',sans-serif; font-size:.82rem; transition:color .2s; }
.footer-links a:hover { color:var(--lime); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; }
.footer-copy { color:rgba(255,255,255,.24); font-family:'Geon',sans-serif; font-size:.78rem; }
.footer-slogan { color:rgba(200,212,78,.3); font-family:'Geon',sans-serif; font-size:.78rem; font-style:italic; }

/* ===== MODAL LOGIN ===== */
.overlay {
  position:fixed; inset:0; z-index:9000;
  background:rgba(8,14,22,.9); backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transition:opacity .3s, visibility .3s;
}
.overlay.open { opacity:1; visibility:visible; }
.modal {
  background:var(--dark-mid); border-radius:16px; padding:2.8rem 2.4rem;
  width:100%; max-width:400px; border:1px solid rgba(255,255,255,.1);
  transform:translateY(20px) scale(.97); transition:transform .35s; position:relative;
}
.overlay.open .modal { transform:translateY(0) scale(1); }
.modal-x {
  position:absolute; top:1rem; right:1rem; background:none; border:none;
  color:rgba(255,255,255,.3); cursor:pointer; font-size:1.4rem; line-height:1; transition:color .2s;
}
.modal-x:hover { color:#fff; }
.modal-logo { display:flex; justify-content:center; margin-bottom:1.8rem; }
.modal-logo img { height:38px; }
.modal-h { font-family:'Geon',sans-serif; font-weight:700; font-size:1.35rem; color:#fff; text-align:center; margin-bottom:.35rem; }
.modal-sub { font-family:'Geon',sans-serif; font-size:.82rem; color:rgba(255,255,255,.4); text-align:center; margin-bottom:1.9rem; }
.field { margin-bottom:1.1rem; }
.field label { display:block; font-family:'Geon',sans-serif; font-size:.74rem; font-weight:500; letter-spacing:.08em; text-transform:uppercase; color:rgba(255,255,255,.45); margin-bottom:.45rem; }
.field input {
  width:100%; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12);
  border-radius:6px; padding:.78rem .95rem; color:#fff;
  font-family:'Geon',sans-serif; font-size:.92rem; outline:none; transition:border-color .2s;
}
.field input:focus { border-color:var(--lime); }
.field input::placeholder { color:rgba(255,255,255,.2); }
.error-box {
  background:rgba(186,76,23,.18); border:1px solid rgba(186,76,23,.4);
  border-radius:6px; padding:.65rem .95rem; color:#e8a07a;
  font-family:'Geon',sans-serif; font-size:.82rem; text-align:center;
  margin-bottom:.9rem; display:none;
}
.btn-login {
  width:100%; background:var(--lime); color:var(--dark); border:none;
  border-radius:6px; padding:.88rem; margin-top:.4rem;
  font-family:'Geon',sans-serif; font-weight:700; font-size:.9rem;
  letter-spacing:.06em; text-transform:uppercase; cursor:pointer; transition:background .2s, transform .2s;
}
.btn-login:hover { background:var(--lime-hover); transform:translateY(-1px); }
.btn-login:disabled { opacity:.5; cursor:not-allowed; }

/* ===== DASHBOARD ===== */
.dashboard { display:none; min-height:100vh; flex-direction:column; }
.dashboard.show { display:flex; }
.dash-bar {
  background:#182733; padding:.9rem 6%;
  display:flex; align-items:center; justify-content:space-between;
  border-bottom:1px solid rgba(255,255,255,.06); flex-shrink:0;
}
.dash-bar-logo img { height:32px; }
.dash-right { display:flex; align-items:center; gap:1.5rem; }
.dash-who { font-family:'Geon',sans-serif; color:rgba(255,255,255,.6); font-size:.88rem; }
.dash-who span { color:var(--lime); font-weight:700; }
.btn-out {
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.6); padding:.38rem .95rem; border-radius:4px;
  font-family:'Geon',sans-serif; font-size:.78rem; cursor:pointer; transition:all .2s;
}
.btn-out:hover { background:rgba(255,255,255,.12); color:#fff; }
.dash-body { flex:1; background:#182733; }
.dash-body iframe { width:100%; height:calc(100vh - 58px); border:none; display:block; }
.dash-empty {
  height:calc(100vh - 58px); display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:1rem;
  color:rgba(255,255,255,.3); text-align:center; background:var(--dark);
}
.dash-selector {
  flex:1; background:#f0f4f0; display:flex; flex-direction:column;
  align-items:center; justify-content:center; padding:2.5rem 6%;
  min-height:calc(100vh - 58px);
}
.dash-selector-label { font-family:'Geon',sans-serif; color:rgba(24,39,51,.4); font-size:.75rem; letter-spacing:.16em; text-transform:uppercase; margin-bottom:2rem; }
.dash-selector { background: #0d1a24; }
.dash-selector-label { color: rgba(255,255,255,.35); font-size:.8rem; letter-spacing:.18em; }
.reports-grid { display:flex; flex-wrap:wrap; gap:1.4rem; justify-content:center; width:100%; max-width:920px; }

/* ─── Sección Ensayos en el dashboard ─── */
.dash-ensayos-section { margin-top:3rem; width:100%; max-width:920px; }
.ensayos-nav-grid { display:flex; flex-wrap:wrap; gap:1rem; justify-content:center; }
.ensayo-nav-card {
  flex:0 0 200px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
  border-radius:16px; padding:1.6rem 1.2rem; display:flex; flex-direction:column;
  align-items:center; gap:.9rem; text-decoration:none; color:#e8f0e8;
  font-family:'Geon',sans-serif; font-size:.95rem; font-weight:600;
  transition:background .2s, transform .2s, border-color .2s;
}
.ensayo-nav-card svg { width:32px; height:32px; stroke:var(--lime); opacity:.85; }
.ensayo-nav-card:hover {
  background:rgba(200,212,78,.12); border-color:rgba(200,212,78,.35);
  transform:translateY(-4px); color:#fff;
}
.ensayo-nav-card:hover svg { opacity:1; }

/* ── Archivos Generados ────────────────────────────── */
.arch-section { margin-top:2.4rem; width:100%; max-width:780px; }
.arch-list { display:flex; flex-direction:column; gap:.6rem; }
.arch-row {
  display:flex; align-items:center; gap:1rem;
  padding:.95rem 1.2rem; border-radius:14px;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08);
  text-decoration:none; color:#e8f0e8;
  transition:background .18s, border-color .18s, transform .18s;
}
.arch-row:hover {
  background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.2);
  transform:translateX(4px);
}
.arch-icon { width:28px; height:28px; flex-shrink:0; }
.arch-info { flex:1; min-width:0; }
.arch-nombre { font-family:'Geon',sans-serif; font-weight:600; font-size:.95rem; }
.arch-desc { font-size:.78rem; opacity:.55; margin-top:.15rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.arch-dl { width:18px; height:18px; flex-shrink:0; opacity:.4; transition:opacity .18s; }
.arch-row:hover .arch-dl { opacity:.85; }

.report-card {
  flex: 0 0 280px;
  border-radius:22px; padding:2.4rem 1.5rem 2rem;
  cursor:pointer; min-height:195px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:1.1rem; text-align:center; position:relative; overflow:hidden;
  background:var(--card-grad, linear-gradient(145deg,#1a6e3c,#0c4423));
  transition:transform .4s cubic-bezier(.22,.61,.36,1), box-shadow .4s;
  border:1px solid rgba(255,255,255,.1);
}
.report-card::before {
  content:''; position:absolute; top:-40%; left:-30%;
  width:80%; height:80%; border-radius:50%;
  background:rgba(255,255,255,.07); pointer-events:none;
  transition:transform .4s ease, opacity .4s;
}
.report-card:hover::before { transform:scale(1.5); opacity:.18; }
.report-card:hover { transform:translateY(-10px) scale(1.04); box-shadow:0 28px 60px rgba(0,0,0,.6), inset 0 1px 0 rgba(255,255,255,.2); }
.report-card.unavailable { opacity:.3; cursor:default; pointer-events:none; filter:grayscale(.5); }
.report-icon-big {
  width:72px; height:72px; display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.18); border-radius:18px;
  transition:transform .4s cubic-bezier(.22,.61,.36,1), background .3s;
}
.report-icon-big svg { width:34px; height:34px; stroke:#fff; fill:none; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; }
.report-card:nth-child(1) .report-icon-big { animation:iconFloat 4.0s ease-in-out infinite 0.0s; }
.report-card:nth-child(2) .report-icon-big { animation:iconFloat 4.2s ease-in-out infinite 0.6s; }
.report-card:nth-child(3) .report-icon-big { animation:iconFloat 3.8s ease-in-out infinite 1.2s; }
.report-card:nth-child(4) .report-icon-big { animation:iconFloat 4.4s ease-in-out infinite 1.8s; }
.report-card:nth-child(5) .report-icon-big { animation:iconFloat 4.0s ease-in-out infinite 0.9s; }
.report-card:nth-child(6) .report-icon-big { animation:iconFloat 3.6s ease-in-out infinite 0.3s; }
.report-card:nth-child(7) .report-icon-big { animation:iconFloat 4.2s ease-in-out infinite 1.5s; }
@keyframes iconFloat {
  0%,100% { transform:translateY(0); }
  50%      { transform:translateY(-7px); }
}
.report-card:hover .report-icon-big { transform:scale(1.14) translateY(0) !important; animation:none !important; background:rgba(255,255,255,.28); }
.report-name { font-family:'Geon',sans-serif; color:#fff; font-size:.92rem; font-weight:600; line-height:1.35; padding:0 .4rem; text-shadow:0 1px 8px rgba(0,0,0,.35); }
.report-badge {
  position:absolute; bottom:.75rem;
  font-family:'Geon',sans-serif; font-size:.64rem; letter-spacing:.06em;
  color:rgba(255,255,255,.55); background:rgba(0,0,0,.3);
  padding:.18rem .6rem; border-radius:20px; backdrop-filter:blur(4px);
}
.report-gis-badge {
  position:absolute; top:.75rem; right:.75rem;
  background:rgba(255,255,255,.18); color:#fff; font-family:'Geon',sans-serif;
  font-size:.6rem; letter-spacing:.1em; text-transform:uppercase;
  padding:.2rem .55rem; border-radius:20px; font-weight:600;
}
.btn-back {
  background:none; border:none; color:rgba(255,255,255,.4);
  font-family:'Geon',sans-serif; font-size:.82rem; cursor:pointer;
  padding:.3rem .5rem; border-radius:4px; transition:color .2s;
  display:none; align-items:center; gap:.35rem;
}
.btn-back svg { width:15px; height:15px; stroke:currentColor; fill:none; stroke-width:2.5; }
.btn-back:hover { color:var(--lime); }

/* Float buttons group (mobile only) */
.float-btns {
  display:none; position:fixed; bottom:1.4rem; right:1.4rem; z-index:998;
  flex-direction:column; gap:.55rem; align-items:flex-end;
}
.float-app {
  background:var(--green); color:#fff;
  font-family:'Geon',sans-serif; font-weight:700;
  font-size:.78rem; letter-spacing:.07em; text-transform:uppercase;
  padding:.65rem 1.2rem; border-radius:50px; border:none; cursor:pointer;
  box-shadow:0 4px 20px rgba(0,0,0,.35); transition:transform .2s, box-shadow .2s;
  text-decoration:none; display:inline-block; white-space:nowrap;
}
.float-app:hover { transform:translateY(-2px); box-shadow:0 6px 26px rgba(0,0,0,.4); }
.float-portal {
  background:var(--lime); color:var(--dark);
  font-family:'Geon',sans-serif; font-weight:700;
  font-size:.78rem; letter-spacing:.07em; text-transform:uppercase;
  padding:.65rem 1.2rem; border-radius:50px; border:none; cursor:pointer;
  box-shadow:0 4px 20px rgba(0,0,0,.35); transition:transform .2s, box-shadow .2s;
  white-space:nowrap;
}
.float-portal:hover { transform:translateY(-2px); box-shadow:0 6px 26px rgba(0,0,0,.4); }

/* Landing state */
#landing.hide { display:none; }

/* ===== PILARES: MISIÓN / VISIÓN / VALORES ===== */
.pillars-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:1.8rem;
  margin-top:3.5rem;
}
.pillar-card {
  background:#f9fafb; border-radius:var(--radius); padding:2rem 1.6rem;
  border:1px solid #eee; border-top:3px solid var(--green);
  transition:transform .3s, box-shadow .3s;
}
.pillar-card:hover { transform:translateY(-4px); box-shadow:0 12px 30px rgba(0,0,0,.07); }
.pillar-icon {
  width:40px; height:40px; background:rgba(29,133,73,.1); border-radius:8px;
  display:flex; align-items:center; justify-content:center; margin-bottom:1rem;
}
.pillar-icon svg { width:20px; height:20px; stroke:var(--green); fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.pillar-label {
  font-family:'Geon',sans-serif; font-weight:700; font-size:.7rem;
  letter-spacing:.2em; text-transform:uppercase; color:var(--green); margin-bottom:.55rem;
}
.pillar-text { font-family:'Geon',sans-serif; font-size:.88rem; line-height:1.7; color:var(--muted); }

/* ===== TEAM DESC ===== */
.team-desc {
  font-family:'Geon',sans-serif; font-weight:400; font-size:.93rem;
  line-height:1.75; color:var(--muted); max-width:700px; margin-bottom:2.5rem;
}

/* ===== NUESTROS NÚMEROS — NUEVAS MÉTRICAS ===== */
.num-metrics-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; margin-top:2.2rem;
}
.num-col-box {
  background:#f9fafb; border-radius:16px; padding:1.8rem 1.6rem;
  border:1px solid #eee; transition:transform .3s, box-shadow .3s;
}
.num-col-box:hover { transform:translateY(-4px); box-shadow:0 16px 40px rgba(0,0,0,.08); }
.num-col-hdr {
  display:flex; align-items:center; gap:.85rem;
  margin-bottom:1.4rem; padding-bottom:1rem; border-bottom:1px solid #eee;
}
.num-col-icon {
  width:38px; height:38px; background:rgba(29,133,73,.1); border-radius:8px;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.num-col-icon svg { width:18px; height:18px; stroke:var(--green); fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.num-col-ttl { font-family:'Geon',sans-serif; font-weight:700; font-size:.95rem; color:var(--dark); }
.num-col-sub { font-family:'Geon',sans-serif; font-size:.72rem; color:var(--muted); margin-top:.1rem; }

/* SUPERFICIE */
.sup-stack { display:flex; flex-direction:column; gap:.3rem; }
.sup-row {
  display:flex; align-items:center; background:#fff; border-radius:8px;
  padding:.75rem 1rem; gap:.5rem; border:1px solid #eee;
}
.sup-label { font-family:'Geon',sans-serif; font-size:.78rem; color:var(--muted); flex:1; }
.sup-value { font-family:'Geon',sans-serif; font-weight:700; font-size:1.15rem; color:var(--dark); }
.sup-unit { font-family:'Geon',sans-serif; font-size:.72rem; color:var(--muted); min-width:22px; }
.sup-op { text-align:center; font-size:1rem; color:var(--muted); font-weight:700; padding:.05rem 0; }
.sup-ahorro-row { border-color:rgba(29,133,73,.25); background:rgba(29,133,73,.04); }
.sup-ahorro-val { color:var(--green) !important; }

/* MUESTREO */
.muestreo-cards { display:flex; flex-direction:column; gap:.85rem; }
.muestreo-card {
  background:#fff; border-radius:10px; padding:1.2rem 1.4rem;
  border:1px solid #eee; display:flex; align-items:center; gap:1rem;
}
.muestreo-n {
  font-family:'Geon',sans-serif; font-weight:700;
  font-size:2rem; color:var(--green); line-height:1;
  letter-spacing:-.03em; min-width:80px;
}
.muestreo-l { font-family:'Geon',sans-serif; font-size:.8rem; color:var(--muted); line-height:1.4; }

/* ===== RESPONSIVE ===== */
@media (max-width:960px) {
  .about-grid, .loc-grid { grid-template-columns:1fr; gap:3rem; }
  .svc-card { flex: 0 0 calc(50% - 0.7rem); }
  .phase-row { grid-template-columns:1fr 1fr; }
  .phase-row::before { display:none; }
  .nav-links { display:none; }
  .team-grid { grid-template-columns:repeat(2,1fr); }
  .tech-grid { grid-template-columns:1fr 1fr; }
  .stats-strip { grid-template-columns:repeat(2,1fr); }
  .float-btns { display:flex; }
  .pillars-grid { grid-template-columns:1fr; gap:1.2rem; }
  .num-metrics-grid { grid-template-columns:1fr; }
}
@media (max-width:600px) {
  .svc-card { flex: 0 0 100%; }
  .phase-row, .tech-grid { grid-template-columns:1fr; }
  .stats-strip { grid-template-columns:1fr 1fr; }
  .num-cards { grid-template-columns:1fr; }
  .section { padding:4rem 5%; }
  .footer-top { flex-direction:column; gap:2rem; }
  .footer-links { flex-wrap:wrap; gap:1.2rem; }
  .field-strip { height:240px; }
  .reports-grid .report-card { flex: 0 0 calc(50% - 0.7rem); }
}
