/* ============================================================
   BREWED MARKETING — Diseño futurista
   Paleta: magenta #ff3175 · púrpura #8758ee · azul #4e71fe
   ============================================================ */

:root{
  --bg:        #0a0414;
  --bg-2:      #140827;
  --surface:   rgba(255,255,255,.04);
  --surface-2: rgba(255,255,255,.07);
  --border:    rgba(255,255,255,.10);
  --text:      #f4f0fb;
  --muted:     #a99cc7;
  --magenta:   #ff3175;
  --purple:    #8758ee;
  --blue:      #4e71fe;
  --grad:      linear-gradient(110deg,#ff3175 0%,#8758ee 50%,#4e71fe 100%);
  --grad-soft: linear-gradient(110deg,rgba(255,49,117,.18),rgba(135,88,238,.18),rgba(78,113,254,.18));
  --radius:    22px;
  --maxw:      1240px;
  --font-head: 'Space Grotesk', system-ui, sans-serif;
  --font-body: 'Inter', system-ui, sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:var(--font-head);font-weight:700;line-height:1.08;letter-spacing:-.02em}
::selection{background:var(--magenta);color:#fff}

/* ---- scrollbar ---- */
::-webkit-scrollbar{width:10px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--magenta),var(--blue));border-radius:10px}

/* ---- layout helpers ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{position:relative;padding:120px 0}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-head);font-size:.78rem;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;color:var(--magenta);
  padding:8px 16px;border:1px solid var(--border);border-radius:999px;
  background:var(--surface);backdrop-filter:blur(10px);margin-bottom:22px;
}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--grad)}
.section-title{font-size:clamp(2rem,4.4vw,3.6rem);margin-bottom:18px}
.section-sub{color:var(--muted);max-width:620px;font-size:1.08rem}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.center{text-align:center}
.center .section-sub{margin-inline:auto}

/* ---- buttons ---- */
.btn{
  --b:14px;
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-head);font-weight:600;font-size:.98rem;
  padding:16px 30px;border-radius:999px;cursor:pointer;border:none;
  position:relative;overflow:hidden;transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s;
  will-change:transform;
}
.btn-primary{background:var(--grad);color:#fff;background-size:200% 200%;box-shadow:0 10px 40px -10px rgba(255,49,117,.6)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 18px 50px -10px rgba(135,88,238,.7);animation:gradShift 3s ease infinite}
.btn-ghost{background:var(--surface);color:var(--text);border:1px solid var(--border);backdrop-filter:blur(10px)}
.btn-ghost:hover{border-color:var(--magenta);transform:translateY(-3px)}
@keyframes gradShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* ============================================================
   FONDO ANIMADO (gradient mesh)
   ============================================================ */
.bg-mesh{position:fixed;inset:0;z-index:-2;overflow:hidden;background:var(--bg)}
.blob{position:absolute;border-radius:50%;filter:blur(90px);opacity:.5;mix-blend-mode:screen}
.blob.b1{width:50vw;height:50vw;background:radial-gradient(circle,#ff3175,transparent 70%);top:-15%;left:-10%}
.blob.b2{width:46vw;height:46vw;background:radial-gradient(circle,#8758ee,transparent 70%);top:25%;right:-15%}
.blob.b3{width:40vw;height:40vw;background:radial-gradient(circle,#4e71fe,transparent 70%);bottom:-15%;left:25%}
.bg-grid{position:fixed;inset:0;z-index:-1;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000 30%,transparent 80%)}

/* ============================================================
   HEADER
   ============================================================ */
.header{position:fixed;top:0;left:0;right:0;z-index:1000;transition:.4s}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:40px;padding:12px 48px;max-width:100%;margin:0 auto;transition:.4s}
.header.scrolled .header-inner{padding:8px 48px}
.header.scrolled{background:rgba(10,4,20,.72);backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.logo{display:flex;align-items:center}
.logo img{height:72px;width:auto;display:block;transition:.4s}
.header.scrolled .logo img{height:60px}

.nav{display:flex;align-items:center;gap:12px}
.nav>li{position:relative}
.nav>li>a{display:flex;align-items:center;gap:7px;padding:11px 18px;font-family:var(--font-head);font-weight:500;font-size:.95rem;color:var(--text);border-radius:12px;transition:.25s;white-space:nowrap}
.nav>li>a:hover{color:#fff;background:var(--surface)}
.nav .caret{width:8px;height:8px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);margin-top:-3px;transition:.3s;opacity:.7}
.nav>li:hover .caret{transform:rotate(225deg);margin-top:3px}

/* dropdown */
.submenu{
  position:absolute;top:calc(100% + 14px);left:0;min-width:280px;
  background:rgba(20,8,39,.92);backdrop-filter:blur(24px);
  border:1px solid var(--border);border-radius:18px;padding:10px;
  opacity:0;visibility:hidden;transform:translateY(10px);transition:.3s;
  box-shadow:0 30px 60px -20px rgba(0,0,0,.7);
}
.nav>li:hover .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.submenu a{display:block;padding:12px 16px;border-radius:12px;font-size:.92rem;color:var(--muted);transition:.2s}
.submenu a:hover{background:var(--grad-soft);color:#fff;padding-left:22px}

.header-cta{display:flex;align-items:center;gap:14px}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;z-index:1100}
.burger span{width:26px;height:2px;background:var(--text);border-radius:2px;transition:.3s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile drawer */
.mobile-nav{position:fixed;inset:0;z-index:1050;background:rgba(10,4,20,.98);backdrop-filter:blur(20px);padding:100px 28px 40px;transform:translateX(100%);transition:.45s cubic-bezier(.7,0,.2,1);overflow-y:auto}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav a{display:block;padding:16px 0;font-family:var(--font-head);font-size:1.3rem;border-bottom:1px solid var(--border)}
.mobile-nav .sub a{font-size:1rem;color:var(--muted);padding:11px 0 11px 18px;border:none}

/* ============================================================
   HERO
   ============================================================ */
.hero{min-height:100vh;display:flex;align-items:center;padding:140px 0 80px;position:relative}
.hero h1{font-size:clamp(2.6rem,7vw,6rem);line-height:.98;margin-bottom:26px}
.hero .lead{font-size:clamp(1.05rem,2vw,1.4rem);color:var(--muted);max-width:620px;margin-bottom:38px}
.hero-cta{display:flex;flex-wrap:wrap;gap:16px;align-items:center}
.hero-line{overflow:hidden;display:block}
.scroll-hint{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:10px}
.scroll-hint .mouse{width:24px;height:38px;border:2px solid var(--border);border-radius:14px;position:relative}
.scroll-hint .mouse::after{content:"";position:absolute;top:7px;left:50%;transform:translateX(-50%);width:4px;height:7px;border-radius:3px;background:var(--magenta);animation:scrolldot 1.6s infinite}
@keyframes scrolldot{0%{opacity:1;top:7px}80%{opacity:0;top:20px}100%{opacity:0}}

.hero-badges{display:flex;gap:28px;margin-top:46px;flex-wrap:wrap}
.hero-badge{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:.9rem}
.hero-badge .dot{width:9px;height:9px;border-radius:50%;background:var(--grad)}

/* ============================================================
   STATS
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat{text-align:center;padding:38px 18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);backdrop-filter:blur(10px);transition:.4s}
.stat:hover{transform:translateY(-6px);border-color:rgba(255,49,117,.4)}
.stat .num{font-family:var(--font-head);font-size:clamp(2.4rem,4.5vw,3.6rem);font-weight:700;line-height:1}
.stat .label{margin-top:12px;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}

/* ============================================================
   SERVICIOS
   ============================================================ */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:60px}
.service-card{
  position:relative;padding:40px 34px;border-radius:var(--radius);
  background:var(--surface);border:1px solid var(--border);overflow:hidden;
  transition:transform .45s cubic-bezier(.2,.8,.2,1),border-color .4s;
}
.service-card::before{content:"";position:absolute;inset:0;background:var(--grad-soft);opacity:0;transition:.45s;z-index:0}
.service-card:hover{transform:translateY(-10px);border-color:rgba(135,88,238,.5)}
.service-card:hover::before{opacity:1}
.service-card>*{position:relative;z-index:1}
.service-icon{width:64px;height:64px;border-radius:18px;background:var(--grad);display:grid;place-items:center;margin-bottom:24px;font-size:1.6rem}
.service-card h3{font-size:1.6rem;margin-bottom:18px}
.service-card .feat{display:flex;flex-direction:column;gap:12px;margin-bottom:28px}
.service-card .feat li{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:.96rem}
.service-card .feat li::before{content:"✓";flex:0 0 18px;height:18px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;background:var(--grad);color:#fff;font-size:.66rem;font-weight:800;line-height:1}
.service-link{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-head);font-weight:600;font-size:.92rem;color:var(--magenta)}
.service-link .arrow{transition:.3s}
.service-card:hover .service-link .arrow{transform:translateX(6px)}

/* ============================================================
   WHY / FEATURES
   ============================================================ */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:56px}
.why-card{padding:34px 28px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);transition:.4s}
.why-card:hover{transform:translateY(-8px);background:var(--surface-2)}
.why-num{font-family:var(--font-head);font-size:1rem;color:var(--magenta);margin-bottom:18px;opacity:.8}
.why-card h3{font-size:1.25rem;margin-bottom:12px}
.why-card p{color:var(--muted);font-size:.94rem}

/* ============================================================
   COMPARATIVA
   ============================================================ */
.compare{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:0;margin-top:56px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--surface)}
.compare .col{padding:0}
.compare .ch{padding:26px 22px;font-family:var(--font-head);font-weight:600;text-align:center;border-bottom:1px solid var(--border)}
.compare .col.brewed{background:var(--grad-soft)}
.compare .col.brewed .ch{color:#fff;font-size:1.15rem}
.compare .feature-label{text-align:left;color:var(--muted);font-size:.92rem}
.compare .cell{padding:18px 22px;text-align:center;border-bottom:1px solid var(--border);font-size:.92rem}
.compare .col:not(.feat-col) .cell{display:grid;place-items:center}
.tick{width:24px;height:24px;border-radius:50%;background:var(--grad);display:grid;place-items:center;color:#fff;font-size:.8rem}
.cross{width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,.06);display:grid;place-items:center;color:var(--muted)}

/* ============================================================
   PORTAFOLIO
   ============================================================ */
.portfolio-filter{display:flex;flex-wrap:wrap;gap:10px;margin:36px 0 44px}
.portfolio-filter button{font-family:var(--font-head);font-size:.88rem;font-weight:500;padding:10px 20px;border-radius:999px;background:var(--surface);border:1px solid var(--border);color:var(--muted);cursor:pointer;transition:.3s}
.portfolio-filter button.active,.portfolio-filter button:hover{background:var(--grad);color:#fff;border-color:transparent}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pf-item{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;border:1px solid var(--border);background:var(--bg-2)}
.pf-item img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.2,.8,.2,1)}
.pf-item:hover img{transform:scale(1.08)}
.pf-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:26px;background:linear-gradient(to top,rgba(10,4,20,.9),rgba(10,4,20,.15) 55%,transparent 80%);opacity:1;transition:.45s}
.pf-item:hover .pf-overlay{background:linear-gradient(to top,rgba(10,4,20,.96),rgba(10,4,20,.45) 70%,rgba(10,4,20,.1) 100%)}
.pf-overlay h4{font-size:1.3rem;margin-bottom:6px;transform:translateY(8px);transition:transform .45s cubic-bezier(.2,.8,.2,1)}
.pf-item:hover .pf-overlay h4{transform:translateY(0)}
.pf-overlay p{color:var(--muted);font-size:.88rem;opacity:0;max-height:0;overflow:hidden;transform:translateY(8px);transition:.45s}
.pf-item:hover .pf-overlay p{opacity:1;max-height:48px;transform:translateY(0)}
.pf-loadmore-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:10px}
.pf-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;display:none}
.pf-loadmore-btn.is-loading{opacity:.85;pointer-events:none}
.pf-loadmore-btn.is-loading .pf-spinner{display:inline-block;animation:pf-spin .6s linear infinite}
@keyframes pf-spin{to{transform:rotate(360deg)}}

/* ============================================================
   MARQUEE de herramientas
   ============================================================ */
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee-track{display:flex;gap:60px;width:max-content;animation:marquee 26s linear infinite}
.marquee-track span{font-family:var(--font-head);font-weight:700;font-size:clamp(1.4rem,3vw,2.4rem);color:rgba(255,255,255,.18);white-space:nowrap;transition:.3s}
.marquee-track span:hover{color:var(--text)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ============================================================
   TESTIMONIOS
   ============================================================ */
.reviews-head{display:flex;flex-wrap:wrap;align-items:center;gap:30px;justify-content:space-between;margin-bottom:46px}
.google-rating{display:flex;align-items:center;gap:18px;padding:22px 28px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}
.google-rating .big{font-family:var(--font-head);font-size:3rem;font-weight:700;line-height:1}
.stars{color:#ffc83d;font-size:1.1rem;letter-spacing:2px}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.review{display:flex;flex-direction:column;height:100%;padding:28px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);transition:.4s}
.review:hover{border-color:rgba(135,88,238,.5);transform:translateY(-5px)}
.review .who{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.review .avatar{flex:0 0 42px;width:42px;height:42px;border-radius:50%;background:var(--grad);display:grid;place-items:center;font-family:var(--font-head);font-weight:700;color:#fff}
.review .name{font-family:var(--font-head);font-weight:600;font-size:.95rem}
.review .when{font-size:.78rem;color:var(--muted)}
.review p{color:var(--muted);font-size:.92rem;margin:0}
.review .stars{font-size:.85rem;margin-bottom:10px}

/* ============================================================
   CTA CONTACTO
   ============================================================ */
.cta-section{position:relative}
.cta-box{position:relative;text-align:center;padding:90px 40px;border-radius:36px;background:var(--grad-soft);border:1px solid var(--border);overflow:hidden}
.cta-box::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(255,49,117,.25),transparent 60%)}
.cta-box>*{position:relative;z-index:1}
.cta-box h2{font-size:clamp(2rem,5vw,3.4rem);margin-bottom:20px}
.cta-box p{color:var(--muted);max-width:560px;margin:0 auto 36px;font-size:1.1rem}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{position:relative;border-top:1px solid var(--border);padding:80px 0 30px;background:var(--bg-2)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;margin-bottom:60px}
.footer .logo{display:inline-flex}
.footer .logo img{height:72px;margin-bottom:22px}
.footer .about{color:var(--muted);font-size:.94rem;max-width:300px;margin-bottom:24px}
.footer h4{font-size:1.05rem;margin-bottom:22px}
.footer .fmenu li{margin-bottom:13px}
.footer .fmenu a{color:var(--muted);font-size:.92rem;transition:.25s}
.footer .fmenu a:hover{color:var(--magenta);padding-left:6px}
.footer .contact-item{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:.92rem;margin-bottom:14px}
.social{display:flex;gap:12px;margin-top:8px}
.social a{width:42px;height:42px;border-radius:12px;background:var(--surface);border:1px solid var(--border);display:grid;place-items:center;transition:.3s}
.social a:hover{background:var(--grad);transform:translateY(-4px)}
.footer-bottom{display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;align-items:center;padding-top:30px;border-top:1px solid var(--border);color:var(--muted);font-size:.84rem}
/* Selector de ciudad (footer) */
.city-switch{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:30px;padding-top:26px;border-top:1px solid var(--border)}
.city-switch-label{color:var(--muted);font-size:.84rem;font-weight:600;letter-spacing:.02em}
.city-chip{font-size:.82rem;color:var(--muted);padding:6px 14px;border-radius:999px;border:1px solid var(--border);background:var(--surface);transition:.25s;text-decoration:none}
a.city-chip:hover{color:#fff;border-color:transparent;background:var(--grad);transform:translateY(-2px)}
.city-chip.active{color:#fff;background:var(--grad);border-color:transparent;cursor:default}
.city-switch + .footer-bottom{border-top:none;padding-top:18px}
/* Cobertura local por ciudad (sección en páginas de servicio) */
.city-areas{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:30px}
.area-chip{font-size:.84rem;color:var(--text);padding:8px 16px;border-radius:999px;border:1px solid var(--border);background:var(--surface)}

/* WhatsApp flotante */
.wa-float{position:fixed;bottom:26px;right:26px;z-index:900;width:60px;height:60px;border-radius:50%;background:#25d366;display:grid;place-items:center;box-shadow:0 10px 30px -6px rgba(37,211,102,.6);transition:.3s;animation:wapulse 2.4s infinite}
.wa-float:hover{transform:scale(1.1)}
.wa-float svg{width:32px;height:32px;fill:#fff}
@keyframes wapulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 18px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}

/* ============================================================
   ANIMACIÓN (estados iniciales para GSAP)
   ============================================================ */
.reveal{opacity:0}
.no-js .reveal{opacity:1}

/* preloader */
.preloader{position:fixed;inset:0;z-index:9999;background:var(--bg);display:grid;place-items:center;transition:opacity .6s,visibility .6s}
.preloader.hide{opacity:0;visibility:hidden}
.preloader .pl-logo{font-family:var(--font-head);font-weight:700;font-size:1.5rem;letter-spacing:.05em}
.preloader .bar{width:160px;height:3px;background:var(--border);border-radius:3px;margin-top:18px;overflow:hidden}
.preloader .bar i{display:block;height:100%;width:0;background:var(--grad);border-radius:3px}

/* ============================================================
   PÁGINAS INTERNAS
   ============================================================ */
.hero-inner{min-height:auto;padding:200px 0 90px;text-align:center}
.hero-inner h1{font-size:clamp(2.4rem,6vw,4.6rem)}
.hero-inner .lead{margin-inline:auto}
.hero-inner .hero-cta{justify-content:center}
.hero-orbit{position:absolute;top:50%;left:50%;width:min(900px,90vw);height:min(900px,90vw);transform:translate(-50%,-50%);border-radius:50%;border:1px solid var(--border);z-index:-1;opacity:.5}
.hero-orbit::before,.hero-orbit::after{content:"";position:absolute;inset:18%;border-radius:50%;border:1px solid var(--border)}
.hero-orbit::after{inset:36%}

/* ============================================================
   HERO "se construye una página web" (Diseño de páginas web)
   Loop CSS puro: la URL se teclea y un haz de construcción barre
   de arriba a abajo revelando nav/hero/imagen/tarjetas. ~9s.
   ============================================================ */
.hero-fx{position:relative;overflow:hidden}
.hero-fx .wrap{position:relative;z-index:2}
.hero-build{position:absolute;top:50%;left:50%;transform:translate(-50%,-46%);
  width:min(880px,92vw);z-index:0;opacity:.5;pointer-events:none;
  filter:drop-shadow(0 40px 80px rgba(135,88,238,.25));
  -webkit-mask-image:radial-gradient(120% 120% at 50% 40%,#000 55%,transparent 92%);
          mask-image:radial-gradient(120% 120% at 50% 40%,#000 55%,transparent 92%)}
.hb-window{border:1px solid var(--border);border-radius:16px;overflow:hidden;
  background:linear-gradient(180deg,rgba(20,8,39,.9),rgba(10,4,20,.92));
  backdrop-filter:blur(6px)}
.hb-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.03)}
.hb-dot{width:11px;height:11px;border-radius:50%;background:var(--border)}
.hb-dot:nth-child(1){background:#ff5f57}.hb-dot:nth-child(2){background:#febc2e}.hb-dot:nth-child(3){background:#28c840}
.hb-url{flex:1;margin-left:10px;height:26px;display:flex;align-items:center;gap:1px;
  padding:0 14px;border-radius:999px;background:rgba(255,255,255,.05);
  font:600 .8rem/1 var(--font-body);color:var(--muted);letter-spacing:.01em;overflow:hidden}
.hb-type{display:inline-block;overflow:hidden;white-space:nowrap;max-width:0;
  animation:hbType 9s steps(17,end) infinite}
.hb-caret{flex:0 0 2px;width:2px;height:14px;background:var(--magenta);opacity:0;animation:hbCaret 9s infinite}
.hb-canvas{position:relative;height:360px;overflow:hidden;background:radial-gradient(120% 100% at 80% 0,rgba(135,88,238,.10),transparent 60%)}
.hb-page{position:absolute;inset:0;padding:22px;display:flex;flex-direction:column;gap:20px;
  clip-path:inset(0 0 100% 0);animation:hbReveal 9s ease infinite}
/* nav */
.hb-nav{display:flex;align-items:center;justify-content:space-between}
.hb-logo{width:74px;height:18px;border-radius:6px;background:var(--grad);background-size:200% 200%;animation:hbGrad 4s ease infinite}
.hb-links{display:flex;align-items:center;gap:14px}
.hb-links i{width:34px;height:8px;border-radius:4px;background:var(--surface-2)}
.hb-links .hb-pill{width:60px;height:22px;border-radius:999px;background:var(--grad-soft);border:1px solid var(--border)}
/* bloque hero */
.hb-hero{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:center}
.hb-htext{display:flex;flex-direction:column;gap:12px}
.hb-line{height:14px;border-radius:6px;background:var(--surface-2)}
.hb-line:first-child{height:22px;background:linear-gradient(90deg,var(--magenta),var(--purple));opacity:.85}
.hb-line.w-90{width:90%}.hb-line.w-70{width:70%}.hb-line.w-55{width:55%}.hb-line.w-40{width:40%}
.hb-line.dim{height:10px;opacity:.6}
.hb-btn{margin-top:10px;width:130px;height:38px;border-radius:12px;background:var(--grad);background-size:200% 200%;
  box-shadow:0 10px 30px -10px rgba(255,49,117,.6);animation:hbGrad 4s ease infinite}
.hb-himg{height:150px;border-radius:14px;border:1px solid var(--border);
  background:linear-gradient(135deg,rgba(255,49,117,.18),rgba(78,113,254,.18));position:relative;overflow:hidden}
.hb-himg::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.12) 50%,transparent 70%);transform:translateX(-100%);animation:hbShine 4s ease-in-out infinite}
/* tarjetas */
.hb-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:auto}
.hb-card{height:74px;border-radius:14px;background:var(--surface);border:1px solid var(--border)}
.hb-card::before{content:"";display:block;width:36px;height:36px;margin:14px;border-radius:10px;background:var(--grad-soft);border:1px solid var(--border)}
/* haz de construcción */
.hb-beam{position:absolute;left:0;right:0;top:0;height:3px;opacity:0;
  background:linear-gradient(90deg,transparent,var(--magenta),var(--blue),transparent);
  box-shadow:0 0 24px 6px rgba(255,49,117,.55),0 0 60px 18px rgba(78,113,254,.35);
  animation:hbBeam 9s ease infinite}

@keyframes hbType{0%{max-width:0}14%,100%{max-width:160px}}
@keyframes hbCaret{0%,15%{opacity:1}16%,86%{opacity:0}87%,100%{opacity:1}}
@keyframes hbReveal{0%,10%{clip-path:inset(0 0 100% 0)}66%{clip-path:inset(0 0 0 0)}88%{clip-path:inset(0 0 0 0);opacity:1}100%{clip-path:inset(0 0 0 0);opacity:0}}
@keyframes hbBeam{0%,10%{top:0;opacity:0}13%{opacity:1}64%{top:100%;opacity:1}70%,100%{top:100%;opacity:0}}
@keyframes hbGrad{0%,100%{background-position:0 50%}50%{background-position:100% 50%}}
@keyframes hbShine{0%,40%{transform:translateX(-100%)}70%,100%{transform:translateX(100%)}}

/* ---- Tienda en línea: la tienda se llena sola (add-to-cart, badge 1→2→3) ---- */
.hs-page{position:absolute;inset:0;padding:22px;display:flex;flex-direction:column;gap:18px}
.hs-top{display:flex;align-items:center;gap:14px}
.hs-logo{width:78px;height:18px;border-radius:6px;background:var(--grad);background-size:200% 200%;animation:hbGrad 4s ease infinite}
.hs-search{flex:1;height:26px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border)}
.hs-cart{position:relative;width:42px;height:42px;border-radius:12px;background:var(--surface);border:1px solid var(--border);display:grid;place-items:center;color:var(--text);animation:hsCart 9s ease infinite}
.hs-cart svg{width:21px;height:21px;fill:none;stroke:currentColor;stroke-width:2}
.hs-badge{position:absolute;top:-7px;right:-7px;width:20px;height:20px;border-radius:50%;background:var(--magenta);color:#fff;font:700 .72rem/20px var(--font-head);text-align:center;transform:scale(0);box-shadow:0 4px 12px rgba(255,49,117,.6);animation:hsBadge 9s ease infinite}
.hs-badge i{position:absolute;inset:0;font-style:normal;opacity:0}
.hs-badge .d1{animation:hsD1 9s step-end infinite}
.hs-badge .d2{animation:hsD2 9s step-end infinite}
.hs-badge .d3{animation:hsD3 9s step-end infinite}
.hs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;flex:1}
.hs-prod{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:14px;overflow:hidden;background:var(--surface);opacity:0}
.hs-prod.p1{animation:hsCard1 9s ease infinite}
.hs-prod.p2{animation:hsCard2 9s ease infinite}
.hs-prod.p3{animation:hsCard3 9s ease infinite}
.hs-img{flex:1;min-height:88px;background:linear-gradient(135deg,rgba(255,49,117,.22),rgba(78,113,254,.22));position:relative;overflow:hidden}
.hs-img::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 35%,rgba(255,255,255,.14) 50%,transparent 65%);transform:translateX(-100%);animation:hbShine 4.5s ease-in-out infinite}
.hs-meta{display:flex;align-items:center;justify-content:space-between;padding:10px 12px}
.hs-price{width:46px;height:12px;border-radius:5px;background:var(--surface-2)}
.hs-add{width:26px;height:26px;border-radius:8px;background:var(--grad);color:#fff;font:700 1.05rem/24px var(--font-head);text-align:center}

@keyframes hsCard1{0%{opacity:0;transform:translateY(14px) scale(.92)}6%{opacity:1;transform:none}20%{box-shadow:0 0 0 0 rgba(255,49,117,0)}24%{box-shadow:0 0 0 3px rgba(255,49,117,.6),0 16px 30px -12px rgba(255,49,117,.5);transform:translateY(-5px)}30%{box-shadow:0 0 0 0 rgba(255,49,117,0);transform:none}88%{opacity:1}100%{opacity:0}}
@keyframes hsCard2{0%{opacity:0;transform:translateY(14px) scale(.92)}10%{opacity:1;transform:none}40%{box-shadow:0 0 0 0 rgba(135,88,238,0)}44%{box-shadow:0 0 0 3px rgba(135,88,238,.6),0 16px 30px -12px rgba(135,88,238,.5);transform:translateY(-5px)}50%{box-shadow:0 0 0 0 rgba(135,88,238,0);transform:none}88%{opacity:1}100%{opacity:0}}
@keyframes hsCard3{0%{opacity:0;transform:translateY(14px) scale(.92)}14%{opacity:1;transform:none}60%{box-shadow:0 0 0 0 rgba(78,113,254,0)}64%{box-shadow:0 0 0 3px rgba(78,113,254,.6),0 16px 30px -12px rgba(78,113,254,.5);transform:translateY(-5px)}70%{box-shadow:0 0 0 0 rgba(78,113,254,0);transform:none}88%{opacity:1}100%{opacity:0}}
@keyframes hsBadge{0%,18%{transform:scale(0)}22%{transform:scale(1.3)}26%{transform:scale(1)}40%{transform:scale(1)}42%{transform:scale(1.3)}46%{transform:scale(1)}60%{transform:scale(1)}62%{transform:scale(1.3)}66%{transform:scale(1)}87%{transform:scale(1)}100%{transform:scale(0)}}
@keyframes hsD1{0%,19%{opacity:0}20%{opacity:1}40%{opacity:0}100%{opacity:0}}
@keyframes hsD2{0%,39%{opacity:0}40%{opacity:1}60%{opacity:0}100%{opacity:0}}
@keyframes hsD3{0%,59%{opacity:0}60%{opacity:1}87%{opacity:0}100%{opacity:0}}
@keyframes hsCart{0%,18%{box-shadow:0 0 0 0 rgba(255,49,117,0)}22%{box-shadow:0 0 0 9px rgba(255,49,117,.16)}30%{box-shadow:0 0 0 0 rgba(255,49,117,0)}42%{box-shadow:0 0 0 9px rgba(135,88,238,.16)}50%{box-shadow:0 0 0 0 rgba(135,88,238,0)}62%{box-shadow:0 0 0 9px rgba(78,113,254,.16)}70%,100%{box-shadow:0 0 0 0 rgba(78,113,254,0)}}

/* ---- Mantenimiento web: panel de monitoreo (escaneo + checklist + progreso) ---- */
.hc-page{position:absolute;inset:0;padding:22px;display:flex;flex-direction:column;gap:15px}
.hc-head{display:flex;align-items:center;justify-content:space-between}
.hc-status{display:flex;align-items:center;gap:9px;padding:6px 12px;border-radius:999px;background:rgba(40,200,100,.12);border:1px solid rgba(40,200,100,.32)}
.hc-status b{display:block;width:46px;height:7px;border-radius:4px;background:rgba(40,200,100,.55)}
.hc-dot{width:9px;height:9px;border-radius:50%;background:#28c840;box-shadow:0 0 0 0 rgba(40,200,100,.5);animation:hcPulse 2.2s ease infinite}
.hc-gear{width:30px;height:30px;color:var(--muted);display:block}
.hc-gear svg{width:100%;height:100%;fill:currentColor;transform-origin:50% 50%;animation:spin 7s linear infinite}
.hc-chart{position:relative;height:108px;border:1px solid var(--border);border-radius:14px;background:radial-gradient(100% 100% at 50% 0,rgba(135,88,238,.12),transparent 70%);overflow:hidden;padding:12px}
.hc-spark{display:block;width:100%;height:100%}
.hc-scan{position:absolute;top:0;bottom:0;width:2px;left:0;background:linear-gradient(180deg,transparent,rgba(255,255,255,.65),transparent);box-shadow:0 0 16px 3px rgba(135,88,238,.65);animation:hcScan 3.4s linear infinite}
.hc-list{display:flex;flex-direction:column;gap:11px}
.hc-item{display:flex;align-items:center;gap:12px}
.hc-ic{flex:0 0 22px;width:22px;height:22px;border-radius:50%;background:var(--surface-2);border:1px solid var(--border);display:grid;place-items:center;font:700 .72rem/1 var(--font-head);color:transparent}
.hc-bar{height:9px;border-radius:5px;background:var(--surface-2)}
.hc-item.i1 .hc-bar{width:64%}.hc-item.i2 .hc-bar{width:48%}.hc-item.i3 .hc-bar{width:72%}.hc-item.i4 .hc-bar{width:40%}
.hc-item.i1 .hc-ic{animation:hcCheck1 9s ease infinite}
.hc-item.i2 .hc-ic{animation:hcCheck2 9s ease infinite}
.hc-item.i3 .hc-ic{animation:hcCheck3 9s ease infinite}
.hc-item.i4 .hc-ic{animation:hcCheck4 9s ease infinite}
.hc-prog{height:6px;border-radius:999px;background:var(--surface-2);overflow:hidden;margin-top:auto}
.hc-prog i{display:block;height:100%;width:0;border-radius:999px;background:var(--grad);background-size:200% 200%;animation:hcProg 9s ease infinite,hbGrad 4s ease infinite}

@keyframes hcPulse{0%,100%{box-shadow:0 0 0 0 rgba(40,200,100,.5)}70%{box-shadow:0 0 0 8px rgba(40,200,100,0)}}
@keyframes hcScan{0%{left:0;opacity:0}8%{opacity:1}92%{opacity:1}100%{left:100%;opacity:0}}
@keyframes hcProg{0%{width:0;opacity:1}78%{width:100%}87%{width:100%;opacity:1}100%{width:100%;opacity:0}}
@keyframes hcCheck1{0%,16%{background:var(--surface-2);color:transparent;border-color:var(--border);transform:scale(1)}20%{background:var(--grad);color:#fff;border-color:transparent;transform:scale(1.25)}24%,86%{background:var(--grad);color:#fff;border-color:transparent;transform:scale(1)}100%{background:var(--surface-2);color:transparent;border-color:var(--border)}}
@keyframes hcCheck2{0%,32%{background:var(--surface-2);color:transparent;border-color:var(--border);transform:scale(1)}36%{background:var(--grad);color:#fff;border-color:transparent;transform:scale(1.25)}40%,86%{background:var(--grad);color:#fff;border-color:transparent;transform:scale(1)}100%{background:var(--surface-2);color:transparent;border-color:var(--border)}}
@keyframes hcCheck3{0%,48%{background:var(--surface-2);color:transparent;border-color:var(--border);transform:scale(1)}52%{background:var(--grad);color:#fff;border-color:transparent;transform:scale(1.25)}56%,86%{background:var(--grad);color:#fff;border-color:transparent;transform:scale(1)}100%{background:var(--surface-2);color:transparent;border-color:var(--border)}}
@keyframes hcCheck4{0%,64%{background:var(--surface-2);color:transparent;border-color:var(--border);transform:scale(1)}68%{background:var(--grad);color:#fff;border-color:transparent;transform:scale(1.25)}72%,86%{background:var(--grad);color:#fff;border-color:transparent;transform:scale(1)}100%{background:var(--surface-2);color:transparent;border-color:var(--border)}}

/* ---- Optimización: medidor PageSpeed (0→99) + métricas + cohete despegando ---- */
.op-page{position:absolute;inset:0;padding:22px;display:flex;flex-direction:column;gap:16px}
.op-head{display:flex;align-items:center;justify-content:space-between}
.op-logo{width:80px;height:18px;border-radius:6px;background:var(--grad);background-size:200% 200%;animation:hbGrad 4s ease infinite}
.op-pill{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;background:rgba(40,200,100,.12);border:1px solid rgba(40,200,100,.32);color:#28c840;font:700 .85rem/1 var(--font-head)}
.op-pill b{display:block;width:32px;height:7px;border-radius:4px;background:rgba(40,200,100,.5)}
.op-body{flex:1;display:grid;grid-template-columns:auto 1fr;gap:28px;align-items:center}
.op-gauge{position:relative;width:148px;height:148px;justify-self:center}
.op-gauge svg{display:block;width:100%;height:100%}
.op-track{fill:none;stroke:var(--surface-2);stroke-width:10}
.op-prog{fill:none;stroke:#ff3175;stroke-width:10;stroke-linecap:round;stroke-dasharray:327;stroke-dashoffset:327;
  transform-box:fill-box;transform-origin:center;transform:rotate(-90deg);animation:opRing 9s ease infinite,opHue 9s ease infinite}
.op-num{position:absolute;inset:0;display:grid;place-items:center;font:800 2.7rem/1 var(--font-head)}
.op-num span{grid-area:1/1;opacity:0}
.op-num .n1{color:#ff3175;animation:opN1 9s step-end infinite}
.op-num .n2{color:#febc2e;animation:opN2 9s step-end infinite}
.op-num .n3{color:#9be15d;animation:opN3 9s step-end infinite}
.op-num .n4{color:#28c840;animation:opN4 9s step-end infinite}
.op-metrics{display:flex;flex-direction:column;gap:16px}
.op-row{display:flex;align-items:center;gap:12px}
.op-lbl{flex:0 0 36px;height:9px;border-radius:5px;background:var(--surface-2)}
.op-track2{flex:1;height:10px;border-radius:999px;background:var(--surface-2);overflow:hidden}
.op-track2 i{display:block;height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,var(--purple),#28c840)}
.op-track2 .f1{animation:opFill1 9s ease infinite}
.op-track2 .f2{animation:opFill2 9s ease infinite}
.op-track2 .f3{animation:opFill3 9s ease infinite}
.op-rocket{position:absolute;right:22px;bottom:16px;width:28px;height:28px;color:var(--magenta);opacity:0;animation:opRocket 9s ease infinite}
.op-rocket svg{width:100%;height:100%;display:block;filter:drop-shadow(0 0 10px rgba(255,49,117,.7))}
.op-flame{position:absolute;left:50%;top:96%;transform:translateX(-50%);width:9px;height:0;border-radius:50% 50% 60% 60%;background:linear-gradient(180deg,#febc2e,#ff3175);filter:blur(2px);animation:opFlame 9s ease infinite}

@keyframes opRing{0%,8%{stroke-dashoffset:327}60%{stroke-dashoffset:3}86%{stroke-dashoffset:3}100%{stroke-dashoffset:327}}
@keyframes opHue{0%,8%{stroke:#ff3175}30%{stroke:#febc2e}50%{stroke:#9be15d}60%,86%{stroke:#28c840}100%{stroke:#ff3175}}
@keyframes opN1{0%,7%{opacity:0}8%{opacity:1}26%{opacity:0}100%{opacity:0}}
@keyframes opN2{0%,25%{opacity:0}26%{opacity:1}42%{opacity:0}100%{opacity:0}}
@keyframes opN3{0%,41%{opacity:0}42%{opacity:1}58%{opacity:0}100%{opacity:0}}
@keyframes opN4{0%,57%{opacity:0}58%{opacity:1}86%{opacity:0}100%{opacity:0}}
@keyframes opFill1{0%,12%{width:0}55%{width:92%}86%{width:92%}100%{width:0}}
@keyframes opFill2{0%,18%{width:0}58%{width:84%}86%{width:84%}100%{width:0}}
@keyframes opFill3{0%,24%{width:0}60%{width:96%}86%{width:96%}100%{width:0}}
@keyframes opRocket{0%,57%{transform:translateY(0);opacity:0}61%{opacity:1}86%{transform:translateY(-310px);opacity:0}100%{opacity:0}}
@keyframes opFlame{0%,59%{height:0;opacity:0}62%{height:15px;opacity:1}83%{height:15px;opacity:1}86%,100%{height:0;opacity:0}}

/* ---- Administración web: panel CMS (menú activo + publicar borrador→publicado) ---- */
.ad-app{position:absolute;inset:0;padding:18px;display:grid;grid-template-columns:78px 1fr;gap:16px}
.ad-side{display:flex;flex-direction:column;gap:18px;padding:12px;border:1px solid var(--border);border-radius:14px;background:rgba(255,255,255,.03)}
.ad-logo{width:42px;height:14px;border-radius:5px;background:var(--grad);background-size:200% 200%;animation:hbGrad 4s ease infinite}
.ad-nav{position:relative;display:flex;flex-direction:column;gap:10px}
.ad-nav i{position:relative;z-index:1;height:24px;border-radius:8px;display:flex;align-items:center}
.ad-nav i::before{content:"";margin-left:10px;width:62%;height:7px;border-radius:4px;background:var(--muted);opacity:.45}
.ad-slider{position:absolute;left:0;top:0;width:100%;height:24px;border-radius:8px;background:var(--grad-soft);border:1px solid var(--border);animation:adSlide 9s ease infinite}
.ad-main{display:flex;flex-direction:column;min-width:0}
.ad-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.ad-title{width:96px;height:14px;border-radius:5px;background:var(--surface-2)}
.ad-pub{width:62px;height:26px;border-radius:8px;background:var(--grad);background-size:200% 200%;animation:hbGrad 4s ease infinite,adBtn 9s ease infinite}
.ad-list{display:flex;flex-direction:column;gap:11px}
.ad-item{display:flex;align-items:center;gap:12px;padding:9px;border:1px solid var(--border);border-radius:12px;background:var(--surface)}
.ad-thumb{flex:0 0 36px;width:36px;height:36px;border-radius:8px;background:var(--grad-soft);border:1px solid var(--border);position:relative;overflow:hidden}
.ad-thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 35%,rgba(255,255,255,.14) 50%,transparent 65%);transform:translateX(-100%);animation:hbShine 5s ease-in-out infinite}
.ad-lines{flex:1;min-width:0;display:flex;flex-direction:column;gap:7px}
.ad-lines span{height:9px;border-radius:5px;background:var(--surface-2)}
.ad-lines span:first-child{width:72%}.ad-lines span:last-child{width:46%;opacity:.6;height:8px}
.ad-status{flex:0 0 40px;width:40px;height:14px;border-radius:999px;background:var(--surface-2)}
.ad-item.r1 .ad-status{animation:adSt1 9s ease infinite}
.ad-item.r2 .ad-status{animation:adSt2 9s ease infinite}
.ad-item.r3 .ad-status{animation:adSt3 9s ease infinite}
.ad-item.r4 .ad-status{animation:adSt4 9s ease infinite}

@keyframes adSlide{0%,16%{transform:translateY(0)}20%,38%{transform:translateY(34px)}42%,60%{transform:translateY(68px)}64%,86%{transform:translateY(102px)}100%{transform:translateY(0)}}
@keyframes adBtn{0%,17%{box-shadow:0 0 0 0 rgba(255,49,117,0)}21%{box-shadow:0 0 0 8px rgba(255,49,117,.16)}29%,37%{box-shadow:0 0 0 0 rgba(255,49,117,0)}41%{box-shadow:0 0 0 8px rgba(135,88,238,.16)}49%,53%{box-shadow:0 0 0 0 rgba(135,88,238,0)}57%{box-shadow:0 0 0 8px rgba(78,113,254,.16)}65%,69%{box-shadow:0 0 0 0 rgba(78,113,254,0)}73%{box-shadow:0 0 0 8px rgba(40,200,100,.18)}81%,100%{box-shadow:0 0 0 0 rgba(40,200,100,0)}}
@keyframes adSt1{0%,18%{background:var(--surface-2);transform:scale(1)}22%{background:linear-gradient(90deg,#28c840,#9be15d);transform:scale(1.18)}26%,86%{background:linear-gradient(90deg,#28c840,#9be15d);transform:scale(1)}100%{background:var(--surface-2)}}
@keyframes adSt2{0%,38%{background:var(--surface-2);transform:scale(1)}42%{background:linear-gradient(90deg,#28c840,#9be15d);transform:scale(1.18)}46%,86%{background:linear-gradient(90deg,#28c840,#9be15d);transform:scale(1)}100%{background:var(--surface-2)}}
@keyframes adSt3{0%,58%{background:var(--surface-2);transform:scale(1)}62%{background:linear-gradient(90deg,#28c840,#9be15d);transform:scale(1.18)}66%,86%{background:linear-gradient(90deg,#28c840,#9be15d);transform:scale(1)}100%{background:var(--surface-2)}}
@keyframes adSt4{0%,70%{background:var(--surface-2);transform:scale(1)}74%{background:linear-gradient(90deg,#28c840,#9be15d);transform:scale(1.18)}78%,86%{background:linear-gradient(90deg,#28c840,#9be15d);transform:scale(1)}100%{background:var(--surface-2)}}

/* ---- Sección "pruébalo tú mismo" (PageSpeed / Pingdom) ---- */
.speed-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px}
.speed-card{display:block;padding:34px 32px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);backdrop-filter:blur(10px);transition:.3s}
.speed-card:hover{transform:translateY(-6px);border-color:var(--magenta);box-shadow:0 24px 54px -22px rgba(255,49,117,.5)}
.speed-ic{display:grid;place-items:center;width:56px;height:56px;border-radius:16px;background:var(--grad-soft);border:1px solid var(--border);font-size:1.7rem;margin-bottom:20px}
.speed-card h3{font-size:1.28rem;margin-bottom:10px}
.speed-card p{color:var(--muted);font-size:.96rem;line-height:1.6;margin-bottom:20px}
.speed-link{font-family:var(--font-head);font-weight:600;color:var(--magenta);transition:.3s}
.speed-card:hover .speed-link{color:var(--text)}

@media (max-width:760px){
  .hb-canvas{height:280px}.hb-hero{grid-template-columns:1fr;gap:14px}.hb-himg{height:84px}
  .hs-page{padding:16px;gap:12px}.hs-img{min-height:56px}.hs-grid{gap:10px}
  .hs-cart{width:36px;height:36px}.hs-search{height:22px}.hs-meta{padding:8px 9px}.hs-add{width:22px;height:22px;line-height:20px}
  .hc-page{padding:16px;gap:11px}.hc-chart{height:80px;padding:9px}.hc-list{gap:8px}.hc-gear{width:26px;height:26px}
  .op-page{padding:16px;gap:12px}.op-body{grid-template-columns:1fr;gap:14px}
  .op-gauge{width:118px;height:118px}.op-num{font-size:2.1rem}.op-metrics{gap:12px}
  .speed-grid{grid-template-columns:1fr;gap:16px;margin-top:32px}.speed-card{padding:26px 24px}
  .ad-app{padding:14px;gap:11px;grid-template-columns:62px 1fr}.ad-side{padding:10px;gap:14px}
  .ad-list{gap:9px}.ad-item{padding:8px;gap:9px}.ad-thumb{flex-basis:30px;width:30px;height:30px}
  .hb-page{padding:16px;gap:14px}.hb-cards{gap:10px}.hb-card{height:56px}
  .hero-build{width:106vw;opacity:.32}
}
@media (prefers-reduced-motion:reduce){
  .hb-type{max-width:160px;animation:none}.hb-caret{display:none}
  .hb-page{clip-path:none;opacity:1;animation:none}
  .hb-himg::after,.hb-logo,.hb-btn{animation:none}.hb-beam{display:none}
  .hs-prod{opacity:1;animation:none}
  .hs-badge{transform:scale(1);animation:none}.hs-badge .d3{opacity:1;animation:none}.hs-badge .d1,.hs-badge .d2{display:none}
  .hs-cart,.hs-logo,.hs-img::after{animation:none}
  .hc-ic{background:var(--grad);color:#fff;border-color:transparent;animation:none}
  .hc-prog i{width:100%;animation:none}.hc-scan{display:none}.hc-dot,.hc-gear svg{animation:none}
  .op-prog{stroke-dashoffset:3;stroke:#28c840;animation:none}
  .op-num .n4{opacity:1;animation:none}.op-num .n1,.op-num .n2,.op-num .n3{display:none}
  .op-track2 i{width:92%;animation:none}.op-rocket{display:none}.op-logo{animation:none}
  .ad-status{background:linear-gradient(90deg,#28c840,#9be15d);animation:none}
  .ad-slider{animation:none}.ad-pub,.ad-logo,.ad-thumb::after{animation:none}
}

/* split 2 cols */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}

/* checklist */
.check-list{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.check-list li{display:flex;align-items:flex-start;gap:12px;padding:18px 20px;background:var(--surface);border:1px solid var(--border);border-radius:16px;font-size:.95rem}
.check-list .ck{flex:0 0 24px;height:24px;border-radius:50%;background:var(--grad);display:grid;place-items:center;color:#fff;font-size:.8rem}

/* proceso */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:56px;counter-reset:step}
.step{position:relative;padding:34px 26px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);transition:.4s}
.step:hover{transform:translateY(-8px);border-color:rgba(255,49,117,.4)}
.step-num{font-family:var(--font-head);font-size:2.4rem;font-weight:700;line-height:1;margin-bottom:18px;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.step h3{font-size:1.15rem;margin-bottom:10px}
.step p{color:var(--muted);font-size:.92rem}

/* ============================================================
   CONTENIDO REAL REDISEÑADO (content-page)
   ============================================================ */
.hero-subtitle{font-family:var(--font-head);font-size:clamp(1.3rem,3vw,2rem);font-weight:600;line-height:1.2;margin-bottom:18px;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;max-width:760px;margin-inline:auto}
.section-alt{background:linear-gradient(180deg,transparent,rgba(135,88,238,.05),transparent)}
.section-alt::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 50% 50%,rgba(255,49,117,.05),transparent 70%);pointer-events:none}

.content-split{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.content-split.reverse .content-text{order:2}
.content-split.reverse .content-media{order:1}
.content-text .section-title{text-align:left}
.content-media img{width:100%;height:auto;border-radius:var(--radius);border:1px solid var(--border);box-shadow:0 30px 60px -25px rgba(0,0,0,.7)}
.content-media{position:relative}
.content-media::after{content:"";position:absolute;inset:-1px;border-radius:var(--radius);background:var(--grad);opacity:.18;z-index:-1;filter:blur(30px)}
.prose-center{margin:0 auto;text-align:center}
.prose-center ul{display:inline-block;text-align:left}

/* ============================================================
   BLOQUES DE PÁGINA DE SERVICIO (pilares, precio, clientes, faq)
   ============================================================ */
.section{position:relative}
.section-alt>.wrap{position:relative;z-index:1}

/* pilares / columnas de servicio */
.pillar-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px}
.pillar-card{position:relative;padding:38px 30px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);transition:.4s;overflow:hidden}
.pillar-card:hover{transform:translateY(-8px);border-color:rgba(255,49,117,.4)}
.pillar-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:.45s}
.pillar-card:hover::before{transform:scaleX(1)}
.pillar-num{font-family:var(--font-head);font-size:.9rem;font-weight:700;letter-spacing:.1em;color:var(--magenta);display:block;margin-bottom:16px}
.pillar-card h3{font-size:1.25rem;margin-bottom:12px;line-height:1.2}
.pillar-card p{color:var(--muted);font-size:.95rem;line-height:1.6}
/* Tarjeta-enlace (páginas relacionadas / marketing por industria) */
.pillar-link{display:flex;flex-direction:column;text-decoration:none;color:inherit}
.pillar-link h3{color:var(--text)}
.pillar-link .pillar-arrow{margin-top:auto;padding-top:18px;font-family:var(--font-head);font-size:.9rem;font-weight:700;letter-spacing:.02em;color:var(--magenta);transition:.3s}
.pillar-link:hover .pillar-arrow{letter-spacing:.06em}

/* tarjeta de precio */
.price-card{display:grid;grid-template-columns:.9fr 1.1fr;gap:0;max-width:920px;margin:0 auto;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);background:var(--surface)}
.price-head{padding:48px 40px;background:var(--grad-soft,linear-gradient(160deg,rgba(255,49,117,.12),rgba(135,88,238,.12)));border-right:1px solid var(--border);display:flex;flex-direction:column;gap:16px;align-items:flex-start}
.price-amount{font-family:var(--font-head);font-size:3rem;font-weight:700;line-height:1;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.price-amount span{display:block;font-size:.95rem;font-weight:500;color:var(--muted);-webkit-text-fill-color:var(--muted);margin-top:8px}
.price-list{padding:48px 40px;display:grid;gap:14px;align-content:center}
.price-list li{display:flex;align-items:flex-start;gap:12px;font-size:.95rem;color:var(--text)}
.price-list .ck{flex:0 0 22px;height:22px;border-radius:50%;background:var(--grad);display:grid;place-items:center;color:#fff;font-size:.75rem}
.price-sub{font-size:.9rem;color:var(--muted);margin:-4px 0 0;line-height:1.5}

/* banner de cruce (esto vs. el otro servicio) */
.xsell{display:flex;align-items:center;gap:18px;max-width:920px;margin:0 auto;padding:22px 28px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);text-decoration:none;color:var(--text);transition:.3s}
.xsell:hover{border-color:var(--magenta);transform:translateY(-2px);box-shadow:0 12px 30px rgba(135,88,238,.12)}
.xsell-icon{flex:0 0 44px;height:44px;border-radius:50%;background:var(--grad-soft,linear-gradient(160deg,rgba(255,49,117,.14),rgba(135,88,238,.14)));display:grid;place-items:center;font-size:1.3rem;color:var(--magenta)}
.xsell-text{flex:1;font-size:.98rem;line-height:1.55}
.xsell-cta{flex:0 0 auto;font-family:var(--font-head);font-weight:700;font-size:.92rem;letter-spacing:.02em;color:var(--magenta);white-space:nowrap;transition:.3s}
.xsell:hover .xsell-cta{letter-spacing:.05em}
@media(max-width:680px){.xsell{flex-direction:column;align-items:flex-start;text-align:left}}

/* paquetes (3 niveles) */
.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start;margin-top:44px}
.pkg-card{position:relative;display:flex;flex-direction:column;gap:16px;padding:34px 28px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);transition:transform .35s cubic-bezier(.2,.8,.2,1),border-color .35s}
.pkg-card:hover{transform:translateY(-6px);border-color:rgba(255,255,255,.22)}
.pkg-featured{border-color:transparent;background:linear-gradient(160deg,rgba(255,49,117,.14),rgba(135,88,238,.12),rgba(78,113,254,.12));box-shadow:0 0 0 1.5px transparent;position:relative}
.pkg-featured::before{content:"";position:absolute;inset:0;border-radius:var(--radius);padding:1.5px;background:var(--grad);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.pkg-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--grad);color:#fff;font-family:var(--font-head);font-size:.74rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:6px 16px;border-radius:999px;white-space:nowrap;z-index:2}
.pkg-badge-alt{background:#fff;color:#150828}
.pkg-name{font-family:var(--font-head);font-size:1.32rem;font-weight:600;margin:0}
.pkg-price{font-family:var(--font-head);display:flex;flex-direction:column;gap:2px;line-height:1.05}
.pkg-price-old{font-size:1rem;font-weight:500;color:var(--muted);text-decoration:line-through;opacity:.85}
.pkg-price-now{font-size:2.4rem;font-weight:700;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.pkg-price-now small{font-size:.85rem;font-weight:500;color:var(--muted);-webkit-text-fill-color:var(--muted);margin-left:4px}
.pkg-desc{color:var(--muted);font-size:.92rem;line-height:1.6;margin:0}
.pkg-cta{width:100%;justify-content:center;text-align:center}
.pkg-list{list-style:none;margin:0;padding:0;display:grid;gap:11px;border-top:1px solid var(--border);padding-top:22px}
.pkg-list li{display:flex;align-items:flex-start;gap:10px;font-size:.9rem;color:var(--text);line-height:1.4}
.pkg-list .ck{flex:0 0 20px;height:20px;border-radius:50%;background:var(--grad);display:grid;place-items:center;color:#fff;font-size:.7rem;margin-top:1px}
.pkg-extra{border-top:1px dashed var(--border);padding-top:14px;display:flex;flex-direction:column;gap:5px}
.pkg-extra-label{font-family:var(--font-head);font-size:.78rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:var(--text)}
.pkg-extra-items{font-size:.86rem;color:var(--muted);line-height:1.5}
.pkg-foot{margin-top:34px;color:var(--muted);font-size:.95rem}
@media(max-width:900px){.pkg-grid{grid-template-columns:1fr;max-width:460px;margin-left:auto;margin-right:auto}.pkg-featured{order:-1}}

/* clientes */
.client-row{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;margin-top:48px}
.client-chip{padding:14px 26px;border-radius:50px;background:var(--surface);border:1px solid var(--border);font-family:var(--font-head);font-weight:600;font-size:1rem;color:var(--text);transition:.3s}
.client-chip:hover{border-color:rgba(255,49,117,.5);transform:translateY(-3px)}

/* faq */
.faq{max-width:820px;margin:48px auto 0;display:grid;gap:14px}
.faq-item{background:var(--surface);border:1px solid var(--border);border-radius:16px;overflow:hidden;transition:.3s}
.faq-item[open]{border-color:rgba(135,88,238,.5)}
.faq-item summary{list-style:none;cursor:pointer;padding:22px 26px;display:flex;justify-content:space-between;align-items:center;gap:16px;font-family:var(--font-head);font-weight:600;font-size:1.05rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-ic{flex:0 0 28px;height:28px;border-radius:50%;background:var(--grad);display:grid;place-items:center;color:#fff;font-size:1.1rem;transition:.3s}
.faq-item[open] .faq-ic{transform:rotate(45deg)}
.faq-a{padding:0 26px 24px}
.faq-a p{color:var(--muted);font-size:.96rem;line-height:1.7;margin:0}

/* ============================================================
   CONTENIDO (prosa) — base
   ============================================================ */
.prose{max-width:820px;margin:0 auto;font-size:1.06rem;color:var(--text)}
.prose h1,.prose h2,.prose h3,.prose h4{margin:1.6em 0 .6em;line-height:1.15}
.prose h2{font-size:clamp(1.6rem,3.5vw,2.4rem)}
.prose h3{font-size:1.4rem}
.prose p{margin:0 0 1.2em;color:var(--muted)}
.prose a{color:var(--magenta);text-decoration:underline;text-underline-offset:3px}
.prose ul,.prose ol{margin:0 0 1.4em 1.2em}
.prose li{margin-bottom:.6em;color:var(--muted)}
.prose ul li{list-style:none;position:relative;padding-left:24px}
.prose ul li::before{content:"";position:absolute;left:0;top:.55em;width:9px;height:9px;border-radius:50%;background:var(--grad)}
.prose img{border-radius:var(--radius);margin:2em auto;border:1px solid var(--border)}
.prose strong{color:var(--text)}
.prose blockquote{border-left:3px solid var(--magenta);padding-left:22px;margin:1.6em 0;font-style:italic;color:var(--text)}

/* ============================================================
   ARTÍCULO DE BLOG — lectura cómoda, una columna
   ============================================================ */
.article-section{padding-top:24px}
.article-body{max-width:740px;margin:0 auto;font-size:1.14rem;line-height:1.85}
.article-body p{margin:0 0 1.5em;color:var(--text-soft,#cdc5da);line-height:1.85}
/* primer párrafo como entradilla */
.article-body>p:first-of-type{font-size:1.26rem;line-height:1.7;color:var(--text);margin-bottom:1.6em}
.article-body h2,.article-body h3,.article-body h4{color:#fff;font-family:var(--font-head);letter-spacing:-.01em}
.article-body h2{font-size:clamp(1.55rem,3vw,2.1rem);margin:1.9em 0 .5em;padding-left:18px;position:relative;line-height:1.2}
.article-body h2::before{content:"";position:absolute;left:0;top:.18em;bottom:.18em;width:4px;border-radius:4px;background:var(--grad)}
.article-body h3{font-size:1.32rem;margin:1.7em 0 .5em}
.article-body ul,.article-body ol{margin:0 0 1.6em 0}
.article-body li{margin-bottom:.7em;line-height:1.7;color:var(--text-soft,#cdc5da)}
.article-body ul li{padding-left:28px}
.article-body ul li::before{top:.62em;width:8px;height:8px}
.article-body img{width:100%;margin:2.4em auto;box-shadow:0 30px 60px -30px rgba(0,0,0,.7)}
.article-body a{color:var(--magenta);text-decoration:underline;text-underline-offset:3px}
.article-body strong{color:#fff}
.article-body blockquote{font-size:1.18rem;border-left-width:4px}

/* ============================================================
   BLOG
   ============================================================ */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.blog-card{border-radius:var(--radius);overflow:hidden;background:var(--surface);border:1px solid var(--border);transition:.45s;display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-8px);border-color:rgba(135,88,238,.5)}
.blog-thumb{aspect-ratio:16/10;overflow:hidden;background:var(--bg-2)}
.blog-thumb img{width:100%;height:100%;object-fit:cover;transition:.7s}
.blog-card:hover .blog-thumb img{transform:scale(1.07)}
.blog-body{padding:26px;display:flex;flex-direction:column;gap:12px;flex:1}
.blog-date{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--magenta)}
.blog-body h3{font-size:1.25rem;line-height:1.2}
.blog-body p{color:var(--muted);font-size:.92rem;flex:1}
.blog-body .more{font-family:var(--font-head);font-weight:600;font-size:.88rem;color:var(--text)}

/* single article */
.article{max-width:820px;margin:0 auto}
.article-head{text-align:center;margin-bottom:46px}
.article-head h1{font-size:clamp(2rem,5vw,3.4rem);margin:18px 0}
.article-cover{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);margin-bottom:46px}
.article-cover img{width:100%;height:auto}

/* paginación */
.pagination{display:flex;gap:10px;justify-content:center;margin-top:56px}
.pagination a,.pagination span{padding:12px 18px;border-radius:12px;background:var(--surface);border:1px solid var(--border);font-family:var(--font-head);font-size:.9rem;transition:.3s}
.pagination a:hover{background:var(--grad);border-color:transparent}
.pagination .current{background:var(--grad);border-color:transparent}

/* breadcrumb */
.crumb{font-size:.84rem;color:var(--muted);margin-bottom:14px}
.crumb a{color:var(--muted)}.crumb a:hover{color:var(--magenta)}

/* formulario contacto */
.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.contact-info .ci{display:flex;gap:16px;align-items:flex-start;padding:22px 0;border-bottom:1px solid var(--border)}
.contact-info .ci .ic{flex:0 0 48px;height:48px;border-radius:14px;background:var(--grad-soft);border:1px solid var(--border);display:grid;place-items:center;font-size:1.3rem}
.contact-info .ci h4{font-size:1.05rem;margin-bottom:4px}
.contact-info .ci p,.contact-info .ci a{color:var(--muted);font-size:.94rem}
.form{padding:38px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border)}
.form .field{margin-bottom:20px}
.form label{display:block;font-size:.85rem;margin-bottom:8px;color:var(--muted);font-family:var(--font-head)}
.form input,.form textarea,.form select{width:100%;padding:15px 18px;border-radius:14px;background:var(--bg);border:1px solid var(--border);color:var(--text);font-family:var(--font-body);font-size:.95rem;transition:.3s}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--magenta);box-shadow:0 0 0 3px rgba(255,49,117,.15)}
.form textarea{min-height:130px;resize:vertical}
.form .btn{width:100%;justify-content:center}
.form-msg{padding:16px;border-radius:14px;margin-bottom:20px;font-size:.92rem}
.form-msg.ok{background:rgba(46,204,113,.12);border:1px solid rgba(46,204,113,.4);color:#7ee2a8}
.form-msg.err{background:rgba(255,49,117,.12);border:1px solid rgba(255,49,117,.4);color:#ff9bbf}

/* --- formulario de marketing (calificación de leads) --- */
.lead-form{display:flex;flex-direction:column;gap:8px}
.fset{border:none;padding:0;margin:0 0 26px;min-width:0}
.fset legend{display:flex;align-items:center;gap:10px;font-family:var(--font-head);font-size:1.05rem;color:var(--text);margin-bottom:16px;padding:0;width:100%}
.fset .step-n{flex:0 0 26px;height:26px;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;font-size:.85rem;font-weight:700}
.fhint{color:var(--muted);font-size:.85rem;margin:-8px 0 14px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-2 .field{margin-bottom:0}
.lead-form .field{margin-bottom:16px}
/* checkboxes tipo chip */
.chk-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.chip,.opt{position:relative;display:flex;align-items:center;gap:10px;padding:13px 16px;border-radius:14px;background:var(--bg);border:1px solid var(--border);cursor:pointer;transition:.25s;font-size:.92rem;color:var(--text)}
.chip:hover,.opt:hover{border-color:var(--magenta)}
.chip input,.opt input{position:absolute;opacity:0;width:0;height:0}
.chip span,.opt span{line-height:1.3}
.chip::before,.opt::before{content:'';flex:0 0 20px;height:20px;border:2px solid var(--border);background:transparent;transition:.25s}
.chip::before{border-radius:6px}
.opt::before{border-radius:50%}
.chip:has(input:checked),.opt:has(input:checked){border-color:var(--magenta);background:var(--grad-soft);box-shadow:0 0 0 3px rgba(255,49,117,.12)}
.chip:has(input:checked)::before,.opt:has(input:checked)::before{border-color:var(--magenta);background:var(--grad);box-shadow:inset 0 0 0 3px var(--bg)}
.chip:has(input:focus-visible),.opt:has(input:focus-visible){outline:2px solid var(--magenta);outline-offset:2px}
/* radios en una columna */
.opt-grid{display:grid;grid-template-columns:1fr;gap:10px}
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0;pointer-events:none}
.fprivacy{color:var(--muted);font-size:.8rem;text-align:center;margin-top:14px}
/* panel "qué sigue" en el sidebar */
.next-steps{margin-top:28px;padding:24px;border-radius:var(--radius);background:var(--grad-soft);border:1px solid var(--border)}
.next-steps h4{font-size:1rem;margin-bottom:14px}
.next-steps ol{margin:0 0 20px;padding-left:20px;display:flex;flex-direction:column;gap:8px}
.next-steps li{color:var(--muted);font-size:.9rem;line-height:1.45}
.next-steps .btn{width:100%;justify-content:center}

/* --- switcher de idioma ES/EN --- */
.lang-switch{display:inline-flex;align-items:center;gap:2px;padding:5px;border:1px solid var(--border);border-radius:999px;background:var(--surface);font-family:var(--font-head);font-size:.78rem;line-height:1;backdrop-filter:blur(10px)}
.lang-switch span{padding:5px 9px;border-radius:999px;color:var(--muted);transition:.25s}
.lang-switch span.on{background:var(--grad);color:#fff}
.lang-switch:hover span:not(.on){color:var(--text)}
.lang-switch-m{display:block;margin-top:18px;text-align:center;color:var(--magenta);border:none;background:none;font-size:1rem}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .services-grid,.why-grid{grid-template-columns:repeat(2,1fr)}
  .portfolio-grid,.blog-grid{grid-template-columns:repeat(2,1fr)}
  .reviews-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .process{grid-template-columns:repeat(2,1fr)}
  .pillar-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .section{padding:80px 0}
  .nav,.header-cta .btn{display:none}
  .burger{display:flex}
  .services-grid,.why-grid,.portfolio-grid,.stats,.blog-grid,.process,.pillar-grid{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .compare{display:block;overflow-x:auto}
  .split,.contact-wrap,.check-list,.content-split,.price-card{grid-template-columns:1fr;gap:34px}
  .grid-2,.chk-grid{grid-template-columns:1fr}
  .price-card{gap:0}
  .price-head{border-right:none;border-bottom:1px solid var(--border)}
  .price-list{padding:32px 28px}
  .hero{padding-top:120px}
  .hero-inner{padding-top:140px}
}

/* ===== Caso de estudio de portafolio ===== */
.cs-hero .lead{max-width:680px}
.cs-cover{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);
  box-shadow:0 30px 80px -30px rgba(0,0,0,.7);background:var(--surface)}
.cs-cover img{display:block;width:100%;height:auto}
.cs-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);
  border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.cs-meta-item{display:flex;flex-direction:column;gap:7px;padding:26px 24px;background:var(--bg)}
.cs-meta-k{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.cs-meta-v{font-family:var(--font-head);font-weight:600;font-size:1.05rem;color:var(--text)}
.cs-link{color:var(--magenta);text-decoration:none;word-break:break-word}
.cs-link:hover{text-decoration:underline}
.cs-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.cs-shot{margin:0;border-radius:18px;overflow:hidden;border:1px solid var(--border);
  background:var(--surface);box-shadow:0 18px 50px -28px rgba(0,0,0,.6);
  transition:transform .4s ease,box-shadow .4s ease}
.cs-shot:hover{transform:translateY(-5px);box-shadow:0 28px 60px -28px rgba(135,88,238,.5)}
.cs-shot img{display:block;width:100%;height:auto}
.cs-cta{max-width:760px;margin:0 auto;text-align:center}
.cs-cta h2{font-family:var(--font-head);font-size:clamp(1.8rem,4vw,2.6rem);line-height:1.1;margin-bottom:16px}
.cs-cta p{color:var(--muted);max-width:560px;margin:0 auto 30px}
@media(max-width:900px){.cs-meta{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.cs-gallery{grid-template-columns:1fr;gap:18px}}
@media(max-width:560px){.cs-meta{grid-template-columns:1fr}}

/* ============================================================
   Página 404 creativa (glitch + parallax + buscador en vivo)
   ============================================================ */
.e404{position:relative;min-height:calc(100vh - 90px);display:flex;align-items:center;justify-content:center;padding:120px 0 90px;overflow:hidden}
.e404-stage{position:relative;text-align:center;perspective:900px;z-index:1}

/* Órbita decorativa giratoria detrás del número */
.e404-orbit{position:absolute;top:46%;left:50%;width:min(640px,86vw);height:min(640px,86vw);transform:translate(-50%,-50%);z-index:-1;pointer-events:none}
.e404-orbit i{position:absolute;inset:0;border-radius:50%;border:1px solid var(--border)}
.e404-orbit i:nth-child(1){animation:spin 26s linear infinite}
.e404-orbit i:nth-child(2){inset:14%;border-color:rgba(255,49,117,.22);animation:spin 18s linear infinite reverse}
.e404-orbit i:nth-child(3){inset:30%;border-color:rgba(78,113,254,.22);animation:spin 34s linear infinite}
.e404-orbit i:nth-child(1)::after{content:"";position:absolute;top:-5px;left:50%;width:10px;height:10px;border-radius:50%;background:var(--magenta);box-shadow:0 0 18px 3px var(--magenta)}
.e404-orbit i:nth-child(3)::after{content:"";position:absolute;bottom:-4px;left:30%;width:8px;height:8px;border-radius:50%;background:var(--blue);box-shadow:0 0 16px 3px var(--blue)}
@keyframes spin{to{transform:rotate(360deg)}}

/* Número 404 con degradado, flotación y glitch */
.e404-num{display:inline-flex;gap:.02em;font-family:var(--font-head);font-weight:700;font-size:clamp(7rem,27vw,20rem);line-height:.86;letter-spacing:-.03em;position:relative;transition:transform .15s ease-out;transform-style:preserve-3d;will-change:transform;animation:e404float 6s ease-in-out infinite}
.e404-num span{background:var(--grad);background-size:200% 200%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradShift 6s ease infinite}
.e404-num .zero{position:relative}
.e404-num .zero::before{content:"";position:absolute;inset:14% 12%;border-radius:50%;border:.06em solid transparent;background:conic-gradient(from 0deg,var(--magenta),var(--purple),var(--blue),var(--magenta)) border-box;-webkit-mask:linear-gradient(#000 0 0) padding-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;animation:spin 7s linear infinite;opacity:.85}
@keyframes e404float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

/* Glitch: dos capas que parpadean en cortes (respeta el parallax del padre) */
.glitch::before,.glitch::after{content:attr(data-text);position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:.02em;font:inherit;letter-spacing:inherit;pointer-events:none;opacity:.85}
.glitch::before{color:var(--magenta);mix-blend-mode:screen;animation:glitchA 2.6s steps(2,end) infinite}
.glitch::after{color:var(--blue);mix-blend-mode:screen;animation:glitchB 3.1s steps(2,end) infinite}
@keyframes glitchA{0%,12%,100%{clip-path:inset(0 0 100% 0);transform:translate(0)}14%{clip-path:inset(8% 0 72% 0);transform:translate(-5px,-2px)}20%{clip-path:inset(40% 0 38% 0);transform:translate(5px,2px)}26%{clip-path:inset(70% 0 8% 0);transform:translate(-4px,1px)}30%{clip-path:inset(0 0 100% 0)}}
@keyframes glitchB{0%,16%,100%{clip-path:inset(0 0 100% 0);transform:translate(0)}18%{clip-path:inset(62% 0 14% 0);transform:translate(5px,2px)}24%{clip-path:inset(20% 0 60% 0);transform:translate(-6px,-1px)}34%{clip-path:inset(48% 0 30% 0);transform:translate(4px,-2px)}40%{clip-path:inset(0 0 100% 0)}}

.e404-title{font-family:var(--font-head);font-size:clamp(1.5rem,4vw,2.6rem);margin:.4em 0 .25em;line-height:1.1}
.e404-lead{color:var(--muted);max-width:620px;margin:0 auto 34px;font-size:1.08rem;line-height:1.6}

/* Buscador en vivo */
.e404-search{position:relative;max-width:560px;margin:0 auto 26px;text-align:left}
.e404-search>svg{position:absolute;left:20px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}
.e404-search input{width:100%;padding:18px 22px 18px 52px;border-radius:60px;background:var(--surface-2);border:1px solid var(--border);color:var(--text);font-family:var(--font-body);font-size:1.02rem;backdrop-filter:blur(12px);transition:border-color .2s,box-shadow .2s}
.e404-search input:focus{outline:none;border-color:var(--magenta);box-shadow:0 0 0 4px rgba(255,49,117,.16)}
.e404-results{position:absolute;top:calc(100% + 10px);left:0;right:0;background:rgba(20,8,39,.96);border:1px solid var(--border);border-radius:18px;overflow:hidden;backdrop-filter:blur(16px);box-shadow:0 24px 60px -12px rgba(0,0,0,.6);opacity:0;visibility:hidden;transform:translateY(-8px);transition:.18s;z-index:5}
.e404-results.open{opacity:1;visibility:visible;transform:none}
.e404-results a{display:block;padding:13px 20px;color:var(--text);border-bottom:1px solid var(--border);transition:background .15s,padding .15s}
.e404-results a:last-child{border-bottom:0}
.e404-results a:hover{background:var(--grad-soft);padding-left:26px}

/* Chips de sugerencia */
.e404-suggest{margin:0 auto 34px;max-width:680px}
.e404-suggest-label{display:block;color:var(--muted);font-size:.85rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:14px}
.e404-chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.e404-chip{padding:9px 18px;border-radius:60px;background:var(--surface);border:1px solid var(--border);color:var(--text);font-size:.92rem;font-weight:500;transition:transform .2s,border-color .2s,background .2s}
.e404-chip:hover{transform:translateY(-3px);border-color:var(--magenta);background:var(--grad-soft)}
.e404-cta{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}

@media(prefers-reduced-motion:reduce){
  .e404-num,.e404-orbit i,.e404-num .zero::before,.glitch::before,.glitch::after{animation:none}
}
@media(max-width:560px){
  .e404{padding:100px 0 70px}
  .e404-cta .btn{width:100%;justify-content:center}
}
