:root{--ink:#17120e;--sea:#16b8b8;--coral:#ff4f7b;--lime:#b7f04a;--violet:#7a5cff;--white:#fffaf2}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Hanken Grotesk',sans-serif;color:var(--ink);background:var(--white);overflow-x:hidden}
a{color:inherit}
.gradient{background:
  radial-gradient(120% 120% at 12% 18%, #ff5d8f 0%, rgba(255,93,143,0) 55%),
  radial-gradient(120% 120% at 88% 28%, #ffd24a 0%, rgba(255,210,74,0) 55%),
  linear-gradient(115deg,#ff6b8a 0%,#ff9d6e 42%,#ffd24a 78%,#fff08a 100%);
  background-size:200% 200%;animation:flow 16s ease-in-out infinite}
@keyframes flow{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
/* nav */
nav{position:relative;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:22px 5vw}
.logo{display:flex;align-items:center;gap:11px;text-decoration:none;color:inherit}
.logo .ico{width:42px;height:42px;display:block;border-radius:12px;flex:none}
.logo .wm{display:flex;flex-direction:column;line-height:.88}
.logo .wm small{font-weight:700;font-size:11px;letter-spacing:.17em;text-transform:uppercase;opacity:.72}
.logo .wm strong{font-weight:900;font-size:20px;letter-spacing:-.02em}
.links{display:flex;gap:24px;font-weight:700;font-size:15px;align-items:center}
.links a,.navlink{text-decoration:none;opacity:.9;background:none;border:0;font:inherit;cursor:pointer;color:inherit}
.pill{border:2px solid var(--ink);border-radius:30px;padding:9px 18px;font-weight:800;font-size:14px;background:#fff;opacity:1}
.drop{position:relative}
.drop .menu{position:absolute;top:130%;left:0;background:#fff;border:2px solid var(--ink);border-radius:14px;padding:8px;display:none;flex-direction:column;min-width:220px;box-shadow:6px 6px 0 rgba(23,18,14,.15)}
.drop .menu a{padding:9px 12px;border-radius:8px;font-size:14px;white-space:nowrap}
.drop .menu a:hover{background:var(--white)}
.drop:hover .menu{display:flex}
.navlink.act,.menu a.act{color:var(--coral)}
/* hero (home) */
.hero{min-height:78vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:20px 20px 80px}
.kicker{font-weight:800;font-size:14px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px;opacity:.85}
h1{font-weight:900;line-height:.9;letter-spacing:-.03em;font-size:clamp(44px,9vw,140px);text-transform:uppercase}
.mark{background:var(--ink);color:#fff;padding:0 .12em;border-radius:14px;display:inline-block}
.sub{margin-top:22px;font-weight:700;font-size:clamp(16px,2vw,21px);max-width:640px;opacity:.92}
.ctas{margin-top:36px;display:flex;gap:18px;flex-wrap:wrap;justify-content:center}
.cta{font-weight:900;font-size:clamp(15px,1.5vw,18px);text-transform:uppercase;text-decoration:none;
  background:#fff;border:3px solid var(--ink);border-radius:40px;padding:14px 24px;box-shadow:6px 6px 0 var(--ink);transition:.1s;cursor:pointer}
.cta .hl{border-radius:8px;padding:0 6px;color:#fff}
.cta.sea .hl{background:var(--sea)} .cta.coral .hl{background:var(--coral)}
.cta:hover{transform:translate(2px,2px);box-shadow:3px 3px 0 var(--ink)}
/* service hero */
.svc-hero{padding:14px 5vw 70px;max-width:1000px;margin:0 auto;text-align:center}
.svc-hero h1{font-size:clamp(38px,7vw,92px)}
.bc{font-weight:700;font-size:13px;opacity:.7;margin-bottom:18px}
.bc a{text-decoration:none}.bc span{opacity:.9}
.svc-hero .sub{margin:22px auto 0}
.svc-hero .ctas{margin-top:32px}
/* strip */
.strip{background:var(--ink);color:var(--white);padding:18px 0;overflow:hidden;white-space:nowrap;font-weight:800;font-size:15px;letter-spacing:.04em}
.strip .run{display:inline-block;animation:march 26s linear infinite}
.strip span{margin:0 24px;opacity:.9} .strip b{color:var(--lime)}
@keyframes march{from{transform:translateX(0)}to{transform:translateX(-50%)}}
/* blocks */
section.block{padding:80px 5vw;max-width:1180px;margin:0 auto}
.eyebrow{font-weight:900;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--coral);margin-bottom:10px}
h2{font-size:clamp(30px,5vw,60px);font-weight:900;letter-spacing:-.02em;line-height:1;text-transform:uppercase}
.lead{font-weight:700;opacity:.7;max-width:600px;margin-top:14px;font-size:18px}
/* cards (home) */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:40px}
.card{border:3px solid var(--ink);border-radius:22px;padding:24px;background:#fff;min-height:210px;display:flex;flex-direction:column;justify-content:space-between;text-decoration:none;transition:.12s}
.card:hover{transform:translateY(-4px);box-shadow:6px 8px 0 var(--ink)}
.card .tag{align-self:flex-start;font-weight:900;font-size:12px;text-transform:uppercase;border-radius:20px;padding:5px 12px;color:#fff}
.card h3{font-size:23px;font-weight:900;letter-spacing:-.01em}
.card.s1 .tag{background:var(--coral)} .card.s2 .tag{background:var(--sea)} .card.s3 .tag{background:#ff9d2e} .card.s4 .tag{background:var(--violet)}
.card small{font-weight:600;opacity:.66;font-size:14px;line-height:1.45}
/* checklist (service) */
.checklist{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:14px 30px;margin-top:34px;max-width:900px}
.checklist li{font-weight:700;font-size:17px;padding-left:36px;position:relative}
.checklist li::before{content:"✓";position:absolute;left:0;top:-2px;width:24px;height:24px;background:var(--sea);color:#fff;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:900}
/* why */
.why{background:var(--ink);color:var(--white)}
.why .inner{max-width:1180px;margin:0 auto;padding:80px 5vw;display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.why ul{list-style:none;display:grid;gap:16px}
.why li{font-weight:700;font-size:17px;padding-left:34px;position:relative;opacity:.95}
.why li::before{content:"→";position:absolute;left:0;color:var(--lime);font-weight:900}
/* steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:40px}
.step{border:3px solid var(--ink);border-radius:22px;padding:22px;background:#fff}
.step .n{font-size:30px;font-weight:900;color:var(--coral)} .step h4{font-size:18px;font-weight:900;margin:6px 0} .step small{font-weight:600;opacity:.66}
/* band */
.band{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1180px;margin:0 auto 90px;padding:0 5vw}
.stat{text-align:center;border:3px solid var(--ink);border-radius:22px;padding:26px}
.stat .n{font-size:52px;font-weight:900;letter-spacing:-.03em;line-height:1} .stat .l{font-weight:700;opacity:.7;margin-top:6px}
/* faq */
.faq{margin-top:30px;max-width:860px;display:grid;gap:12px}
.faq details{border:3px solid var(--ink);border-radius:16px;background:#fff;overflow:hidden}
.faq summary{cursor:pointer;font-weight:800;font-size:17px;padding:18px 22px;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq summary::after{content:"+";font-size:24px;font-weight:900}
.faq details[open] summary::after{content:"–"}
.faq details>div{padding:0 22px 20px;font-weight:600;opacity:.78;line-height:1.5}
/* team */
.team{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;margin-top:40px}
.member{border:3px solid var(--ink);border-radius:20px;overflow:hidden;background:#fff}
.member img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;filter:saturate(1.02)}
.member .mb{padding:14px 16px}
.member h3{font-size:17px;font-weight:900;letter-spacing:-.01em;line-height:1.1}
.member .role{font-weight:800;font-size:12px;color:var(--coral);text-transform:uppercase;letter-spacing:.05em;margin-top:4px}
@media(max-width:1000px){.team{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.team{grid-template-columns:repeat(2,1fr)}}
/* AI band */
.ai-band{background:linear-gradient(135deg,#1b1430 0%,#2a1d54 55%,#10243a 100%);color:#fff;padding:70px 5vw}
.ai-inner{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1.1fr .9fr;gap:46px;align-items:center}
.ai-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ai-list li{font-weight:800;font-size:15px;border:2px solid rgba(255,255,255,.25);border-radius:30px;padding:11px 16px;text-align:center}
/* clients logos band (home) */
.logos-band{background:#fff;padding:46px 0 36px;border-top:3px solid var(--ink);border-bottom:3px solid var(--ink)}
.logos-title{text-align:center;font-weight:900;font-size:14px;letter-spacing:.1em;text-transform:uppercase;opacity:.55;margin-bottom:24px}
.logos-row{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.logos-row .run{display:flex;gap:54px;align-items:center;width:max-content;animation:march 60s linear infinite}
.logos-row img{height:42px;width:auto;object-fit:contain;filter:grayscale(1);opacity:.55}
.seelink{font-weight:800;text-decoration:none;color:var(--coral)}
/* clients grid (page) */
.clients-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:40px}
.client{border:2px solid #e2dccf;border-radius:16px;background:#fff;height:118px;display:flex;align-items:center;justify-content:center;padding:22px}
.client img{max-width:100%;max-height:100%;object-fit:contain;filter:grayscale(1);opacity:.72;transition:.2s}
.client:hover img{filter:none;opacity:1}
@media(max-width:1000px){.clients-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.clients-grid{grid-template-columns:repeat(2,1fr)}.ai-inner{grid-template-columns:1fr}}
/* casos de éxito */
.cases{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px}
.case{border:3px solid var(--ink);border-radius:20px;overflow:hidden;background:#fff;transition:.12s}
.case:hover{transform:translateY(-4px);box-shadow:7px 9px 0 var(--ink)}
.case-img{aspect-ratio:4/3;overflow:hidden;border-bottom:3px solid var(--ink);background:var(--white)}
.case-img img{width:100%;height:100%;object-fit:cover;display:block}
.case figcaption{padding:16px 18px}
.case-cat{font-weight:800;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--coral)}
.case h3{font-size:20px;font-weight:900;letter-spacing:-.01em;margin-top:3px}
@media(max-width:900px){.cases{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.cases{grid-template-columns:1fr}}
/* blog */
.posts{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:10px}
.post-card{border:3px solid var(--ink);border-radius:20px;padding:0;overflow:hidden;background:#fff;text-decoration:none;display:flex;flex-direction:column;transition:.12s}
.post-card:hover{transform:translateY(-4px);box-shadow:7px 9px 0 var(--ink)}
.post-thumb{aspect-ratio:16/9;overflow:hidden;border-bottom:3px solid var(--ink);background:var(--white)}
.post-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.post-card-body{padding:24px;display:flex;flex-direction:column;gap:8px;flex:1}
.post-cat{font-weight:800;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--coral)}
.post-card h3{font-size:22px;font-weight:900;letter-spacing:-.01em;line-height:1.1}
.post-card p{font-weight:600;opacity:.7;font-size:15px;line-height:1.45}
.post-more{font-weight:800;color:var(--sea);margin-top:auto}
.post-cover-wrap{max-width:840px;margin:0 auto;padding:40px 5vw 0}
.post-cover{width:100%;height:auto;aspect-ratio:3/2;object-fit:cover;border-radius:20px;border:3px solid var(--ink);display:block}
.post-hero h1{text-transform:none}
.post-body{max-width:840px;margin:0 auto;padding:48px 5vw 84px}
.post-body .lead{font-size:19px;margin-bottom:8px;max-width:none}
.post-body h2{text-transform:none;font-size:24px;margin-top:30px}
.post-cta{margin-top:40px;border:3px solid var(--ink);border-radius:20px;padding:26px;background:var(--white)}
.post-cta h3{font-size:22px;font-weight:900}
@media(max-width:700px){.posts{grid-template-columns:1fr}}
/* legal */
.legal{max-width:820px}
.legal h2{font-size:22px;text-transform:none;margin:30px 0 6px}
.legal p{font-weight:500;opacity:.85;line-height:1.6;margin:8px 0}
.legal a{color:var(--coral)}
/* final */
.final{text-align:center;padding:92px 5vw}.final h2{margin-bottom:8px}
/* contacto */
.contact .cgrid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.clist{list-style:none;margin-top:24px;display:grid;gap:14px}
.clist li{display:flex;flex-direction:column;border-bottom:1px dashed #d8cfc2;padding-bottom:12px}
.clist b{font-size:13px;text-transform:uppercase;letter-spacing:.08em;opacity:.6}
.clist span,.clist li{font-weight:700;font-size:17px}
.pend{color:var(--violet)}
.muted2{font-size:13px;opacity:.6;font-weight:600;margin-top:18px}
.cform{border:3px solid var(--ink);border-radius:22px;padding:26px;display:grid;gap:14px;background:#fff}
.cform label{display:grid;gap:6px;font-weight:800;font-size:14px}
.cform input,.cform select,.cform textarea{font:inherit;font-weight:600;border:2px solid var(--ink);border-radius:10px;padding:11px 13px;background:var(--white)}
.cform .cta{justify-self:start;margin-top:4px}
/* footer */
footer{background:var(--ink);color:var(--white);padding:66px 5vw 30px;font-weight:600;font-size:14.5px}
.fgrid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1.2fr;gap:36px}
.fbrand{max-width:300px}
.fbrand .logo{margin-bottom:14px}
.fbrand p{opacity:.55;line-height:1.65;font-weight:600}
.fcol b{display:block;margin-bottom:15px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;opacity:.5;font-weight:800}
.fcol a{display:block;text-decoration:none;opacity:.85;margin:9px 0;transition:.15s}
.fcol a:hover{opacity:1;color:var(--lime)}
.fzone{display:block;margin-top:14px;opacity:.5;font-size:13px;line-height:1.5}
.legalbar{max-width:1180px;margin:50px auto 0;padding-top:24px;border-top:1px solid rgba(255,255,255,.14);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.legalbar .ctmd{display:flex;align-items:center;gap:10px;text-decoration:none;color:#fff}
.legalbar .ctmd span{font-size:12px;opacity:.5;font-weight:600}
.legalbar .ctmd img{height:30px;width:auto;display:block}
.legalbar .ctmd strong{font-weight:800;font-size:14px}
.legalbar .llinks{display:flex;gap:24px}
.legalbar .llinks a{text-decoration:none;opacity:.7;font-size:13px;font-weight:600;transition:.15s}
.legalbar .llinks a:hover{opacity:1}
.fcopy{opacity:.45;font-size:13px;font-weight:600}
.draftbar{background:var(--violet);color:#fff;text-align:center;font-weight:800;font-size:13px;padding:10px;letter-spacing:.03em}
/* mobile menu (hamburger) */
.navtog{display:none}
.burger{display:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px;z-index:30}
.burger span{display:block;width:26px;height:3px;background:var(--ink);border-radius:2px;transition:.2s}
@media(max-width:860px){
  .cards,.steps{grid-template-columns:repeat(2,1fr)}
  .band,.why .inner,.contact .cgrid,.checklist{grid-template-columns:1fr}
  nav{flex-wrap:wrap;align-items:center}
  .burger{display:flex}
  .navtog:checked ~ .burger span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .navtog:checked ~ .burger span:nth-child(2){opacity:0}
  .navtog:checked ~ .burger span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  .links{display:none;flex-direction:column;align-items:flex-start;width:100%;gap:4px;padding:14px 0 4px}
  .navtog:checked ~ .links{display:flex}
  .links .navlink{padding:9px 0;font-size:17px}
  .links .pill{align-self:stretch;text-align:center;margin-top:10px;padding:13px}
  .drop{width:100%}
  .drop .navlink{width:100%;font-weight:900;opacity:.55;font-size:13px;text-transform:uppercase;letter-spacing:.06em;padding:14px 0 4px}
  .drop .menu{position:static;display:flex;flex-direction:column;border:0;box-shadow:none;padding:0 0 4px 12px;min-width:0;background:transparent}
  .drop .menu a{padding:7px 0;font-size:16px}
  .drop:hover .menu{display:flex}
  .fgrid{grid-template-columns:1fr 1fr;gap:32px}
  .fbrand{grid-column:1/-1;max-width:none}
  .legalbar{justify-content:flex-start;gap:14px}
}
@media(max-width:520px){.fgrid{grid-template-columns:1fr}}
