/* =================================================================
   JULIANA FACCHIN — sitio de artista
   Diseño: galería de arte + pop hecho a mano. Paleta tomada de su obra.
   ================================================================= */

:root{
  /* paleta */
  --paper:   #F4EEE2;
  --paper-2: #ECE3D3;
  --paper-3: #E4D9C5;
  --ink:     #17120C;
  --ink-2:   #2A2318;
  --muted:   #6c6354;

  --blue:   #2436D8;
  --red:    #E8412B;
  --yellow: #F4B70B;
  --purple: #6E29C9;
  --teal:   #11A39B;
  --pink:   #EC6A93;
  --green:  #9DBB5B;
  --orange: #EF8B2B;
  --acc-ink:#BE2E1A;            /* rojo oscuro: texto chico + botones (contraste AA) */

  --acc: var(--red);            /* acento dinámico */
  --acc-2: var(--blue);

  /* tipos */
  --display: "Bricolage Grotesque", "Arial Black", sans-serif;
  --body: "Space Grotesk", system-ui, sans-serif;
  --hand: "Caveat", cursive;

  /* medidas */
  --pad: clamp(20px, 5vw, 90px);
  --maxw: 1480px;
  --r: 18px;
  --ease: cubic-bezier(.22,1,.36,.58);
  --ease2: cubic-bezier(.16,1,.3,1);
}

/* ---------- reset ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.5;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--acc);color:#fff}
:focus-visible{outline:3px solid var(--blue);outline-offset:3px;border-radius:4px}

/* ---------- grain ---------- */
.grain{
  position:fixed;inset:0;z-index:9990;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px 180px;
  mix-blend-mode:multiply;
}
@media (prefers-reduced-motion:no-preference){
  .grain{animation:grain 6s steps(6) infinite}
}
@keyframes grain{
  0%{background-position:0 0}20%{background-position:-12px 8px}40%{background-position:10px -10px}
  60%{background-position:-8px 6px}80%{background-position:12px 4px}100%{background-position:0 0}
}

/* ---------- cursor ---------- */
.cursor{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;mix-blend-mode:difference;will-change:transform}
.cursor span{
  display:block;width:14px;height:14px;border-radius:50%;background:#fff;
  transform:translate(-50%,-50%);transition:width .25s var(--ease2),height .25s var(--ease2),background .2s;
}
.cursor.is-hover span{width:54px;height:54px;background:#fff}
.cursor.is-down span{width:30px;height:30px}
@media (hover:none),(pointer:coarse){.cursor{display:none}}

/* ---------- loader ---------- */
.loader{position:fixed;inset:0;z-index:9995;background:var(--ink);display:grid;place-items:center;color:var(--paper);
  transition:transform .9s var(--ease2);}
.loader.done{transform:translateY(-101%)}
.loader__inner{display:flex;flex-direction:column;align-items:center;gap:18px;text-align:center}
.loader__star{width:54px;height:54px;fill:var(--yellow);animation:spin 3s linear infinite}
.loader__name{font-family:var(--display);font-weight:800;font-size:clamp(28px,7vw,64px);letter-spacing:-.02em}
.loader__count{font-family:var(--hand);font-size:26px;color:var(--acc)}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;width:100%;z-index:900;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--pad);
  transition:padding .4s var(--ease2),background .4s,backdrop-filter .4s;
}
.nav.scrolled{
  padding:11px var(--pad);
  background:color-mix(in srgb,var(--paper) 82%,transparent);
  backdrop-filter:blur(12px);
  border-bottom:1px solid color-mix(in srgb,var(--ink) 12%,transparent);
}
.nav__logo{display:flex;align-items:center;gap:11px}
.nav__mark{
  font-family:var(--display);font-weight:800;font-size:20px;
  width:42px;height:42px;display:grid;place-items:center;border-radius:50%;
  background:var(--ink);color:var(--paper);transition:transform .5s var(--ease2),background .3s;
}
.nav__logo:hover .nav__mark{transform:rotate(-12deg) scale(1.05);background:var(--acc)}
.nav__logo-txt{font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:-.01em}
.nav__links{display:flex;align-items:center;gap:6px}
.nav__links a{
  position:relative;padding:9px 15px;font-weight:500;font-size:15.5px;border-radius:30px;
  transition:color .25s,background .25s;
}
.nav__links a:not(.nav__cta)::after{
  content:"";position:absolute;left:15px;right:15px;bottom:5px;height:2px;background:var(--acc);
  transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease2);
}
.nav__links a:not(.nav__cta):hover::after{transform:scaleX(1)}
.nav__cta{background:var(--ink);color:var(--paper)!important;padding:9px 20px}
.nav__cta:hover{background:var(--acc)}
.nav__burger{display:none;flex-direction:column;gap:6px;width:42px;height:42px;border-radius:50%;align-items:center;justify-content:center;background:var(--ink)}
.nav__burger span{width:20px;height:2px;background:var(--paper);transition:transform .3s,opacity .3s}
.nav.open .nav__burger span:nth-child(1){transform:translateY(4px) rotate(45deg)}
.nav.open .nav__burger span:nth-child(2){transform:translateY(-4px) rotate(-45deg)}

/* mobile menu */
.menu{
  position:fixed;inset:0;z-index:850;background:var(--ink);color:var(--paper);
  display:flex;flex-direction:column;justify-content:center;gap:6px;padding:90px var(--pad) 40px;
  clip-path:circle(0% at 92% 4%);transition:clip-path .7s var(--ease2);pointer-events:none;
  overflow-y:auto;-webkit-overflow-scrolling:touch;
}
@media (max-height:560px){.menu{justify-content:flex-start;gap:0}}
/* logo legible con el menú oscuro abierto */
.nav.open{background:transparent;backdrop-filter:none;border-bottom-color:transparent}
.nav.open .nav__logo-txt{color:var(--paper)}
.nav.open .nav__mark{background:var(--acc);color:var(--paper)}
.menu.open{clip-path:circle(150% at 92% 4%);pointer-events:auto}
.menu a[data-menu]{
  font-family:var(--display);font-weight:700;font-size:clamp(34px,10vw,72px);letter-spacing:-.02em;
  display:flex;align-items:baseline;gap:14px;padding:6px 0;line-height:1.05;
  opacity:0;transform:translateY(30px);transition:opacity .5s,transform .5s,color .2s;
}
.menu.open a[data-menu]{opacity:1;transform:none}
.menu.open a[data-menu]:nth-child(1){transition-delay:.12s}
.menu.open a[data-menu]:nth-child(2){transition-delay:.18s}
.menu.open a[data-menu]:nth-child(3){transition-delay:.24s}
.menu.open a[data-menu]:nth-child(4){transition-delay:.30s}
.menu.open a[data-menu]:nth-child(5){transition-delay:.36s}
.menu a[data-menu] em{font-family:var(--body);font-size:16px;font-style:normal;color:var(--acc)}
.menu a[data-menu]:hover{color:var(--yellow)}
.menu__foot{margin-top:40px;display:flex;gap:24px;flex-wrap:wrap;font-size:15px;opacity:.8}
.menu__foot a:hover{color:var(--yellow)}

/* ---------- shared ---------- */
.hand{font-family:var(--hand);font-weight:700;line-height:.8}
.kicker{display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:14px;letter-spacing:.18em;text-transform:uppercase;color:var(--acc-ink)}
.kicker span{font-size:18px}
.section-h{font-family:var(--display);font-weight:800;font-size:clamp(44px,9vw,118px);line-height:.92;letter-spacing:-.03em}
.section-h--light{color:var(--paper)}
.hl{background:linear-gradient(transparent 58%, color-mix(in srgb,var(--yellow) 75%,transparent) 58%);padding:0 .05em}

.btn{
  position:relative;display:inline-flex;align-items:center;gap:10px;
  font-weight:600;font-size:16px;padding:15px 28px;border-radius:40px;
  transition:transform .3s var(--ease2),background .3s,color .3s,box-shadow .3s;will-change:transform;
}
.btn i{font-style:normal;transition:transform .3s var(--ease2)}
.btn--ink{background:var(--ink);color:var(--paper)}
.btn--ink:hover{background:var(--acc)}
.btn--ink:hover i{transform:translate(3px,3px)}
.btn--ghost{border:2px solid var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--paper)}

/* reveal */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease2),transform .8s var(--ease2)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal,.card,.prod{opacity:1!important;transform:none!important;transition:none!important}
  .hero__title .w{transform:none!important}
  .loader{display:none!important}
  *{animation-duration:.001s!important}
}

/* =================================================================
   HERO
   ================================================================= */
.hero{position:relative;min-height:100svh;padding:120px var(--pad) 40px;display:flex;flex-direction:column;justify-content:center;overflow:hidden}
.qa .hero{min-height:auto;padding:150px var(--pad) 70px}
.qa .hero__scroll{display:none}
.qa .pillar{min-height:auto}
.hero__doodles{position:absolute;inset:0;pointer-events:none;z-index:0}
.hero__doodles svg{position:absolute;will-change:transform}

.hero__inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto}
.hero__eyebrow{display:inline-flex;align-items:center;gap:10px;font-weight:500;font-size:15px;color:var(--muted);margin-bottom:10px}
.hero__eyebrow .dot{width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 var(--green);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--green) 60%,transparent)}70%{box-shadow:0 0 0 12px transparent}100%{box-shadow:0 0 0 0 transparent}}

.hero__title{font-family:var(--display);font-weight:800;letter-spacing:-.045em;line-height:.82;font-size:clamp(68px,17.5vw,290px);text-transform:none}
.hero__title .line{display:block;overflow:hidden}
.hero__title .w{display:inline-block;transform:translateY(110%);transition:transform 1s var(--ease2)}
.hero.in .hero__title .w{transform:none}
.hero__title .line:nth-child(2) .w{transition-delay:.12s;color:var(--acc)}

.hero__feature{display:grid;grid-template-columns:auto 1fr;align-items:end;gap:clamp(20px,4vw,60px);margin-top:clamp(20px,4vw,46px)}
.hero__art{position:relative;width:clamp(150px,22vw,290px);flex:none;border-radius:14px;overflow:hidden;transform:rotate(-3deg);box-shadow:0 30px 60px -20px rgba(0,0,0,.35);transition:transform .6s var(--ease2)}
.hero__art:hover{transform:rotate(0) scale(1.02)}
.hero__art img{width:100%;aspect-ratio:4/5;object-fit:cover}
.hero__art figcaption{position:absolute;left:0;bottom:0;width:100%;padding:18px 14px 12px;color:#fff;font-size:13px;background:linear-gradient(transparent,rgba(0,0,0,.6))}
.hero__art figcaption .hand{font-size:24px;display:block}
.hero__lead{max-width:46ch;min-width:0;font-size:clamp(17px,2vw,21px);align-self:center;overflow-wrap:break-word}
.hero__lead strong{color:var(--acc-ink)}
.hero__actions{grid-column:2;display:flex;gap:14px;flex-wrap:wrap;margin-top:22px}

.hero__scroll{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.hero__scroll i{width:1px;height:40px;background:var(--ink);position:relative;overflow:hidden}
.hero__scroll i::after{content:"";position:absolute;top:-100%;left:0;width:100%;height:100%;background:var(--acc);animation:scrolldn 1.8s var(--ease2) infinite}
@keyframes scrolldn{0%{top:-100%}60%,100%{top:100%}}
@media (max-width:1024px){.hero__scroll{display:none}}

/* =================================================================
   MARQUEE
   ================================================================= */
.marquee{background:var(--ink);color:var(--paper);padding:18px 0;overflow:hidden;white-space:nowrap;border-top:2px solid var(--ink);border-bottom:2px solid var(--ink)}
.marquee__row{display:inline-flex;gap:42px;align-items:center;will-change:transform;animation:marq 26s linear infinite}
.marquee:hover .marquee__row{animation-play-state:paused}
.marquee__row span{font-family:var(--display);font-weight:700;font-size:clamp(26px,4vw,48px);letter-spacing:-.01em;text-transform:uppercase;display:inline-flex;align-items:center;gap:42px}
.marquee__row span i{color:var(--yellow);font-style:normal}
.marquee__row span:nth-child(even){-webkit-text-stroke:1.4px var(--paper);color:transparent}
@keyframes marq{to{transform:translateX(-50%)}}

/* =================================================================
   ABOUT
   ================================================================= */
.about{display:grid;grid-template-columns:.85fr 1fr;gap:clamp(30px,6vw,90px);align-items:center;padding:clamp(70px,11vw,150px) var(--pad);max-width:var(--maxw);margin:0 auto}
.about__media{position:relative}
.about__media>img{width:100%;border-radius:var(--r);aspect-ratio:4/5;object-fit:cover}
.about__media2{position:absolute;width:46%;bottom:-9%;right:-7%;border:8px solid var(--paper);transform:rotate(5deg);box-shadow:0 20px 50px -18px rgba(0,0,0,.4)}
.about__blob{position:absolute;width:42%;top:-12%;left:-12%;fill:var(--yellow);z-index:-1;animation:morph 9s ease-in-out infinite}
@keyframes morph{0%,100%{transform:rotate(0) scale(1)}50%{transform:rotate(20deg) scale(1.08)}}
.about__h{font-family:var(--display);font-weight:800;font-size:clamp(36px,6vw,76px);letter-spacing:-.03em;line-height:1;margin:14px 0 22px}
.about__h .hand{color:var(--acc);font-size:1.15em}
.about__h .wave{display:inline-block;transform-origin:70% 70%;animation:wave 2.4s ease-in-out infinite}
@keyframes wave{0%,60%,100%{transform:rotate(0)}10%,30%{transform:rotate(16deg)}20%{transform:rotate(-8deg)}}
.about__p{font-size:clamp(16px,1.5vw,19px);max-width:54ch;margin-bottom:16px;color:var(--ink-2)}
.about__p em{font-family:var(--hand);font-size:1.35em;font-style:normal;color:var(--acc)}
.about__facts{list-style:none;display:grid;grid-template-columns:repeat(4,auto);gap:clamp(16px,3vw,40px);margin:30px 0}
.about__facts li{display:flex;flex-direction:column}
.about__facts b{font-family:var(--display);font-weight:800;font-size:clamp(34px,5vw,56px);line-height:1;letter-spacing:-.02em}
.about__facts li:nth-child(1) b{color:var(--red)}
.about__facts li:nth-child(2) b{color:var(--blue)}
.about__facts li:nth-child(3) b{color:var(--purple)}
.about__facts li:nth-child(4) b{color:var(--teal)}
.about__facts span{font-size:13px;color:var(--muted);margin-top:4px;text-transform:uppercase;letter-spacing:.06em}
.about__skills{display:flex;flex-wrap:wrap;gap:9px}
.about__skills .pill{border:1.5px solid color-mix(in srgb,var(--ink) 22%,transparent);padding:7px 15px;border-radius:30px;font-size:14px;font-weight:500;transition:background .25s,color .25s,border-color .25s}
.about__skills .pill:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* =================================================================
   PILARES
   ================================================================= */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--ink);border-top:2px solid var(--ink);border-bottom:2px solid var(--ink)}
.pillar{--c:var(--red);background:var(--paper);padding:clamp(34px,4vw,64px) clamp(26px,3vw,48px);position:relative;overflow:hidden;transition:background .4s,color .4s;min-height:46vh;display:flex;flex-direction:column;justify-content:space-between}
.pillar[data-acc=blue]{--c:var(--blue)}
.pillar[data-acc=purple]{--c:var(--purple)}
.pillar::before{content:"";position:absolute;inset:0;background:var(--c);transform:translateY(101%);transition:transform .5s var(--ease2);z-index:0}
.pillar:hover,.pillar:focus-visible{color:var(--paper)}
.pillar:hover::before,.pillar:focus-visible::before{transform:translateY(0)}
.pillar>*{position:relative;z-index:1}
.pillar__n{font-family:var(--hand);font-size:28px;color:var(--c);transition:color .3s}
.pillar:hover .pillar__n{color:var(--paper)}
.pillar h3{font-family:var(--display);font-weight:800;font-size:clamp(30px,3.4vw,52px);line-height:.96;letter-spacing:-.02em;margin:6px 0 16px}
.pillar p{font-size:16px;max-width:34ch;color:var(--ink-2);transition:color .3s;margin-bottom:24px}
.pillar:hover p{color:color-mix(in srgb,var(--paper) 88%,transparent)}
.pillar__link{font-weight:600;align-self:flex-start;border-bottom:2px solid currentColor;padding-bottom:3px}

/* =================================================================
   OBRA / GALERÍA
   ================================================================= */
.obra{padding:clamp(70px,10vw,140px) var(--pad);max-width:var(--maxw);margin:0 auto}
.obra__head{margin-bottom:38px}
.obra__head .section-h{margin:6px 0 26px}
.filters,.shop-tabs{display:flex;flex-wrap:wrap;gap:10px}
.chip{
  border:1.6px solid color-mix(in srgb,var(--ink) 20%,transparent);
  padding:9px 18px;border-radius:30px;font-weight:600;font-size:14.5px;
  transition:background .25s,color .25s,border-color .25s,transform .25s var(--ease2);
}
.chip:hover{transform:translateY(-2px)}
.chip.is-on{background:var(--ink);color:var(--paper);border-color:var(--ink)}

.gallery{columns:4;column-gap:18px;margin-top:8px}
.card{
  break-inside:avoid;margin-bottom:18px;position:relative;border-radius:14px;overflow:hidden;
  background:var(--paper-2);cursor:pointer;
  opacity:0;transform:translateY(26px) scale(.98);transition:opacity .6s var(--ease2),transform .6s var(--ease2),box-shadow .4s;
}
.card.in{opacity:1;transform:none}
.card:hover{box-shadow:0 26px 50px -22px rgba(0,0,0,.5)}
.card img{width:100%;transition:transform .7s var(--ease2)}
.card:hover img{transform:scale(1.05)}
.card__meta{
  position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;
  padding:18px;color:#fff;background:linear-gradient(transparent 45%,rgba(0,0,0,.72));
  opacity:0;transition:opacity .4s;
}
.card:hover .card__meta{opacity:1}
.card__title{font-family:var(--display);font-weight:700;font-size:23px;line-height:1;display:block}
.card__meta p{font-size:13px;opacity:.85;margin-top:3px}
.card__tag{position:absolute;top:12px;left:12px;background:var(--acc-ink);color:#fff;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:5px 11px;border-radius:20px;opacity:0;transform:translateY(-6px);transition:opacity .3s,transform .3s}
.card:hover .card__tag{opacity:1;transform:none}
.card__plus{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.16);backdrop-filter:blur(4px);display:grid;place-items:center;color:#fff;font-size:18px;opacity:0;transition:opacity .3s}
.card:hover .card__plus{opacity:1}

/* =================================================================
   TIENDA
   ================================================================= */
.tienda{background:var(--paper-2);border-top:2px solid var(--ink);padding:clamp(70px,10vw,140px) var(--pad)}
.tienda__head{max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap}
.tienda__head .section-h{margin-top:6px}
.tienda__head .hand{color:var(--acc);font-size:1.1em}
.tienda__note{max-width:40ch;font-size:15px;color:var(--ink-2)}
.tienda__note a{color:var(--acc-ink);font-weight:600;border-bottom:1.5px solid currentColor}
.shop-tabs{max-width:var(--maxw);margin:26px auto 0}
.shop{max-width:var(--maxw);margin:30px auto 0;display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.prod{
  background:var(--paper);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;
  border:1.5px solid color-mix(in srgb,var(--ink) 9%,transparent);
  transition:transform .4s var(--ease2),box-shadow .4s;
  opacity:0;transform:translateY(26px);
}
.prod.in{opacity:1;transform:none}
.prod:hover{transform:translateY(-6px);box-shadow:0 24px 44px -22px rgba(0,0,0,.4)}
.prod__img{position:relative;overflow:hidden;aspect-ratio:1}
.prod__img img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease2)}
.prod:hover .prod__img img{transform:scale(1.06)}
.prod__kind{position:absolute;top:11px;left:11px;background:var(--ink);color:var(--paper);font-size:10.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:5px 10px;border-radius:18px}
.prod__body{padding:16px 16px 18px;display:flex;flex-direction:column;gap:5px;flex:1}
.prod__name{font-family:var(--display);font-weight:700;font-size:20px;line-height:1}
.prod__type{font-size:13px;color:var(--muted)}
.prod__note{font-size:13px;color:var(--ink-2);flex:1}
.prod__foot{display:flex;align-items:center;justify-content:space-between;margin-top:10px;gap:10px}
.prod__price{font-family:var(--display);font-weight:700;font-size:19px}
.prod__price small{font-weight:400;font-size:12px;color:var(--muted)}
.prod__btn{background:var(--acc-ink);color:#fff;font-weight:600;font-size:13.5px;padding:9px 15px;border-radius:30px;transition:transform .25s var(--ease2),background .25s;white-space:nowrap}
.prod__btn:hover{transform:scale(1.05);background:var(--ink)}

/* =================================================================
   ENCARGOS (sección oscura)
   ================================================================= */
.encargos{position:relative;background:var(--ink);color:var(--paper);padding:clamp(70px,10vw,150px) var(--pad);overflow:hidden}
.encargos .kicker{color:var(--yellow)}
.encargos__doodles{position:absolute;inset:0;pointer-events:none;opacity:.5}
.encargos__head{position:relative;max-width:var(--maxw);margin:0 auto;z-index:1}
.encargos__head .section-h{margin:6px 0 18px}
.encargos__lead{max-width:54ch;font-size:clamp(16px,1.6vw,20px);color:color-mix(in srgb,var(--paper) 80%,transparent)}
.encargos__lead strong{color:var(--yellow)}
.steps{list-style:none;position:relative;z-index:1;max-width:var(--maxw);margin:48px auto;display:grid;grid-template-columns:repeat(3,1fr);gap:24px;counter-reset:s}
.steps li{border-top:2px solid color-mix(in srgb,var(--paper) 22%,transparent);padding-top:18px}
.steps span{font-family:var(--hand);font-size:30px;color:var(--yellow)}
.steps h4{font-family:var(--display);font-weight:700;font-size:23px;margin:6px 0 8px}
.steps p{font-size:15px;color:color-mix(in srgb,var(--paper) 72%,transparent)}

/* =================================================================
   FORMULARIOS
   ================================================================= */
.form{position:relative;z-index:1}
.form--encargo{max-width:var(--maxw);margin:0 auto;background:color-mix(in srgb,var(--paper) 7%,transparent);border:1.5px solid color-mix(in srgb,var(--paper) 16%,transparent);border-radius:24px;padding:clamp(24px,4vw,46px)}
.form__grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:8px}
.field--full{grid-column:1/-1}
.field>span{font-size:13.5px;font-weight:600;letter-spacing:.02em}
.field>span i{font-weight:400;font-style:normal;opacity:.6}
.field input,.field select,.field textarea{
  font-family:inherit;font-size:16px;color:inherit;
  background:color-mix(in srgb,var(--paper) 10%,transparent);
  border:1.5px solid color-mix(in srgb,var(--paper) 22%,transparent);
  border-radius:12px;padding:13px 15px;transition:border-color .25s,background .25s;
}
.encargos .field input,.encargos .field select,.encargos .field textarea{color:var(--paper)}
.encargos .field input::placeholder,.encargos .field textarea::placeholder{color:color-mix(in srgb,var(--paper) 45%,transparent)}
.field select option{color:#000}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--yellow);background:color-mix(in srgb,var(--paper) 16%,transparent)}
.field input:focus-visible,.field select:focus-visible,.field textarea:focus-visible{outline:3px solid var(--blue);outline-offset:2px}
.field input.is-error,.field select.is-error,.field textarea.is-error{border-color:var(--red);box-shadow:0 0 0 3px color-mix(in srgb,var(--red) 20%,transparent)}
.field textarea{resize:vertical;min-height:90px}
.form__send{display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-top:24px}
.encargos .btn--ink{background:var(--yellow);color:var(--ink)}
.encargos .btn--ink:hover{background:var(--paper)}
.form__hint{font-size:13.5px;color:color-mix(in srgb,var(--paper) 65%,transparent)}
.form__hint a{color:var(--yellow);border-bottom:1px solid currentColor}

/* =================================================================
   CONTACTO
   ================================================================= */
.contacto{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,90px);padding:clamp(70px,10vw,140px) var(--pad);max-width:var(--maxw);margin:0 auto;align-items:start}
.contacto__l .section-h{margin:8px 0 18px}
.contacto__l .hand{color:var(--acc)}
.contacto__p{font-size:18px;color:var(--ink-2);max-width:36ch;margin-bottom:26px}
.contacto__links{list-style:none;display:flex;flex-direction:column;gap:2px}
.contacto__links a{display:flex;align-items:center;justify-content:space-between;gap:14px;min-width:0;overflow-wrap:anywhere;padding:18px 4px;border-top:1.5px solid color-mix(in srgb,var(--ink) 14%,transparent);font-family:var(--display);font-weight:600;font-size:clamp(18px,2.4vw,28px);transition:padding .3s var(--ease2),color .3s}
.contacto__links a:last-child{border-bottom:1.5px solid color-mix(in srgb,var(--ink) 14%,transparent)}
.contacto__links a:hover{padding-left:18px;color:var(--acc)}
.contacto__links a i{font-style:normal;font-family:var(--body);font-size:14px;color:var(--muted);transition:transform .3s var(--ease2)}
.contacto__links a:hover i{transform:translateX(6px);color:var(--acc)}
.form--contacto{display:flex;flex-direction:column;gap:18px;background:var(--paper-2);border-radius:24px;padding:clamp(24px,4vw,42px);border:1.5px solid color-mix(in srgb,var(--ink) 9%,transparent)}
.form--contacto .field input,.form--contacto .field select,.form--contacto .field textarea{background:var(--paper);border-color:color-mix(in srgb,var(--ink) 16%,transparent)}
.form--contacto .field input:focus,.form--contacto .field select:focus,.form--contacto .field textarea:focus{border-color:var(--acc)}

/* =================================================================
   FOOTER
   ================================================================= */
.footer{background:var(--ink);color:var(--paper);padding:clamp(50px,7vw,90px) var(--pad) 30px;overflow:hidden}
.footer__big{display:flex;gap:40px;white-space:nowrap;overflow:hidden;opacity:.92;margin-bottom:30px}
.footer__big span{font-family:var(--display);font-weight:800;font-size:clamp(60px,15vw,200px);letter-spacing:-.04em;-webkit-text-stroke:1.5px var(--paper);color:transparent;animation:marq 18s linear infinite}
.footer__row{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;padding:30px 0;border-top:1.5px solid color-mix(in srgb,var(--paper) 18%,transparent)}
.footer__mail{font-family:var(--display);font-weight:700;font-size:clamp(22px,4vw,46px);letter-spacing:-.02em;overflow-wrap:anywhere;transition:color .3s}
.footer__mail:hover{color:var(--yellow)}
.footer__social{display:flex;gap:10px;flex-wrap:wrap}
.footer__social a{border:1.5px solid color-mix(in srgb,var(--paper) 30%,transparent);padding:10px 18px;border-radius:30px;font-size:14px;font-weight:500;transition:background .25s,color .25s}
.footer__social a:hover{background:var(--yellow);color:var(--ink);border-color:var(--yellow)}
.footer__base{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13px;color:color-mix(in srgb,var(--paper) 60%,transparent);padding-top:24px}
.footer__top:hover{color:var(--yellow)}

/* =================================================================
   LIGHTBOX
   ================================================================= */
.lightbox{position:fixed;inset:0;z-index:1000;background:color-mix(in srgb,var(--ink) 94%,transparent);backdrop-filter:blur(8px);display:grid;place-items:center;opacity:0;pointer-events:none;transition:opacity .4s}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox__fig{max-width:min(90vw,900px);max-height:86vh;display:flex;flex-direction:column;gap:14px;transform:scale(.94);transition:transform .5s var(--ease2)}
.lightbox.open .lightbox__fig{transform:none}
.lightbox__fig img{max-height:74vh;width:auto;margin:0 auto;border-radius:8px;box-shadow:0 30px 80px -20px rgba(0,0,0,.6)}
.lightbox__fig figcaption{color:var(--paper);text-align:center}
.lightbox__fig figcaption b{font-family:var(--display);font-weight:700;font-size:22px;display:block}
.lightbox__fig figcaption span{font-size:13px;opacity:.7}
.lightbox__close,.lightbox__nav{position:absolute;color:var(--paper);width:52px;height:52px;border-radius:50%;border:1.5px solid color-mix(in srgb,var(--paper) 30%,transparent);display:grid;place-items:center;font-size:22px;transition:background .25s,color .25s}
.lightbox__close:hover,.lightbox__nav:hover{background:var(--paper);color:var(--ink)}
.lightbox__close{top:22px;right:22px}
.lightbox__nav{top:50%;transform:translateY(-50%)}
.lightbox__prev{left:22px}.lightbox__next{right:22px}

/* toast */
.toast{position:fixed;left:50%;bottom:28px;transform:translate(-50%,140%);z-index:1100;background:var(--ink);color:var(--paper);padding:15px 24px;border-radius:40px;font-weight:500;font-size:15px;box-shadow:0 18px 40px -14px rgba(0,0,0,.5);transition:transform .5s var(--ease2);max-width:90vw;text-align:center}
.toast.show{transform:translateX(-50%)}
.toast b{color:var(--yellow)}

/* =================================================================
   RESPONSIVE
   ================================================================= */
@media (max-width:1200px){ .gallery{columns:3} .shop{grid-template-columns:repeat(3,1fr)} }
@media (max-width:1024px){
  .nav__links{display:none}
  .nav__burger{display:flex}
  .about{grid-template-columns:1fr;gap:60px}
  .about__media{max-width:440px}
  .pillars{grid-template-columns:1fr}
  .pillar{min-height:auto}
  .hero__feature{grid-template-columns:1fr;align-items:start}
  .hero__actions{grid-column:1}
  .contacto{grid-template-columns:1fr}
}
@media (max-width:760px){
  .hero__feature>*{min-width:0;max-width:100%}
  .hero__lead{max-width:100%}
  .hero__title{font-size:clamp(58px,16vw,120px)}
  .gallery{columns:2;column-gap:12px}
  .card{margin-bottom:12px}
  .shop{grid-template-columns:repeat(2,1fr);gap:13px}
  .form__grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr;gap:14px}
  .tienda__head{flex-direction:column;align-items:flex-start;gap:16px}
  .hero__feature{gap:22px}
  .about__facts{grid-template-columns:repeat(2,1fr)}
  .marquee__row span{font-size:30px}
}
@media (max-width:430px){
  .gallery{columns:1}
  .shop{grid-template-columns:1fr}
  .nav__logo-txt{display:none}
}

/* =================================================================
   AJUSTES FINOS (post-revisión)
   ================================================================= */
/* skip link */
.skip-link{position:absolute;left:10px;top:-60px;z-index:9999;background:var(--ink);color:#fff;
  padding:10px 16px;border-radius:8px;font-weight:600;transition:top .2s var(--ease2)}
.skip-link:focus{top:10px}
#main{outline:none}

/* lightbox: fade de imagen + contador */
#lbImg{opacity:0;transition:opacity .35s var(--ease2)}
.lightbox__count{color:var(--paper);text-align:center;font-size:13px;opacity:.6;letter-spacing:.04em}

/* galería: estado vacío */
.gallery__empty{column-span:all;text-align:center;padding:60px 20px;display:flex;flex-direction:column;align-items:center;gap:16px}
.gallery__star{font-size:38px;color:var(--yellow)}
.gallery__empty p{font-size:18px;color:var(--ink-2);max-width:30ch}
.gallery__empty-cta{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}

/* about: contener decorativos en pantallas chicas */
@media (max-width:760px){
  .about__blob{display:none}
  .about__media2{right:0;width:42%}
}

/* targets táctiles cómodos en dispositivos touch */
@media (pointer:coarse){
  .chip{padding:12px 18px}
  .prod__btn{min-height:44px;display:inline-flex;align-items:center;justify-content:center;padding:0 18px}
  .nav__burger{width:46px;height:46px}
  .menu__foot a{padding:8px 4px}
  .footer__social a{padding:12px 18px}
}

/* =================================================================
   PREMIUM PASS (v3) — estudio, rotador, meta, números, mobile bar
   ================================================================= */

/* hero: meta editorial + rotador de roles */
.hero__meta{position:absolute;top:118px;right:var(--pad);z-index:2;display:flex;flex-direction:column;align-items:flex-end;gap:3px;
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);text-align:right}
@media (max-width:1024px){.hero__meta{display:none}}
.rotator{display:inline-block;height:1.25em;overflow:hidden;vertical-align:bottom;position:relative;color:var(--acc-ink);font-weight:600}
.rotator__track{display:flex;flex-direction:column}
.rotator__track span{height:1.25em;line-height:1.25em;white-space:nowrap}
@media (prefers-reduced-motion:no-preference){.rotator__track{animation:rotate 9s cubic-bezier(.7,0,.3,1) infinite}}
@keyframes rotate{
  0%,17%{transform:translateY(0)}
  25%,42%{transform:translateY(-1.25em)}
  50%,67%{transform:translateY(-2.5em)}
  75%,92%{transform:translateY(-3.75em)}
  100%{transform:translateY(-5em)}
}

/* número de sección (marca de agua) */
[data-num]{position:relative}
[data-num]::before{content:attr(data-num);position:absolute;top:clamp(24px,4vw,54px);right:clamp(12px,4vw,40px);
  font-family:var(--display);font-weight:800;font-size:clamp(56px,9vw,150px);line-height:1;color:currentColor;opacity:.05;pointer-events:none;z-index:0}
.about>*,.obra>*,.tienda>*,.estudio>*,.encargos>*,.contacto>*{position:relative;z-index:1}
@media (max-width:760px){[data-num]::before{font-size:clamp(44px,14vw,80px);top:18px}}

/* scroll-spy nav */
.nav__links a.is-active:not(.nav__cta){color:var(--acc-ink)}
.nav__links a.is-active:not(.nav__cta)::after{transform:scaleX(1)}

/* =================================================================
   ESTUDIO · Diseño & Contenido
   ================================================================= */
.estudio{padding:clamp(70px,10vw,150px) var(--pad);max-width:var(--maxw);margin:0 auto}
.estudio__head{max-width:860px;margin-bottom:clamp(38px,5vw,64px)}
.estudio__head .section-h{margin:6px 0 22px}
.estudio__head .hand{color:var(--acc)}
.estudio__lead{font-size:clamp(17px,1.7vw,21px);color:var(--ink-2);max-width:62ch}
.estudio__lead strong{color:var(--acc-ink)}
.estudio__services{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,44px)}
.svc{border-top:2px solid var(--ink);padding-top:16px;opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease2),transform .7s var(--ease2)}
.svc.in{opacity:1;transform:none}
.svc__n{font-family:var(--hand);font-size:28px;line-height:1;color:var(--c,var(--acc))}
.svc:nth-child(1){--c:var(--red)}.svc:nth-child(2){--c:var(--blue)}.svc:nth-child(3){--c:var(--purple)}.svc:nth-child(4){--c:var(--teal)}
.svc h3{font-family:var(--display);font-weight:700;font-size:clamp(19px,1.5vw,23px);margin:10px 0 10px;line-height:1.05}
.svc p{font-size:14.5px;color:var(--ink-2)}
.estudio__brands{margin-top:clamp(46px,6vw,84px)}
.estudio__brands-label{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.estudio__marquee{overflow:hidden;margin-top:16px;border-top:1.5px solid color-mix(in srgb,var(--ink) 16%,transparent);border-bottom:1.5px solid color-mix(in srgb,var(--ink) 16%,transparent);padding:16px 0}
.estudio__brands-row{display:inline-flex;gap:clamp(28px,5vw,60px);white-space:nowrap;font-family:var(--display);font-weight:800;letter-spacing:-.01em;
  font-size:clamp(26px,4vw,48px);will-change:transform}
@media (prefers-reduced-motion:no-preference){.estudio__brands-row{animation:marq 26s linear infinite}}
.estudio__brands-row span{color:var(--ink)}
.estudio__brands-row span:nth-child(even){-webkit-text-stroke:1.5px var(--ink);color:transparent}
.estudio__brands-row i{font-style:normal;color:var(--acc)}
.estudio__cta{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  margin-top:clamp(40px,6vw,74px);padding-top:30px;border-top:1.5px solid color-mix(in srgb,var(--ink) 16%,transparent)}
.estudio__cta p{font-family:var(--display);font-weight:700;font-size:clamp(22px,3vw,38px);letter-spacing:-.02em;max-width:20ch}
@media (max-width:900px){.estudio__services{grid-template-columns:repeat(2,1fr);gap:30px}}
@media (max-width:460px){.estudio__services{grid-template-columns:1fr}}

/* =================================================================
   BARRA CTA MOBILE
   ================================================================= */
.mobilebar{position:fixed;left:0;right:0;bottom:0;z-index:840;display:none;gap:10px;
  padding:11px 14px calc(11px + env(safe-area-inset-bottom));
  background:color-mix(in srgb,var(--paper) 88%,transparent);backdrop-filter:blur(12px);
  border-top:1px solid color-mix(in srgb,var(--ink) 14%,transparent);
  transform:translateY(130%);transition:transform .4s var(--ease2)}
.mobilebar.show{transform:none}
.mobilebar__btn{flex:1;text-align:center;padding:14px 10px;border-radius:40px;font-weight:600;font-size:15.5px;border:1.8px solid var(--ink);min-height:48px;display:flex;align-items:center;justify-content:center}
.mobilebar__btn--primary{background:var(--ink);color:var(--paper)}
@media (max-width:760px){
  .mobilebar{display:flex}
  .footer{padding-bottom:96px}
}
.menu.open ~ .mobilebar,.mobilebar.hidden{transform:translateY(130%)!important}

/* estado de éxito de formularios */
.form__ok{max-width:var(--maxw);margin:0 auto;text-align:center;padding:clamp(40px,6vw,72px) 24px;
  border:1.5px solid color-mix(in srgb,currentColor 22%,transparent);border-radius:24px;
  display:flex;flex-direction:column;align-items:center;gap:12px;position:relative;z-index:1}
.form__ok-star{font-size:44px;color:var(--yellow);display:inline-block}
@media (prefers-reduced-motion:no-preference){.form__ok-star{animation:spin 5s linear infinite}}
.form__ok b{font-family:var(--display);font-weight:800;font-size:clamp(28px,4vw,46px);letter-spacing:-.02em}
.form__ok p{opacity:.82;max-width:32ch}
