/* ================================================================
   BAI THEME · extras.css
   Estilos de componentes (slider home, carrusel productos, manifesto, etc)
   ================================================================ */

/* ----------------------------------------------------------------
   HOME HERO
   ---------------------------------------------------------------- */
.home-hero{
  position:relative;
  min-height:100vh;
  padding:140px 32px 80px;
  display:flex;
  align-items:center;
  overflow:hidden;
}
.home-hero-bg{
  position:absolute;inset:0;
  background-size:cover;
  background-position:center;
  z-index:0;
}
.home-hero-bg::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,10,10,0.6) 0%,rgba(10,10,10,0.35) 35%,rgba(10,10,10,0.95) 100%);
}
.home-hero-content{
  position:relative;z-index:2;
  max-width:1280px;margin:0 auto;
  width:100%;
}
.home-hero-eyebrow{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--fg-dim);
  display:flex;align-items:center;gap:14px;
  margin-bottom:32px;
}
.dot-red{display:inline-block;width:8px;height:8px;background:var(--accent);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.4}}
.home-hero-title{
  font-family:'Big Shoulders Display',sans-serif;
  font-weight:900;
  font-size:clamp(4rem,11vw,11rem);
  line-height:0.82;
  letter-spacing:-0.045em;
  text-transform:uppercase;
  color:var(--fg);
  margin-bottom:40px;
}
.home-hero-title .accent{color:var(--accent);position:relative}
.home-hero-title .dot{display:inline-block;width:0.5em;height:0.5em;background:var(--accent);vertical-align:-0.04em;margin-left:0.05em}
.home-hero-sub{
  font-family:'Inter',sans-serif;
  font-size:18px;
  line-height:1.55;
  color:var(--fg-dim);
  max-width:560px;
  letter-spacing:-0.005em;
}
.home-hero-sub b{color:var(--fg);font-weight:600}
.home-hero-cta{display:flex;gap:14px;margin-top:40px;flex-wrap:wrap}

/* ----------------------------------------------------------------
   BUTTONS
   ---------------------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:16px 28px;
  font-family:'JetBrains Mono',monospace;
  font-size:11px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  font-weight:500;
  transition:all 250ms ease;
  text-decoration:none;
}
.btn-primary{background:var(--accent);color:var(--fg)}
.btn-primary:hover{background:var(--accent-hover);transform:translate(2px,-2px)}
.btn-ghost{border:1px solid var(--fg-dim);color:var(--fg)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn-primary-dark{background:var(--ink);color:var(--cream)}
.btn-primary-dark:hover{background:var(--accent);color:var(--fg)}

/* ----------------------------------------------------------------
   SLIDER HOME (trabajos marquee)
   ---------------------------------------------------------------- */
.trabajos-marquee{
  position:relative;
  overflow:hidden;
  cursor:grab;
  user-select:none;
  padding:0;margin:0;
  -webkit-tap-highlight-color:transparent;
}
.trabajos-marquee.is-dragging{cursor:grabbing}
.trabajos-marquee.is-dragging *{pointer-events:none}
.trabajos-track{
  display:flex;
  gap:18px;
  will-change:transform;
  width:max-content;
  padding:0 32px;
}
.trabajo-card{
  flex-shrink:0;
  position:relative;
  overflow:hidden;
  background:var(--bg-2);
  transition:transform 600ms cubic-bezier(.2,.8,.2,1);
  display:flex;flex-direction:column;justify-content:space-between;
  padding:24px 24px 28px;
  text-decoration:none;color:var(--fg);
}
.trabajo-card.w-small  { height:440px; width:300px; }
.trabajo-card.w-square { height:480px; width:380px; }
.trabajo-card.w-tall   { height:560px; width:340px; }
.trabajo-card.w-wide   { height:480px; width:560px; }
.trabajo-card.w-mega   { height:560px; width:720px; }
.trabajo-card.is-image::before{
  content:"";
  position:absolute;inset:0;
  background-color:rgba(10,10,10,0.4);
  background-blend-mode:multiply;
  pointer-events:none;
  z-index:1;
  background-image:linear-gradient(180deg,rgba(10,10,10,0.2) 0%,rgba(10,10,10,0.55) 60%,rgba(10,10,10,0.92) 100%);
}
.trabajo-card.is-image{
  background-size:cover;
  background-position:center;
}
.trabajo-card > *{position:relative;z-index:2}
.trabajo-card .t-top{display:flex;justify-content:space-between;align-items:flex-start}
.trabajo-card .t-label{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--fg-dim);
  background:rgba(10,10,10,0.45);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  padding:6px 10px;
}
.trabajo-card .t-arrow{
  font-family:'JetBrains Mono',monospace;
  color:var(--fg);
  background:rgba(10,10,10,0.45);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  padding:6px 10px;
  transition:all 250ms ease;
}
.trabajo-card:hover .t-arrow{background:var(--accent);transform:translate(2px,-2px)}
.trabajo-card .t-tag{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--accent);
  display:block;margin-bottom:8px;
}
.trabajo-card .t-name{
  font-family:'Big Shoulders Display',sans-serif;
  font-weight:900;
  font-size:clamp(2rem,3.5vw,3rem);
  line-height:0.85;
  letter-spacing:-0.03em;
  text-transform:uppercase;
  color:var(--fg);
  margin-bottom:10px;
}
.trabajo-card .t-desc{
  font-family:'Inter',sans-serif;
  font-size:13px;
  line-height:1.5;
  color:var(--fg-dim);
  max-width:90%;
}
.t-marquee-hint{
  text-align:center;
  padding:40px 32px 80px;
  color:var(--fg-mute);
}

/* Code overlay sobre las cards */
.trab-code-overlay,.prod-code-overlay{
  position:absolute;
  top:18px;right:18px;
  z-index:3;
  font-family:'JetBrains Mono',monospace;
  font-size:10px;
  line-height:1.4;
  color:rgba(242,239,233,0.92);
  background:rgba(8,8,8,0.55);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  padding:8px 12px;
  border-left:2px solid var(--accent);
  max-width:240px;
  pointer-events:none;
}
.trab-code-overlay .ln,.prod-code-overlay .ln{display:block;overflow:hidden;white-space:nowrap;animation:codeType 1.4s steps(28,end) backwards}
.caret{
  display:inline-block;width:6px;background:var(--accent);height:1em;
  margin-left:3px;vertical-align:-2px;animation:caretBlink 1s infinite;
}
@keyframes codeType{from{width:0}to{width:100%}}
@keyframes caretBlink{0%,49%{opacity:1}50%,100%{opacity:0}}

/* ----------------------------------------------------------------
   MANIFESTO
   ---------------------------------------------------------------- */
.manifesto{max-width:880px;margin:0 auto;padding:40px 0}
.manifesto-eyebrow{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--ink-dim);
  margin-bottom:32px;
}
.manifesto-title{
  font-family:'Big Shoulders Display',sans-serif;
  font-weight:900;
  font-size:clamp(3rem,7vw,6rem);
  line-height:0.88;
  letter-spacing:-0.04em;
  text-transform:uppercase;
  color:var(--ink);
  margin-bottom:40px;
}
.manifesto-title b{color:var(--accent)}
.manifesto-body{
  font-family:'Inter',sans-serif;
  font-size:17px;
  line-height:1.65;
  color:var(--ink-dim);
  letter-spacing:-0.005em;
  max-width:680px;
}
.manifesto-body b{color:var(--ink);font-weight:600}

/* ----------------------------------------------------------------
   PRODUCTOS FEATURED GRID (home)
   ---------------------------------------------------------------- */
.productos-featured-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.productos-featured-grid > .prod-card{
  width:auto;height:420px;
}

/* ----------------------------------------------------------------
   PRODUCTOS CARRUSEL (página productos)
   ---------------------------------------------------------------- */
.prod-marquee{position:relative;overflow:hidden;cursor:grab;user-select:none;padding:0;margin:0;-webkit-tap-highlight-color:transparent}
.prod-marquee.is-dragging{cursor:grabbing}
.prod-marquee.is-dragging *{pointer-events:none}
.prod-track{display:flex;gap:18px;will-change:transform;width:max-content;padding:0 32px}
.prod-card{
  flex-shrink:0;
  height:520px;width:380px;
  position:relative;overflow:hidden;
  background:var(--bg-2);
  transition:transform 600ms cubic-bezier(.2,.8,.2,1);
  text-decoration:none;color:var(--fg);
}
.prod-card.is-tall{height:560px;width:340px}
.prod-card.is-wide{height:480px;width:560px}
.prod-card.is-mega{height:560px;width:680px}
.prod-card.is-square{height:480px;width:480px}
.prod-card.is-small{height:440px;width:300px}
.prod-card-img{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:saturate(0.94) contrast(1.06) brightness(0.7);
  transition:filter 700ms ease,transform 1.2s cubic-bezier(.2,.8,.2,1);
}
.prod-card:hover .prod-card-img{filter:saturate(1.05) contrast(1.1) brightness(0.78);transform:scale(1.04)}
.prod-card::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,10,10,0.2) 0%,rgba(10,10,10,0.55) 55%,rgba(10,10,10,0.95) 100%);
  pointer-events:none;
}
.prod-card-num{
  position:absolute;top:24px;left:24px;
  font-family:'JetBrains Mono',monospace;
  font-size:11px;letter-spacing:0.18em;
  color:var(--accent);font-weight:500;z-index:2;
  display:flex;gap:12px;align-items:center;
  background:rgba(10,10,10,0.4);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  padding:6px 12px;
}
.prod-card-num::before{content:"";display:inline-block;width:14px;height:1px;background:var(--accent)}
.prod-card-arrow{
  position:absolute;top:24px;right:24px;
  font-family:'JetBrains Mono',monospace;font-size:14px;
  color:var(--fg);z-index:2;
  background:rgba(10,10,10,0.5);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  padding:6px 10px;
  transition:all 250ms ease;
}
.prod-card:hover .prod-card-arrow{background:var(--accent);transform:translate(2px,-2px)}
.prod-card-content{
  position:absolute;left:28px;right:28px;bottom:28px;
  z-index:2;
  display:flex;flex-direction:column;gap:12px;
}
.prod-card-cat{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--fg);opacity:0.75;
}
.prod-card-name{
  font-family:'Big Shoulders Display',sans-serif;
  font-weight:900;
  font-size:clamp(2rem,3vw,2.8rem);
  line-height:0.85;letter-spacing:-0.025em;
  color:var(--fg);text-transform:uppercase;
}
.prod-card-name .accent{color:var(--accent)}
.prod-card-desc{
  font-family:'Inter',sans-serif;
  font-size:13px;line-height:1.5;
  color:rgba(242,239,233,0.8);max-width:90%;
}

/* ----------------------------------------------------------------
   CATEGORY BANNERS (full-bleed)
   ---------------------------------------------------------------- */
.cat-block{padding:80px 0 0}
.cat-block:first-of-type{padding-top:32px}
.cat-strip{
  position:relative;
  width:100vw;
  margin-left:calc(50% - 50vw);
  min-height:300px;
  background-size:cover;background-position:center;
  display:flex;align-items:flex-end;
  margin-bottom:24px;
  overflow:hidden;
}
.cat-strip::before{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,10,10,0.45) 0%,rgba(10,10,10,0.15) 35%,rgba(10,10,10,0.95) 100%);
  pointer-events:none;z-index:1;
}
.cat-strip-inner{
  position:relative;z-index:2;
  max-width:1280px;margin:0 auto;width:100%;
  padding:48px 32px 32px;
  display:grid;
  grid-template-columns:80px 1fr auto;
  gap:48px;align-items:end;
  border-bottom:var(--hairline);
}
.cat-num{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;letter-spacing:0.18em;
  color:var(--accent);font-weight:500;
  background:rgba(10,10,10,0.5);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  padding:6px 12px;display:inline-block;
}
.cat-title{
  font-family:'Big Shoulders Display',sans-serif;
  font-weight:900;
  font-size:clamp(2.4rem,5vw,4.5rem);
  line-height:0.88;letter-spacing:-0.035em;
  text-transform:uppercase;color:var(--fg);
}
.cat-title b{color:var(--accent)}
.cat-meta{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;letter-spacing:0.16em;
  text-transform:uppercase;
  color:rgba(242,239,233,0.6);
  text-align:right;line-height:1.5;
  max-width:280px;
  background:rgba(10,10,10,0.4);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  padding:10px 14px;
}
.cat-meta b{color:var(--fg);font-weight:500}

/* ----------------------------------------------------------------
   PRODUCTOS LIST (rows verticales)
   ---------------------------------------------------------------- */
.productos-list{display:flex;flex-direction:column}
.prod-row{
  display:grid;
  grid-template-columns:80px 1fr 280px 80px;
  gap:48px;align-items:center;
  padding:36px 0;
  border-bottom:var(--hairline);
  text-decoration:none;color:var(--fg);
  position:relative;
  transition:padding-left 500ms cubic-bezier(.2,.8,.2,1);
}
.prod-row:first-child{border-top:var(--hairline)}
.prod-row:hover{padding-left:16px;background:linear-gradient(90deg,rgba(255,54,23,0.04),transparent 60%)}
.prod-row::before{
  content:"";position:absolute;left:-16px;top:50%;
  width:0;height:1px;background:var(--accent);
  transition:width 400ms cubic-bezier(.2,.8,.2,1);
}
.prod-row:hover::before{width:12px}
.prod-num{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.16em;color:var(--accent);font-weight:500}
.prod-info{display:flex;flex-direction:column;gap:8px}
.prod-cat{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--fg-mute)}
.prod-name{
  font-family:'Big Shoulders Display',sans-serif;
  font-weight:800;
  font-size:clamp(1.8rem,3.4vw,3rem);
  line-height:0.88;letter-spacing:-0.025em;
  text-transform:uppercase;color:var(--fg);
}
.prod-name span{color:var(--accent)}
.prod-desc{font-family:'Inter',sans-serif;font-size:14px;line-height:1.55;color:var(--fg-dim);max-width:680px}
.prod-deliv{
  display:flex;flex-direction:column;gap:6px;
  font-family:'JetBrains Mono',monospace;
  font-size:10px;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--fg-dim);
}
.prod-deliv .lbl{color:var(--accent);font-weight:500;margin-bottom:2px}
.prod-deliv ul{list-style:none}
.prod-deliv li{padding:2px 0}
.prod-arrow{
  font-family:'JetBrains Mono',monospace;
  font-size:13px;color:var(--fg-mute);
  justify-self:end;
  transition:transform 300ms ease,color 250ms ease;
}
.prod-row:hover .prod-arrow{color:var(--accent);transform:translate(4px,-4px)}

/* ----------------------------------------------------------------
   POSTS GRID (blog)
   ---------------------------------------------------------------- */
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px}
.post-item{display:flex;flex-direction:column;gap:14px}
.post-thumb{display:block;aspect-ratio:16/10;overflow:hidden}
.post-thumb img{width:100%;height:100%;object-fit:cover;transition:transform 600ms ease}
.post-thumb:hover img{transform:scale(1.04)}

/* ----------------------------------------------------------------
   RESPONSIVE
   ---------------------------------------------------------------- */
@media (max-width: 1024px){
  .productos-featured-grid{grid-template-columns:repeat(2,1fr)}
  .posts-grid{grid-template-columns:1fr 1fr}
  .cat-strip{min-height:240px}
  .cat-strip-inner{grid-template-columns:60px 1fr;gap:24px;padding:36px 18px 24px}
  .cat-meta{grid-column:1/3;text-align:left;margin-top:8px;max-width:none}
  .prod-row{grid-template-columns:60px 1fr 60px;gap:24px;padding:28px 0}
  .prod-deliv{display:none}
}
@media (max-width: 640px){
  .productos-featured-grid{grid-template-columns:1fr}
  .posts-grid{grid-template-columns:1fr}
  .home-hero{min-height:90vh;padding:120px 18px 60px}
  .trabajo-card.w-small,.trabajo-card.w-square,.trabajo-card.w-tall,.trabajo-card.w-wide,.trabajo-card.w-mega{
    width:280px;height:440px;
  }
  .prod-card{width:280px;height:440px}
}


/* ----------------------------------------------------------------
   TRABAJOS GRID (página trabajos)
   ---------------------------------------------------------------- */
.trabajos-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.trab{
  position:relative;
  background:var(--bg-2);
  overflow:hidden;
  text-decoration:none;color:var(--fg);
  display:flex;flex-direction:column;
  transition:transform 600ms cubic-bezier(.2,.8,.2,1);
}
.trab.col-4{grid-column:span 4}
.trab.col-6{grid-column:span 6}
.trab.col-8{grid-column:span 8}
.trab.col-12{grid-column:span 12}
.trab-img{
  width:100%;aspect-ratio:16/9;
  background-size:cover;background-position:center;
  transition:transform 700ms cubic-bezier(.2,.8,.2,1);
  filter:saturate(0.94) brightness(0.85);
}
.trab:hover .trab-img{transform:scale(1.04);filter:saturate(1.05) brightness(0.95)}
.trab.col-4 .trab-img{aspect-ratio:4/3}
.trab.col-8 .trab-img{aspect-ratio:21/9}
.trab-info{padding:24px 28px 28px;display:flex;flex-direction:column;gap:8px;flex:1}
.trab-tag{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;letter-spacing:0.16em;
  text-transform:uppercase;color:var(--accent);
}
.trab-name{
  font-family:'Big Shoulders Display',sans-serif;
  font-weight:800;
  font-size:clamp(1.8rem,3vw,2.8rem);
  line-height:0.88;letter-spacing:-0.025em;
  text-transform:uppercase;color:var(--fg);
}
.trab-desc{
  font-family:'Inter',sans-serif;
  font-size:14px;line-height:1.55;
  color:var(--fg-dim);
  max-width:90%;
}
.trab-arrow{
  position:absolute;top:18px;right:18px;
  font-family:'JetBrains Mono',monospace;font-size:14px;
  color:var(--fg);
  background:rgba(10,10,10,0.5);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  padding:6px 10px;
  transition:all 250ms ease;
}
.trab:hover .trab-arrow{background:var(--accent);transform:translate(2px,-2px)}

/* ----------------------------------------------------------------
   LOGOS BAND (página trabajos, cream)
   ---------------------------------------------------------------- */
.logos-band-head{
  display:grid;grid-template-columns:5fr 7fr;gap:64px;
  align-items:end;margin-bottom:64px;
}
.logos-band-l{padding-bottom:8px}
.logos-band-eyebrow{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--accent);
  display:flex;gap:14px;align-items:center;
  margin-bottom:24px;
}
.logos-band-eyebrow::before{content:"";display:inline-block;width:24px;height:1px;background:var(--accent)}
.logos-band-title{
  font-family:'Big Shoulders Display',sans-serif;
  font-weight:900;
  font-size:clamp(3rem,6vw,5.6rem);
  line-height:0.85;letter-spacing:-0.035em;
  color:var(--ink);text-transform:uppercase;
  max-width:520px;
}
.logos-band-title b{color:var(--accent)}
.logos-band-r{
  font-family:'Inter',sans-serif;
  font-size:16px;line-height:1.6;
  color:var(--ink-dim);
  max-width:480px;
  letter-spacing:-0.005em;
  margin-left:auto;
}
.logos-band-r b{color:var(--ink);font-weight:600}

.logos-grid{
  display:grid;grid-template-columns:repeat(6,1fr);gap:0;
  border-top:var(--hairline-ink);border-left:var(--hairline-ink);
}
.logo-cell{
  aspect-ratio:1.5/1;
  border-right:var(--hairline-ink);
  border-bottom:var(--hairline-ink);
  display:flex;align-items:center;justify-content:center;
  padding:24px;position:relative;
  transition:background 350ms ease;
  background:var(--cream);overflow:hidden;
}
.logo-cell:hover{background:rgba(255,54,23,0.04)}
.logo-cell img{
  max-width:65%;max-height:55%;
  width:auto;height:auto;object-fit:contain;
  filter:grayscale(1) brightness(0.4);
  transition:filter 400ms ease,transform 400ms ease;
  opacity:0.7;
}
.logo-cell:hover img{filter:grayscale(0) brightness(1);opacity:1;transform:scale(1.05)}
.logo-cell .wm{
  font-family:'Big Shoulders Display',sans-serif;
  font-weight:700;text-transform:uppercase;
  letter-spacing:-0.02em;font-size:1.25rem;
  color:rgba(10,10,10,0.45);
  transition:color 350ms ease;
  text-align:center;line-height:1;
  align-items:center;justify-content:center;
}
.logo-cell:hover .wm{color:var(--ink)}
.logo-cell .lbl{
  position:absolute;bottom:8px;left:12px;
  font-family:'JetBrains Mono',monospace;
  font-size:9px;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--ink-mute);
  opacity:0;transition:opacity 250ms ease;
}
.logo-cell:hover .lbl{opacity:1}

@media (max-width: 1024px){
  .trabajos-grid{grid-template-columns:repeat(6,1fr);gap:16px}
  .trab.col-8,.trab.col-6,.trab.col-4{grid-column:span 6}
  .logos-band-head{grid-template-columns:1fr;gap:24px}
  .logos-band-r{margin-left:0}
  .logos-grid{grid-template-columns:repeat(4,1fr)}
}
@media (max-width: 640px){
  .trabajos-grid{grid-template-columns:1fr}
  .trab.col-8,.trab.col-6,.trab.col-4{grid-column:1/-1}
  .logos-grid{grid-template-columns:repeat(3,1fr)}
}
