/* casos-deep.css · estilos compartidos de páginas /casos/<slug>/index.html
   Cada caso de estudio público comparte este shell. Mismo brutalist + y2k MX
   que el resto del sitio. NO em-dashes en copy. */

:root{
  --ink:#0a0a0a;
  --paper:#f4f1ea;
  --paper-alt:#ece8de;
  --dim:#8a8680;
  --accent:#ff2d6f;
  --cyan:#00d4ff;
  --lime:#c8ff2e;
  --yellow:#ffd400;
  --mono:'JetBrains Mono','Courier New',monospace;
  --display:'Archivo Black','Anton',Impact,sans-serif;
  --sans:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{
  background:var(--paper);color:var(--ink);font-family:var(--sans);
  line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
::selection{background:var(--accent);color:#fff}
a{color:inherit}
img,svg{max-width:100%;display:block}

/* TOPBAR consistente con resto del sitio */
.topbar{
  position:sticky;top:0;z-index:50;
  background:var(--ink);color:var(--paper);
  border-bottom:3px solid var(--ink);
  padding:10px 16px;
  display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;
  font-family:var(--mono);font-size:11px;letter-spacing:1.4px;text-transform:uppercase;font-weight:700;
}
.topbar a.brand{display:flex;align-items:center;gap:8px;text-decoration:none;color:inherit;cursor:pointer;transition:opacity .15s}
.topbar a.brand:hover{opacity:.7}
.topbar .brand .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);display:inline-block;
  animation:pulse-dot 2s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}
.topbar-nav{display:none;gap:16px;align-items:center;font-family:var(--mono);font-size:11px;letter-spacing:1.4px;text-transform:uppercase;font-weight:700}
@media(min-width:760px){.topbar-nav{display:flex}}
.topbar-nav a{color:rgba(244,241,234,.65);text-decoration:none;border-bottom:1.5px solid transparent;padding-bottom:1px;transition:color .15s,border-color .15s}
.topbar-nav a:hover,.topbar-nav a.active{color:var(--lime);border-bottom-color:var(--lime)}

/* WRAP */
.wrap{max-width:920px;margin:0 auto;padding:24px 16px 80px}
@media(min-width:768px){.wrap{padding:36px 28px 110px}}
section{margin-top:30px}
@media(min-width:768px){section{margin-top:44px}}

/* TYPE primitives */
.lab{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:1.4px;color:var(--dim)}
.lab.light{color:rgba(244,241,234,.7)}

/* HERO */
.hero{
  background:var(--ink);color:var(--paper);
  border:3px solid var(--ink);
  box-shadow:6px 6px 0 var(--lime);
  padding:30px 22px;margin-top:24px;
  position:relative;overflow:hidden;
}
@media(min-width:768px){.hero{padding:48px 40px}}
.hero::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--lime) 0%,var(--accent) 50%,var(--cyan) 100%);
  background-size:200% 100%;animation:slide-bg 6s linear infinite;
}
@keyframes slide-bg{0%{background-position:0% 0}100%{background-position:200% 0}}
.hero .eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:1.6px;text-transform:uppercase;color:rgba(244,241,234,.7);margin-bottom:14px}
.hero h1{
  font-family:var(--display);
  font-size:clamp(38px,8.4vw,76px);
  text-transform:uppercase;line-height:.9;letter-spacing:-1.6px;
}
.hero h1 .accent{background:var(--accent);color:#fff;padding:0 11px;display:inline-block;transform:rotate(-1deg)}
.hero h1 .out{-webkit-text-stroke:1.6px var(--paper);color:transparent}
.hero .lead{
  margin-top:22px;
  font-family:var(--display);
  font-size:clamp(17px,3vw,24px);
  text-transform:uppercase;line-height:1.2;max-width:680px;
}
.hero .lead b{background:var(--lime);color:var(--ink);padding:0 6px}
.hero .meta-row{
  margin-top:24px;padding-top:18px;border-top:2px dashed rgba(244,241,234,.3);
  display:flex;flex-wrap:wrap;gap:8px 22px;
  font-family:var(--mono);font-size:11px;letter-spacing:1.3px;text-transform:uppercase;color:rgba(244,241,234,.7);
}

/* TL;DR card destacado */
.tldr{
  background:var(--lime);color:var(--ink);
  border:3px solid var(--ink);
  box-shadow:6px 6px 0 var(--ink);
  padding:24px 20px;
}
@media(min-width:768px){.tldr{padding:32px 30px}}
.tldr .lab{color:rgba(10,10,10,.65)}
.tldr h2{font-family:var(--display);font-size:clamp(22px,4.4vw,34px);text-transform:uppercase;line-height:.95;letter-spacing:-.4px;margin-top:8px}
.tldr ul{margin-top:14px;list-style:none;font-family:var(--mono);font-size:13.5px;line-height:1.75}
.tldr ul li{margin-bottom:4px}
.tldr ul li b{background:var(--ink);color:var(--lime);padding:1px 6px;font-weight:700}
.tldr p{font-family:var(--mono);font-size:13px;line-height:1.65;margin-top:14px}
.tldr p b{background:var(--ink);color:var(--lime);padding:1px 5px}

/* SECCION TITLE */
.sec-head{margin-bottom:14px}
.sec-head h2{
  font-family:var(--display);font-size:clamp(28px,5.6vw,42px);
  text-transform:uppercase;line-height:.95;letter-spacing:-.5px;margin-top:4px;
}
.sec-head h2 .hl{background:var(--lime);padding:0 8px;display:inline-block;transform:rotate(-1deg);border:3px solid var(--ink)}
.sec-head h2 .hl-y{background:var(--yellow);padding:0 8px;display:inline-block;transform:rotate(1deg);border:3px solid var(--ink)}
.sec-head h2 .accent{background:var(--accent);color:#fff;padding:0 8px;display:inline-block;transform:rotate(-1deg)}

/* PROSE — body de párrafos largos */
.prose{font-family:var(--sans);font-size:15.5px;line-height:1.7;color:var(--ink)}
.prose p{margin-top:14px;max-width:720px}
.prose p:first-child{margin-top:0}
.prose b,.prose strong{background:var(--lime);color:var(--ink);padding:1px 5px;font-weight:700}
.prose b.cyan{background:var(--cyan)}
.prose b.yellow{background:var(--yellow)}
.prose b.ink{background:var(--ink);color:var(--lime)}
.prose h3{
  font-family:var(--display);font-size:clamp(20px,3.4vw,26px);
  text-transform:uppercase;line-height:1.05;letter-spacing:-.3px;
  margin-top:28px;
}
.prose ul, .prose ol{margin-top:14px;padding-left:22px;font-size:15px;line-height:1.7}
.prose li{margin-bottom:6px}
.prose li::marker{color:var(--accent)}

/* STATS GRID */
.stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
@media(min-width:560px){.stats{grid-template-columns:repeat(4,1fr);gap:12px}}
.stat{
  border:3px solid var(--ink);background:#fff;
  box-shadow:6px 6px 0 var(--ink);padding:18px 16px;
}
.stat.lime{background:var(--lime)}
.stat.cyan{background:var(--cyan)}
.stat.accent{background:var(--accent);color:#fff}
.stat.accent .lab{color:rgba(255,255,255,.85)}
.stat .v{font-family:var(--display);font-size:clamp(24px,5vw,34px);line-height:.92;margin-top:8px;font-variant-numeric:tabular-nums;letter-spacing:-.5px}
.stat .sub{font-family:var(--mono);font-size:10.5px;color:var(--dim);margin-top:8px;letter-spacing:.6px}
.stat.lime .sub,.stat.cyan .sub{color:rgba(10,10,10,.65)}
.stat.accent .sub{color:rgba(255,255,255,.9)}

/* COMPARE PAUTA · price anchor */
.compare-paid{
  margin-top:18px;background:var(--ink);color:var(--paper);
  border:3px solid var(--ink);box-shadow:6px 6px 0 var(--cyan);padding:24px;
}
@media(min-width:768px){.compare-paid{padding:32px}}
.compare-paid .lab{color:rgba(244,241,234,.7)}
.compare-paid h3{font-family:var(--display);font-size:clamp(22px,4.4vw,32px);text-transform:uppercase;line-height:1;margin-top:8px}
.compare-paid h3 .hl{background:var(--cyan);color:var(--ink);padding:0 8px}
.compare-paid h3 .hl-pink{background:var(--accent);color:#fff;padding:0 8px}
.compare-paid p{font-family:var(--mono);font-size:13px;line-height:1.65;margin-top:14px;opacity:.92}
.compare-paid p b{background:var(--cyan);color:var(--ink);padding:1px 5px;font-weight:700}
.compare-paid .vs-grid{
  margin-top:18px;display:grid;grid-template-columns:1fr;gap:12px;
}
@media(min-width:560px){.compare-paid .vs-grid{grid-template-columns:1fr 1fr;gap:16px}}
.compare-paid .vs-box{
  border:2.5px solid var(--paper);padding:16px 14px;
}
.compare-paid .vs-box.win{background:var(--lime);color:var(--ink);border-color:var(--ink)}
.compare-paid .vs-box .l{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:1.3px;color:rgba(244,241,234,.7);margin-bottom:6px}
.compare-paid .vs-box.win .l{color:rgba(10,10,10,.7)}
.compare-paid .vs-box .v{font-family:var(--display);font-size:clamp(24px,4.6vw,32px);line-height:1;letter-spacing:-.6px}
.compare-paid .vs-box .sub{font-family:var(--mono);font-size:10.5px;margin-top:6px;letter-spacing:.6px}

/* QUOTE block */
.quote-block{
  background:var(--ink);color:var(--paper);
  border:3px solid var(--ink);box-shadow:6px 6px 0 var(--accent);
  padding:24px;margin-top:18px;
}
@media(min-width:768px){.quote-block{padding:34px}}
.quote-block .lab{color:rgba(244,241,234,.7)}
.quote-block .quote{
  font-family:var(--display);font-size:clamp(22px,4.4vw,32px);
  text-transform:uppercase;line-height:1.1;color:#fff;margin-top:14px;letter-spacing:-.4px;
}
.quote-block .attrib{font-family:var(--mono);font-size:11px;color:rgba(244,241,234,.7);margin-top:14px;letter-spacing:1.2px;text-transform:uppercase}
.quote-block .attrib .cyan{color:var(--cyan)}

/* THUMB row · video preview + caption */
.thumb-row{display:grid;grid-template-columns:1fr;gap:18px;margin-top:14px}
@media(min-width:680px){.thumb-row{grid-template-columns:280px 1fr;align-items:start;gap:24px}}
.thumb-frame{aspect-ratio:9/16;border:3px solid var(--ink);box-shadow:6px 6px 0 var(--ink);overflow:hidden;background:var(--ink);max-width:280px;margin:0 auto}
.thumb-frame a{display:block;width:100%;height:100%;text-decoration:none;color:inherit;position:relative}
.thumb-frame img{width:100%;height:100%;object-fit:cover;display:block}
.thumb-frame .overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,0.65) 100%);color:#fff;text-align:center;padding:18px}
.thumb-frame .play{font-family:var(--display);font-size:60px;line-height:1;opacity:.95;margin-bottom:8px}
.thumb-frame .cta{font-family:var(--mono);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;background:var(--accent);padding:6px 12px;border:2px solid #fff;margin-top:auto}

/* CTA CIERRE */
.closing{
  margin-top:30px;background:var(--lime);color:var(--ink);
  border:3px solid var(--ink);box-shadow:8px 8px 0 var(--ink);
  padding:30px 22px;
}
@media(min-width:768px){.closing{padding:44px 40px}}
.closing .lab{color:rgba(10,10,10,.65)}
.closing h2{font-family:var(--display);font-size:clamp(28px,6vw,42px);text-transform:uppercase;line-height:.95;letter-spacing:-.5px;margin-top:8px}
.closing h2 .hl{background:var(--ink);color:var(--lime);padding:0 8px;display:inline-block}
.closing p{font-family:var(--sans);font-size:15.5px;line-height:1.65;margin-top:14px;max-width:660px}
.closing .cta-row{margin-top:22px;display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:560px){.closing .cta-row{grid-template-columns:1fr 1fr;gap:14px}}
.closing .btn{
  display:flex;flex-direction:column;align-items:flex-start;gap:6px;
  padding:18px 20px;border:3px solid var(--ink);text-decoration:none;color:inherit;
  transition:transform .15s cubic-bezier(.2,.8,.2,1),box-shadow .15s;
  box-shadow:5px 5px 0 var(--ink);cursor:pointer;
}
.closing .btn:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--ink)}
.closing .btn.go{background:#22c55e;color:#fff}
.closing .btn.alt{background:#fff;color:var(--ink)}
.closing .btn .title{font-family:var(--display);font-size:18px;text-transform:uppercase;line-height:1;letter-spacing:-.3px}
.closing .btn .sub{font-family:var(--mono);font-size:10.5px;letter-spacing:1.2px;text-transform:uppercase;opacity:.85;line-height:1.5}

/* RELATED CASES · cross-link */
.related{margin-top:36px;border-top:1px solid var(--ink);padding-top:24px}
.related .grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:14px}
@media(min-width:680px){.related .grid{grid-template-columns:1fr 1fr}}
.related .item{
  border:2.5px solid var(--ink);background:#fff;padding:16px 18px;
  text-decoration:none;color:var(--ink);box-shadow:5px 5px 0 var(--ink);
  transition:transform .15s,box-shadow .15s;display:block;
}
.related .item:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--ink)}
.related .item .lab{margin-bottom:4px}
.related .item .name{font-family:var(--display);font-size:18px;text-transform:uppercase;letter-spacing:-.2px;line-height:1.05}
.related .item .num{font-family:var(--mono);font-size:11.5px;color:var(--dim);margin-top:6px;letter-spacing:.5px}

/* BREADCRUMBS · UX + SEO */
.breadcrumbs{
  margin-top:18px;font-family:var(--mono);font-size:11px;letter-spacing:1.3px;
  text-transform:uppercase;color:var(--dim);
}
.breadcrumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.breadcrumbs li{display:inline-flex;align-items:center;gap:6px}
.breadcrumbs li + li::before{content:'/';color:var(--dim);margin-right:0}
.breadcrumbs a{color:var(--ink);text-decoration:none;border-bottom:1.5px solid transparent;padding-bottom:1px;transition:border-color .15s,color .15s}
.breadcrumbs a:hover{border-bottom-color:var(--accent);color:var(--accent)}
.breadcrumbs .current{color:var(--ink);font-weight:700}

/* LAST-UPDATED badge · E-E-A-T signal */
.updated{
  margin-top:14px;display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:1.3px;
  text-transform:uppercase;color:rgba(244,241,234,.7);
  background:rgba(255,255,255,.08);
  border:1.5px solid rgba(244,241,234,.3);
  padding:5px 10px;
}
.updated .dot{width:6px;height:6px;border-radius:50%;background:var(--lime);display:inline-block;animation:pulse-dot 2s ease-in-out infinite}

/* FAQ · accordion brutalist · semantic details/summary (no JS) */
.faq-list{display:grid;grid-template-columns:1fr;gap:10px;margin-top:16px}
.faq-item{
  border:3px solid var(--ink);background:#fff;
  box-shadow:5px 5px 0 var(--ink);transition:box-shadow .15s;
}
.faq-item[open]{box-shadow:7px 7px 0 var(--lime)}
.faq-item summary{
  list-style:none;cursor:pointer;
  padding:16px 18px;display:flex;align-items:center;gap:14px;
  font-family:var(--display);font-size:clamp(15px,2.4vw,18px);
  text-transform:uppercase;line-height:1.2;letter-spacing:-.2px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:'+';margin-left:auto;font-family:var(--display);font-size:24px;
  line-height:1;color:var(--accent);transition:transform .2s;flex:0 0 auto;
}
.faq-item[open] summary::after{content:'×';transform:rotate(0deg)}
.faq-item summary .q-mark{
  font-family:var(--mono);font-size:11px;letter-spacing:1.3px;
  background:var(--ink);color:var(--lime);padding:3px 7px;
  flex:0 0 auto;
}
.faq-item .a-body{
  padding:0 18px 18px 18px;border-top:1.5px dashed var(--ink);margin-top:0;padding-top:14px;
  font-family:var(--sans);font-size:14.5px;line-height:1.65;color:var(--ink);
}
.faq-item .a-body p + p{margin-top:10px}
.faq-item .a-body b{background:var(--lime);color:var(--ink);padding:1px 4px;font-weight:700}
.faq-item .a-body a{color:var(--accent);border-bottom:1.5px solid var(--accent);text-decoration:none;padding-bottom:1px}
.faq-item .a-body a:hover{background:var(--accent);color:#fff}

/* FOOTER global */
footer.global{
  margin-top:50px;padding-top:20px;border-top:1px solid var(--ink);
  display:flex;flex-wrap:wrap;gap:8px 18px;justify-content:space-between;
  font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:1.3px;color:var(--dim);
}
footer.global a{color:var(--ink);text-decoration:none;border-bottom:1.5px solid var(--ink);padding-bottom:1px}
footer.global a:hover{color:var(--accent);border-bottom-color:var(--accent)}
