/* ============================================================
   MIMO · BOUTIQUE — Hoja de estilos compartida
   Estilo: moda minimal, alto contraste (blanco/negro + nude)
   Diseño de concepto · Saudade Agency
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Jost:wght@300;400;500;600&family=Cormorant+Garamond:ital,wght@0,400;0,500;1,400&display=swap');

:root{
  --negro:#0c0c0c;
  --tinta:#1a1a1a;
  --gris:#6b6b6b;
  --gris-claro:#a9a9a9;
  --linea:#e7e4df;
  --blanco:#ffffff;
  --hueso:#faf9f7;
  --nude:#cbb6a4;
  --nude-claro:#efe7df;
  --arena:#f4efe9;
  --sans:'Jost',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --serif:'Cormorant Garamond',Georgia,serif;
  --ancho:1280px;
  --transi:.45s cubic-bezier(.22,.61,.36,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--tinta);
  background:var(--blanco);
  line-height:1.6;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

.wrap{max-width:var(--ancho);margin:0 auto;padding:0 40px}

/* ---------- Tipografía ---------- */
h1,h2,h3{font-weight:400;line-height:1.1;letter-spacing:.01em}
.eyebrow{
  font-size:.7rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--nude);font-weight:500;
}
.serif{font-family:var(--serif)}

/* ---------- Imagen con placeholder/fallback ---------- */
.ph{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--arena),var(--nude-claro));
}
.ph img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.1s cubic-bezier(.22,.61,.36,1),opacity .6s;
}

/* ============================================================
   NAVBAR
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(255,255,255,.9);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--linea);
}
.nav-inner{
  max-width:var(--ancho);margin:0 auto;padding:0 40px;
  height:74px;display:flex;align-items:center;justify-content:space-between;
}
.logo{
  font-size:1.5rem;letter-spacing:.42em;font-weight:500;
  text-transform:uppercase;padding-left:.42em;
}
.nav-links{display:flex;align-items:center;gap:42px;list-style:none}
.nav-links a{
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  font-weight:400;color:var(--tinta);position:relative;padding:6px 0;
  transition:color .3s;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:0;
  background:var(--negro);transition:width .4s var(--transi);
}
.nav-links a:hover::after,.nav-links a.activo::after{width:100%}
.nav-links a.activo{font-weight:500}
.bolsa{
  display:flex;align-items:center;gap:7px;
  font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
}
.bolsa svg{width:18px;height:18px;stroke:var(--tinta);fill:none;stroke-width:1.2}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:26px;height:1.5px;background:var(--negro);transition:.35s}
.burger.abierto span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.abierto span:nth-child(2){opacity:0}
.burger.abierto span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ============================================================
   BOTONES
   ============================================================ */
.btn{
  display:inline-block;font-size:.72rem;letter-spacing:.24em;
  text-transform:uppercase;font-weight:500;padding:17px 42px;
  border:1px solid var(--negro);background:var(--negro);color:#fff;
  cursor:pointer;transition:.4s var(--transi);
}
.btn:hover{background:#fff;color:var(--negro)}
.btn.ghost{background:transparent;color:var(--negro)}
.btn.ghost:hover{background:var(--negro);color:#fff}

/* ============================================================
   HERO (index)
   ============================================================ */
.hero{padding-top:74px}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;min-height:88vh}
.hero-txt{
  display:flex;flex-direction:column;justify-content:center;
  padding:80px 80px 80px 0;
}
.hero-txt .eyebrow{margin-bottom:28px}
.hero-txt h1{
  font-size:clamp(2.8rem,5vw,4.6rem);font-weight:300;
  letter-spacing:-.01em;margin-bottom:26px;
}
.hero-txt h1 em{font-family:var(--serif);font-weight:400}
.hero-txt p{color:var(--gris);max-width:420px;margin-bottom:40px;font-size:1.02rem}
.hero-img{position:relative}
.hero-img .ph{position:absolute;inset:0}
.hero-tag{
  position:absolute;bottom:28px;left:28px;z-index:2;
  background:#fff;padding:10px 18px;font-size:.66rem;
  letter-spacing:.2em;text-transform:uppercase;
}

/* ============================================================
   TIRA DE CATEGORÍAS
   ============================================================ */
.cats{padding:110px 0}
.cats-head{text-align:center;margin-bottom:60px}
.cats-head h2{font-size:2.2rem;font-weight:300;margin-top:14px}
.cats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.cat-card{display:block;position:relative}
.cat-card .ph{aspect-ratio:3/4}
.cat-card .ph img{transition:transform 1.1s var(--transi)}
.cat-card:hover .ph img{transform:scale(1.05)}
.cat-name{
  position:absolute;left:0;right:0;bottom:0;
  background:linear-gradient(transparent,rgba(0,0,0,.55));
  color:#fff;padding:26px 20px 20px;text-align:center;
}
.cat-name span{font-size:.78rem;letter-spacing:.26em;text-transform:uppercase}
.cat-name small{display:block;font-size:.62rem;letter-spacing:.18em;opacity:.8;margin-top:6px}

/* ============================================================
   REJILLA DE PRODUCTOS (novedades / tienda)
   ============================================================ */
.section{padding:100px 0}
.section.alt{background:var(--hueso)}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:48px}
.sec-head h2{font-size:2.2rem;font-weight:300}
.sec-head .eyebrow{margin-bottom:12px}
.sec-head a{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;border-bottom:1px solid var(--negro);padding-bottom:3px}

.grid-prod{display:grid;grid-template-columns:repeat(4,1fr);gap:30px 26px}
.card{display:block;position:relative}
.card .ph{aspect-ratio:3/4;margin-bottom:16px}
.card .img-b{position:absolute;inset:0;opacity:0;transition:opacity .7s var(--transi)}
.card:hover .img-b{opacity:1}
.card:hover .img-a{transform:scale(1.04)}
.card .tag{
  position:absolute;top:14px;left:14px;z-index:3;
  background:#fff;font-size:.58rem;letter-spacing:.18em;
  text-transform:uppercase;padding:6px 11px;
}
.card .tag.negro{background:var(--negro);color:#fff}
.card .quick{
  position:absolute;left:14px;right:14px;bottom:80px;z-index:3;
  background:#fff;text-align:center;padding:13px;
  font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;
  opacity:0;transform:translateY(10px);transition:.45s var(--transi);
  font-weight:500;
}
.card:hover .quick{opacity:1;transform:translateY(0)}
.card h3{font-size:.95rem;font-weight:400;letter-spacing:.02em}
.card .marca{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gris-claro);margin-bottom:5px}
.card .precio{font-size:.92rem;color:var(--tinta);margin-top:5px}
.card .precio s{color:var(--gris-claro);margin-right:8px;font-size:.82rem}
.card .precio .off{color:var(--nude)}

/* ============================================================
   FRANJA DE VALORES / MARCA
   ============================================================ */
.valores{background:var(--negro);color:#fff;padding:90px 0}
.valores-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:50px;text-align:center}
.valores .vi{}
.valores .vi h3{font-size:1.1rem;letter-spacing:.06em;margin-bottom:12px;font-weight:400}
.valores .vi .num{font-family:var(--serif);font-size:2rem;color:var(--nude);display:block;margin-bottom:14px}
.valores .vi p{color:var(--gris-claro);font-size:.9rem}

/* ============================================================
   BLOQUE MANIFIESTO / INSTAGRAM
   ============================================================ */
.manifiesto{padding:120px 0;text-align:center}
.manifiesto p{
  font-family:var(--serif);font-size:clamp(1.6rem,3.5vw,2.6rem);
  font-weight:400;max-width:880px;margin:0 auto;line-height:1.35;color:var(--tinta);
}
.manifiesto .eyebrow{margin-bottom:30px}

.insta{padding:0 0 110px}
.insta-head{text-align:center;margin-bottom:44px}
.insta-head h2{font-size:1.9rem;font-weight:300;margin-top:12px}
.insta-head a{color:var(--nude);border-bottom:1px solid var(--nude);font-size:.95rem}
.insta-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}
.insta-grid .ph{aspect-ratio:1}
.insta-grid .ph img{transition:transform .8s var(--transi),opacity .6s}
.insta-grid .ph:hover img{transform:scale(1.08)}

/* ============================================================
   CABECERA DE PÁGINA (tienda / contacto)
   ============================================================ */
.pagehead{padding:140px 0 50px;text-align:center;border-bottom:1px solid var(--linea)}
.pagehead h1{font-size:clamp(2.4rem,5vw,3.6rem);font-weight:300}
.pagehead h1 em{font-family:var(--serif)}
.pagehead p{color:var(--gris);margin-top:14px;max-width:520px;margin-left:auto;margin-right:auto}
.breadcrumb{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gris-claro);margin-bottom:18px}
.breadcrumb a:hover{color:var(--tinta)}

/* ============================================================
   FILTROS (chips) — tienda
   ============================================================ */
.tienda-bar{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:20px;padding:34px 0;border-bottom:1px solid var(--linea);
}
.chips{display:flex;gap:10px;flex-wrap:wrap}
.chip{
  font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;
  padding:10px 22px;border:1px solid var(--linea);background:#fff;
  cursor:pointer;transition:.3s;color:var(--gris);
}
.chip:hover{border-color:var(--negro);color:var(--negro)}
.chip.activo{background:var(--negro);border-color:var(--negro);color:#fff}
.tienda-bar .cuenta{font-size:.72rem;letter-spacing:.14em;color:var(--gris)}

/* ============================================================
   FICHA DE PRODUCTO
   ============================================================ */
.producto{padding:120px 0 60px}
.prod-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:start}
.galeria{display:grid;grid-template-columns:74px 1fr;gap:16px}
.miniaturas{display:flex;flex-direction:column;gap:12px}
.mini{aspect-ratio:3/4;cursor:pointer;border:1px solid transparent;transition:.3s}
.mini.activa{border-color:var(--negro)}
.mini:hover{border-color:var(--nude)}
.principal{aspect-ratio:3/4}
.prod-info .marca{font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--nude);margin-bottom:14px}
.prod-info h1{font-size:2.3rem;font-weight:300;margin-bottom:16px}
.prod-info .precio{font-size:1.3rem;margin-bottom:8px}
.prod-info .precio s{color:var(--gris-claro);font-size:1rem;margin-right:12px}
.prod-info .iva{font-size:.74rem;color:var(--gris-claro);margin-bottom:28px}
.prod-info .desc{color:var(--gris);margin-bottom:34px;max-width:440px}
.opt-bloque{margin-bottom:28px}
.opt-bloque .label{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:13px;display:block}
.opt-bloque .label span{color:var(--gris-claro);margin-left:8px}
.tallas{display:flex;gap:10px}
.talla{
  width:50px;height:50px;border:1px solid var(--linea);background:#fff;
  cursor:pointer;font-size:.8rem;letter-spacing:.05em;transition:.3s;
  display:flex;align-items:center;justify-content:center;
}
.talla:hover{border-color:var(--negro)}
.talla.sel{background:var(--negro);color:#fff;border-color:var(--negro)}
.colores{display:flex;gap:12px}
.color{
  width:30px;height:30px;border-radius:50%;cursor:pointer;
  border:1px solid var(--linea);position:relative;transition:.3s;
}
.color.sel{box-shadow:0 0 0 2px #fff,0 0 0 3px var(--negro)}
.prod-acciones{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap}
.prod-acciones .btn{flex:1;min-width:200px;text-align:center}
.aviso{
  margin-top:22px;padding:15px 20px;background:var(--arena);
  border-left:2px solid var(--nude);font-size:.85rem;color:var(--tinta);
  display:none;
}
.aviso.show{display:block}
.prod-meta{margin-top:40px;border-top:1px solid var(--linea);padding-top:26px}
.prod-meta .fila{display:flex;justify-content:space-between;padding:10px 0;font-size:.84rem;border-bottom:1px solid var(--hueso)}
.prod-meta .fila span:first-child{color:var(--gris)}

/* ============================================================
   CONTACTO
   ============================================================ */
.contacto-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;padding:90px 0;align-items:start}
.contacto-info h2{font-size:1.6rem;font-weight:300;margin-bottom:24px}
.contacto-info .bloque{margin-bottom:32px}
.contacto-info .bloque h3{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--nude);margin-bottom:10px;font-weight:500}
.contacto-info .bloque p{color:var(--gris);font-size:.95rem}
.contacto-info .bloque a{border-bottom:1px solid var(--linea)}
.contacto-info .bloque a:hover{border-color:var(--negro)}
.redes{display:flex;gap:18px;margin-top:6px}
.redes a{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;border-bottom:1px solid var(--negro);padding-bottom:2px}

.form{background:var(--hueso);padding:48px}
.form h2{font-size:1.4rem;font-weight:300;margin-bottom:8px}
.form .sub{font-size:.88rem;color:var(--gris);margin-bottom:30px}
.campo{margin-bottom:22px}
.campo label{display:block;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:9px;color:var(--gris)}
.campo input,.campo select,.campo textarea{
  width:100%;padding:14px 16px;border:1px solid var(--linea);
  background:#fff;font-family:var(--sans);font-size:.92rem;font-weight:300;
  color:var(--tinta);transition:.3s;
}
.campo input:focus,.campo select:focus,.campo textarea:focus{outline:none;border-color:var(--negro)}
.campo textarea{resize:vertical;min-height:130px}
.form .btn{width:100%;border:0}
.form-ok{
  display:none;margin-top:20px;padding:16px 20px;
  background:var(--negro);color:#fff;font-size:.85rem;letter-spacing:.04em;
}
.form-ok.show{display:block}

.comprar{padding:0 0 100px}
.comprar-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.paso{}
.paso .num{font-family:var(--serif);font-size:2.4rem;color:var(--nude);display:block;margin-bottom:14px}
.paso h3{font-size:1.05rem;font-weight:400;margin-bottom:10px}
.paso p{color:var(--gris);font-size:.9rem}

.mapa{height:340px;border-top:1px solid var(--linea)}
.mapa .ph{height:100%;background:linear-gradient(135deg,#ecebe8,#f6f3ee)}
.mapa-tag{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  background:#fff;padding:14px 26px;text-align:center;z-index:2;
}
.mapa-tag span{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase}
.mapa-tag small{display:block;color:var(--gris);font-size:.8rem;margin-top:4px;letter-spacing:0;text-transform:none}

/* ============================================================
   PIE
   ============================================================ */
.foot{background:var(--negro);color:#fff;padding:80px 0 36px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:56px}
.foot .logo{color:#fff;margin-bottom:18px;display:inline-block}
.foot-col p,.foot-col li{color:var(--gris-claro);font-size:.88rem;line-height:1.9}
.foot-col h4{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:18px;color:#fff;font-weight:500}
.foot-col ul{list-style:none}
.foot-col a:hover{color:#fff}
.foot-bottom{
  border-top:1px solid #262626;padding-top:28px;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;
}
.foot-bottom small{color:var(--gris);font-size:.76rem;letter-spacing:.03em}
.foot-bottom .volver{color:var(--nude);font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;border-bottom:1px solid var(--nude);padding-bottom:2px}
.credito{
  text-align:center;font-size:.72rem;color:var(--gris);
  letter-spacing:.04em;margin-top:24px;line-height:1.7;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .grid-prod{grid-template-columns:repeat(3,1fr)}
  .cats-grid{grid-template-columns:repeat(2,1fr)}
  .insta-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:820px){
  .wrap,.nav-inner{padding:0 22px}
  .burger{display:flex}
  .nav-links{
    position:fixed;top:74px;left:0;right:0;
    background:#fff;flex-direction:column;align-items:flex-start;
    gap:0;padding:0 22px;border-bottom:1px solid var(--linea);
    max-height:0;overflow:hidden;transition:max-height .45s var(--transi);
  }
  .nav-links.abierto{max-height:340px}
  .nav-links li{width:100%;border-bottom:1px solid var(--hueso)}
  .nav-links a{display:block;padding:20px 0;width:100%}
  .nav-links .bolsa{padding:20px 0}

  .hero-grid{grid-template-columns:1fr}
  .hero-txt{padding:60px 0 56px;order:2}
  .hero-img{order:1;min-height:60vh}

  .cats-grid{grid-template-columns:1fr 1fr;gap:14px}
  .grid-prod{grid-template-columns:1fr 1fr;gap:24px 16px}
  .valores-grid{grid-template-columns:1fr;gap:38px}
  .insta-grid{grid-template-columns:repeat(3,1fr)}

  .section,.cats{padding:64px 0}
  .manifiesto{padding:76px 0}

  .prod-grid{grid-template-columns:1fr;gap:36px}
  .galeria{grid-template-columns:1fr}
  .miniaturas{flex-direction:row;order:2}
  .mini{width:70px}

  .contacto-grid{grid-template-columns:1fr;gap:48px;padding:56px 0}
  .form{padding:32px 24px}
  .comprar-grid{grid-template-columns:1fr;gap:34px}

  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
  .sec-head{flex-direction:column;align-items:flex-start;gap:14px}
  .foot-bottom{flex-direction:column;align-items:flex-start}
}
@media(max-width:480px){
  .foot-grid{grid-template-columns:1fr}
  .prod-acciones .btn{min-width:100%}
}
