/* Aparece en Google 2.0 — styles.css (compartido) · T3 performance-first · animaciones GPU (transform/opacity) */

/* Fuentes self-host (woff2, subset latino). Sustituye al <link> render-blocking de Google Fonts.
   Mismas familias/pesos que antes; font-display: optional intacto (CLS 0). */
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:optional;src:url('/assets/fonts/inter-latin-400-normal.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:optional;src:url('/assets/fonts/inter-latin-500-normal.woff2') format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:optional;src:url('/assets/fonts/inter-latin-600-normal.woff2') format('woff2')}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:600;font-display:optional;src:url('/assets/fonts/space-grotesk-latin-600-normal.woff2') format('woff2')}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:700;font-display:optional;src:url('/assets/fonts/space-grotesk-latin-700-normal.woff2') format('woff2')}

:root{
  --bg:#0A0F1A; --surface:#121A2B; --primary:#3B82F6; --primary-d:#2f6fe0;
  --success:#22C99A; --cta:#FF6B35; --cta-d:#e85a28; --text:#EAF0F7; --muted:#93A2B7;
  --line:rgba(255,255,255,.09); --glass:rgba(255,255,255,.04);
  --r:16px; --rs:12px; --maxw:1140px;
  --fd:'Space Grotesk',-apple-system,system-ui,sans-serif;
  --fb:'Inter',-apple-system,system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--fb);background:var(--bg);color:var(--text);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3{font-family:var(--fd);font-weight:700;line-height:1.12;letter-spacing:-.02em}
a{color:inherit}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.wrap-narrow{max-width:780px;margin:0 auto;padding:0 22px}
section{padding:clamp(54px,8vw,94px) 0}
.eyebrow{font-family:var(--fb);font-size:.8rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--success)}
.skip{position:absolute;left:-9999px;top:0;z-index:200;background:var(--primary);color:#fff;padding:10px 18px;border-radius:0 0 8px 0;font-weight:600;text-decoration:none}
.skip:focus{left:0}
.hl{color:var(--success)}
.villain{color:var(--cta);font-weight:600}

/* aurora animada (GPU: transform sobre pseudo-elemento) */
.aurora{position:fixed;inset:-20% -10%;z-index:-1;pointer-events:none;
  background:radial-gradient(45% 40% at 78% 8%,rgba(59,130,246,.18),transparent 60%),
             radial-gradient(40% 35% at 14% 92%,rgba(34,201,154,.12),transparent 60%);
  will-change:transform;animation:drift 22s ease-in-out infinite alternate}
@keyframes drift{from{transform:translate3d(0,0,0) scale(1)}to{transform:translate3d(-3%,2%,0) scale(1.08)}}

/* BUTTONS */
.btn{display:inline-block;background:var(--cta);color:#0A0F1A;font-family:var(--fb);font-weight:700;padding:15px 28px;border-radius:999px;text-decoration:none;font-size:1.02rem;border:none;cursor:pointer;transition:transform .18s ease,filter .18s ease}
.btn:hover{transform:translateY(-2px);filter:brightness(1.06)}
.btn:focus-visible{outline:3px solid var(--text);outline-offset:3px}
.btn-ghost{background:transparent;border:1.5px solid var(--line);color:var(--text);font-weight:600}
.btn-ghost:hover{border-color:var(--primary);transform:translateY(-2px)}

/* HEADER — glass sutil dark on-brand (PL-02). Fase D: + prefijo -webkit (blur en Safari) + fallback sólido @supports */
header{position:sticky;top:0;z-index:100;background:rgba(10,15,26,.82);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
/* Fallback sólido obligatorio: sin soporte de backdrop-filter → nav opaca legible (nunca translúcida ilegible) */
@supports not ((-webkit-backdrop-filter:blur(2px)) or (backdrop-filter:blur(2px))){header{background:rgba(10,15,26,.97)}}
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:13px 22px;max-width:var(--maxw);margin:0 auto}
.logo{font-family:var(--fd);font-weight:700;font-size:1.2rem;text-decoration:none;color:var(--text);letter-spacing:-.01em;display:flex;align-items:center;gap:9px}
.logo .dot{width:11px;height:11px;border-radius:50%;background:var(--success);box-shadow:0 0 0 4px rgba(34,201,154,.18);animation:pulse 3.4s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:.9}50%{transform:scale(1.18);opacity:1}}
.nav-links{display:flex;align-items:center;gap:22px}
.nav-links a{color:var(--muted);text-decoration:none;font-size:.93rem;font-weight:500;transition:color .15s;position:relative}
.nav-links a:not(.nav-cta)::after{content:'';position:absolute;left:0;bottom:-4px;width:100%;height:2px;background:var(--primary);transform:scaleX(0);transform-origin:left;transition:transform .22s ease}
.nav-links a:not(.nav-cta):hover{color:var(--text)}
.nav-links a:not(.nav-cta):hover::after{transform:scaleX(1)}
.nav-cta{padding:10px 18px;font-size:.92rem}
.menu-btn{display:none;background:none;border:none;color:var(--text);font-size:1.5rem;cursor:pointer}

/* HERO */
.hero{padding:clamp(24px,4vw,52px) 0 clamp(26px,4vw,48px)}
.hero .eyebrow{margin-bottom:18px}
.hero h1{font-size:clamp(2.1rem,5.4vw,3.9rem);max-width:16ch;margin-bottom:20px}
.hero .lead{font-size:clamp(1.05rem,2.2vw,1.28rem);color:var(--muted);max-width:56ch;margin-bottom:28px}
.hero .btns{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero .micro{margin-top:16px;font-size:.88rem;color:var(--muted)}
.hero .micro b{color:var(--text)}
.page-hero{padding:clamp(46px,7vw,80px) 0 clamp(20px,3vw,34px)}
.page-hero h1{font-size:clamp(1.9rem,4.6vw,3rem);max-width:20ch;margin-bottom:16px}
.page-hero .lead{font-size:clamp(1.04rem,2vw,1.2rem);color:var(--muted);max-width:58ch}
.crumbs{font-size:.82rem;color:var(--muted);margin-bottom:14px}
.crumbs a{color:var(--muted);text-decoration:none}
.crumbs a:hover{color:var(--text)}

/* section heads */
.head{max-width:62ch}
.head h2{font-size:clamp(1.6rem,4vw,2.5rem);margin:12px 0 14px}
.head p{color:var(--muted);font-size:1.05rem}

/* GRID CARDS (steps / features / cases) */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:42px}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:38px}
.card{background:var(--glass);border:1px solid var(--line);border-radius:var(--r);padding:28px;backdrop-filter:blur(6px);transition:transform .22s ease,border-color .22s ease}
.card:hover{transform:translateY(-5px);border-color:rgba(59,130,246,.4)}
.card .n{width:46px;height:46px;border-radius:12px;background:rgba(59,130,246,.14);color:var(--primary);font-family:var(--fd);font-weight:700;font-size:1.3rem;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.card .ico{width:46px;height:46px;border-radius:12px;background:rgba(34,201,154,.13);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.card .ico svg{width:24px;height:24px;stroke:var(--success);fill:none;stroke-width:2}
.card h3{font-size:1.15rem;margin-bottom:8px}
.card p{color:var(--muted);font-size:.97rem}

/* CASES */
.cases{background:var(--surface)}
.case .nm{font-family:var(--fd);font-weight:600;font-size:1.05rem;margin-bottom:14px;color:var(--text)}
.case .metric{display:flex;align-items:baseline;gap:8px;margin-bottom:6px}
.case .num{font-family:var(--fd);font-weight:700;font-size:2rem;color:var(--success);line-height:1;letter-spacing:-.02em}
.case .unit{color:var(--muted);font-size:.9rem}
.case.soon .num{color:var(--muted);font-size:1.1rem}
.case-note{text-align:center;color:var(--muted);font-size:.82rem;margin-top:20px}
.src{color:var(--muted);font-size:.84rem;margin-top:6px}

/* AUDIT band */
.band{background:linear-gradient(140deg,rgba(59,130,246,.16),rgba(34,201,154,.10));border:1px solid var(--line);border-radius:calc(var(--r) + 4px);padding:clamp(28px,5vw,52px);text-align:center}
.band h2{font-size:clamp(1.55rem,4vw,2.3rem);margin-bottom:12px;max-width:24ch;margin-inline:auto}
.band p{color:var(--muted);max-width:54ch;margin:0 auto 24px}

/* WHY / split */
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}
.badge{background:var(--glass);border:1px solid var(--line);border-radius:999px;padding:8px 15px;font-size:.85rem;color:var(--muted);font-weight:500}
.art{background:var(--glass);border:1px solid var(--line);border-radius:var(--r);padding:30px;text-align:center}
.art svg .spark{animation:floaty 4s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

/* PROSE (blog / service detail) */
.prose{max-width:720px}
.prose h2{font-size:clamp(1.4rem,3.4vw,2rem);margin:34px 0 12px}
.prose h3{font-size:1.2rem;margin:24px 0 8px}
.prose p{color:#cdd6e2;margin-bottom:14px;font-size:1.04rem}
.prose ul{color:#cdd6e2;margin:0 0 16px 20px}
.prose li{margin-bottom:8px}
.prose a{color:var(--primary);text-decoration:underline}
.callout{background:var(--glass);border-left:3px solid var(--cta);border-radius:8px;padding:16px 20px;margin:20px 0;color:var(--text)}

/* FAQ */
.faq-list{max-width:760px;margin-top:34px}
.qa{border-bottom:1px solid var(--line)}
.qa button{width:100%;text-align:left;background:none;border:none;color:var(--text);cursor:pointer;padding:20px 0;font-family:var(--fd);font-size:1.05rem;font-weight:600;display:flex;justify-content:space-between;align-items:center;gap:16px}
.qa .plus{color:var(--cta);font-size:1.4rem;flex:none;transition:transform .25s}
.qa.open .plus{transform:rotate(45deg)}
.qa .ans{max-height:0;overflow:hidden;transition:max-height .3s ease}
.qa .ans p{color:var(--muted);padding-bottom:20px;max-width:64ch}

/* CONTACT */
.contact{background:var(--surface);text-align:center}
.contact .mail{display:inline-block;font-family:var(--fd);font-weight:700;font-size:clamp(1.2rem,3vw,1.8rem);color:var(--primary);text-decoration:none;margin:10px 0 22px;word-break:break-word;transition:color .18s}
.contact .mail:hover{color:var(--success)}
.cform{max-width:520px;margin:14px auto 0;display:grid;gap:12px;text-align:left}
.cform label{font-size:.85rem;font-weight:600;color:var(--muted)}
.cform input,.cform textarea{width:100%;background:var(--bg);border:1px solid var(--line);border-radius:var(--rs);padding:13px 14px;color:var(--text);font-family:var(--fb);font-size:1rem}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--primary)}
.cform textarea{min-height:96px;resize:vertical}

/* FOOTER */
footer{border-top:1px solid var(--line);padding:40px 0 30px;color:var(--muted);font-size:.9rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:24px;margin-bottom:26px}
.foot-grid h4{color:var(--text);font-family:var(--fd);font-size:.95rem;margin-bottom:12px}
.foot-grid a{display:block;color:var(--muted);text-decoration:none;margin-bottom:8px;transition:color .15s}
.foot-grid a:hover{color:var(--text)}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;border-top:1px solid var(--line);padding-top:18px;font-size:.85rem}

/* BACK TO TOP — cohete temático */
#btt{position:fixed;right:18px;bottom:18px;z-index:120;width:54px;height:54px;border:none;background:transparent;cursor:pointer;opacity:0;transform:translateY(14px) scale(.9);transition:opacity .3s,transform .3s;padding:0}
#btt.show{opacity:1;transform:none}
#btt svg{width:54px;height:54px;display:block;filter:drop-shadow(0 6px 14px rgba(0,0,0,.45))}
#btt .flame{transform-box:fill-box;transform-origin:50% 0%;transform:scaleY(var(--flame,.2));transition:transform .35s cubic-bezier(.22,1,.36,1)}
#btt:focus-visible{outline:3px solid var(--text);outline-offset:3px;border-radius:50%}

/* REVEAL (gate body.js + fallback) */
body.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
body.js .reveal.in{opacity:1;transform:none}
body.js .stagger.in>*{animation:rise .55s ease backwards}
body.js .stagger.in>*:nth-child(2){animation-delay:.08s}
body.js .stagger.in>*:nth-child(3){animation-delay:.16s}
body.js .stagger.in>*:nth-child(4){animation-delay:.24s}
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* RESPONSIVE */
@media(max-width:860px){.grid3,.grid2,.split{grid-template-columns:1fr;gap:16px}.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:680px){
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--bg);flex-direction:column;align-items:flex-start;padding:16px 22px;gap:14px;border-bottom:1px solid var(--line)}
  .nav-links.open{display:flex}
  .menu-btn{display:block}
  .foot-grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  html{scroll-behavior:auto}
  body.js .reveal{opacity:1!important;transform:none!important}
  .aurora{animation:none!important}
  #btt .flame{transform:scaleY(.4)!important}
}

/* Select del formulario (Tarea F): casa con .cform input/textarea + flecha propia */
.cform select{width:100%;background:var(--bg);border:1px solid var(--line);border-radius:var(--rs);padding:13px 38px 13px 14px;color:var(--text);font-family:var(--fb);font-size:1rem;cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%2393A2B7' stroke-width='2'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.cform select:focus{outline:none;border-color:var(--primary)}

/* Banner de cookies (Tarea C): propio, ligero, accesible. Fondo casi opaco (sin blur, CWV-safe) */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:200;display:flex;justify-content:center;padding:16px;pointer-events:none}
.cookie-banner__box{pointer-events:auto;width:100%;max-width:680px;background:rgba(18,26,43,.98);border:1px solid var(--line);border-radius:var(--r);padding:20px 22px;box-shadow:0 -4px 30px rgba(0,0,0,.4)}
.cookie-banner__title{font-family:var(--fd);font-size:1.05rem;margin-bottom:6px;color:var(--text)}
.cookie-banner__desc{font-size:.9rem;line-height:1.55;color:var(--muted);margin-bottom:14px}
.cookie-banner__desc a{color:var(--primary);text-decoration:underline}
.cookie-banner__actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie-banner__actions .btn{padding:10px 20px;font-size:.95rem}
@media (max-width:560px){.cookie-banner__actions{flex-direction:column}.cookie-banner__actions .btn{width:100%;text-align:center}}

/* ============================================================
   HERO SERP CLIMBER — widget animado (el negocio escalando en Google)
   Portado de la v1 y adaptado a tokens 2.0. Decorativo (aria-hidden).
   ============================================================ */
:root{--serp-row-h:56px}

/* Split del hero: copy a la izquierda, widget a la derecha */
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,4vw,3.4rem);align-items:start}
@media(max-width:980px){.hero-grid{grid-template-columns:1fr}.hero__serp{display:none}}

/* Card con chrome de navegador, ligeramente girada en 3D */
.hero__serp{position:relative;background:rgba(18,26,43,.96);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 32px 64px rgba(0,0,0,.5),0 0 0 1px rgba(59,130,246,.12);transform:perspective(900px) rotateY(-6deg) rotateX(2deg) scale(.92);transform-origin:top center;transition:transform .6s ease;font-family:var(--fb)}
.hero__serp:hover{transform:perspective(900px) rotateY(-2deg) rotateX(1deg) scale(.93)}
.hero__serp-chrome{display:flex;align-items:center;gap:.75rem;padding:.6rem .9rem;background:rgba(255,255,255,.03);border-bottom:1px solid var(--line)}
.hero__serp-chrome-dots{display:flex;gap:.4rem}
.hero__serp-chrome-dots span{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.18)}
.hero__serp-chrome-url{font-size:.72rem;color:var(--muted)}
.hero__serp-search{display:flex;align-items:center;gap:.75rem;padding:.9rem}
.hero__serp-glogo{flex:none}
.hero__serp-input-wrap{flex:1;display:flex;align-items:center;min-height:36px;padding:0 .9rem;background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:999px;font-size:.85rem;color:var(--text)}
.hero__serp-qtext{white-space:nowrap}
.hero__serp-cursor{display:inline-block;margin-left:1px;color:var(--primary);font-weight:600;animation:serp-blink .8s step-end infinite}
@keyframes serp-blink{50%{opacity:0}}
.hero__serp-tabs{display:flex;gap:1.25rem;padding:0 .9rem .6rem;border-bottom:1px solid var(--line)}
.hero__serp-tab{font-size:.75rem;color:var(--muted);padding-bottom:.35rem;border-bottom:2px solid transparent}
.hero__serp-tab--active{color:var(--primary);border-bottom-color:var(--primary)}
.hero__serp-list{position:relative;height:calc(7 * var(--serp-row-h) + 8px);padding:8px 0 0;overflow:hidden}
.hero__serp-row{position:absolute;left:0;right:0;height:var(--serp-row-h);padding:.5rem .9rem;display:flex;flex-direction:column;justify-content:center;gap:.12rem;opacity:0;transition:opacity .5s ease,transform .5s cubic-bezier(.34,1.3,.64,1)}
.hero__serp-list.is-ready .hero__serp-row{opacity:1}
.hero__serp-list.is-instant .hero__serp-row{transition:none!important}
.hero__serp-row-domain{font-size:.72rem;color:var(--success)}
.hero__serp-row-title{font-size:.86rem;color:#8ab4f8;line-height:1.25}
.hero__serp-row-pos{position:absolute;top:50%;right:.9rem;transform:translateY(-50%);font-size:.8rem;font-weight:700;color:var(--muted)}
.hero__serp-row--star{top:calc(7 * var(--serp-row-h));background:rgba(34,201,154,.06);border-left:2px solid var(--success);z-index:10;opacity:1;will-change:transform;transition:transform .55s cubic-bezier(.34,1.55,.5,1),background .4s ease,box-shadow .4s ease}
.hero__serp-row--star .hero__serp-row-pos{color:var(--success)}
.hero__serp-row--star.is-jumping{box-shadow:0 10px 30px rgba(34,201,154,.4),0 0 0 1px rgba(34,201,154,.5),0 0 26px rgba(34,201,154,.3)}
.hero__serp-row--star.is-winner{background:rgba(34,201,154,.12);box-shadow:0 0 22px rgba(34,201,154,.18)}
.hero__serp-row--star .hero__serp-row-title::after{content:"\2605";display:inline-block;overflow:hidden;max-width:0;margin-left:0;opacity:0;color:#ffd14a;text-shadow:0 0 12px rgba(255,209,74,.75);transform:scale(.3) rotate(-45deg);transform-origin:left center;transition:max-width .35s ease,margin-left .35s ease,opacity .3s ease,transform .55s cubic-bezier(.34,1.7,.5,1)}
.hero__serp-row--star.is-winner .hero__serp-row-title::after{max-width:1.4em;margin-left:.4rem;opacity:1;transform:scale(1) rotate(0)}
.hero__serp-row.is-shoved{animation:serp-shoved .46s ease}
@keyframes serp-shoved{0%{background:rgba(239,68,68,.22)}100%{background:transparent}}
.hero__serp-bubble{position:absolute;left:1rem;top:0;z-index:20;max-width:175px;padding:.42rem .7rem;background:#fff;color:#0a0a0a;font-size:.72rem;font-weight:700;line-height:1.25;letter-spacing:-.01em;border-radius:13px;box-shadow:0 10px 28px rgba(0,0,0,.45);opacity:0;transform:translateY(-100%) translateY(-9px) scale(.8);transform-origin:18px bottom;transition:top .55s cubic-bezier(.34,1.5,.5,1),opacity .3s ease,transform .42s cubic-bezier(.34,1.7,.5,1);pointer-events:none}
.hero__serp-bubble.is-visible{opacity:1;transform:translateY(-100%) translateY(-9px) scale(1)}
.hero__serp-bubble::after{content:"";position:absolute;left:14px;bottom:-5px;width:12px;height:12px;background:#fff;transform:rotate(45deg);border-radius:0 0 3px 0}
.hero__serp-bubble-dots{display:none;gap:4px;padding:.1rem 0}
.hero__serp-bubble.is-thinking .hero__serp-bubble-dots{display:inline-flex}
.hero__serp-bubble.is-thinking .hero__serp-bubble-text{display:none}
.hero__serp-bubble-dots i{width:5px;height:5px;border-radius:50%;background:#0a0a0a;opacity:.4;animation:serp-think 1s infinite ease-in-out}
.hero__serp-bubble-dots i:nth-child(2){animation-delay:.15s}
.hero__serp-bubble-dots i:nth-child(3){animation-delay:.3s}
@keyframes serp-think{0%,100%{opacity:.3;transform:translateY(0)}50%{opacity:1;transform:translateY(-2px)}}
.hero__serp-win{padding:.7rem .9rem;font-size:.82rem;font-weight:600;color:var(--success);border-top:1px solid var(--line);opacity:0;transition:opacity .4s ease}
.hero__serp-win.is-visible{opacity:1}
@media(prefers-reduced-motion:reduce){.hero__serp-row,.hero__serp-row--star,.hero__serp-row--star .hero__serp-row-title::after,.hero__serp-bubble{transition:none}.hero__serp-bubble{transform:translateY(-100%) translateY(-9px) scale(1)}.hero__serp-bubble-dots i{animation:none}.hero__serp-row.is-shoved{animation:none}.hero__serp-cursor{animation:none}}

/* ===== FAQ con foto de confianza (precios) ===== */
.faq-split{display:grid;grid-template-columns:1.25fr .85fr;gap:clamp(2rem,4vw,3.5rem);align-items:center}
.faq-split .faq-list{max-width:none}
.faq-photo{margin:0;position:relative;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);background:linear-gradient(140deg,rgba(59,130,246,.16),rgba(34,201,154,.10))}
.faq-photo img{display:block;width:100%;height:auto;aspect-ratio:4/5;object-fit:cover}
.faq-photo figcaption{position:absolute;left:0;right:0;bottom:0;margin:0;padding:16px;font-size:.86rem;font-weight:600;color:var(--text);background:linear-gradient(to top,rgba(10,15,26,.92),transparent)}
@media(max-width:900px){.faq-split{grid-template-columns:1fr;gap:1.5rem}.faq-photo{max-width:420px;margin:0 auto}}

/* ===== Casos: en producción ===== */
.cases-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(1rem,2.5vw,1.5rem)}
.case{display:flex;flex-direction:column;gap:.5rem}
.case-thumb{border-radius:var(--rs);overflow:hidden;border:1px solid var(--line);background:linear-gradient(140deg,rgba(59,130,246,.16),rgba(34,201,154,.10));aspect-ratio:16/10}
.case-thumb img{display:block;width:100%;height:100%;object-fit:cover;object-position:top center}
.case-sector{font-size:.82rem;color:var(--muted)}
.case-metrics{display:flex;flex-wrap:wrap;gap:1.1rem;margin:.35rem 0 .2rem;min-height:1.2em}
.case-soon{font-size:.82rem;color:var(--muted);font-style:italic}
.case-link{margin-top:auto;width:100%;text-align:center}
.case-cta{justify-content:center;text-align:center;gap:.75rem}
.case-cta .nm{font-size:1.1rem}

/* ===== Casos: en el taller (preview navegador) ===== */
.workshop-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:clamp(1.2rem,3vw,2rem)}
.card.dev{padding:0;background:transparent;border:0;box-shadow:none;display:flex;flex-direction:column;gap:.55rem}
.demo-frame{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--surface);box-shadow:0 18px 40px rgba(0,0,0,.35)}
.demo-bar{display:flex;align-items:center;gap:.6rem;padding:.5rem .7rem;background:rgba(255,255,255,.04);border-bottom:1px solid var(--line)}
.demo-dots{display:inline-flex;gap:5px;flex:none}
.demo-dots span{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.16)}
.demo-url{flex:1;text-align:center;font-size:.72rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:rgba(255,255,255,.05);border-radius:999px;padding:.2rem .7rem}
.demo-view{position:relative;height:460px;overflow:hidden;background:radial-gradient(120% 120% at 50% 0%,rgba(59,130,246,.12),transparent 60%),var(--bg)}
.demo-view iframe{position:absolute;inset:0;width:100%;height:100%;border:0;background:transparent}
.demo-poster{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.45rem;text-align:center;padding:1.5rem;color:var(--text)}
.demo-poster strong{font-family:'Space Grotesk',sans-serif;font-size:1.25rem}
.demo-poster span{color:var(--muted);font-size:.9rem;max-width:26ch}
.dev-badge{display:inline-block;background:rgba(34,201,154,.14);color:var(--success);border:1px solid rgba(34,201,154,.35);font-size:.7rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:.2rem .6rem;border-radius:999px;margin-bottom:.3rem}
.demo-hint{font-size:.78rem!important;opacity:.8;margin-top:.4rem}
@media(max-width:760px){.demo-view{height:380px}.demo-view iframe{display:none}}
