/* ============================================================
   ¿Quién Fue? · Landing one-page · v1.0
   ============================================================ */
:root{
  --noche:#0F141F;
  --sombra:#1B2330;
  --sombra-hi:#26303F;
  --papel:#F5F1E8;
  --lavanda:#A595D0;
  --lavanda-dark:#6B5B96;
  --lavanda-light:#C8BBE0;
  --rojo:#C8302B;
  --rojo-dark:#8E1F1B;
  --blanco:#F8F4ED;
  --apagado:#A0A4AD;
  --tenue:#6B707B;
  --cinta:#F5C518;
}

*, *::before, *::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  background:var(--noche);
  color:var(--papel);
  font-family:'Inter', system-ui, sans-serif;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

.container{ max-width:1200px; margin:0 auto; padding:0 24px; }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(15,20,31,0.92);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--sombra-hi);
}
.nav-row{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 24px; gap:24px;
}
.nav-brand{ display:flex; align-items:center; gap:10px; }
.nav-sym{
  width:36px; height:36px; border-radius:50%; background:var(--lavanda);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.nav-sym-frame{
  border:2px solid var(--rojo);
  padding:2px 5px;
  font-family:'Anton',sans-serif; font-size:14px;
  color:var(--blanco); line-height:1;
  transform:rotate(-2deg);
  text-shadow:1px 1px 0 var(--noche);
}
.nav-name{
  font-family:'Anton',sans-serif; font-size:20px;
  letter-spacing:.01em; color:var(--papel);
}
.nav-name .q{ color:var(--lavanda); }
.nav-menu{
  display:flex; gap:24px;
  font-size:14px; font-weight:500;
  color:var(--apagado);
}
.nav-menu a{ transition:color .2s; }
.nav-menu a:hover{ color:var(--lavanda); }
.nav-cta{ flex-shrink:0; }

/* ============ BOTÓN HAMBURGUESA (solo mobile) ============ */
/* CTA mobile oculto por default; visible solo en mobile */
.nav-mobile-cta{ display:none !important; }
@media (max-width:760px){
  .nav-mobile-cta{ display:block !important; }
}

.nav-toggle{
  display:none;
  width:42px; height:42px;
  background:transparent;
  border:1px solid var(--sombra-hi);
  border-radius:8px;
  cursor:pointer;
  padding:0;
  position:relative;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:5px;
  transition:border-color .2s;
  z-index:60;
}
.nav-toggle:hover{ border-color:var(--lavanda); }
.nav-toggle span{
  display:block;
  width:20px; height:2px;
  background:var(--papel);
  border-radius:2px;
  transition:transform .3s ease, opacity .2s ease;
  transform-origin:center;
}

/* ============ BACKDROP DEL MENÚ MOBILE ============ */
.nav-backdrop{
  display:none;
  position:fixed; inset:0;
  background:rgba(15,20,31,0.75);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  z-index:48;
  opacity:0;
  transition:opacity .25s ease;
}

@media (max-width:760px){
  .nav-toggle{ display:flex; }
  .nav-cta{ display:none; } /* el "Sumarme" se duplica dentro del menú */

  /* Menú slide-in desde la derecha */
  .nav-menu{
    position:fixed;
    top:0; right:0;
    height:100vh;
    width:min(320px, 85vw);
    background:var(--sombra);
    border-left:1px solid var(--sombra-hi);
    box-shadow:-12px 0 40px rgba(0,0,0,.5);
    flex-direction:column;
    gap:4px;
    padding:84px 22px 28px;
    transform:translateX(105%);
    transition:transform .3s ease;
    z-index:50;
    overflow-y:auto;
  }
  .nav-menu a{
    padding:14px 18px;
    border-radius:10px;
    font-size:17px;
    font-weight:500;
    color:var(--papel);
    border:1px solid transparent;
    transition:background .2s, border-color .2s, color .2s;
  }
  .nav-menu a:hover,
  .nav-menu a.active{
    background:var(--sombra-hi);
    color:var(--lavanda);
    border-color:var(--lavanda-dark);
  }
  /* CTA "Sumarme" destacado dentro del menú mobile */
  .nav-menu .nav-mobile-cta{
    background:var(--rojo);
    color:var(--papel);
    margin-top:auto; /* empuja al fondo del overlay */
    text-align:center;
    font-weight:700;
    font-size:14px;
    letter-spacing:.05em;
    text-transform:uppercase;
    border-color:var(--rojo);
  }
  .nav-menu .nav-mobile-cta:hover{
    background:var(--rojo-dark);
    color:var(--papel);
    border-color:var(--rojo-dark);
  }

  /* Estado abierto */
  .nav.menu-open .nav-menu{
    transform:translateX(0);
  }
  .nav.menu-open .nav-backdrop{
    display:block;
    opacity:1;
  }
  /* Hamburger -> X animado */
  .nav.menu-open .nav-toggle span:nth-child(1){
    transform:translateY(7px) rotate(45deg);
  }
  .nav.menu-open .nav-toggle span:nth-child(2){
    opacity:0;
  }
  .nav.menu-open .nav-toggle span:nth-child(3){
    transform:translateY(-7px) rotate(-45deg);
  }
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:11px 20px; border-radius:7px;
  font-family:'Inter',sans-serif; font-weight:700; font-size:13px;
  letter-spacing:.06em; text-transform:uppercase;
  cursor:pointer; border:none;
  transition:transform .15s, background .2s, box-shadow .2s;
  white-space:nowrap;
}
.btn-primary{
  background:var(--rojo); color:var(--blanco);
  box-shadow:0 4px 14px rgba(200,48,43,.35);
}
.btn-primary:hover{
  background:var(--rojo-dark);
  transform:translateY(-1px);
  box-shadow:0 6px 20px rgba(200,48,43,.45);
}
.btn-ghost{
  background:transparent; color:var(--papel);
  border:1.5px solid var(--sombra-hi);
}
.btn-ghost:hover{
  border-color:var(--lavanda);
  color:var(--lavanda);
}
.btn-block{ width:100%; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  padding:100px 0 96px;
  text-align:left;
  overflow:hidden;
  background:var(--noche);
}
.hero::before{
  content:'';
  position:absolute; inset:0;
  background-image:url('assets/images/hero-landing.jpg');
  background-size:cover;
  background-position:center;
  filter:saturate(.85);
  opacity:.45;
  z-index:0;
}
.hero::after{
  content:'';
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 900px 500px at 20% 10%, rgba(165,149,208,.30), transparent 65%),
    radial-gradient(ellipse 700px 400px at 80% 90%, rgba(200,48,43,.18), transparent 65%),
    linear-gradient(to bottom, rgba(15,20,31,.55) 0%, rgba(15,20,31,.85) 100%);
  z-index:1;
}
.hero .container{
  position:relative;
  z-index:2;
}
.tape{
  display:inline-block;
  background:var(--cinta); color:var(--noche);
  padding:6px 14px;
  font-family:'Special Elite',serif;
  font-size:12px; font-weight:700;
  letter-spacing:.22em;
  transform:rotate(-2deg);
  margin-bottom:24px;
  box-shadow:0 4px 12px rgba(0,0,0,.3);
}
.hero-title{
  font-family:'Anton', sans-serif;
  font-weight:400;
  font-size:clamp(48px, 9vw, 96px);
  line-height:.98;
  letter-spacing:.005em;
  margin-bottom:24px;
  color:var(--papel);
}
.hero-accent{ color:var(--lavanda); }
.hero-sub{
  font-size:18px; color:var(--apagado);
  max-width:620px; margin-bottom:32px;
  line-height:1.55;
}
.hero-actions{
  display:flex; gap:12px; flex-wrap:wrap;
  margin-bottom:32px;
}
.hero-meta{
  display:flex; gap:12px; flex-wrap:wrap;
  font-size:13px; color:var(--apagado);
  font-family:'JetBrains Mono', monospace;
}
.hero-meta strong{ color:var(--papel); font-weight:500; }
.dot{ color:var(--tenue); }

/* ============================================================
   SECTIONS
   ============================================================ */
.section{ padding:96px 0; }
.section-dark{
  background:var(--sombra);
  border-top:1px solid var(--sombra-hi);
  border-bottom:1px solid var(--sombra-hi);
}
.sec-kicker{
  font-family:'JetBrains Mono', monospace;
  font-size:11px; font-weight:600;
  color:var(--lavanda);
  text-transform:uppercase;
  letter-spacing:.3em;
  margin-bottom:14px;
  display:inline-flex; align-items:center; gap:12px;
}
.sec-kicker::after{ content:''; width:48px; height:1px; background:var(--lavanda-dark); }
.sec-title{
  font-family:'Anton', sans-serif; font-weight:400;
  font-size:clamp(36px, 6vw, 56px);
  line-height:1; letter-spacing:.01em;
  margin-bottom:40px;
  color:var(--papel);
  max-width:920px;
}

/* ============================================================
   COMO FUNCIONA · STEPS
   ============================================================ */
.steps{
  display:grid; gap:24px;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
}
.step{
  background:var(--sombra);
  border:1px solid var(--sombra-hi);
  border-radius:14px;
  padding:32px 28px;
  position:relative;
  transition:transform .25s, border-color .25s;
}
.step:hover{
  transform:translateY(-4px);
  border-color:var(--lavanda-dark);
}
.step-icon{
  width:52px; height:52px;
  border-radius:50%;
  background:rgba(165,149,208,0.12);
  border:1.5px solid var(--lavanda-dark);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--lavanda);
  margin-bottom:12px;
}
.step-icon svg{ width:24px; height:24px; }
.step-num{
  font-family:'Anton',sans-serif;
  font-size:36px; line-height:1;
  color:var(--lavanda-dark);
  margin-bottom:10px;
  opacity:.7;
}
.step-title{
  font-family:'Anton',sans-serif; font-weight:400;
  font-size:26px; line-height:1.1;
  letter-spacing:.01em;
  margin-bottom:12px;
  color:var(--papel);
}
.step p{
  color:var(--apagado);
  font-size:15px; line-height:1.6;
}
.step strong{ color:var(--papel); font-weight:600; }

/* ============================================================
   TEASER CASO
   ============================================================ */
.teaser{
  display:grid; gap:36px;
  grid-template-columns:1fr 1fr;
  align-items:start;
}
.teaser-lead{
  font-size:20px; line-height:1.5;
  color:var(--papel);
  margin-bottom:18px;
  font-weight:500;
}
.teaser-left p{
  color:var(--apagado);
  font-size:15.5px; line-height:1.65;
  margin-bottom:14px;
}
.teaser-left strong{ color:var(--lavanda); font-weight:600; }
.teaser-meta{
  list-style:none;
  margin-top:24px;
  border-top:1px solid var(--sombra-hi);
  padding-top:18px;
}
.teaser-meta li{
  display:flex; justify-content:space-between;
  padding:7px 0;
  border-bottom:1px solid var(--sombra-hi);
  font-size:13px;
  font-family:'JetBrains Mono', monospace;
}
.mt-key{ color:var(--apagado); text-transform:uppercase; letter-spacing:.15em; font-size:11px; }
.mt-val{ color:var(--papel); font-weight:500; }

.evidence-card{
  background:var(--noche);
  border:1px solid var(--sombra-hi);
  border-radius:12px;
  overflow:hidden;
}
.ev-tag{
  background:var(--cinta);
  color:var(--noche);
  padding:8px 16px;
  font-family:'Special Elite',serif;
  font-size:11px; font-weight:700;
  letter-spacing:.22em;
}
.ev-text{
  font-family:'JetBrains Mono', monospace;
  font-size:13px; line-height:1.85;
  color:var(--papel);
  padding:20px 22px;
  white-space:pre-wrap;
  background:var(--noche);
}

@media (max-width:760px){
  .teaser{ grid-template-columns:1fr; }
}

/* ============================================================
   PRICING
   ============================================================ */
.pricing{
  max-width:520px; margin:0 auto;
}
.price-card{
  background:var(--sombra);
  border:2px solid var(--lavanda);
  border-radius:18px;
  padding:36px 32px;
  position:relative;
  box-shadow:0 24px 60px rgba(165,149,208,.18);
}
.price-tag{
  position:absolute; top:-12px; left:32px;
  background:var(--lavanda);
  color:var(--noche);
  padding:4px 12px;
  font-family:'JetBrains Mono',monospace;
  font-size:11px; font-weight:600;
  letter-spacing:.2em;
  border-radius:4px;
}
.price-amount{
  display:flex; align-items:baseline; gap:6px;
  margin:14px 0 28px;
}
.price-currency{
  font-family:'Anton',sans-serif;
  font-size:24px;
  color:var(--lavanda);
}
.price-big{
  font-family:'Anton',sans-serif;
  font-size:88px; line-height:.9;
  color:var(--papel);
}
.price-period{
  font-family:'Inter',sans-serif;
  font-size:18px; color:var(--apagado);
  font-weight:500;
}
.price-features{
  list-style:none;
  margin-bottom:28px;
}
.price-features li{
  padding:10px 0;
  border-bottom:1px solid var(--sombra-hi);
  font-size:15px;
  color:var(--papel);
  position:relative;
  padding-left:28px;
}
.price-features li::before{
  content:'✓';
  position:absolute;
  left:0; top:10px;
  color:var(--lavanda);
  font-weight:700;
  font-size:16px;
}
.price-features li strong{ color:var(--lavanda); }
.price-features li:last-child{ border-bottom:none; }
.price-note{
  font-size:12.5px;
  color:var(--apagado);
  text-align:center;
  margin-top:16px;
  line-height:1.55;
}

/* ============================================================
   FAQ
   ============================================================ */
.faq{ max-width:820px; }
.faq-item{
  border-bottom:1px solid var(--sombra-hi);
  padding:18px 0;
}
.faq-item summary{
  cursor:pointer;
  font-family:'Anton', sans-serif;
  font-weight:400;
  font-size:20px;
  color:var(--papel);
  letter-spacing:.005em;
  list-style:none;
  display:flex; justify-content:space-between; align-items:center;
  padding-right:8px;
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{
  content:'+';
  font-family:'Anton', sans-serif;
  font-size:28px;
  color:var(--lavanda);
  margin-left:14px;
  transition:transform .2s;
}
.faq-item[open] summary::after{ content:'−'; }
.faq-item p{
  color:var(--apagado);
  font-size:15px;
  margin-top:12px;
  line-height:1.65;
}

/* ============================================================
   CTA / WAITLIST
   ============================================================ */
.section-cta{
  padding:80px 0;
  background:
    radial-gradient(ellipse 600px 300px at 50% 50%, rgba(165,149,208,.18), transparent 70%),
    var(--noche);
}
.cta-box{
  max-width:680px;
  margin:0 auto;
}
.cta-frame{
  background:var(--sombra);
  border:2px solid var(--rojo);
  border-radius:18px;
  padding:44px 36px;
  text-align:center;
  position:relative;
}
.cta-tag{
  position:absolute; top:-14px; left:50%;
  transform:translateX(-50%);
  background:var(--cinta); color:var(--noche);
  padding:6px 14px;
  font-family:'Special Elite',serif;
  font-size:11px; font-weight:700;
  letter-spacing:.22em;
  white-space:nowrap;
  box-shadow:0 4px 12px rgba(0,0,0,.3);
}
.cta-title{
  font-family:'Anton',sans-serif; font-weight:400;
  font-size:clamp(36px, 5vw, 48px);
  line-height:1; letter-spacing:.01em;
  color:var(--papel);
  margin:16px 0 14px;
}
.cta-sub{
  font-size:16px; color:var(--apagado);
  max-width:480px; margin:0 auto 28px;
  line-height:1.55;
}
.waitlist-form{
  display:flex; gap:8px;
  max-width:480px; margin:0 auto 16px;
}
.waitlist-input{
  flex:1;
  background:var(--noche);
  color:var(--papel);
  border:1.5px solid var(--sombra-hi);
  border-radius:8px;
  padding:12px 16px;
  font-family:'Inter',sans-serif;
  font-size:15px;
  outline:none;
  transition:border-color .2s;
}
.waitlist-input:focus{ border-color:var(--lavanda); }
.waitlist-input::placeholder{ color:var(--tenue); }
.waitlist-meta{
  font-size:12.5px;
  color:var(--apagado);
  display:flex; gap:8px; justify-content:center;
  flex-wrap:wrap;
}
.waitlist-meta strong{ color:var(--lavanda); font-weight:600; }

.waitlist-success{
  background:rgba(165,149,208,0.12);
  border:1px solid var(--lavanda);
  border-radius:10px;
  padding:18px 22px;
  color:var(--papel);
  font-size:15px;
  text-align:center;
  max-width:480px;
  margin:0 auto;
  line-height:1.5;
}
.waitlist-error{
  background:rgba(200,48,43,0.10);
  border:1px solid var(--rojo);
  border-radius:8px;
  padding:10px 14px;
  color:var(--papel);
  font-size:13px;
  text-align:center;
  margin-top:12px;
}

@media (max-width:520px){
  .waitlist-form{ flex-direction:column; }
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  background:var(--sombra);
  border-top:1px solid var(--sombra-hi);
  padding:48px 0 32px;
}
.footer-row{
  display:flex; flex-direction:column; gap:24px;
  align-items:flex-start;
}
.footer-brand{
  display:flex; align-items:center; gap:14px;
}
.footer-sym{
  width:48px; height:48px; border-radius:50%; background:var(--lavanda);
  display:flex; align-items:center; justify-content:center;
}
.footer-sym .nav-sym-frame{ font-size:18px; padding:3px 7px; }
.footer-name{
  font-family:'Anton',sans-serif; font-size:22px;
  color:var(--papel); letter-spacing:.01em;
}
.footer-tag{ font-size:13px; color:var(--apagado); }
.footer-links{
  display:flex; gap:20px; flex-wrap:wrap;
  font-size:13.5px; color:var(--apagado);
}
.footer-links a{ transition:color .2s; }
.footer-links a:hover{ color:var(--lavanda); }
.footer-legal{
  font-size:12px; color:var(--tenue);
  font-family:'JetBrains Mono', monospace;
  padding-top:18px;
  border-top:1px solid var(--sombra-hi);
  width:100%;
}

@media (min-width:760px){
  .footer-row{
    flex-direction:row; justify-content:space-between; align-items:center;
  }
  .footer-legal{ border-top:none; padding-top:0; width:auto; }
}

/* ============================================================
   NAV ACTIVE STATE (multi-página)
   ============================================================ */
.nav-menu a.active{
  color:var(--lavanda);
  font-weight:600;
}
.nav-menu a.active::after{
  content:'';
  display:block;
  height:2px;
  background:var(--lavanda);
  margin-top:2px;
  border-radius:1px;
}

/* ============================================================
   PAGE HERO (casos.html, como-funciona.html)
   ============================================================ */
.page-hero{
  position:relative;
  padding:120px 0 80px;
  overflow:hidden;
  min-height:480px;
  display:flex;
  align-items:center;
}
.page-hero-bg{
  position:absolute; inset:0;
  background-size:cover;
  background-position:center;
  filter:saturate(.8) contrast(1.05);
  z-index:0;
}
.page-hero-overlay{
  position:absolute; inset:0;
  background:
    linear-gradient(to bottom, rgba(15,20,31,0.55) 0%, rgba(15,20,31,0.85) 80%, var(--noche) 100%),
    radial-gradient(ellipse 600px 300px at 30% 30%, rgba(165,149,208,.25), transparent 70%);
  z-index:1;
}
.page-hero-content{
  position:relative;
  z-index:2;
}
.page-hero-title{
  font-family:'Anton', sans-serif;
  font-weight:400;
  font-size:clamp(40px, 7vw, 72px);
  line-height:1;
  letter-spacing:.005em;
  color:var(--papel);
  margin:18px 0 18px;
  max-width:900px;
}
.page-hero-sub{
  font-size:17px;
  color:var(--apagado);
  max-width:680px;
  line-height:1.6;
}

/* ============================================================
   CASE CARD (casos.html)
   ============================================================ */
.case-card{
  background:var(--sombra);
  border:1px solid var(--sombra-hi);
  border-radius:14px;
  overflow:hidden;
  margin-bottom:32px;
  display:grid;
  grid-template-columns:1fr;
  transition:border-color .25s, transform .25s;
}
.case-card:hover{
  border-color:var(--lavanda-dark);
  transform:translateY(-2px);
}
@media (min-width:880px){
  .case-card{ grid-template-columns:480px 1fr; }
}
.case-cover{
  position:relative;
  min-height:280px;
  background-size:cover;
  background-position:center;
  background-color:var(--lavanda-dark);
}
.case-cover::after{
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(135deg, rgba(15,20,31,0.35) 0%, rgba(15,20,31,0) 60%);
}
.case-badge{
  position:absolute;
  top:18px; left:18px;
  background:var(--cinta);
  color:var(--noche);
  padding:6px 14px;
  font-family:'Special Elite', serif;
  font-size:11px;
  font-weight:700;
  letter-spacing:.22em;
  transform:rotate(-2deg);
  z-index:2;
  box-shadow:0 4px 12px rgba(0,0,0,.4);
}
.case-badge-soon{
  background:var(--sombra-hi);
  color:var(--lavanda);
}
.case-body{
  padding:32px 32px 28px;
}
.case-meta{
  display:flex;
  flex-wrap:wrap;
  gap:18px;
  margin-bottom:18px;
  padding-bottom:18px;
  border-bottom:1px solid var(--sombra-hi);
}
.case-mt{
  font-family:'JetBrains Mono', monospace;
  font-size:11.5px;
  color:var(--papel);
}
.case-mt strong{
  display:block;
  color:var(--lavanda);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.15em;
  font-size:10px;
  margin-bottom:3px;
}
.case-title{
  font-family:'Anton', sans-serif;
  font-weight:400;
  font-size:clamp(28px, 3.6vw, 38px);
  line-height:1.05;
  letter-spacing:.005em;
  color:var(--papel);
  margin-bottom:14px;
}
.case-pitch{
  font-size:17px;
  color:var(--papel);
  line-height:1.5;
  font-weight:500;
  margin-bottom:14px;
}
.case-body p{
  color:var(--apagado);
  font-size:14.5px;
  line-height:1.6;
  margin-bottom:16px;
}
.case-body p strong{
  color:var(--lavanda);
  font-weight:600;
}
.case-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:22px;
}
.case-tag{
  background:var(--sombra-hi);
  color:var(--papel);
  padding:5px 11px;
  border-radius:14px;
  font-size:11.5px;
  font-weight:500;
  letter-spacing:.04em;
}
.case-cta{
  align-self:flex-start;
}

/* ============================================================
   FUTURE CASES BLOCK
   ============================================================ */
.future-cases{
  text-align:center;
  margin-top:48px;
  padding:48px 32px;
  background:var(--sombra);
  border:1px dashed var(--sombra-hi);
  border-radius:14px;
}
.future-tag{
  display:inline-block;
  background:var(--lavanda);
  color:var(--noche);
  padding:5px 14px;
  font-family:'JetBrains Mono', monospace;
  font-size:10.5px;
  font-weight:600;
  letter-spacing:.22em;
  border-radius:4px;
  margin-bottom:16px;
}
.future-cases h3{
  font-family:'Anton', sans-serif;
  font-weight:400;
  font-size:32px;
  letter-spacing:.005em;
  color:var(--papel);
  margin-bottom:12px;
}
.future-cases p{
  color:var(--apagado);
  font-size:15px;
  line-height:1.6;
  max-width:620px;
  margin:0 auto 24px;
}

/* ============================================================
   ANATOMY GRID (como-funciona.html · anatomía del caso)
   ============================================================ */
.anatomy-grid{
  display:grid;
  gap:20px;
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
}
.anatomy-item{
  background:var(--sombra);
  border:1px solid var(--sombra-hi);
  border-radius:14px;
  padding:28px 24px;
  text-align:center;
  transition:border-color .25s, transform .25s;
}
.anatomy-item:hover{
  border-color:var(--lavanda-dark);
  transform:translateY(-3px);
}
.anatomy-num{
  font-family:'Anton', sans-serif;
  font-size:88px;
  line-height:.9;
  color:var(--lavanda);
  margin-bottom:6px;
}
.anatomy-label{
  font-family:'JetBrains Mono', monospace;
  font-size:11.5px;
  color:var(--papel);
  text-transform:uppercase;
  letter-spacing:.25em;
  font-weight:600;
  margin-bottom:14px;
}
.anatomy-item p{
  color:var(--apagado);
  font-size:14px;
  line-height:1.55;
}

/* ============================================================
   EVIDENCE TYPES GRID (como-funciona.html · tipos de evidencia)
   ============================================================ */
.evidence-types{
  display:grid;
  gap:20px;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
}
.ev-type{
  background:var(--noche);
  border:1px solid var(--sombra-hi);
  border-radius:14px;
  padding:24px;
  transition:border-color .25s, transform .25s;
}
.ev-type:hover{
  border-color:var(--lavanda-dark);
  transform:translateY(-3px);
}
.ev-icon{
  width:56px;
  height:56px;
  border-radius:50%;
  background:rgba(165,149,208,0.12);
  border:1.5px solid var(--lavanda-dark);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-bottom:14px;
  color:var(--lavanda);
}
.ev-icon svg{
  width:26px;
  height:26px;
}
.ev-type h3{
  font-family:'Anton', sans-serif;
  font-weight:400;
  font-size:22px;
  color:var(--papel);
  letter-spacing:.005em;
  margin-bottom:8px;
}
.ev-type p{
  color:var(--apagado);
  font-size:14px;
  line-height:1.55;
}

/* ============================================================
   MODES GRID (como-funciona.html · modos de juego)
   ============================================================ */
.modes-grid{
  display:grid;
  gap:20px;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
}
.mode{
  background:var(--sombra);
  border:1px solid var(--sombra-hi);
  border-radius:14px;
  padding:28px 26px;
  transition:border-color .25s, transform .25s;
}
.mode-featured{
  border-color:var(--lavanda);
  box-shadow:0 12px 36px rgba(165,149,208,.15);
}
.mode:hover{
  border-color:var(--lavanda);
  transform:translateY(-3px);
}
.mode-tag{
  display:inline-block;
  background:var(--lavanda);
  color:var(--noche);
  padding:4px 11px;
  font-family:'JetBrains Mono', monospace;
  font-size:10.5px;
  font-weight:700;
  letter-spacing:.22em;
  border-radius:4px;
  margin-bottom:14px;
}
.mode h3{
  font-family:'Anton', sans-serif;
  font-weight:400;
  font-size:26px;
  color:var(--papel);
  letter-spacing:.005em;
  margin-bottom:10px;
  line-height:1.1;
}
.mode p{
  color:var(--apagado);
  font-size:14.5px;
  line-height:1.55;
  margin-bottom:16px;
}
.mode ul{
  list-style:none;
  padding:0;
}
.mode li{
  padding:7px 0 7px 22px;
  position:relative;
  font-size:13.5px;
  color:var(--papel);
  border-top:1px solid var(--sombra-hi);
}
.mode li:first-child{ border-top:none; }
.mode li::before{
  content:'✓';
  position:absolute;
  left:0; top:7px;
  color:var(--lavanda);
  font-weight:700;
  font-size:14px;
}

/* ============================================================
   TIMELINE (como-funciona.html · una noche así)
   ============================================================ */
.timeline{
  list-style:none;
  padding:0;
  max-width:820px;
  margin:0 auto;
  counter-reset:tl;
  position:relative;
}
.timeline::before{
  content:'';
  position:absolute;
  left:90px; top:14px; bottom:14px;
  width:2px;
  background:linear-gradient(to bottom, var(--lavanda) 0%, var(--lavanda-dark) 60%, transparent 100%);
}
@media (max-width:680px){
  .timeline::before{ left:60px; }
}
.tl-item{
  display:grid;
  grid-template-columns:120px 1fr;
  gap:24px;
  padding:18px 0;
  position:relative;
}
@media (max-width:680px){
  .tl-item{ grid-template-columns:80px 1fr; gap:12px; }
}
.tl-time{
  font-family:'JetBrains Mono', monospace;
  font-size:18px;
  font-weight:600;
  color:var(--lavanda);
  text-align:right;
  padding-right:32px;
  padding-top:3px;
}
.tl-content{
  position:relative;
}
.tl-content::before{
  content:'';
  position:absolute;
  left:-39px; top:8px;
  width:12px; height:12px;
  border-radius:50%;
  background:var(--lavanda);
  border:3px solid var(--noche);
  box-shadow:0 0 0 2px var(--lavanda);
}
@media (max-width:680px){
  .tl-content::before{ left:-25px; }
}
.tl-content h3{
  font-family:'Anton', sans-serif;
  font-weight:400;
  font-size:22px;
  letter-spacing:.005em;
  color:var(--papel);
  margin-bottom:6px;
  line-height:1.1;
}
.tl-content p{
  color:var(--apagado);
  font-size:14.5px;
  line-height:1.6;
}
.tl-content p strong{
  color:var(--lavanda);
  font-weight:600;
}

/* ============================================================
   EVIDENCIA INTERACTIVA · index.html
   ============================================================ */
.sec-lead{
  color:var(--apagado);
  font-size:17px;
  max-width:720px;
  margin:-20px 0 32px;
  line-height:1.55;
}

.ev-grid{
  display:grid;
  gap:18px;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
  margin-bottom:32px;
}

.ev-card{
  position:relative;
  background:var(--noche);
  border:1px solid var(--sombra-hi);
  border-radius:14px;
  overflow:hidden;
  display:flex; flex-direction:column;
  cursor:pointer;
  text-align:left;
  font-family:inherit;
  color:inherit;
  padding:0;
  transition:transform .22s, border-color .22s, box-shadow .22s;
}
.ev-card:hover{
  transform:translateY(-4px);
  border-color:var(--lavanda);
  box-shadow:0 16px 40px rgba(165,149,208,.18);
}
.ev-card::after{
  content:'›';
  position:absolute;
  top:14px; right:14px;
  width:28px; height:28px;
  border-radius:50%;
  background:var(--sombra-hi);
  color:var(--lavanda);
  display:flex; align-items:center; justify-content:center;
  font-size:22px; font-weight:700;
  transition:background .22s, transform .22s;
}
.ev-card:hover::after{
  background:var(--lavanda);
  color:var(--noche);
  transform:translateX(2px);
}

.ev-card-preview{
  position:relative;
  height:170px;
  overflow:hidden;
  border-bottom:1px solid var(--sombra-hi);
}
.ev-card-meta{
  padding:18px 20px 20px;
}
.ev-card-tag{
  font-family:'JetBrains Mono', monospace;
  font-size:10.5px;
  font-weight:600;
  color:var(--lavanda);
  letter-spacing:.22em;
  text-transform:uppercase;
  margin-bottom:8px;
  display:inline-block;
}
.ev-card-meta h3{
  font-family:'Anton', sans-serif;
  font-weight:400;
  font-size:22px;
  color:var(--papel);
  letter-spacing:.005em;
  margin-bottom:6px;
  line-height:1.1;
}
.ev-card-meta p{
  color:var(--apagado);
  font-size:13.5px;
  line-height:1.5;
}

/* --- preview: CHAT --- */
.chat-preview{
  background:linear-gradient(135deg, #1a1f2c 0%, #232a3a 100%);
  padding:18px 18px;
  display:flex; flex-direction:column; gap:6px;
  justify-content:flex-end;
}
.cp-bubble{
  font-family:'Inter', sans-serif;
  font-size:12px;
  padding:6px 11px;
  border-radius:14px;
  max-width:80%;
  line-height:1.3;
}
.cp-them{
  background:var(--sombra-hi);
  color:var(--papel);
  align-self:flex-start;
  border-bottom-left-radius:4px;
}
.cp-me{
  background:var(--lavanda-dark);
  color:var(--blanco, var(--papel));
  align-self:flex-end;
  border-bottom-right-radius:4px;
}

/* --- preview: AUDIO --- */
.audio-preview{
  background:linear-gradient(135deg, #1a1f2c 0%, #2a2238 100%);
  display:flex; align-items:center; justify-content:center;
  padding:0 16px;
}
.aw-mini{
  display:flex; align-items:center; gap:3px; height:60px;
}
.aw-mini span{
  display:block;
  width:3px;
  border-radius:2px;
  background:var(--lavanda);
  animation:aw-mini-anim 1.6s ease-in-out infinite;
}
.aw-mini span:nth-child(1){ height:30%; animation-delay:0s; }
.aw-mini span:nth-child(2){ height:55%; animation-delay:.08s; }
.aw-mini span:nth-child(3){ height:45%; animation-delay:.16s; }
.aw-mini span:nth-child(4){ height:80%; animation-delay:.24s; }
.aw-mini span:nth-child(5){ height:60%; animation-delay:.32s; }
.aw-mini span:nth-child(6){ height:90%; animation-delay:.4s; }
.aw-mini span:nth-child(7){ height:50%; animation-delay:.48s; }
.aw-mini span:nth-child(8){ height:75%; animation-delay:.56s; }
.aw-mini span:nth-child(9){ height:35%; animation-delay:.64s; }
.aw-mini span:nth-child(10){ height:65%; animation-delay:.72s; }
.aw-mini span:nth-child(11){ height:55%; animation-delay:.8s; }
.aw-mini span:nth-child(12){ height:85%; animation-delay:.88s; }
.aw-mini span:nth-child(13){ height:45%; animation-delay:.96s; }
.aw-mini span:nth-child(14){ height:70%; animation-delay:1.04s; }
.aw-mini span:nth-child(15){ height:60%; animation-delay:1.12s; }
.aw-mini span:nth-child(16){ height:50%; animation-delay:1.2s; }
.aw-mini span:nth-child(17){ height:80%; animation-delay:1.28s; }
.aw-mini span:nth-child(18){ height:40%; animation-delay:1.36s; }
.aw-mini span:nth-child(19){ height:65%; animation-delay:1.44s; }
.aw-mini span:nth-child(20){ height:35%; animation-delay:1.52s; }
@keyframes aw-mini-anim {
  0%, 100%{ transform:scaleY(.55); opacity:.7; }
  50%{ transform:scaleY(1); opacity:1; }
}

/* --- preview: CCTV --- */
.cctv-preview{
  background:var(--noche) center/cover no-repeat;
  position:relative;
  filter:saturate(.7) brightness(.85);
}
.cctv-preview .cctv-corner{
  position:absolute;
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  color:#0f0;
  text-shadow:0 0 4px rgba(0,255,0,.6);
  letter-spacing:.1em;
  padding:6px 10px;
}
.cctv-corner-tl{ top:6px; left:6px; }
.cctv-corner-br{ bottom:6px; right:6px; }
.cctv-grain{
  position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(0deg, rgba(255,255,255,.02) 0 1px, transparent 1px 3px);
  pointer-events:none;
  mix-blend-mode:overlay;
}

/* --- preview: FORENSE --- */
.forensic-preview{
  background:#e8e2d0;
  padding:20px 18px;
  position:relative;
  overflow:hidden;
}
.fp-header{
  font-family:'Special Elite', monospace;
  font-size:9px;
  letter-spacing:.18em;
  color:#3a3a3a;
  margin-bottom:14px;
  padding-bottom:6px;
  border-bottom:1px solid #b8b0a0;
}
.fp-line{
  background:#6b665a;
  height:6px;
  margin-bottom:8px;
  border-radius:1px;
  opacity:.5;
}
.fp-line.short{ width:60%; }
.fp-stamp{
  position:absolute;
  top:60%; right:-25px;
  transform:rotate(-18deg);
  font-family:'Anton', sans-serif;
  color:var(--rojo);
  font-size:22px;
  letter-spacing:.2em;
  border:3px solid var(--rojo);
  padding:4px 14px;
  opacity:.55;
}

/* --- footer note de la sección --- */
.ev-foot{
  text-align:center;
  color:var(--apagado);
  font-size:14px;
  padding:14px 20px;
  background:rgba(165,149,208,0.06);
  border:1px dashed var(--lavanda-dark);
  border-radius:10px;
}
.ev-foot-dot{ color:var(--lavanda); font-size:11px; margin-right:4px; }
.ev-foot strong{ color:var(--papel); font-weight:600; }

/* ============================================================
   MODAL · base
   ============================================================ */
.ev-modal{
  background:var(--sombra);
  color:var(--papel);
  border:1px solid var(--lavanda-dark);
  border-radius:16px;
  padding:0;
  max-width:740px;
  width:92vw;
  max-height:88vh;
  overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.65);
}
/* Native <dialog> default es display:none. Cuando abre con showModal()
   el browser le agrega [open]. Aplicamos flex SOLO al abierto, para que
   al cerrar vuelva a desaparecer completamente. */
.ev-modal[open]{
  display:flex;
  flex-direction:column;
}
.ev-modal:not([open]){
  display:none;
}
.ev-modal::backdrop{
  background:rgba(15,20,31,.85);
  backdrop-filter:blur(6px);
}
.ev-modal[open]{
  animation:modal-in .22s ease-out;
}
@keyframes modal-in {
  from{ opacity:0; transform:translateY(12px) scale(.98); }
  to{ opacity:1; transform:translateY(0) scale(1); }
}
.ev-modal-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 22px;
  background:var(--sombra-hi);
  border-bottom:1px solid var(--lavanda-dark);
  flex-shrink:0;
}
.ev-modal-tag{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  color:var(--lavanda);
  letter-spacing:.28em;
  font-weight:600;
}
.ev-modal-close{
  background:transparent;
  border:1px solid var(--sombra-hi);
  color:var(--papel);
  width:34px; height:34px;
  border-radius:50%;
  font-size:22px;
  font-family:inherit;
  cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  line-height:1;
  transition:background .2s, border-color .2s;
}
.ev-modal-close:hover{
  background:var(--rojo);
  border-color:var(--rojo);
  color:var(--papel);
}

/* ============================================================
   MODAL: CHAT
   ============================================================ */
.chat-wrap{ overflow-y:auto; padding:0; }
.chat-header{
  display:flex; gap:12px; align-items:center;
  padding:18px 22px;
  background:linear-gradient(180deg, #232b3a 0%, #1d2330 100%);
  border-bottom:1px solid var(--sombra-hi);
}
.chat-avatar{
  width:42px; height:42px; border-radius:50%;
  background:linear-gradient(135deg, var(--lavanda) 0%, var(--lavanda-dark) 100%);
  display:flex; align-items:center; justify-content:center;
  font-family:'Anton', sans-serif;
  font-size:20px; color:var(--noche);
  flex-shrink:0;
}
.chat-name{ font-family:'Inter', sans-serif; font-weight:700; font-size:15px; color:var(--papel); }
.chat-sub{ font-size:11px; color:var(--apagado); font-family:'JetBrains Mono', monospace; letter-spacing:.05em; }
.chat-body{
  padding:24px 22px;
  background:
    radial-gradient(ellipse 500px 200px at 50% 0%, rgba(165,149,208,.07), transparent 70%),
    var(--noche);
  display:flex; flex-direction:column; gap:10px;
}
.chat-day{
  text-align:center;
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  color:var(--apagado);
  margin-bottom:6px;
  letter-spacing:.2em;
}
.chat-msg{ display:flex; flex-direction:column; max-width:78%; }
.chat-msg.me{ align-self:flex-end; align-items:flex-end; }
.chat-msg.them{ align-self:flex-start; align-items:flex-start; }
.chat-bubble{
  padding:10px 14px;
  border-radius:18px;
  font-size:14.5px;
  line-height:1.4;
  font-family:'Inter', sans-serif;
}
.chat-msg.me .chat-bubble{
  background:var(--lavanda-dark);
  color:var(--papel);
  border-bottom-right-radius:5px;
}
.chat-msg.them .chat-bubble{
  background:var(--sombra-hi);
  color:var(--papel);
  border-bottom-left-radius:5px;
}
.chat-bubble.bubble-red{
  background:var(--rojo);
  color:var(--papel);
  font-weight:500;
}
.chat-time{
  font-size:10px;
  color:var(--tenue);
  font-family:'JetBrains Mono', monospace;
  margin-top:3px;
  padding:0 4px;
}
.chat-note{
  background:rgba(200,48,43,.08);
  border-top:1px solid var(--rojo-dark);
  padding:16px 22px;
  font-size:13.5px;
  color:var(--papel);
  line-height:1.55;
}
.chat-note strong{ color:var(--rojo); }

/* Audio note (igual estilo que chat-note pero usado en audio modals) */
.audio-note{
  margin-top:18px;
  background:rgba(200,48,43,.10);
  border-left:3px solid var(--rojo);
  padding:14px 18px;
  border-radius:0 8px 8px 0;
  font-size:13.5px;
  color:var(--papel);
  line-height:1.6;
}
.audio-note strong{ color:var(--rojo); font-weight:700; }

/* ============================================================
   MODAL: AUDIO
   ============================================================ */
.audio-wrap{ overflow-y:auto; padding:24px 26px 26px; }
.audio-meta-tag{
  font-family:'JetBrains Mono', monospace;
  font-size:10.5px;
  color:var(--lavanda);
  letter-spacing:.25em;
  font-weight:600;
  margin-bottom:6px;
  display:inline-block;
}
.audio-meta h3{
  font-family:'Anton', sans-serif;
  font-weight:400;
  font-size:32px;
  color:var(--papel);
  letter-spacing:.01em;
  line-height:1;
  margin-bottom:6px;
}
.audio-meta-sub{
  font-size:12.5px;
  color:var(--apagado);
  font-family:'JetBrains Mono', monospace;
  letter-spacing:.05em;
  margin-bottom:24px;
}
.audio-player{
  display:flex; gap:16px; align-items:center;
  padding:18px;
  background:var(--noche);
  border:1px solid var(--sombra-hi);
  border-radius:12px;
  margin-bottom:18px;
}
.audio-play{
  width:54px; height:54px;
  border-radius:50%;
  background:var(--lavanda);
  color:var(--noche);
  border:none;
  cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:transform .15s, background .2s;
  flex-shrink:0;
}
.audio-play:hover{ transform:scale(1.05); background:var(--lavanda-light); }
.audio-play svg{ width:22px; height:22px; margin-left:2px; }
.audio-play.is-playing svg{ display:none; }
.audio-play.is-playing::before{
  content:'';
  display:block;
  width:14px; height:14px;
  background:var(--noche);
  border-radius:2px;
}
.audio-track{ flex:1; }
.audio-waveform{
  display:flex;
  gap:2px;
  height:50px;
  align-items:center;
  margin-bottom:6px;
}
.audio-waveform span{
  display:block;
  flex:1;
  height:var(--h);
  background:var(--lavanda-dark);
  border-radius:1px;
  transition:background .3s;
}
.audio-waveform span.is-played{ background:var(--lavanda); }
.audio-times{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  color:var(--apagado);
  letter-spacing:.05em;
  display:flex; justify-content:space-between;
}
.audio-transcript{
  background:rgba(165,149,208,.08);
  border-left:3px solid var(--lavanda);
  padding:14px 18px;
  border-radius:0 8px 8px 0;
}
.audio-transcript-label{
  font-family:'JetBrains Mono', monospace;
  font-size:10.5px;
  color:var(--lavanda);
  letter-spacing:.25em;
  font-weight:600;
  margin-bottom:8px;
}
.audio-transcript p{
  font-size:14px;
  line-height:1.6;
  color:var(--papel);
  font-style:italic;
}
.audio-transcript p strong{ color:var(--lavanda); font-style:normal; }

/* ============================================================
   SOBRE.HTML
   ============================================================ */
.manifesto-grid{
  display:grid;
  gap:20px;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
}
.manifesto-card{
  background:var(--sombra);
  border:1px solid var(--sombra-hi);
  border-radius:14px;
  padding:28px 26px;
  transition:transform .25s, border-color .25s;
}
.manifesto-card:hover{
  transform:translateY(-4px);
  border-color:var(--lavanda-dark);
}
.manifesto-icon{
  width:48px; height:48px;
  border-radius:12px;
  background:rgba(165,149,208,0.12);
  border:1.5px solid var(--lavanda-dark);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--lavanda);
  margin-bottom:16px;
}
.manifesto-icon svg{ width:24px; height:24px; }
.manifesto-card h3{
  font-family:'Anton', sans-serif;
  font-weight:400;
  font-size:22px;
  color:var(--papel);
  letter-spacing:.005em;
  margin-bottom:10px;
  line-height:1.15;
}
.manifesto-card p{
  color:var(--apagado);
  font-size:14.5px;
  line-height:1.6;
}
.manifesto-card p strong{ color:var(--lavanda); font-weight:600; }

/* TEAM */
.team-grid{
  display:grid;
  gap:20px;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  margin-bottom:32px;
}
.team-card{
  background:var(--noche);
  border:1px solid var(--sombra-hi);
  border-radius:14px;
  padding:28px 26px;
  transition:border-color .25s;
}
.team-card:hover{ border-color:var(--lavanda); }
.team-role-icon{
  width:56px; height:56px;
  border-radius:50%;
  background:linear-gradient(135deg, var(--lavanda) 0%, var(--lavanda-dark) 100%);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--noche);
  margin-bottom:18px;
}
.team-role-icon svg{ width:24px; height:24px; }
.team-role{
  font-family:'JetBrains Mono', monospace;
  font-size:10.5px;
  color:var(--lavanda);
  letter-spacing:.22em;
  font-weight:600;
  margin-bottom:8px;
}
.team-meta h3{
  font-family:'Anton', sans-serif;
  font-weight:400;
  font-size:24px;
  color:var(--papel);
  letter-spacing:.005em;
  margin-bottom:10px;
  line-height:1.15;
}
.team-card p{
  color:var(--apagado);
  font-size:14px;
  line-height:1.6;
}
.team-card em{ color:var(--lavanda); font-style:italic; }
.team-photo{
  width:100%;
  height:380px;
  border-radius:14px;
  background-size:cover;
  background-position:center;
  filter:saturate(.85);
  margin-top:20px;
  border:1px solid var(--sombra-hi);
}

/* PROCESS */
.process-list{
  list-style:none;
  padding:0;
  max-width:900px;
  margin:0 auto 32px;
}
.proc-step{
  display:grid;
  grid-template-columns:80px 1fr;
  gap:28px;
  padding:24px 0;
  border-bottom:1px solid var(--sombra-hi);
}
.proc-step:last-child{ border-bottom:none; }
@media (max-width:680px){
  .proc-step{ grid-template-columns:60px 1fr; gap:18px; }
}
.proc-num{
  font-family:'Anton', sans-serif;
  font-size:54px;
  line-height:1;
  color:var(--lavanda);
  text-align:right;
}
.proc-body h3{
  font-family:'Anton', sans-serif;
  font-weight:400;
  font-size:24px;
  color:var(--papel);
  letter-spacing:.005em;
  margin-bottom:8px;
  line-height:1.15;
}
.proc-body p{
  color:var(--apagado);
  font-size:15px;
  line-height:1.65;
}
.proc-body p strong{ color:var(--lavanda); font-weight:600; }
.process-image{
  width:100%;
  height:340px;
  border-radius:14px;
  background-size:cover;
  background-position:center;
  filter:saturate(.85);
  border:1px solid var(--sombra-hi);
  margin-top:18px;
}

/* NOT US */
.not-us-grid{
  display:grid;
  gap:20px;
  grid-template-columns:repeat(auto-fit, minmax(260px, 1fr));
}
.not-us-item{
  background:var(--noche);
  border:1px solid var(--sombra-hi);
  border-radius:14px;
  padding:26px 24px;
  position:relative;
  transition:border-color .25s, transform .25s;
}
.not-us-item:hover{
  border-color:var(--rojo);
  transform:translateY(-3px);
}
.not-us-x{
  position:absolute;
  top:18px; right:20px;
  font-family:'Anton', sans-serif;
  font-size:36px;
  line-height:1;
  color:var(--rojo);
  opacity:.5;
}
.not-us-item h3{
  font-family:'Anton', sans-serif;
  font-weight:400;
  font-size:22px;
  color:var(--papel);
  letter-spacing:.005em;
  margin-bottom:12px;
  line-height:1.15;
  padding-right:30px;
}
.not-us-item p{
  color:var(--apagado);
  font-size:14px;
  line-height:1.6;
}
.not-us-item p strong{ color:var(--papel); font-weight:600; }

/* ============================================================
   404.HTML
   ============================================================ */
.body-404{ overflow:hidden; height:100vh; }
.page-404{
  position:relative;
  min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
}
.page-404-bg{
  position:absolute; inset:0;
  background-size:cover;
  background-position:center;
  filter:saturate(.55) brightness(.5) contrast(1.1);
  z-index:0;
}
.page-404-overlay{
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 600px 400px at 50% 40%, rgba(165,149,208,.15), transparent 70%),
    linear-gradient(135deg, rgba(15,20,31,.92), rgba(27,35,48,.88));
  z-index:1;
}
.page-404-content{
  position:relative;
  z-index:2;
  text-align:center;
  max-width:680px;
  padding:48px 24px;
}
.page-404-brand{
  display:inline-flex; align-items:center; gap:12px;
  margin-bottom:36px;
}
.page-404-stamp{
  display:inline-block;
  border:3px solid var(--rojo);
  color:var(--rojo);
  padding:6px 18px;
  font-family:'Anton', sans-serif;
  font-size:18px;
  letter-spacing:.25em;
  transform:rotate(-3deg);
  margin-bottom:20px;
  opacity:.95;
}
.page-404-title{
  font-family:'Anton', sans-serif;
  font-weight:400;
  font-size:clamp(120px, 22vw, 220px);
  line-height:.9;
  letter-spacing:-.02em;
  color:var(--papel);
  text-shadow:6px 6px 0 var(--lavanda-dark), 12px 12px 0 rgba(200,48,43,.45);
  margin-bottom:20px;
}
.page-404-sub{
  font-family:'Anton', sans-serif;
  font-size:clamp(24px, 4vw, 36px);
  color:var(--papel);
  line-height:1.15;
  margin-bottom:32px;
  font-weight:400;
  letter-spacing:.005em;
}
.page-404-clue{
  background:rgba(165,149,208,.10);
  border-left:3px solid var(--lavanda);
  padding:18px 22px;
  border-radius:0 10px 10px 0;
  text-align:left;
  max-width:520px;
  margin:0 auto 32px;
}
.page-404-clue-label{
  font-family:'JetBrains Mono', monospace;
  font-size:10.5px;
  color:var(--lavanda);
  letter-spacing:.28em;
  font-weight:600;
  margin-bottom:8px;
}
.page-404-clue p{
  font-size:14.5px;
  color:var(--papel);
  line-height:1.6;
}
.page-404-clue em{ color:var(--rojo); font-style:italic; }
.page-404-actions{
  display:flex;
  gap:12px;
  justify-content:center;
  flex-wrap:wrap;
  margin-bottom:32px;
}
.page-404-foot{
  font-size:13px;
  color:var(--apagado);
}
.page-404-foot a{
  color:var(--lavanda);
  text-decoration:underline;
}
.page-404-foot a:hover{ color:var(--lavanda-light); }

/* ============================================================
   MODAL: CCTV
   ============================================================ */
.cctv-wrap{ overflow-y:auto; }
.cctv-frame{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  background:#000 center/cover no-repeat;
  filter:saturate(.7) brightness(.92) contrast(1.1);
  font-family:'JetBrains Mono', monospace;
  color:#0f0;
  text-shadow:0 0 4px rgba(0,255,0,.6);
}
.cctv-overlay-tl, .cctv-overlay-tr{
  position:absolute;
  padding:10px 14px;
  font-size:11px;
  letter-spacing:.12em;
}
.cctv-overlay-tl{ top:8px; left:8px; }
.cctv-overlay-tr{ top:8px; right:8px; text-align:right; }
.cctv-rec{
  display:flex; align-items:center; gap:6px;
  font-weight:700;
  margin-bottom:4px;
}
.cctv-dot{
  width:8px; height:8px; border-radius:50%;
  background:#f00; box-shadow:0 0 6px #f00;
  animation:cctv-blink 1.2s infinite;
}
@keyframes cctv-blink { 0%, 50%{ opacity:1; } 51%, 100%{ opacity:.2; } }
.cctv-cam{ font-size:10px; opacity:.85; }
.cctv-ts{ font-weight:700; font-size:13px; }
.cctv-date{ font-size:10px; opacity:.85; margin-top:2px; }
.cctv-frame .cctv-grain{
  position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(0deg, rgba(255,255,255,.03) 0 1px, transparent 1px 3px);
  mix-blend-mode:overlay;
  pointer-events:none;
}
.cctv-scanline{
  position:absolute; left:0; right:0;
  height:3px;
  background:linear-gradient(to bottom, transparent, rgba(255,255,255,.15), transparent);
  animation:cctv-scan 4s linear infinite;
  pointer-events:none;
}
@keyframes cctv-scan { from{ top:-3px; } to{ top:100%; } }
.cctv-meta{
  padding:18px 24px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px 24px;
}
.cctv-meta-item{
  font-size:13.5px;
  color:var(--apagado);
}
.cctv-meta-item strong{
  display:block;
  font-family:'JetBrains Mono', monospace;
  font-size:10.5px;
  letter-spacing:.22em;
  color:var(--lavanda);
  margin-bottom:3px;
  text-transform:uppercase;
  font-weight:600;
}
.cctv-meta-item span{ color:var(--papel); }
@media (max-width:520px){
  .cctv-meta{ grid-template-columns:1fr; }
}

/* ============================================================
   MODAL: FORENSE
   ============================================================ */
.forensic-wrap{
  overflow-y:auto;
  padding:24px;
  background:repeating-linear-gradient(0deg, var(--sombra) 0 32px, var(--sombra-hi) 32px 33px);
}
.forensic-doc{
  background:
    repeating-linear-gradient(0deg, transparent 0 26px, rgba(0,0,0,.04) 26px 27px),
    linear-gradient(180deg, #f5efd9 0%, #ebe2c6 100%);
  color:#2a2520;
  padding:32px 32px 28px;
  border-radius:4px;
  box-shadow:0 12px 36px rgba(0,0,0,.4);
  position:relative;
  overflow:hidden;
}
.forensic-doc-head{
  display:flex; align-items:center; gap:14px;
  padding-bottom:14px;
  border-bottom:2px solid #2a2520;
  margin-bottom:18px;
}
.fd-logo{
  width:42px; height:42px; border-radius:50%;
  background:#2a2520;
  color:#f5efd9;
  display:flex; align-items:center; justify-content:center;
  font-size:22px;
  flex-shrink:0;
}
.fd-org{
  font-family:'Special Elite', monospace;
  font-size:11px;
  letter-spacing:.22em;
  margin-bottom:2px;
}
.fd-num{
  font-family:'Anton', sans-serif;
  font-size:18px;
  letter-spacing:.02em;
  color:#2a2520;
}
.forensic-stamp{
  position:absolute;
  top:42%; right:-30px;
  transform:rotate(-12deg);
  font-family:'Anton', sans-serif;
  color:var(--rojo);
  font-size:48px;
  letter-spacing:.2em;
  border:5px solid var(--rojo);
  padding:8px 26px;
  opacity:.42;
  pointer-events:none;
  white-space:nowrap;
}
.forensic-table{
  width:100%;
  border-collapse:collapse;
  font-family:'Inter', sans-serif;
  font-size:13.5px;
  margin-bottom:18px;
}
.forensic-table td{
  padding:9px 4px;
  border-bottom:1px solid rgba(42,37,32,.2);
  vertical-align:top;
}
.forensic-table td:first-child{
  font-family:'Special Elite', monospace;
  color:#5a4d3a;
  width:38%;
  text-transform:uppercase;
  font-size:11px;
  letter-spacing:.12em;
  padding-right:14px;
}
.forensic-table td:last-child{
  color:#2a2520;
  font-weight:500;
}
.forensic-table strong{ color:var(--rojo); font-weight:700; }
.redacted{
  display:inline-block;
  background:#2a2520;
  color:#2a2520;
  letter-spacing:-.1em;
  padding:0 4px;
  border-radius:2px;
}
.forensic-note{
  background:rgba(200,48,43,.08);
  border-left:3px solid var(--rojo);
  padding:12px 16px;
  font-size:13px;
  color:#2a2520;
  margin-bottom:24px;
  border-radius:0 4px 4px 0;
  line-height:1.55;
}
.forensic-note strong{ color:var(--rojo); }
.forensic-sign{
  font-family:'Special Elite', monospace;
  font-size:11px;
  color:#5a4d3a;
  text-align:right;
}
.forensic-sign-line{
  width:200px;
  height:1px;
  background:#2a2520;
  margin:18px 0 4px auto;
}
