/* ================================================================
   A10WEB — AGENCIA DIGITAL PREMIUM
   CSS Principal v2.0 — Tema WordPress Completo
   Zamora · Toledo · España
================================================================ */

/* ── RESET & VARIABLES ─────────────────────────────────────── */
:root {
  --c-bg:       #060608;
  --c-bg2:      #0d0d12;
  --c-bg3:      #111118;
  --c-surface:  #16161f;
  --c-border:   rgba(255,255,255,0.07);
  --c-red:      #ff2d55;
  --c-red2:     #ff6b6b;
  --c-blue:     #4fc3f7;
  --c-purple:   #a855f7;
  --c-green:    #22d3a5;
  --c-text:     #f0f0f5;
  --c-muted:    rgba(240,240,245,0.5);
  --c-faint:    rgba(240,240,245,0.12);
  --f-head:     'Sora', sans-serif;
  --f-body:     'Inter', sans-serif;
  --r-sm:       8px;
  --r-md:       16px;
  --r-lg:       24px;
  --r-xl:       40px;
  --r-full:     9999px;
  --sh-glow:    0 0 60px rgba(255,45,85,0.25);
  --sh-card:    0 20px 60px rgba(0,0,0,0.5);
  --ease:       cubic-bezier(0.4,0,0.2,1);
  --ease-out:   cubic-bezier(0,0,0.2,1);
  --ease-spring:cubic-bezier(0.34,1.56,0.64,1);
  --t:          0.35s;
}

*,*::before,*::after { margin:0;padding:0;box-sizing:border-box; }
html { scroll-behavior:auto; font-size:16px; }
body { font-family:var(--f-body); background:var(--c-bg); color:var(--c-text); line-height:1.6; overflow-x:hidden; }
img { max-width:100%; height:auto; display:block; }
a { color:inherit; text-decoration:none; }

::selection { background:var(--c-red); color:#fff; }
::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-track { background:var(--c-bg); }
::-webkit-scrollbar-thumb { background:var(--c-red); border-radius:2px; }

/* ── CURSOR PERSONALIZADO ──────────────────────────────────── */
.cursor { position:fixed; pointer-events:none; z-index:9999; mix-blend-mode:difference; }
.cursor-dot { width:8px; height:8px; background:#fff; border-radius:50%; transform:translate(-50%,-50%); transition:width .2s,height .2s; }
.cursor-ring { width:36px; height:36px; border:1.5px solid rgba(255,255,255,0.6); border-radius:50%; transform:translate(-50%,-50%); transition:width .3s var(--ease),height .3s var(--ease),opacity .3s; }
.cursor-ring.hover { width:56px; height:56px; border-color:var(--c-red); }

/* ── LOADER ─────────────────────────────────────────────────── */
#loader { position:fixed; inset:0; z-index:9998; background:var(--c-bg); display:flex; align-items:center; justify-content:center; flex-direction:column; gap:24px; }
.loader-logo { font-family:var(--f-head); font-size:clamp(36px,6vw,72px); font-weight:900; letter-spacing:-3px; }
.loader-logo span { color:var(--c-red); }
.loader-bar { width:200px; height:2px; background:rgba(255,255,255,0.1); border-radius:2px; overflow:hidden; }
.loader-fill { height:100%; background:linear-gradient(90deg,var(--c-red),var(--c-blue)); width:0; border-radius:2px; }
.loader-pct { font-size:12px; color:var(--c-muted); letter-spacing:3px; font-weight:500; }

/* ── LAYOUT HELPERS ─────────────────────────────────────────── */
.container { max-width:1200px; margin:0 auto; padding:0 32px; }
.container-wide { max-width:1440px; margin:0 auto; padding:0 48px; }
.container-narrow { max-width:800px; margin:0 auto; padding:0 32px; }

/* ── NOISE TEXTURE OVERLAY ─────────────────────────────────── */
body::before {
  content:'';position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");
  pointer-events:none;z-index:1;opacity:0.4;
}

/* ── TOPBAR ─────────────────────────────────────────────────── */
.topbar { background:rgba(255,45,85,0.08); border-bottom:1px solid rgba(255,45,85,0.15); padding:10px 0; font-size:12px; position:relative; z-index:100; }
.topbar-inner { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px; }
.topbar-office { display:flex; align-items:center; gap:8px; color:rgba(255,255,255,0.6); }
.topbar-office .pill { background:var(--c-red); color:#fff; font-size:10px; font-weight:700; padding:3px 10px; border-radius:var(--r-full); letter-spacing:1px; text-transform:uppercase; }
.topbar-offices { display:flex; gap:28px; flex-wrap:wrap; }
.topbar-links { display:flex; gap:20px; }
.topbar-links a { color:rgba(255,255,255,0.55); font-size:12px; display:flex; align-items:center; gap:6px; transition:color var(--t); }
.topbar-links a:hover { color:var(--c-red); }

/* ── HEADER ─────────────────────────────────────────────────── */
#site-header { position:sticky; top:0; z-index:500; transition:background var(--t),border-color var(--t),backdrop-filter var(--t); background:rgba(6,6,8,0.1); border-bottom:1px solid transparent; }
#site-header.scrolled { background:rgba(6,6,8,0.92); backdrop-filter:blur(24px); border-bottom:1px solid var(--c-border); }
.nav-wrap { display:flex; align-items:center; justify-content:space-between; height:72px; }
.site-logo { display:flex; align-items:center; gap:12px; }
.logo-mark { width:46px; height:46px; background:linear-gradient(135deg,var(--c-red),#c0152f); border-radius:14px; display:flex; align-items:center; justify-content:center; font-family:var(--f-head); font-size:17px; font-weight:900; color:#fff; letter-spacing:-1px; box-shadow:0 4px 20px rgba(255,45,85,0.4); flex-shrink:0; transition:transform var(--t) var(--ease-spring); }
.logo-mark:hover { transform:scale(1.08) rotate(-3deg); }
.logo-name { font-family:var(--f-head); font-size:22px; font-weight:800; letter-spacing:-0.5px; }
.logo-name em { color:var(--c-red); font-style:normal; }
.logo-tagline { font-size:10px; color:var(--c-muted); letter-spacing:2px; text-transform:uppercase; font-weight:500; margin-top:2px; display:block; }

.nav-menu { display:flex; align-items:center; gap:2px; list-style:none; }
.nav-menu > li > a { display:block; padding:8px 16px; font-size:14px; font-weight:500; color:rgba(255,255,255,0.75); border-radius:var(--r-sm); transition:all var(--t); position:relative; }
.nav-menu > li > a:hover, .nav-menu > li > a.current { color:#fff; background:rgba(255,255,255,0.06); }
.nav-menu > li > a.current::after { content:''; position:absolute; bottom:4px; left:50%; transform:translateX(-50%); width:16px; height:2px; background:var(--c-red); border-radius:2px; }

.nav-cta { display:flex; align-items:center; gap:12px; }
.btn-nav { display:inline-flex; align-items:center; gap:8px; background:linear-gradient(135deg,var(--c-red),#c0152f); color:#fff; font-size:13px; font-weight:700; padding:10px 22px; border-radius:var(--r-full); border:none; cursor:pointer; transition:all var(--t); box-shadow:0 4px 16px rgba(255,45,85,0.35); letter-spacing:0.3px; }
.btn-nav:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(255,45,85,0.5); }

.hamburger { display:none; background:none; border:none; cursor:pointer; padding:8px; flex-direction:column; gap:5px; }
.hamburger span { width:24px; height:2px; background:#fff; border-radius:2px; transition:all var(--t); display:block; }
.hamburger.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.active span:nth-child(2) { opacity:0; }
.hamburger.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ── BOTONES GLOBALES ───────────────────────────────────────── */
.btn { display:inline-flex; align-items:center; gap:10px; font-family:var(--f-body); font-size:15px; font-weight:600; padding:14px 32px; border-radius:var(--r-full); border:none; cursor:pointer; transition:all var(--t); text-decoration:none; white-space:nowrap; }
.btn-primary { background:linear-gradient(135deg,var(--c-red),#c0152f); color:#fff; box-shadow:0 4px 24px rgba(255,45,85,0.4); }
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 12px 40px rgba(255,45,85,0.55); }
.btn-ghost { background:rgba(255,255,255,0.06); color:rgba(255,255,255,0.85); border:1px solid rgba(255,255,255,0.12); }
.btn-ghost:hover { background:rgba(255,255,255,0.12); border-color:rgba(255,255,255,0.25); color:#fff; }
.btn-outline-red { background:transparent; color:var(--c-red); border:2px solid var(--c-red); }
.btn-outline-red:hover { background:var(--c-red); color:#fff; transform:translateY(-2px); box-shadow:var(--sh-glow); }
.btn-lg { padding:18px 44px; font-size:17px; }
.btn-sm { padding:9px 22px; font-size:13px; }
.btn-icon { width:48px; height:48px; padding:0; justify-content:center; border-radius:50%; }

/* ── TAGS / LABELS ──────────────────────────────────────────── */
.eyebrow { display:inline-flex; align-items:center; gap:8px; font-size:11px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--c-red); margin-bottom:20px; }
.eyebrow::before { content:''; width:20px; height:2px; background:var(--c-red); border-radius:1px; }
.eyebrow.blue { color:var(--c-blue); }
.eyebrow.blue::before { background:var(--c-blue); }

/* ── SECTION WRAPPER ────────────────────────────────────────── */
.section { padding:120px 0; }
.section-sm { padding:80px 0; }
.section-header { margin-bottom:72px; }
.section-header.center { text-align:center; }
.section-header.center .eyebrow { justify-content:center; }

h1,h2,h3,h4 { font-family:var(--f-head); line-height:1.1; letter-spacing:-0.03em; }
.display-xl { font-size:clamp(52px,7vw,96px); font-weight:900; line-height:1.0; }
.display-lg { font-size:clamp(40px,5.5vw,72px); font-weight:800; }
.display-md { font-size:clamp(32px,4vw,52px); font-weight:800; }
.display-sm { font-size:clamp(24px,3vw,38px); font-weight:700; }
.body-lg { font-size:18px; line-height:1.75; color:var(--c-muted); }
.body-md { font-size:16px; line-height:1.7; color:var(--c-muted); }

.gradient-text { background:linear-gradient(135deg,var(--c-red) 0%,var(--c-red2) 40%,var(--c-blue) 100%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.gradient-text-2 { background:linear-gradient(90deg,#fff 0%,var(--c-muted) 100%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }

/* ── SPLIT TEXT ANIMATION TARGETS ──────────────────────────── */
.split-chars .char { display:inline-block; will-change:transform,opacity; }
.split-words .word { display:inline-block; overflow:hidden; }
.reveal-up { opacity:0; transform:translateY(40px); }
.reveal-left { opacity:0; transform:translateX(-40px); }
.reveal-scale { opacity:0; transform:scale(0.9); }

/* ══════════════════════════════════════════════════════════════
   HERO
══════════════════════════════════════════════════════════════ */
.hero { position:relative; min-height:100svh; display:flex; align-items:center; overflow:hidden; padding:120px 0 80px; }

.hero-bg { position:absolute; inset:0; z-index:0; }
.hero-gradient { position:absolute; inset:0; background:radial-gradient(ellipse 80% 70% at 60% 30%, rgba(255,45,85,0.18) 0%, transparent 60%), radial-gradient(ellipse 50% 50% at 10% 80%, rgba(79,195,247,0.12) 0%, transparent 50%), radial-gradient(ellipse 40% 60% at 90% 70%, rgba(168,85,247,0.1) 0%, transparent 50%); }
.hero-grid-lines { position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,0.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.025) 1px,transparent 1px); background-size:80px 80px; }

.hero-content { position:relative; z-index:2; max-width:780px; }
.hero-badge { display:inline-flex; align-items:center; gap:10px; background:rgba(255,45,85,0.12); border:1px solid rgba(255,45,85,0.3); padding:8px 20px; border-radius:var(--r-full); margin-bottom:32px; font-size:13px; font-weight:600; color:rgba(255,150,170,0.9); }
.hero-badge .dot { width:8px; height:8px; background:var(--c-red); border-radius:50%; animation:blink 2s infinite; }
@keyframes blink { 0%,100%{opacity:1}50%{opacity:0.3} }

.hero h1 { margin-bottom:24px; }
.hero-desc { font-size:19px; line-height:1.75; color:var(--c-muted); margin-bottom:40px; max-width:560px; }
.hero-actions { display:flex; gap:16px; flex-wrap:wrap; margin-bottom:64px; }

.hero-metrics { display:flex; gap:48px; flex-wrap:wrap; padding-top:48px; border-top:1px solid var(--c-border); }
.hero-metric .num { font-family:var(--f-head); font-size:44px; font-weight:900; line-height:1; background:linear-gradient(135deg,#fff,var(--c-muted)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.hero-metric .num em { color:var(--c-red); -webkit-text-fill-color:var(--c-red); font-style:normal; }
.hero-metric .label { font-size:13px; color:var(--c-muted); margin-top:6px; text-transform:uppercase; letter-spacing:1.5px; font-weight:500; }

.hero-visual { position:absolute; right:0; top:50%; transform:translateY(-50%); width:50%; max-width:700px; z-index:1; opacity:0.7; pointer-events:none; }
.hero-orb { position:absolute; border-radius:50%; filter:blur(80px); }
.hero-orb-1 { width:500px; height:500px; background:rgba(255,45,85,0.25); top:-100px; right:-100px; animation:float1 8s ease-in-out infinite; }
.hero-orb-2 { width:300px; height:300px; background:rgba(79,195,247,0.2); bottom:0; left:20%; animation:float2 10s ease-in-out infinite; }
.hero-orb-3 { width:200px; height:200px; background:rgba(168,85,247,0.2); top:40%; right:30%; animation:float3 6s ease-in-out infinite; }
@keyframes float1 { 0%,100%{transform:translate(0,0)}50%{transform:translate(-30px,20px)} }
@keyframes float2 { 0%,100%{transform:translate(0,0)}50%{transform:translate(20px,-30px)} }
@keyframes float3 { 0%,100%{transform:translate(0,0)}50%{transform:translate(-15px,15px)} }

/* Scroll indicator */
.scroll-cue { position:absolute; bottom:40px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:8px; z-index:10; }
.scroll-cue span { font-size:11px; letter-spacing:3px; text-transform:uppercase; color:var(--c-muted); font-weight:500; }
.scroll-line { width:1px; height:48px; background:linear-gradient(to bottom,var(--c-red),transparent); animation:scrollDown 2s ease-in-out infinite; }
@keyframes scrollDown { 0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom} }

/* ── MARQUEE / TICKER ───────────────────────────────────────── */
.marquee-section { padding:24px 0; background:var(--c-red); overflow:hidden; }
.marquee-track { display:flex; gap:0; animation:marquee 25s linear infinite; white-space:nowrap; }
.marquee-item { display:flex; align-items:center; gap:16px; padding:0 32px; font-family:var(--f-head); font-size:15px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:#fff; }
.marquee-item .sep { font-size:20px; opacity:0.5; }
@keyframes marquee { 0%{transform:translateX(0)}100%{transform:translateX(-50%)} }

/* ══════════════════════════════════════════════════════════════
   CLIENTES / LOGOS
══════════════════════════════════════════════════════════════ */
.clients-section { padding:72px 0; border-bottom:1px solid var(--c-border); }
.clients-label { text-align:center; font-size:12px; letter-spacing:3px; text-transform:uppercase; color:var(--c-muted); margin-bottom:48px; font-weight:500; }
.clients-scroll { overflow:hidden; }
.clients-row { display:flex; gap:0; animation:marquee-slow 30s linear infinite; }
.client-item { display:flex; align-items:center; justify-content:center; padding:0 48px; height:48px; opacity:0.3; filter:grayscale(1) brightness(2); transition:opacity var(--t),filter var(--t); cursor:default; flex-shrink:0; }
.client-item:hover { opacity:0.7; filter:grayscale(0) brightness(1); }
.client-item span { font-family:var(--f-head); font-size:18px; font-weight:700; letter-spacing:-0.5px; color:#fff; white-space:nowrap; }
@keyframes marquee-slow { 0%{transform:translateX(0)}100%{transform:translateX(-50%)} }

/* ══════════════════════════════════════════════════════════════
   SERVICIOS
══════════════════════════════════════════════════════════════ */
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:var(--c-border); border:1px solid var(--c-border); border-radius:var(--r-lg); overflow:hidden; }
.service-tile { background:var(--c-bg2); padding:44px 36px; position:relative; overflow:hidden; cursor:pointer; transition:background var(--t); }
.service-tile::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(255,45,85,0.08),transparent); opacity:0; transition:opacity var(--t); }
.service-tile:hover { background:var(--c-bg3); }
.service-tile:hover::before { opacity:1; }
.service-tile:hover .tile-icon { background:var(--c-red); color:#fff; transform:scale(1.1) rotate(-5deg); }
.tile-icon { width:64px; height:64px; border-radius:var(--r-md); background:rgba(255,45,85,0.12); border:1px solid rgba(255,45,85,0.2); display:flex; align-items:center; justify-content:center; font-size:28px; margin-bottom:28px; transition:all var(--t) var(--ease-spring); }
.tile-num { position:absolute; top:24px; right:28px; font-family:var(--f-head); font-size:60px; font-weight:900; color:rgba(255,255,255,0.04); line-height:1; }
.service-tile h3 { font-family:var(--f-head); font-size:22px; font-weight:700; margin-bottom:12px; color:#fff; }
.service-tile p { font-size:14px; color:var(--c-muted); line-height:1.7; margin-bottom:24px; }
.tile-tags { display:flex; flex-wrap:wrap; gap:6px; }
.tile-tag { font-size:11px; font-weight:500; padding:4px 12px; background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.1); border-radius:var(--r-full); color:var(--c-muted); transition:all var(--t); }
.service-tile:hover .tile-tag { background:rgba(255,45,85,0.12); border-color:rgba(255,45,85,0.25); color:rgba(255,150,170,0.9); }
.tile-arrow { position:absolute; bottom:28px; right:28px; width:40px; height:40px; border-radius:50%; border:1px solid rgba(255,255,255,0.1); display:flex; align-items:center; justify-content:center; color:var(--c-muted); font-size:16px; transition:all var(--t); opacity:0; transform:translateX(-8px); }
.service-tile:hover .tile-arrow { opacity:1; transform:translateX(0); background:var(--c-red); border-color:var(--c-red); color:#fff; }

/* ══════════════════════════════════════════════════════════════
   PROCESO — PASOS
══════════════════════════════════════════════════════════════ */
.process-steps { display:flex; flex-direction:column; gap:0; position:relative; }
.process-steps::before { content:''; position:absolute; left:28px; top:60px; bottom:60px; width:1px; background:linear-gradient(to bottom,transparent,var(--c-red),var(--c-blue),transparent); }
.process-step { display:grid; grid-template-columns:56px 1fr; gap:32px; align-items:start; padding:40px 0; border-bottom:1px solid var(--c-border); position:relative; }
.process-step:last-child { border-bottom:none; }
.step-dot { width:56px; height:56px; border-radius:50%; background:var(--c-bg3); border:1px solid var(--c-border); display:flex; align-items:center; justify-content:center; font-family:var(--f-head); font-size:20px; font-weight:800; color:var(--c-muted); transition:all var(--t); flex-shrink:0; position:relative; z-index:1; }
.process-step.active .step-dot, .process-step:hover .step-dot { background:var(--c-red); border-color:var(--c-red); color:#fff; box-shadow:0 0 30px rgba(255,45,85,0.5); }
.step-body { padding-top:12px; }
.step-body h3 { font-family:var(--f-head); font-size:24px; font-weight:700; margin-bottom:8px; }
.step-body p { color:var(--c-muted); font-size:15px; line-height:1.7; }
.step-tag { display:inline-block; font-size:11px; font-weight:600; letter-spacing:2px; text-transform:uppercase; color:var(--c-red); margin-bottom:8px; }

/* ══════════════════════════════════════════════════════════════
   PORTFOLIO / TRABAJOS
══════════════════════════════════════════════════════════════ */
.portfolio-filters { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:48px; }
.filter-btn { padding:8px 20px; border-radius:var(--r-full); background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.1); color:var(--c-muted); font-size:13px; font-weight:500; cursor:pointer; transition:all var(--t); }
.filter-btn.active, .filter-btn:hover { background:var(--c-red); border-color:var(--c-red); color:#fff; }

.portfolio-grid { display:grid; grid-template-columns:repeat(12,1fr); gap:20px; }
.portfolio-item { position:relative; overflow:hidden; border-radius:var(--r-lg); cursor:pointer; background:var(--c-surface); }
.portfolio-item.span-8 { grid-column:span 8; }
.portfolio-item.span-4 { grid-column:span 4; }
.portfolio-item.span-6 { grid-column:span 6; }
.portfolio-item.span-4-tall { grid-column:span 4; grid-row:span 2; }

.portfolio-thumb { aspect-ratio:16/10; overflow:hidden; }
.portfolio-item.span-4-tall .portfolio-thumb { aspect-ratio:auto; height:100%; }
.portfolio-thumb img { width:100%; height:100%; object-fit:cover; transition:transform 0.7s var(--ease); }
.portfolio-item:hover .portfolio-thumb img { transform:scale(1.07); }

.portfolio-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(6,6,8,0.95) 0%,rgba(6,6,8,0.4) 50%,transparent 100%); opacity:0; transition:opacity 0.4s; display:flex; flex-direction:column; justify-content:flex-end; padding:32px; }
.portfolio-item:hover .portfolio-overlay { opacity:1; }
.portfolio-overlay h3 { font-family:var(--f-head); font-size:20px; font-weight:700; color:#fff; margin-bottom:6px; transform:translateY(16px); transition:transform 0.35s var(--ease-out); }
.portfolio-overlay p { font-size:13px; color:rgba(255,255,255,0.6); transform:translateY(16px); transition:transform 0.4s var(--ease-out); }
.portfolio-overlay .tag { display:inline-flex; align-items:center; gap:6px; background:var(--c-red); color:#fff; font-size:11px; font-weight:700; padding:4px 12px; border-radius:var(--r-full); margin-bottom:12px; transform:translateY(16px); transition:transform 0.3s; }
.portfolio-item:hover .portfolio-overlay h3,
.portfolio-item:hover .portfolio-overlay p,
.portfolio-item:hover .portfolio-overlay .tag { transform:translateY(0); }
.portfolio-overlay .link-icon { position:absolute; top:24px; right:24px; width:44px; height:44px; border-radius:50%; background:rgba(255,255,255,0.12); border:1px solid rgba(255,255,255,0.2); display:flex; align-items:center; justify-content:center; font-size:18px; color:#fff; transform:translate(8px,-8px) scale(0.8); opacity:0; transition:all 0.35s var(--ease-spring); }
.portfolio-item:hover .link-icon { transform:translate(0,0) scale(1); opacity:1; }

/* Imagen placeholder con URL de Unsplash */
.portfolio-thumb { background:var(--c-surface); }

/* ══════════════════════════════════════════════════════════════
   NÚMEROS / STATS
══════════════════════════════════════════════════════════════ */
.stats-band { background:var(--c-bg2); border-top:1px solid var(--c-border); border-bottom:1px solid var(--c-border); padding:72px 0; }
.stats-row { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--c-border); }
.stat-cell { background:var(--c-bg2); text-align:center; padding:48px 32px; transition:background var(--t); }
.stat-cell:hover { background:var(--c-bg3); }
.stat-num { font-family:var(--f-head); font-size:clamp(48px,5vw,72px); font-weight:900; line-height:1; background:linear-gradient(135deg,#fff 0%,var(--c-muted) 100%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; margin-bottom:8px; }
.stat-num .accent { -webkit-text-fill-color:var(--c-red); }
.stat-label { font-size:14px; color:var(--c-muted); text-transform:uppercase; letter-spacing:2px; font-weight:500; }

/* ══════════════════════════════════════════════════════════════
   TEXTO GRANDE ANIMADO (MARQUEE PHRASE)
══════════════════════════════════════════════════════════════ */
.big-text-scroll { overflow:hidden; padding:60px 0; border-top:1px solid var(--c-border); border-bottom:1px solid var(--c-border); }
.big-text-inner { white-space:nowrap; display:flex; gap:60px; font-family:var(--f-head); font-size:clamp(60px,8vw,120px); font-weight:900; line-height:1; letter-spacing:-3px; animation:marquee-big 20s linear infinite; }
.big-text-inner .filled { color:#fff; }
.big-text-inner .outline { -webkit-text-stroke:1px rgba(255,255,255,0.25); color:transparent; }
.big-text-inner .red { color:var(--c-red); }

/* ══════════════════════════════════════════════════════════════
   LOCALIZACIÓN / OFICINAS
══════════════════════════════════════════════════════════════ */
.offices-grid { display:grid; grid-template-columns:1fr 1fr; gap:2px; background:var(--c-border); border-radius:var(--r-lg); overflow:hidden; }
.office-card { background:var(--c-bg2); padding:56px 48px; position:relative; overflow:hidden; transition:background var(--t); }
.office-card:hover { background:var(--c-bg3); }
.office-card::before { content:''; position:absolute; top:-80px; right:-80px; width:240px; height:240px; border-radius:50%; background:radial-gradient(circle,rgba(255,45,85,0.12),transparent 70%); }
.office-city-name { font-family:var(--f-head); font-size:clamp(40px,5vw,64px); font-weight:900; letter-spacing:-2px; margin-bottom:8px; }
.office-region { font-size:13px; color:var(--c-red); letter-spacing:3px; text-transform:uppercase; font-weight:600; margin-bottom:40px; }
.office-details { display:flex; flex-direction:column; gap:20px; margin-bottom:40px; }
.office-detail { display:flex; align-items:center; gap:16px; }
.detail-icon { width:40px; height:40px; border-radius:10px; background:rgba(255,45,85,0.12); border:1px solid rgba(255,45,85,0.2); display:flex; align-items:center; justify-content:center; font-size:16px; flex-shrink:0; }
.detail-text { font-size:15px; color:rgba(255,255,255,0.8); line-height:1.5; }
.detail-label { font-size:11px; color:var(--c-muted); text-transform:uppercase; letter-spacing:1.5px; margin-bottom:2px; }
.office-kws { display:flex; flex-wrap:wrap; gap:8px; }
.office-kw { font-size:12px; font-weight:500; padding:5px 14px; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.1); border-radius:var(--r-full); color:var(--c-muted); transition:all var(--t); }
.office-card:hover .office-kw { border-color:rgba(255,45,85,0.25); color:rgba(255,150,170,0.8); }

/* ══════════════════════════════════════════════════════════════
   TESTIMONIOS
══════════════════════════════════════════════════════════════ */
.testimonials-layout { display:grid; grid-template-columns:1fr 1.5fr; gap:80px; align-items:start; }
.testimonials-sticky { position:sticky; top:100px; }
.testimonials-sticky h2 { font-size:clamp(32px,4vw,52px); font-weight:800; margin-bottom:20px; }
.reviews-summary { display:flex; align-items:center; gap:16px; margin-top:40px; }
.reviews-score { font-family:var(--f-head); font-size:56px; font-weight:900; line-height:1; }
.reviews-meta .stars { font-size:20px; color:#fbbf24; margin-bottom:4px; }
.reviews-meta p { font-size:14px; color:var(--c-muted); }

.testimonials-feed { display:flex; flex-direction:column; gap:20px; }
.testi-card { background:var(--c-bg2); border:1px solid var(--c-border); border-radius:var(--r-lg); padding:36px; transition:all var(--t); }
.testi-card:hover { border-color:rgba(255,45,85,0.25); box-shadow:0 8px 40px rgba(0,0,0,0.3); transform:translateY(-4px); }
.testi-stars { color:#fbbf24; font-size:15px; margin-bottom:16px; }
.testi-text { font-size:16px; line-height:1.75; color:rgba(255,255,255,0.8); margin-bottom:24px; font-style:italic; }
.testi-text::before { content:'"'; color:var(--c-red); font-size:32px; font-family:var(--f-head); line-height:0; vertical-align:-0.3em; margin-right:4px; }
.testi-author { display:flex; align-items:center; gap:14px; }
.testi-avatar { width:48px; height:48px; border-radius:50%; background:linear-gradient(135deg,var(--c-red),var(--c-purple)); display:flex; align-items:center; justify-content:center; font-family:var(--f-head); font-weight:700; font-size:18px; color:#fff; flex-shrink:0; }
.testi-name { font-weight:700; font-size:15px; }
.testi-role { font-size:13px; color:var(--c-muted); }

/* ══════════════════════════════════════════════════════════════
   PRECIOS
══════════════════════════════════════════════════════════════ */
.pricing-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:var(--c-border); border-radius:var(--r-lg); overflow:hidden; }
.price-card { background:var(--c-bg2); padding:48px 36px; position:relative; transition:background var(--t); }
.price-card:hover { background:var(--c-bg3); }
.price-card.featured { background:linear-gradient(160deg,rgba(255,45,85,0.15),var(--c-bg2)); }
.price-badge { position:absolute; top:-1px; left:50%; transform:translateX(-50%); background:var(--c-red); color:#fff; font-size:11px; font-weight:700; padding:6px 20px; border-radius:0 0 var(--r-md) var(--r-md); letter-spacing:1.5px; text-transform:uppercase; white-space:nowrap; }
.price-tier { font-size:11px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--c-red); margin-bottom:8px; }
.price-name { font-family:var(--f-head); font-size:28px; font-weight:800; margin-bottom:8px; }
.price-desc { font-size:14px; color:var(--c-muted); margin-bottom:36px; line-height:1.6; }
.price-amount { margin-bottom:36px; padding-bottom:36px; border-bottom:1px solid var(--c-border); }
.price-from { font-size:12px; color:var(--c-muted); text-transform:uppercase; letter-spacing:1px; margin-bottom:8px; }
.price-num { font-family:var(--f-head); font-size:52px; font-weight:900; line-height:1; }
.price-num sup { font-size:24px; vertical-align:top; margin-top:8px; font-weight:600; }
.price-num sub { font-size:16px; font-weight:400; color:var(--c-muted); }
.price-list { list-style:none; display:flex; flex-direction:column; gap:12px; margin-bottom:36px; }
.price-list li { display:flex; align-items:center; gap:10px; font-size:14px; color:rgba(255,255,255,0.8); }
.price-check { width:20px; height:20px; border-radius:50%; background:rgba(34,211,165,0.15); border:1px solid rgba(34,211,165,0.3); display:flex; align-items:center; justify-content:center; font-size:10px; color:var(--c-green); flex-shrink:0; font-weight:700; }

/* ══════════════════════════════════════════════════════════════
   CTA SECTION
══════════════════════════════════════════════════════════════ */
.cta-block { background:var(--c-bg2); border:1px solid var(--c-border); border-radius:var(--r-xl); padding:80px; text-align:center; position:relative; overflow:hidden; }
.cta-block::before { content:''; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:600px; height:600px; background:radial-gradient(circle,rgba(255,45,85,0.15),transparent 60%); pointer-events:none; }
.cta-block h2 { font-size:clamp(36px,5vw,64px); font-weight:900; letter-spacing:-2px; margin-bottom:20px; position:relative; z-index:1; }
.cta-block p { font-size:18px; color:var(--c-muted); max-width:560px; margin:0 auto 44px; position:relative; z-index:1; }
.cta-actions { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; position:relative; z-index:1; margin-bottom:48px; }
.cta-offices-strip { display:flex; justify-content:center; gap:48px; flex-wrap:wrap; position:relative; z-index:1; }
.cta-office-info { display:flex; align-items:center; gap:10px; font-size:14px; color:var(--c-muted); }
.cta-office-info strong { color:#fff; font-weight:600; }

/* ══════════════════════════════════════════════════════════════
   CONTACTO / FORMULARIO
══════════════════════════════════════════════════════════════ */
.contact-layout { display:grid; grid-template-columns:1fr 1.2fr; gap:80px; align-items:start; }
.contact-info h2 { font-size:clamp(32px,4vw,52px); font-weight:800; margin-bottom:20px; }
.contact-info > p { color:var(--c-muted); font-size:16px; line-height:1.75; margin-bottom:48px; }
.contact-channels { display:flex; flex-direction:column; gap:16px; margin-bottom:48px; }
.contact-channel { display:flex; align-items:center; gap:16px; padding:20px 24px; background:var(--c-bg2); border:1px solid var(--c-border); border-radius:var(--r-md); transition:all var(--t); text-decoration:none; color:inherit; }
.contact-channel:hover { border-color:rgba(255,45,85,0.35); background:var(--c-bg3); transform:translateX(6px); }
.channel-icon { width:48px; height:48px; border-radius:12px; background:rgba(255,45,85,0.12); border:1px solid rgba(255,45,85,0.2); display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; }
.channel-label { font-size:12px; color:var(--c-muted); text-transform:uppercase; letter-spacing:1.5px; margin-bottom:4px; font-weight:500; }
.channel-value { font-size:15px; font-weight:600; color:#fff; }

.contact-form-wrap { background:var(--c-bg2); border:1px solid var(--c-border); border-radius:var(--r-lg); padding:48px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.form-group { display:flex; flex-direction:column; gap:8px; margin-bottom:20px; }
.form-group label { font-size:13px; font-weight:600; color:rgba(255,255,255,0.7); letter-spacing:0.5px; }
.form-control { font-family:var(--f-body); font-size:15px; color:#fff; background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.1); border-radius:var(--r-sm); padding:14px 18px; outline:none; transition:all var(--t); width:100%; }
.form-control:focus { border-color:var(--c-red); background:rgba(255,45,85,0.06); box-shadow:0 0 0 4px rgba(255,45,85,0.12); }
.form-control::placeholder { color:rgba(255,255,255,0.25); }
textarea.form-control { resize:vertical; min-height:120px; }
select.form-control { cursor:pointer; }
option { background:var(--c-bg2); }
.form-check { display:flex; align-items:flex-start; gap:10px; font-size:13px; color:var(--c-muted); line-height:1.5; }
.form-check input { margin-top:2px; accent-color:var(--c-red); }
.form-check a { color:var(--c-red); }
.btn-submit { width:100%; justify-content:center; font-size:16px; padding:18px; }

/* ══════════════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════════════ */
footer { background:var(--c-bg); border-top:1px solid var(--c-border); padding:80px 0 40px; }
.footer-top { display:grid; grid-template-columns:2.5fr 1fr 1fr 1fr; gap:60px; margin-bottom:60px; }
.footer-brand { }
.footer-logo { display:flex; align-items:center; gap:12px; margin-bottom:20px; text-decoration:none; }
.footer-desc { font-size:14px; color:var(--c-muted); line-height:1.75; margin-bottom:28px; max-width:280px; }
.footer-offices-mini { display:flex; flex-direction:column; gap:16px; }
.footer-office-mini { }
.office-city-label { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--c-red); margin-bottom:4px; }
.office-city-label::before { content:'● '; }
.footer-office-mini p { font-size:13px; color:rgba(255,255,255,0.45); line-height:1.5; }
.footer-social { display:flex; gap:10px; margin-top:28px; }
.social-btn { width:40px; height:40px; border-radius:10px; background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.1); display:flex; align-items:center; justify-content:center; color:var(--c-muted); font-size:15px; transition:all var(--t); text-decoration:none; }
.social-btn:hover { background:var(--c-red); border-color:var(--c-red); color:#fff; transform:translateY(-4px); }

.footer-col h4 { font-family:var(--f-head); font-size:13px; font-weight:700; color:#fff; text-transform:uppercase; letter-spacing:2px; margin-bottom:24px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-col ul li a { font-size:14px; color:rgba(255,255,255,0.4); transition:all var(--t); display:inline-flex; align-items:center; gap:6px; }
.footer-col ul li a:hover { color:var(--c-red); padding-left:6px; }
.footer-col ul li a::before { content:''; width:0; height:1px; background:var(--c-red); transition:width var(--t); }
.footer-col ul li a:hover::before { width:12px; }

.footer-bottom { padding-top:40px; border-top:1px solid var(--c-border); display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:16px; }
.footer-bottom p { font-size:13px; color:rgba(255,255,255,0.3); }
.footer-legal { display:flex; gap:20px; flex-wrap:wrap; }
.footer-legal a { font-size:13px; color:rgba(255,255,255,0.3); transition:color var(--t); }
.footer-legal a:hover { color:var(--c-red); }

/* ══════════════════════════════════════════════════════════════
   PÁGINA: SOBRE NOSOTROS
══════════════════════════════════════════════════════════════ */
.about-hero { padding:160px 0 100px; }
.about-hero-inner { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.about-lead { font-size:clamp(22px,3vw,32px); font-weight:600; line-height:1.45; color:rgba(255,255,255,0.9); margin-bottom:32px; }
.about-manifesto { font-size:17px; line-height:1.8; color:var(--c-muted); margin-bottom:40px; }
.about-image-wrap { position:relative; }
.about-image-wrap img { width:100%; border-radius:var(--r-lg); }
.about-badge-float { position:absolute; bottom:-20px; left:-20px; background:var(--c-red); color:#fff; border-radius:var(--r-md); padding:20px 28px; }
.about-badge-float .num { font-family:var(--f-head); font-size:40px; font-weight:900; line-height:1; }
.about-badge-float .txt { font-size:12px; opacity:0.85; text-transform:uppercase; letter-spacing:1px; }

.values-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:var(--c-border); border-radius:var(--r-lg); overflow:hidden; margin-top:80px; }
.value-card { background:var(--c-bg2); padding:44px 36px; transition:background var(--t); }
.value-card:hover { background:var(--c-bg3); }
.value-icon { font-size:36px; margin-bottom:20px; display:block; }
.value-card h3 { font-family:var(--f-head); font-size:20px; font-weight:700; margin-bottom:10px; }
.value-card p { font-size:14px; color:var(--c-muted); line-height:1.7; }

.team-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.team-card { position:relative; border-radius:var(--r-lg); overflow:hidden; background:var(--c-bg2); cursor:pointer; }
.team-photo { aspect-ratio:3/4; overflow:hidden; }
.team-photo img { width:100%; height:100%; object-fit:cover; transition:transform 0.6s var(--ease); filter:grayscale(0.3); }
.team-card:hover .team-photo img { transform:scale(1.06); filter:grayscale(0); }
.team-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(6,6,8,0.9) 0%,transparent 60%); padding:28px; display:flex; flex-direction:column; justify-content:flex-end; }
.team-name { font-family:var(--f-head); font-size:18px; font-weight:700; margin-bottom:4px; }
.team-role { font-size:13px; color:var(--c-red); font-weight:600; text-transform:uppercase; letter-spacing:1px; margin-bottom:12px; }
.team-skills { display:flex; flex-wrap:wrap; gap:6px; }
.skill-tag { font-size:11px; padding:3px 10px; background:rgba(255,255,255,0.1); border-radius:var(--r-full); color:rgba(255,255,255,0.7); }

/* ══════════════════════════════════════════════════════════════
   PÁGINA: BLOG
══════════════════════════════════════════════════════════════ */
.blog-hero { padding:140px 0 80px; }
.blog-featured { display:grid; grid-template-columns:1.5fr 1fr; gap:32px; margin-bottom:60px; }
.post-card { background:var(--c-bg2); border:1px solid var(--c-border); border-radius:var(--r-lg); overflow:hidden; transition:all var(--t); }
.post-card:hover { border-color:rgba(255,45,85,0.25); transform:translateY(-6px); box-shadow:var(--sh-card); }
.post-thumb { overflow:hidden; aspect-ratio:16/9; }
.post-thumb img { width:100%; height:100%; object-fit:cover; transition:transform 0.6s; }
.post-card:hover .post-thumb img { transform:scale(1.04); }
.post-content { padding:32px; }
.post-meta { display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.post-cat { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:2px; color:var(--c-red); background:rgba(255,45,85,0.1); padding:4px 12px; border-radius:var(--r-full); }
.post-date { font-size:12px; color:var(--c-muted); }
.post-title { font-family:var(--f-head); font-size:22px; font-weight:700; margin-bottom:12px; line-height:1.3; }
.post-title a { transition:color var(--t); }
.post-title a:hover { color:var(--c-red); }
.post-excerpt { font-size:14px; color:var(--c-muted); line-height:1.7; margin-bottom:24px; }
.read-more { font-size:14px; font-weight:600; color:var(--c-red); display:inline-flex; align-items:center; gap:6px; transition:gap var(--t); }
.read-more:hover { gap:12px; }

.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }

/* ══════════════════════════════════════════════════════════════
   PÁGINA: TRABAJA CON NOSOTROS
══════════════════════════════════════════════════════════════ */
.jobs-hero { padding:160px 0 100px; }
.perks-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:var(--c-border); border-radius:var(--r-lg); overflow:hidden; }
.perk-card { background:var(--c-bg2); padding:36px; transition:background var(--t); }
.perk-card:hover { background:var(--c-bg3); }
.perk-icon { font-size:32px; margin-bottom:16px; }
.perk-card h3 { font-family:var(--f-head); font-size:18px; font-weight:700; margin-bottom:8px; }
.perk-card p { font-size:14px; color:var(--c-muted); line-height:1.7; }

.jobs-list { display:flex; flex-direction:column; gap:2px; background:var(--c-border); border-radius:var(--r-lg); overflow:hidden; }
.job-item { background:var(--c-bg2); padding:36px 40px; display:grid; grid-template-columns:1fr auto; gap:20px; align-items:center; cursor:pointer; transition:background var(--t); }
.job-item:hover { background:var(--c-bg3); }
.job-title { font-family:var(--f-head); font-size:20px; font-weight:700; margin-bottom:8px; }
.job-meta { display:flex; gap:16px; flex-wrap:wrap; }
.job-badge { font-size:12px; font-weight:500; padding:4px 12px; border-radius:var(--r-full); background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.1); color:var(--c-muted); }
.job-badge.open { background:rgba(34,211,165,0.1); border-color:rgba(34,211,165,0.25); color:var(--c-green); }

/* ══════════════════════════════════════════════════════════════
   WHATSAPP FLOAT
══════════════════════════════════════════════════════════════ */
.wa-float { position:fixed; bottom:32px; right:32px; z-index:400; width:58px; height:58px; border-radius:50%; background:#25D366; display:flex; align-items:center; justify-content:center; font-size:26px; text-decoration:none; box-shadow:0 4px 24px rgba(37,211,102,0.5); animation:wa-pulse 3s ease-in-out infinite; transition:transform var(--t); }
.wa-float:hover { transform:scale(1.12); }
@keyframes wa-pulse { 0%,100%{box-shadow:0 4px 24px rgba(37,211,102,0.5)}50%{box-shadow:0 4px 48px rgba(37,211,102,0.8)} }

/* ══════════════════════════════════════════════════════════════
   PROGRESS BAR TOP
══════════════════════════════════════════════════════════════ */
#progress-bar { position:fixed; top:0; left:0; height:3px; background:linear-gradient(90deg,var(--c-red),var(--c-blue)); z-index:600; width:0; transition:width 0.1s linear; }

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════════════════════════ */
@media (max-width:1200px) {
  .services-grid { grid-template-columns:repeat(2,1fr); }
  .footer-top { grid-template-columns:2fr 1fr 1fr; }
  .footer-top .footer-col:last-child { display:none; }
  .portfolio-item.span-8 { grid-column:span 12; }
  .portfolio-item.span-4 { grid-column:span 6; }
  .portfolio-item.span-4-tall { grid-column:span 6; grid-row:span 1; }
}

@media (max-width:1024px) {
  .section { padding:80px 0; }
  .hero-visual { display:none; }
  .about-hero-inner { grid-template-columns:1fr; }
  .testimonials-layout { grid-template-columns:1fr; }
  .testimonials-sticky { position:relative; top:auto; }
  .contact-layout { grid-template-columns:1fr; }
  .offices-grid { grid-template-columns:1fr; }
  .team-grid { grid-template-columns:repeat(2,1fr); }
  .stats-row { grid-template-columns:repeat(2,1fr); }
  .blog-featured { grid-template-columns:1fr; }
  .pricing-grid { grid-template-columns:1fr; }
  .footer-top { grid-template-columns:1fr 1fr; }
  .big-text-inner { font-size:60px; }
}

@media (max-width:768px) {
  .container, .container-wide, .container-narrow { padding:0 20px; }
  .nav-menu { display:none; position:absolute; top:72px; left:0; right:0; background:var(--c-bg); border-bottom:1px solid var(--c-border); flex-direction:column; padding:16px 20px; gap:0; }
  .nav-menu.open { display:flex; }
  .nav-menu > li > a { padding:14px 16px; border-bottom:1px solid var(--c-border); }
  .hamburger { display:flex; }
  .topbar-offices { display:none; }
  .services-grid { grid-template-columns:1fr; }
  .portfolio-grid { grid-template-columns:1fr; }
  .portfolio-item { grid-column:span 12 !important; grid-row:span 1 !important; }
  .process-steps::before { display:none; }
  .values-grid, .perks-grid { grid-template-columns:1fr; }
  .team-grid { grid-template-columns:1fr; }
  .cta-block { padding:48px 28px; }
  .contact-form-wrap { padding:32px 24px; }
  .form-row { grid-template-columns:1fr; }
  .hero h1 { font-size:40px; }
  .hero-metrics { gap:24px; }
  .footer-top { grid-template-columns:1fr; }
  .blog-grid { grid-template-columns:1fr; }
  .jobs-list .job-item { grid-template-columns:1fr; }
}
