:root{
  --bg:#0a0a0a;
  --bg-2:#101010;
  --fg:#f5f1ea;
  --fg-dim:rgba(245,241,234,.70);
  --fg-mute:rgba(245,241,234,.50);
  --line:rgba(245,241,234,.10);
  --line-strong:rgba(245,241,234,.22);
  --accent:#ff5b1f;
  --accent-soft:rgba(255,91,31,.14);
  --max:1360px;
  --pad:clamp(20px, 4vw, 56px);
  --radius:14px;
  --font:'Geist','Inter',-apple-system,Helvetica,Arial,sans-serif;
  --mono:'Geist Mono',ui-monospace,Menlo,monospace;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--fg);
  font-family:var(--font);
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"ss01","cv11";
  overflow-x:hidden;
  cursor:none;
}
@media (hover:none){ body{cursor:auto} .cursor,.cursor-dot{display:none} }

a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:none;padding:0}
img,svg{display:block;max-width:100%}

/* ---------- Grain + cursor ---------- */
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.06;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='.9'/></svg>");
}
.cursor{
  position:fixed;left:0;top:0;width:34px;height:34px;border:1px solid var(--fg-mute);
  border-radius:999px;transform:translate(-50%,-50%);z-index:9999;pointer-events:none;
  transition:width .25s cubic-bezier(.2,.7,.2,1),height .25s cubic-bezier(.2,.7,.2,1),background .2s,border-color .2s,opacity .2s;
  mix-blend-mode:difference;
}
.cursor-dot{
  position:fixed;left:0;top:0;width:5px;height:5px;background:var(--fg);
  border-radius:999px;transform:translate(-50%,-50%);z-index:9999;pointer-events:none;
}
.cursor.hover{width:72px;height:72px;background:var(--accent);border-color:var(--accent);mix-blend-mode:normal}
.cursor.hover ~ #cursor-dot,.cursor-dot.hide{opacity:0}
.cursor.text{width:6px;height:24px;border-radius:2px;background:var(--accent);border-color:transparent;mix-blend-mode:normal}

/* ---------- Layout ---------- */
.shell{max-width:var(--max);margin:0 auto;padding:0 var(--pad);position:relative;z-index:2}
.divider{height:1px;background:var(--line);width:100%}

/* ---------- Header ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  backdrop-filter:blur(14px) saturate(120%);
  -webkit-backdrop-filter:blur(14px) saturate(120%);
  background:rgba(10,10,10,.55);
  border-bottom:1px solid transparent;
  transition:border-color .3s, background .3s;
}
.nav.scrolled{border-bottom-color:var(--line);background:rgba(10,10,10,.78)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px;max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.brand{display:flex;align-items:center;gap:10px;font-weight:500;letter-spacing:-.01em}
.brand-mark{
  width:22px;height:22px;border-radius:5px;
  background:radial-gradient(circle at 30% 30%, var(--accent), #b73f10 70%);
  box-shadow:0 0 0 1px rgba(255,91,31,.35), 0 6px 18px -8px var(--accent);
}
.brand-name{font-size:14px}
.brand-sep{color:var(--fg-mute);font-family:var(--mono);font-size:12px}
.brand-role{font-size:12px;color:var(--fg-dim);font-family:var(--mono)}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{font-size:13px;color:var(--fg-dim);position:relative;padding:6px 0}
.nav-links a:hover{color:var(--fg)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;background:var(--accent);width:0;transition:width .3s}
.nav-links a:hover::after{width:100%}
.nav-cta{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px;padding:8px 14px;border:1px solid var(--line-strong);border-radius:999px;color:var(--fg);transition:background .2s,border-color .2s}
.nav-cta:hover{background:var(--accent);border-color:var(--accent);color:#0a0a0a}
.nav-cta .dot{width:6px;height:6px;border-radius:999px;background:var(--accent);box-shadow:0 0 10px var(--accent)}
.nav-cta:hover .dot{background:#0a0a0a;box-shadow:none}
@media (max-width:760px){ .nav-links{display:none} }

/* ---------- Burger + mobile sheet ---------- */
.nav-burger{
  display:none;width:40px;height:40px;border:1px solid var(--line-strong);border-radius:10px;
  background:transparent;cursor:pointer;position:relative;flex-direction:column;align-items:center;justify-content:center;gap:5px;
  transition:background .2s,border-color .2s;
}
.nav-burger:hover{background:rgba(255,255,255,.04)}
.nav-burger span{display:block;width:18px;height:1.5px;background:var(--fg);transition:transform .3s,opacity .3s}
.nav.menu-open .nav-burger span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav.menu-open .nav-burger span:nth-child(2){opacity:0}
.nav.menu-open .nav-burger span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

.nav-sheet{
  position:fixed;inset:68px 0 0 0;background:#0a0a0a;
  opacity:0;pointer-events:none;transition:opacity .3s;z-index:49;
  overflow-y:auto;
}
.nav-sheet.is-open{opacity:1;pointer-events:auto}
.nav-sheet-links{display:flex;flex-direction:column;padding:24px var(--pad) 48px;gap:0;max-width:var(--max);margin:0 auto}
.nav-sheet-links a{
  display:flex;align-items:baseline;gap:12px;padding:16px 0;font-size:19px;letter-spacing:-.02em;
  color:var(--fg);border-bottom:1px solid var(--line);
}
.nav-sheet-links a:hover{color:var(--accent)}
.nav-sheet-links a .idx{font-family:var(--mono);font-size:10px;color:var(--fg-mute);letter-spacing:.1em;min-width:20px}
.nav-sheet-links a.cta{color:var(--accent);border-bottom-color:var(--accent);margin-top:8px;font-size:17px}

/* ---------- Sections ---------- */
section{position:relative;padding:clamp(80px,11vw,140px) 0;border-top:1px solid var(--line)}
section:first-of-type{border-top:0;padding-top:clamp(120px,15vw,180px)}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-dim);
}
.eyebrow .idx{color:var(--accent)}
.eyebrow::before{content:"";display:inline-block;width:24px;height:1px;background:var(--accent)}

/* ---------- Hero ---------- */
.hero{padding-top:clamp(100px,12vw,140px);padding-bottom:clamp(60px,8vw,100px)}
.hero-grid{display:grid;grid-template-columns: 1fr;gap:48px}
.hero h1{
  font-size:clamp(32px, 8vw, 72px);
  line-height:1.15;letter-spacing:-.04em;margin:20px 0 0;font-weight:500;
  text-wrap:balance;
}
.hero h1 .tail{color:var(--fg-dim);font-style:italic;font-weight:300;letter-spacing:-.035em}
.hero h1 .accent-mark{color:var(--accent)}
.hero-sub{
  display:grid;grid-template-columns:repeat(12,1fr);gap:24px;align-items:end;margin-top:64px
}
.hero-lede{grid-column:span 7;font-size:clamp(18px,1.55vw,22px);line-height:1.45;color:var(--fg);max-width:62ch;font-weight:300}
.hero-lede .hl{color:var(--accent);font-weight:500}
.hero-actions{grid-column:span 5;display:flex;flex-direction:column;align-items:flex-start;gap:16px}
.btn-primary{
  display:inline-flex;align-items:center;gap:14px;background:var(--accent);color:#0a0a0a;
  padding:18px 22px;border-radius:999px;font-weight:500;font-size:15px;
  transition:transform .25s, box-shadow .25s, background .25s;
  box-shadow:0 18px 40px -18px var(--accent);
}
.btn-primary:hover{transform:translateY(-1px);background:#ff7340;box-shadow:0 22px 50px -18px var(--accent)}
.btn-primary svg{transition:transform .3s}
.btn-primary:hover svg{transform:translate(4px,-4px)}
.btn-ghost{display:inline-flex;align-items:center;gap:10px;color:var(--fg-dim);font-family:var(--mono);font-size:12px;letter-spacing:.04em}
.btn-ghost .blip{width:8px;height:8px;border-radius:999px;background:var(--accent);box-shadow:0 0 0 0 var(--accent);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,91,31,.55)}70%{box-shadow:0 0 0 12px rgba(255,91,31,0)}100%{box-shadow:0 0 0 0 rgba(255,91,31,0)}}

@media (max-width:820px){
  .hero-sub{grid-template-columns:1fr;gap:32px}
  .hero-lede,.hero-actions{grid-column:span 12}
}

/* ---------- Hero ticker (top bar) ---------- */
.ticker-rail{
  position:absolute;top:0;left:0;right:0;border-bottom:1px solid var(--line);
  font-family:var(--mono);font-size:11px;color:var(--fg-dim);
  display:flex;justify-content:space-between;padding:16px var(--pad);text-transform:uppercase;letter-spacing:.12em;
}
.ticker-rail .live{display:inline-flex;align-items:center;gap:8px}
.ticker-rail .live::before{content:"";width:6px;height:6px;border-radius:999px;background:#4ade80;box-shadow:0 0 8px #4ade80}

/* ---------- Marquee (hero secondary) ---------- */
.kw-marquee{margin-top:84px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:22px 0;overflow:hidden;position:relative}
.kw-marquee::before,.kw-marquee::after{content:"";position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}
.kw-marquee::before{left:0;background:linear-gradient(90deg,var(--bg),transparent)}
.kw-marquee::after{right:0;background:linear-gradient(-90deg,var(--bg),transparent)}
.kw-track{display:flex;gap:48px;width:max-content;animation:scroll 38s linear infinite}
.kw-track span{font-family:var(--mono);font-size:13px;color:var(--fg-dim);white-space:nowrap;display:inline-flex;align-items:center;gap:48px}
.kw-track span::after{content:"●";color:var(--accent);margin-left:48px;opacity:.6}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Services ---------- */
.section-head{display:grid;grid-template-columns:repeat(12,1fr);gap:24px;margin-bottom:64px;align-items:end}
.section-head .left{grid-column:span 6}
.section-head .right{grid-column:span 6;color:var(--fg-dim);font-size:15px;line-height:1.55;max-width:50ch;justify-self:end}
.section-head h2{font-size:clamp(40px,5.5vw,72px);line-height:1;letter-spacing:-.035em;font-weight:500;margin:18px 0 0;text-wrap:balance}
.section-head h2 em{font-style:italic;font-weight:300;color:var(--fg-dim)}
@media (max-width:820px){.section-head{grid-template-columns:1fr}.section-head .left,.section-head .right{grid-column:span 1}.section-head .right{justify-self:start}}

.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
@media (max-width:760px){.services-grid{grid-template-columns:1fr}}
.svc{background:var(--bg);padding:40px 36px 32px;position:relative;min-height:340px;display:flex;flex-direction:column;transition:background .35s}
.svc:hover{background:#0e0d0c}
.svc-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:auto}
.svc-num{font-family:var(--mono);font-size:11px;color:var(--accent);letter-spacing:.1em}
.svc-tag{font-family:var(--mono);font-size:10px;color:var(--fg-mute);letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--line);padding:5px 9px;border-radius:999px}
.svc-tag.hot{color:var(--accent);border-color:rgba(255,91,31,.4);background:var(--accent-soft)}
.svc h3{font-size:30px;letter-spacing:-.02em;line-height:1.1;margin:64px 0 12px;font-weight:500}
.svc h3 .sym{color:var(--accent);font-family:var(--mono);font-weight:400}
.svc-desc{color:var(--fg-dim);font-size:14.5px;line-height:1.55;max-width:42ch}
.svc-bullets{margin-top:24px;display:flex;flex-direction:column;gap:6px}
.svc-bullets li{list-style:none;font-family:var(--mono);font-size:11.5px;color:var(--fg-mute);letter-spacing:.04em;display:flex;align-items:center;gap:10px}
.svc-bullets li::before{content:"";width:14px;height:1px;background:var(--fg-mute)}
.svc-arrow{position:absolute;top:32px;right:36px;color:var(--fg-mute);transition:color .3s, transform .3s}
.svc:hover .svc-arrow{color:var(--accent);transform:translate(3px,-3px)}

/* ---------- About ---------- */
.about-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:48px;align-items:start}
.about-portrait{grid-column:span 3;position:sticky;top:120px;max-width:280px}
@media (max-width:760px){
  .about-portrait{position:relative;top:auto}
}
.portrait-card{
  aspect-ratio:4/5;border:1px solid var(--line-strong);border-radius:var(--radius);
  background:
    repeating-linear-gradient(45deg,transparent 0 22px, rgba(245,241,234,.04) 22px 23px),
    linear-gradient(180deg,#141312,#0c0b0a);
  position:relative;overflow:hidden;
}
.portrait-card::before{
  content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:transparent;
}
.portrait-img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 22%;
  filter:grayscale(.15) contrast(1.02);
  transition:filter .6s ease, transform .8s ease;
}
.portrait-card:hover .portrait-img{filter:grayscale(0) contrast(1.05);transform:scale(1.02)}
.portrait-overlay{
  position:absolute;inset:0;padding:24px;display:flex;flex-direction:column;justify-content:space-between;z-index:3;
  font-family:var(--mono);font-size:11px;color:#fff;letter-spacing:.06em;
  background:linear-gradient(180deg, rgba(0,0,0,.35) 0%, rgba(0,0,0,0) 30%, rgba(0,0,0,0) 70%, rgba(0,0,0,.55) 100%);
  pointer-events:none;
}
.portrait-overlay .tl,.portrait-overlay .br{display:flex;gap:14px}
.portrait-overlay .tag{padding:5px 9px;border:1px solid rgba(255,255,255,.25);background:rgba(0,0,0,.35);border-radius:4px;backdrop-filter:blur(4px)}
.portrait-center{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:11px;color:rgba(255,255,255,0);letter-spacing:.15em;text-transform:uppercase;gap:10px;
  text-align:center;padding:0 32px;pointer-events:none;
}
.portrait-center .ring{
  width:120px;height:120px;border:1px dashed rgba(255,255,255,0);border-radius:999px;
  display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0);font-size:11px;letter-spacing:.2em;background:transparent;backdrop-filter:none;
  animation:none;
}
@keyframes rotate{to{transform:rotate(360deg)}}

.about-copy{grid-column:span 9;display:flex;flex-direction:column;gap:32px}
.about-copy p{font-size:19px;line-height:1.55;color:var(--fg);max-width:54ch;margin:0;font-weight:300}
.about-copy p .hl{color:var(--accent);font-weight:500}
.about-copy p .strike{text-decoration:line-through;color:var(--fg-mute);text-decoration-color:var(--accent)}

.about-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);margin-top:24px;overflow:hidden}
.stat{background:var(--bg);padding:24px 20px}
.stat .num{font-size:44px;letter-spacing:-.03em;font-weight:500;line-height:1}
.stat .num span{color:var(--accent)}
.stat .lbl{font-family:var(--mono);font-size:11px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.1em;margin-top:10px}

/* ========================================= 
   MOBILE RESPONSIVE
   ========================================= */
@media (max-width:760px){
  :root{--pad:20px}
  
  /* Navigation */
  .shell{padding:0 20px}
  .nav-inner{padding:0 20px}
  .nav-burger{display:flex !important}
  .brand-name{display:none}
  .brand-sep,.brand-role{display:none}
  
  /* Hero */
  .hero{padding-top:128px;padding-bottom:50px}
  /* Preheader/ticker: una línea limpia bajo la barra (en escritorio van 3, aquí solo la principal) */
  .ticker-rail{top:68px;justify-content:flex-start;gap:10px;padding:12px 20px;font-size:10px;letter-spacing:.1em;background:var(--bg);z-index:5;white-space:nowrap;overflow:hidden}
  .ticker-rail .live{overflow:hidden;text-overflow:ellipsis}
  .ticker-rail span:nth-child(2),.ticker-rail span:nth-child(3){display:none}
  .eyebrow{font-size:11px;margin-bottom:16px}
  .hero h1{font-size:clamp(26px, 8vw, 40px) !important;line-height:1.2 !important;margin-bottom:18px}
  .hero-sub{margin-top:28px;grid-template-columns:1fr;gap:24px}
  .hero-lede,.hero-actions{grid-column:span 1}
  .hero-lede{font-size:15px;line-height:1.5}
  .btn-primary{padding:13px 20px;font-size:13px}
  .kw-marquee{margin-top:48px}
  
  /* Section heads */
  .section-head{grid-template-columns:1fr;gap:20px;margin-bottom:48px}
  .section-head .left,.section-head .right{grid-column:span 1}
  .section-head .right{justify-self:start;font-size:14px}
  .section-head h2{font-size:36px;margin:12px 0 0}
  
  /* Services */
  .services-grid{grid-template-columns:1fr}
  .svc{min-height:auto;padding:32px 28px 28px}
  .svc-title{font-size:22px}
  .svc-sub{font-size:12px}
  .svc-desc{font-size:15px;line-height:1.5}
  
  /* About */
  .about-grid{grid-template-columns:1fr;gap:40px}
  .about-portrait,.about-copy{grid-column:span 1}
  .about-portrait{position:relative;top:auto;width:100%;max-width:280px;margin:0 auto;justify-self:center}
  .about-portrait .portrait-card{width:100%}
  .about-copy{gap:28px}
  .about-copy p{font-size:16px;line-height:1.65}
  .about-stats{grid-template-columns:1fr 1fr;margin-top:24px}
  .stat{padding:20px 16px}
  .stat .num{font-size:36px}
  .stat .lbl{font-size:10px}
  .logos-rail{margin-top:48px;padding:24px 0}
  .stack-rail{margin-top:48px;padding-top:28px}
  
  /* FAQs móvil */
  .faq-list{padding:0 0;max-width:100%}
  .faq-q{padding:20px 16px !important;font-size:16px !important;line-height:1.4}
  .faq-a{padding:0 16px 24px !important;font-size:15px !important;line-height:1.6}
  .faq-icon{font-size:24px !important}
  
  /* Contact */
  .contact-inner{padding:64px 0}
  .contact h2{font-size:36px}
  .contact-meta{flex-direction:column;gap:24px}
  
  /* Metodología */
  .step-card{padding:24px 20px}
  .step-title{font-size:20px}
  .step-desc{font-size:15px}
}

/* ---------- Clients marquee ---------- */
.logos-rail{padding:36px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;position:relative;margin-top:72px}
.logos-rail::before,.logos-rail::after{content:"";position:absolute;top:0;bottom:0;width:140px;z-index:2;pointer-events:none}
.logos-rail::before{left:0;background:linear-gradient(90deg,var(--bg),transparent)}
.logos-rail::after{right:0;background:linear-gradient(-90deg,var(--bg),transparent)}
.logos-track{display:flex;gap:80px;width:max-content;animation:scroll 42s linear infinite;align-items:center}
.logo{font-family:var(--mono);font-size:18px;letter-spacing:-.01em;color:var(--fg-dim);white-space:nowrap;font-weight:500;transition:color .3s;display:flex;align-items:center;gap:14px}
.logo:hover{color:var(--fg)}
.logo .glyph{width:22px;height:22px;border:1px solid var(--line-strong);border-radius:5px;display:inline-flex;align-items:center;justify-content:center;color:var(--accent);font-size:11px}

/* ---------- Cases ---------- */
.cases-list{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.case{
  display:grid;grid-template-columns:80px 1fr 1.3fr 220px 40px;gap:32px;align-items:center;
  padding:32px 0;border-bottom:1px solid var(--line);transition:background .3s, padding .3s;cursor:none;
}
.case:hover{background:#0e0d0c;padding-left:16px;padding-right:16px}
.case .yr{font-family:var(--mono);font-size:12px;color:var(--fg-mute)}
.case .client{font-size:22px;letter-spacing:-.015em;font-weight:500}
.case .work{color:var(--fg-dim);font-size:15px;line-height:1.45;max-width:42ch}
.case .tags{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}
.case .tag{font-family:var(--mono);font-size:10.5px;color:var(--fg-dim);border:1px solid var(--line);padding:5px 9px;border-radius:999px;letter-spacing:.06em}
.case .arrow{color:var(--fg-mute);transition:color .3s, transform .3s}
.case:hover .arrow{color:var(--accent);transform:translate(4px,-4px)}
@media (max-width:900px){
  .case{grid-template-columns:60px 1fr 28px;row-gap:8px}
  .case .work{grid-column:1/-1;margin-top:6px}
  .case .tags{grid-column:1/-1;justify-content:flex-start}
}

/* ---------- Metodología ---------- */
.metodologia-section{padding-top:clamp(80px,11vw,140px);padding-bottom:clamp(80px,11vw,140px)}
.steps-list{display:grid;grid-template-columns:1fr;gap:20px}
.step-card{
  background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:32px 36px;
  transition:background .3s,border-color .3s;
}
.step-card:hover{background:#0e0d0c;border-color:var(--line-strong)}
.step-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;gap:16px}
.step-n{
  font-family:var(--mono);font-size:11px;color:var(--accent);letter-spacing:.15em;font-weight:600;
  background:rgba(255,91,31,.12);padding:7px 13px;border-radius:6px;
}
.step-time{
  font-family:var(--mono);font-size:10px;color:var(--fg-mute);letter-spacing:.12em;text-transform:uppercase;
  padding:7px 11px;border:1px solid var(--line);border-radius:6px;white-space:nowrap;
}
.step-title{font-size:24px;font-weight:500;letter-spacing:-.02em;margin:0 0 12px;color:var(--fg)}
.step-desc{font-size:16px;line-height:1.6;color:var(--fg-dim);margin:0;max-width:72ch}
@media (max-width:760px){
  .step-card{padding:24px 24px}
  .step-title{font-size:20px}
  .step-desc{font-size:15px}
}

/* ---------- Talks ---------- */
.talks-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.talks-grid .col{grid-column:span 4;display:flex;flex-direction:column;gap:16px}
.talk-card{
  border:1px solid var(--line);border-radius:var(--radius);padding:28px 24px 24px;background:var(--bg);
  display:flex;flex-direction:column;gap:14px;min-height:220px;transition:background .3s, border-color .3s, transform .3s;
  text-decoration:none;color:inherit;
}
.talk-card:hover{background:#0e0d0c;border-color:var(--line-strong);transform:translateY(-2px)}
.talk-meta{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:11px;color:var(--fg-mute);letter-spacing:.08em;text-transform:uppercase}
.talk-meta .venue{color:var(--accent)}
.talk-title{font-size:19px;line-height:1.25;letter-spacing:-.015em;font-weight:500;margin:0}
.talk-desc{font-size:13.5px;line-height:1.55;color:var(--fg-dim);margin:0}
.talk-where{font-family:var(--mono);font-size:11.5px;color:var(--fg-dim);margin-top:auto;display:flex;align-items:center;gap:8px}
.talk-where::before{content:"";width:14px;height:1px;background:var(--accent)}
.talk-link{
  font-family:var(--mono);font-size:11px;color:var(--accent);letter-spacing:.06em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:6px;margin-top:auto;opacity:1;transition:opacity .3s;
}
.talk-card:hover .talk-link{opacity:1}
@media (max-width:900px){.talks-grid .col{grid-column:span 12}}

/* ---------- Contact ---------- */
.contact{padding-bottom:clamp(80px,11vw,140px)}
.contact-inner{position:relative;border-top:1px solid var(--line);padding-top:clamp(60px,8vw,100px)}
.contact h2{
  font-size:clamp(40px,6.4vw,96px);line-height:.95;letter-spacing:-.035em;font-weight:500;margin:24px 0 40px;
  text-wrap:balance;
}
.contact h2 em{font-style:italic;color:var(--fg-dim);font-weight:300}
.contact h2 .accent-mark{color:var(--accent)}
.email-cta{
  display:inline-flex;align-items:center;gap:18px;padding:18px 28px 18px 24px;
  border:1px solid var(--line-strong);border-radius:999px;font-size:18px;background:transparent;
  transition:background .3s,color .3s,border-color .3s;
}
.email-cta:hover{background:var(--accent);color:#0a0a0a;border-color:var(--accent)}
.email-cta .mail-glyph{
  width:34px;height:34px;border-radius:999px;background:var(--accent);color:#0a0a0a;display:inline-flex;align-items:center;justify-content:center;
}
.email-cta:hover .mail-glyph{background:#0a0a0a;color:var(--accent)}
.contact-meta{display:flex;gap:48px;margin-top:64px;font-family:var(--mono);font-size:12px;color:var(--fg-dim);flex-wrap:wrap}
.contact-meta .col{display:flex;flex-direction:column;gap:6px}
.contact-meta .lbl{color:var(--fg-mute);text-transform:uppercase;letter-spacing:.1em;font-size:10.5px}
.contact-meta a:hover{color:var(--accent)}

/* ---------- FAQ ---------- */
.faq-section{background:var(--bg)}
.faq-list{display:flex;flex-direction:column;gap:0;max-width:920px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line);transition:background .2s}
.faq-item:hover{background:rgba(255,255,255,.02)}
.faq-item[open] .faq-icon{transform:rotate(45deg)}
.faq-q{
  padding:28px 32px;font-size:18px;font-weight:500;letter-spacing:-.01em;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  cursor:pointer;list-style:none;transition:color .2s;
}
.faq-q:hover{color:var(--accent)}
.faq-q::-webkit-details-marker{display:none}
.faq-icon{
  font-size:28px;color:var(--accent);font-weight:300;line-height:1;
  transition:transform .3s cubic-bezier(.2,.7,.2,1);flex-shrink:0;
}
.faq-a{padding:0 32px 32px;color:var(--fg-dim);font-size:16px;line-height:1.6;max-width:72ch}
.faq-a p{margin:0}

/* ---------- Footer ---------- */
.foot{border-top:1px solid var(--line);padding:28px 0 36px;font-family:var(--mono);font-size:11px;color:var(--fg-mute);letter-spacing:.06em}
.foot-inner{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.foot a:hover{color:var(--accent)}

/* ---------- Results gallery ---------- */
.results-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.result{
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--bg);
  display:flex;flex-direction:column;transition:transform .35s,border-color .35s,background .35s;
}
.result:hover{border-color:var(--line-strong);background:#0e0d0c;transform:translateY(-2px)}
.result-shot{
  position:relative;background:#f6f8fa;aspect-ratio: 1340 / 380;overflow:hidden;
  border-bottom:1px solid var(--line);
}
.result-shot img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
.result-shot .country{
  position:absolute;top:14px;right:14px;font-family:var(--mono);font-size:11px;
  padding:5px 9px;background:#0a0a0a;color:var(--fg);border-radius:999px;letter-spacing:.06em;
  border:1px solid rgba(255,255,255,.1);display:inline-flex;align-items:center;gap:8px;
}
.result-shot .country::before{content:"";width:5px;height:5px;border-radius:999px;background:var(--accent)}
.result-body{padding:24px 26px 22px;display:flex;flex-direction:column;gap:18px}
.result-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;flex-wrap:wrap}
.result-title{font-size:18px;font-weight:500;letter-spacing:-.02em;color:var(--fg);margin:0;line-height:1.2}
.result-country{
  font-family:var(--mono);font-size:11px;color:var(--fg-mute);letter-spacing:.08em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:8px;white-space:nowrap;
}
.result-country .dot{width:5px;height:5px;border-radius:999px;background:var(--accent);flex:none}
.result-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.result-stat{background:var(--bg);padding:16px 12px}
.result-stat .lbl{font-family:var(--mono);font-size:9.5px;color:var(--fg-mute);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px}
.result-stat .val{font-size:22px;letter-spacing:-.02em;font-weight:500;line-height:1}
.result-stat.hl{background:var(--accent-soft)}
.result-stat.hl .val{color:var(--accent)}
.result-stat .unit{font-size:12px;color:var(--fg-dim);margin-left:2px}

.results-foot{
  margin-top:32px;font-family:var(--mono);font-size:11px;color:var(--fg-mute);letter-spacing:.06em;
  display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;padding-top:20px;border-top:1px solid var(--line);
}
.results-foot .note{display:inline-flex;align-items:center;gap:8px}
.results-foot .note::before{content:"";width:14px;height:1px;background:var(--accent)}

/* ---------- Results — MÓVIL (debe ir DESPUÉS del bloque escritorio para ganar en cascada) ---------- */
@media (max-width:760px){
  .results-grid{grid-template-columns:1fr;gap:16px}
  .result{border-radius:14px;width:100%;max-width:100%;box-sizing:border-box}
  .result-body{padding:18px 16px;gap:16px;width:100%;box-sizing:border-box;display:flex;flex-direction:column}
  .result-head{flex-direction:column;align-items:flex-start;gap:10px;width:100%}
  .result-country{order:-1;font-size:10px;letter-spacing:.08em;gap:6px;white-space:normal}
  .result-country .dot{width:5px;height:5px}
  .result-title{font-size:17px;font-weight:600;line-height:1.25;letter-spacing:-.02em;word-break:break-word;overflow-wrap:break-word;max-width:100%;width:100%}
  .result-stats{display:grid !important;grid-template-columns:repeat(2,minmax(0,1fr)) !important;grid-template-rows:auto !important;gap:8px !important;background:transparent !important;border:0 !important;border-radius:0 !important;padding:0 !important;margin:0 !important;width:100% !important;box-sizing:border-box;overflow:visible !important}
  .result-stat{grid-column:auto !important;grid-row:auto !important;background:var(--bg);padding:14px 12px;border:1px solid var(--line);border-radius:10px;display:flex;flex-direction:column;justify-content:flex-start;gap:6px;min-width:0;box-sizing:border-box}
  .result-stat .lbl{font-family:var(--mono);font-size:9px;margin-bottom:0;color:var(--fg-mute);text-transform:uppercase;letter-spacing:.06em;line-height:1.3}
  .result-stat .val{font-size:19px;font-weight:600;letter-spacing:-.02em;line-height:1.05;white-space:nowrap}
  .result-stat .val .unit{font-size:11px;color:var(--fg-dim);margin-left:1px}
  .result-stat.hl{background:var(--accent-soft);border-color:rgba(255,91,31,.45)}
  .result-stat.hl .val{color:var(--accent)}
  .results-foot{margin-top:24px;flex-direction:column;gap:12px;align-items:flex-start;padding-top:20px}
}

/* ---------- Stack / toolkit ---------- */
.stack-rail{margin-top:56px;padding-top:32px;border-top:1px solid var(--line)}
@media (max-width:760px){.stack-rail{margin-top:40px;padding-top:24px}}
.stack-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:20px;gap:24px;flex-wrap:wrap}
.stack-head .title{font-family:var(--mono);font-size:12px;color:var(--fg-dim);letter-spacing:.1em;text-transform:uppercase}
.stack-head .meta{font-family:var(--mono);font-size:11px;color:var(--fg-mute);letter-spacing:.08em}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{
  font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;padding:7px 12px;
  border:1px solid var(--line);border-radius:999px;color:var(--fg-dim);
  transition:background .35s,border-color .35s,color .35s,transform .25s,opacity .4s,box-shadow .4s;
}
.chip:hover{background:var(--accent-soft);border-color:rgba(255,91,31,.45);color:var(--accent)}
.chip.star{border-color:rgba(255,91,31,.45);color:var(--accent);background:var(--accent-soft)}

/* --- Efecto "luces": atenuados por defecto, se encienden con el scroll --- */
.chips.lights .chip{opacity:.3;color:var(--fg-mute);border-color:var(--line);background:transparent;box-shadow:none}
.chips.lights .chip.star{opacity:.42;color:rgba(255,91,31,.55);border-color:rgba(255,91,31,.22);background:transparent}
.chips.lights .chip.lit{
  opacity:1;color:var(--fg);border-color:var(--line-strong);background:rgba(245,241,234,.05);
  box-shadow:0 0 0 1px rgba(245,241,234,.05),0 0 20px -6px rgba(245,241,234,.30);
}
.chips.lights .chip.star.lit{
  color:var(--accent);border-color:rgba(255,91,31,.55);background:var(--accent-soft);
  box-shadow:0 0 22px -5px rgba(255,91,31,.55);
}
/* el hover siempre responde, esté encendido o no */
.chips.lights .chip:hover{opacity:1;color:var(--accent);border-color:rgba(255,91,31,.45);background:var(--accent-soft)}

/* ---------- Testimonials ---------- */
.testi-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.testi{
  grid-column:span 6;border:1px solid var(--line);border-radius:var(--radius);
  padding:32px 32px 26px;background:var(--bg);display:flex;flex-direction:column;gap:20px;
  transition:background .3s,border-color .3s;
}
.testi:hover{background:#0e0d0c;border-color:var(--line-strong)}
.testi.feat{grid-column:span 12;background:linear-gradient(180deg,#0e0d0c,#0a0a0a)}
.testi.feat blockquote{font-size:clamp(22px,2.4vw,30px)}
.testi blockquote{
  margin:0;font-size:19px;line-height:1.45;color:var(--fg);letter-spacing:-.01em;font-weight:300;
  text-wrap:balance;
}
.testi blockquote::before{content:"“";color:var(--accent);font-size:42px;line-height:0;vertical-align:-.2em;margin-right:6px;font-family:Georgia,serif}
.testi-foot{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-top:auto;padding-top:8px;border-top:1px solid var(--line);font-family:var(--mono);font-size:11px;color:var(--fg-mute);letter-spacing:.06em;text-transform:uppercase}
.testi-foot .who{color:var(--fg)}
.testi-foot .src{color:var(--accent)}
@media (max-width:820px){.testi{grid-column:span 12}}

/* ---------- Malt strip ---------- */
.malt-strip{
  display:grid;grid-template-columns:auto 1fr auto auto;gap:32px;align-items:center;
  padding:24px 28px;border:1px solid var(--line);border-radius:var(--radius);
  background:linear-gradient(90deg,rgba(255,91,31,.06),transparent 60%);
  margin-top:32px;
}
.malt-strip .badge{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  padding:6px 10px;border:1px solid rgba(255,91,31,.4);color:var(--accent);border-radius:999px;background:var(--accent-soft);
  display:inline-flex;align-items:center;gap:8px;white-space:nowrap;
}
.malt-strip .badge::before{content:"";width:6px;height:6px;border-radius:999px;background:var(--accent);box-shadow:0 0 8px var(--accent)}
.malt-strip .copy{font-size:14.5px;color:var(--fg-dim);line-height:1.5;max-width:60ch}
.malt-strip .copy strong{color:var(--fg);font-weight:500}
.malt-strip .rate{display:flex;flex-direction:column;align-items:flex-end;gap:2px;font-family:var(--mono);font-size:12px;color:var(--fg-dim)}
.malt-strip .rate .stars{color:var(--accent);letter-spacing:2px;font-size:14px}
.malt-strip .rate .price{color:var(--fg);font-size:14px;font-weight:500}
.malt-strip .open{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px;color:var(--fg);padding:10px 16px;border:1px solid var(--line-strong);border-radius:999px;transition:background .2s,color .2s,border-color .2s;white-space:nowrap}
.malt-strip .open:hover{background:var(--accent);color:#0a0a0a;border-color:var(--accent)}
@media (max-width:820px){.malt-strip{grid-template-columns:1fr;align-items:flex-start}.malt-strip .rate{align-items:flex-start}}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.instant,.split-word.instant{transition:none !important}
.reveal.instant > span,.split-word.instant > span{transition:none !important}
.reveal.d1{transition-delay:.08s}
.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}

/* split-word hero animation */
.split-word{display:inline-block;overflow:hidden;vertical-align:bottom;padding-bottom:.18em;margin-bottom:-.14em;line-height:inherit}
.split-word > span{display:inline-block;transform:translateY(110%);transition:transform 1s cubic-bezier(.2,.7,.2,1)}
.split-word.in > span{transform:translateY(0)}
/* La cursiva (.tail) se inclina a la derecha y la última letra se salía del overflow:hidden.
   Damos respiro a la derecha y lo compensamos con margen negativo (no altera el espaciado). */
.split-word:has(.tail){padding-right:.3em;margin-right:-.3em}

/* === Legibilidad en móvil: subir el escalón más pequeño de etiquetas mono === */
@media (max-width:760px){
  /* Tarjetas de proyecto: etiquetas y país */
  .result-stat .lbl{font-size:11px;line-height:1.3}
  .result-stat .val{font-size:20px}
  .result-country{font-size:11px}
  /* Micro-etiquetas mono del resto de secciones */
  .eyebrow{font-size:12px}
  .ticker-rail{font-size:11px}
  .stat .lbl{font-size:11px}
  .svc-num{font-size:12px}
  .svc-tag{font-size:11px}
  .svc-bullets li{font-size:12.5px}
  .case .yr,.case .tag{font-size:12px}
  .process-kicker,.step-kicker{font-size:11px}
  .talk-meta,.talk-where{font-size:12px}
  .contact-meta,.contact-meta .lbl{font-size:12px}
  .stack-head .title,.stack-head .meta{font-size:12px}
  .foot,.testi-foot{font-size:12px}
}
