/* ============================================================
   EDGEBOUND LABS — /work.html  ·  PROPUESTA B (Design-first)
   Visual-dominant portfolio (60% visual / 40% copy).
   Languages mixed: tech-premium (dark) · editorial · gallery.
   Reuses home tokens + .sec/.lt, .eyebrow, .h2, .lead, .btn, .reveal, .tg.
   Only Propuesta-B components defined here. (Prefix: wb-)
   ============================================================ */

/* ---- count-up helper (shared) ---- */
.wb-num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}

/* =========================================================
   S01 · HERO — design-first, editorial display
   ========================================================= */
.wb-hero{position:relative;overflow:hidden;background:var(--bg);padding:172px 0 0}
.wb-hero .gridbg{position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(ellipse 66% 64% at 24% 26%,#000,transparent 72%);
  mask-image:radial-gradient(ellipse 66% 64% at 24% 26%,#000,transparent 72%)}
.wb-hero .glow{position:absolute;top:-22%;right:-8%;width:840px;height:720px;pointer-events:none;
  background:radial-gradient(ellipse at center,rgba(80,70,229,.26),rgba(80,70,229,.05) 48%,transparent 72%);filter:blur(20px)}
.wb-hero .wrap{position:relative;z-index:2}
.wb-hero-top{max-width:980px}
.wb-h1{font-size:clamp(46px,8.4vw,108px);font-weight:800;letter-spacing:-.05em;line-height:.94;color:var(--t1);margin-top:14px}
.wb-h1 .grad{background:linear-gradient(102deg,#fff 20%,var(--blue-bright) 58%,#fff 96%);background-size:220% auto;
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:shine 7s linear infinite}
.wb-hero-sub{max-width:54ch;font-size:clamp(16px,1.9vw,20px);line-height:1.65;color:var(--t2);margin-top:26px}
.wb-hero-sub b{color:var(--t1);font-weight:600}
.wb-hero-cta{display:flex;align-items:center;gap:16px;margin-top:32px;flex-wrap:wrap}
.wb-scrollcue{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--t3)}
.wb-scrollcue .ar{width:22px;height:22px;border:1px solid var(--line-2);border-radius:50%;display:flex;align-items:center;justify-content:center;animation:wbbob 2s var(--ease) infinite}
.wb-scrollcue svg{width:11px;height:11px;stroke:var(--blue-bright);fill:none;stroke-width:2}
@keyframes wbbob{0%,100%{transform:translateY(0)}50%{transform:translateY(3px)}}

/* =========================================================
   S02 · SHOWCASE REEL — horizontal gallery (gallery language)
   ========================================================= */
.wb-reel-wrap{position:relative;margin-top:66px;padding-bottom:96px}
.wb-reel-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;max-width:var(--maxw);margin:0 auto 26px;padding:0 28px;flex-wrap:wrap}
.wb-reel-head .eyebrow{margin-bottom:0}
.wb-reel-drag{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--t3);display:flex;align-items:center;gap:9px}
.wb-reel-drag svg{width:16px;height:16px;stroke:var(--t3);fill:none;stroke-width:1.5}
.wb-reel{display:flex;gap:22px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:6px 28px 22px;scrollbar-width:none;cursor:grab;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 3%,#000 97%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 3%,#000 97%,transparent)}
.wb-reel::-webkit-scrollbar{display:none}
.wb-reel.drag{cursor:grabbing;scroll-snap-type:none}
.wb-card{position:relative;flex:0 0 min(70vw,640px);scroll-snap-align:center;
  aspect-ratio:16/10;border-radius:20px;overflow:hidden;border:1px solid var(--line);
  background:var(--surface);transition:transform .4s var(--ease),border-color .4s var(--ease)}
.wb-card:hover{transform:scale(1.012);border-color:var(--line-2)}
.wb-card .ph{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.wb-card .ph.contain{object-fit:cover}
.wb-card:hover .ph{transform:scale(1.05)}
.wb-card .scrim{position:absolute;inset:0;background:linear-gradient(0deg,rgba(10,10,13,.92) 0%,rgba(10,10,13,.34) 42%,transparent 72%)}
.wb-card .meta{position:absolute;left:0;right:0;bottom:0;padding:26px 28px;display:flex;flex-direction:column;gap:13px;z-index:2}
.wb-card .meta .ix{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--blue-bright)}
.wb-card .meta h3{font-size:clamp(20px,2.3vw,27px);font-weight:800;letter-spacing:-.03em;line-height:1.1;color:#fff;max-width:18ch}
.wb-card .meta .tags{display:flex;flex-wrap:wrap;gap:7px}
.wb-card .meta .tags span{font-family:var(--mono);font-size:10.5px;letter-spacing:.02em;color:rgba(255,255,255,.78);
  border:1px solid rgba(255,255,255,.22);border-radius:100px;padding:4px 10px;backdrop-filter:blur(4px)}
.wb-card .reveal-cta{display:inline-flex;align-items:center;gap:7px;align-self:flex-start;margin-top:3px;
  font-size:13px;font-weight:600;color:#fff;opacity:0;transform:translateY(6px);transition:.35s var(--ease)}
.wb-card .reveal-cta svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.8}
.wb-card:hover .reveal-cta{opacity:1;transform:none}

/* =========================================================
   S03 · STATS STRIP — typographic, count-up
   ========================================================= */
.wb-strip{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.wb-strip .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.wb-stat{padding:14px 26px;border-left:1px solid var(--line);display:flex;flex-direction:column;gap:9px}
.wb-stat:first-child{border-left:0}
.wb-stat .fig{font-family:var(--sans);font-weight:800;letter-spacing:-.045em;line-height:.9;color:var(--t1);
  font-size:clamp(44px,6vw,76px);display:flex;align-items:baseline}
.wb-stat .fig .pfx,.wb-stat .fig .sfx{color:var(--blue-bright);font-size:.46em;font-weight:700;letter-spacing:-.02em}
.wb-stat .fig .pfx{margin-right:.02em}
.wb-stat .cap{font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--t2);line-height:1.5;text-transform:uppercase;max-width:22ch}

/* =========================================================
   S04 · EDITORIAL CASE — alternating light / dark
   ========================================================= */
.wb-case{position:relative;overflow:hidden}
.wb-case .wrap{display:grid;grid-template-columns:minmax(0,42%) minmax(0,58%);gap:64px;align-items:center}
.wb-case.rev .wrap{grid-template-columns:minmax(0,58%) minmax(0,42%)}
.wb-case.rev .wb-copy{order:2}
.wb-case.rev .wb-visual{order:1}
/* dark-case ambient glow */
.wb-case.dk{background:var(--bg)}
.wb-case.dk .glow{position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(680px 440px at 28% 30%,rgba(80,70,229,.16),transparent 60%)}
.wb-case .wrap{position:relative;z-index:2}

.wb-eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:12px;font-weight:500;
  letter-spacing:.05em;color:var(--blue-bright);margin-bottom:18px}
.wb-eyebrow::before{content:"";width:22px;height:1px;background:var(--blue-bright)}
.wb-case.lt .wb-eyebrow{color:var(--blue)}
.wb-case.lt .wb-eyebrow::before{background:var(--blue)}
.wb-copy h2{font-size:clamp(30px,4.4vw,52px);font-weight:800;letter-spacing:-.04em;line-height:1.04;color:var(--t1)}
.wb-case.lt .wb-copy h2{color:var(--lt-ink)}
.wb-copy .desc{font-size:clamp(15px,1.7vw,17.5px);line-height:1.72;color:var(--t2);margin-top:22px;max-width:46ch}
.wb-case.lt .wb-copy .desc{color:var(--lt-2)}
.wb-copy .desc b{color:var(--t1);font-weight:600}
.wb-case.lt .wb-copy .desc b{color:var(--lt-ink)}

/* big typographic metrics */
.wb-metrics{display:flex;flex-wrap:wrap;gap:40px;margin-top:38px}
.wb-metric{display:flex;flex-direction:column;gap:8px}
.wb-metric .v{font-family:var(--sans);font-weight:800;letter-spacing:-.045em;line-height:.9;color:var(--blue-bright);
  font-size:clamp(40px,5.4vw,68px);display:flex;align-items:baseline}
.wb-metric .v .pfx,.wb-metric .v .sfx{font-size:.5em;font-weight:700}
.wb-case.lt .wb-metric .v{color:var(--blue)}
.wb-metric .l{font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--t3);line-height:1.4;max-width:16ch}
.wb-case.lt .wb-metric .l{color:var(--lt-3)}

.wb-foot{display:flex;align-items:center;gap:18px;margin-top:36px;flex-wrap:wrap}
.wb-foot .note{font-family:var(--mono);font-size:11px;letter-spacing:.03em;color:var(--t3);display:flex;align-items:center;gap:8px}
.wb-case.lt .wb-foot .note{color:var(--lt-3)}
.wb-foot .note svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:1.6}

/* visual side */
.wb-visual{position:relative}
.wb-frame{position:relative;border-radius:20px;overflow:hidden;border:1px solid var(--line);
  box-shadow:0 30px 60px rgba(0,0,0,.42)}
.wb-case.lt .wb-frame{border-color:var(--lt-line2);box-shadow:0 30px 70px rgba(31,31,31,.16)}
.wb-frame img{display:block;width:100%;height:auto}
.wb-frame.photo{aspect-ratio:16/10}
.wb-frame.photo img{width:100%;height:100%;object-fit:cover}
.wb-frame.diagram{background:#16161b}
/* floating metric chip over the visual */
.wb-float{position:absolute;left:-14px;bottom:-18px;z-index:3;background:var(--surface);border:1px solid var(--line-2);
  border-radius:15px;padding:16px 20px;display:flex;flex-direction:column;gap:4px;box-shadow:0 18px 40px rgba(0,0,0,.4);min-width:148px}
.wb-case.lt .wb-float{background:#fff;border-color:var(--lt-line2);box-shadow:0 18px 44px rgba(31,31,31,.14)}
.wb-float .fv{font-size:34px;font-weight:800;letter-spacing:-.04em;color:var(--t1);line-height:1}
.wb-case.lt .wb-float .fv{color:var(--lt-ink)}
.wb-float .fl{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--t3)}
.wb-case.lt .wb-float .fl{color:var(--lt-3)}
/* AI highlight pills overlaid on storefront diagram */
.wb-ai-tags{position:absolute;right:-10px;top:24px;z-index:3;display:flex;flex-direction:column;gap:10px;align-items:flex-end}
.wb-ai-tags span{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.02em;
  color:#fff;background:rgba(80,70,229,.92);border:1px solid var(--blue-bright);border-radius:100px;padding:7px 13px;
  box-shadow:0 8px 22px rgba(80,70,229,.4);backdrop-filter:blur(4px)}
.wb-ai-tags span::before{content:"";width:6px;height:6px;border-radius:50%;background:#fff;box-shadow:0 0 8px #fff}

/* =========================================================
   S05 · LOGO MARQUEE — clients · platforms · payments
   ========================================================= */
/* Reduce gap between Retail case and Logos section */
#case-retail{padding-bottom:52px}
.wb-logos{background:var(--lt-bg);color:var(--lt-ink);padding-top:52px}
.wb-logos .sec-head{text-align:center;display:flex;flex-direction:column;align-items:center;margin-bottom:46px}
.wb-logos .sec-head .lead{text-align:center}
.wb-mq{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--lt-line)}
.wb-mq-row{display:grid;grid-template-columns:150px 1fr;align-items:center;gap:18px;
  border-bottom:1px solid var(--lt-line);padding:8px 0}
.wb-mq-row .rl{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--lt-3)}
.wb-track-wrap{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.wb-track{display:flex;align-items:center;gap:56px;width:max-content;animation:wbmq 38s linear infinite}
.wb-mq-row:hover .wb-track{animation-play-state:paused}
.wb-track.rev{animation-duration:46s;animation-direction:reverse}
@keyframes wbmq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.wb-track img{height:26px;width:auto;object-fit:contain;filter:grayscale(1) brightness(.4);opacity:.62;transition:.3s var(--ease)}
.wb-track img:hover{filter:none;opacity:1}
.wb-track .pay{font-family:var(--sans);font-weight:700;font-size:16px;letter-spacing:-.01em;color:var(--lt-3);transition:color .3s}
.wb-track .pay:hover{color:var(--lt-ink)}
@media(prefers-reduced-motion:reduce){.wb-track{animation:none}}

/* Logo grid — 2-col static layout */
.wb-logo-grid{display:grid;grid-template-columns:1fr 1px 1fr;gap:0 52px;border-top:1px solid var(--lt-line);padding-top:40px;max-width:860px;margin:0 auto}
.wb-lg-divider{background:var(--lt-line)}
.wb-lg-col{display:flex;flex-direction:column;gap:20px}
.wb-lg-label{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--lt-3)}
.wb-lg-logos{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:60px;gap:0 32px;align-items:center}
.wb-lg-logos img{height:24px;width:auto;max-width:100px;object-fit:contain;filter:grayscale(1) brightness(.3);opacity:.55;transition:.3s var(--ease)}
.wb-lg-logos img[src*="am.png"]{height:68px;max-width:240px}
.wb-lg-logos img[src*="televisa"]{height:38px;max-width:80px}
.wb-lg-logos img[src*="costco"]{filter:grayscale(1) brightness(.12);opacity:.35}
.wb-lg-logos img[src*="homedepot"]{height:32px;max-width:110px;filter:grayscale(1) brightness(.12);opacity:.35}
.wb-lg-logos img[src*="claro"]{filter:grayscale(1) brightness(.12);opacity:.35}
.wb-lg-logos img[src*="pyosa"]{height:36px;max-width:110px;filter:grayscale(1) brightness(.12);opacity:.35}
.wb-lg-logos img[src*="homedepot"]{height:32px;max-width:110px}
.wb-lg-logos img:nth-child(n+7){margin-top:0}
.wb-lg-logos img:hover{filter:grayscale(1) brightness(.05);opacity:.95}
@media(max-width:768px){
  .wb-logo-grid{grid-template-columns:1fr;gap:36px 0}
  .wb-lg-divider{height:1px;width:100%}
}

/* ISO badge */
.wb-iso{display:flex;justify-content:center;margin-top:44px}
.wb-iso-card{display:flex;align-items:center;gap:16px;border:1px solid var(--lt-line2);border-radius:16px;
  background:#fff;padding:16px 24px;box-shadow:0 10px 30px rgba(31,31,31,.07)}
.wb-iso-card img{height:46px;width:auto;filter:grayscale(1) brightness(.4);opacity:.6}
.wb-iso-card .t{display:flex;flex-direction:column;gap:3px}
.wb-iso-card .t b{font-size:15px;font-weight:800;letter-spacing:-.02em;color:var(--lt-3)}
.wb-iso-card .t span{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--lt-3);text-transform:uppercase}

/* =========================================================
   S06 · FINAL CTA — typographic, dark
   ========================================================= */
.wb-final{position:relative;overflow:hidden;background:var(--bg);text-align:center;padding:128px 0}
.wb-final .glow{position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(820px 480px at 50% -6%,rgba(80,70,229,.24),transparent 62%)}
.wb-final .gridv{position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(ellipse 64% 78% at 50% 26%,#000,transparent 72%);
  mask-image:radial-gradient(ellipse 64% 78% at 50% 26%,#000,transparent 72%)}
.wb-final .wrap{position:relative;z-index:2}
.wb-final h2{font-size:clamp(34px,5.6vw,68px);font-weight:800;letter-spacing:-.045em;line-height:1.02;color:var(--t1);max-width:16ch;margin:0 auto}
.wb-final .sub{font-size:clamp(16px,1.8vw,18px);line-height:1.65;color:var(--t2);max-width:50ch;margin:22px auto 36px}
.wb-final .ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.wb-final .mail{margin-top:26px;font-family:var(--mono);font-size:13px;letter-spacing:.02em;color:var(--t3)}
.wb-final .mail a{color:var(--blue-bright);text-decoration:none}
.wb-final .mail a:hover{text-decoration:underline;text-underline-offset:3px}

/* =========================================================
   responsive
   ========================================================= */
@media(max-width:940px){
  .wb-hero{padding-top:138px}
  .wb-case .wrap,.wb-case.rev .wrap{grid-template-columns:1fr;gap:40px}
  .wb-case.rev .wb-copy{order:1}
  .wb-case.rev .wb-visual{order:2}
  .wb-strip .wrap{grid-template-columns:1fr 1fr;gap:0}
  .wb-stat{border-left:0;padding:24px 16px}
  .wb-stat:nth-child(3),.wb-stat:nth-child(4){border-top:1px solid var(--line)}
  .wb-stat:nth-child(2){border-left:1px solid var(--line)}
  .wb-stat:nth-child(4){border-left:1px solid var(--line)}
}
@media(max-width:600px){
  .wb-card{flex-basis:84vw}
  .wb-metrics{gap:28px}
  .wb-mq-row{grid-template-columns:1fr;gap:8px;padding:14px 0}
  .wb-float{left:12px;bottom:12px}
  .wb-ai-tags{right:8px}
}
