/* HERO */
.rep-hero {
  position:relative; padding:5rem 3rem 4rem; overflow:hidden;
  background:
    linear-gradient(135deg, rgba(215,40,40,0.08) 0%, transparent 50%),
    repeating-linear-gradient(45deg, transparent, transparent 36px, rgba(255,255,255,0.015) 36px, rgba(255,255,255,0.015) 37px),
    var(--negro);
  border-bottom:1px solid var(--gris-borde);
}
.rep-hero::after {
  content:'RPT'; position:absolute; right:-1rem; top:50%; transform:translateY(-50%);
  font-family:var(--font-display); font-size:clamp(8rem,22vw,16rem);
  color:rgba(215,40,40,0.04); pointer-events:none; user-select:none; line-height:1;
}
.rep-hero-inner { max-width:600px; }
.rep-eyebrow { font-size:0.7rem; font-weight:700; letter-spacing:0.22em; text-transform:uppercase; color:var(--rojo); margin-bottom:0.65rem; display:block; }
.rep-hero h1 {
  font-family:var(--font-display); font-size:clamp(3rem,10vw,6rem);
  line-height:0.9; color:var(--blanco); margin-bottom:1rem; letter-spacing:0.02em;
}
.rep-sub { font-size:1rem; font-weight:300; color:var(--gris-muted); max-width:500px; line-height:1.7; margin-bottom:2rem; }
.rep-nota { font-size:0.78rem; color:var(--gris-sub); margin-top:0.75rem; font-style:italic; }
.rep-nota.centro { text-align:center; margin-top:1rem; }

/* BUSCADOR */
.rep-busqueda { background:var(--negro-card); border-bottom:1px solid var(--gris-borde); padding:2.5rem 2rem; }
.rep-busqueda-inner { max-width:860px; margin:0 auto; }
.rep-busqueda h2 { font-family:var(--font-display); font-size:clamp(1.5rem,4vw,2.2rem); color:var(--blanco); margin-bottom:1.25rem; letter-spacing:0.04em; }
.rep-filtros { display:grid; grid-template-columns:1fr 1fr 1fr auto; gap:0.75rem; }
.rep-filtros select,
.rep-filtros input {
  padding:0.65rem 1rem; background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.1); border-radius:var(--r-sm);
  color:var(--hueso); font-family:var(--font-body); font-size:0.85rem;
  outline:none; transition:border-color var(--t-fast);
  -webkit-appearance:none; appearance:none;
}
.rep-filtros select:focus, .rep-filtros input:focus { border-color:var(--rojo); }
.rep-filtros input::placeholder { color:var(--gris-muted); }
.rep-filtros select option { background:var(--negro-card); }
.btn-buscar {
  padding:0.65rem 1.4rem; background:var(--rojo); color:var(--blanco);
  font-family:var(--font-body); font-weight:700; font-size:0.82rem;
  letter-spacing:0.08em; text-transform:uppercase; border:none; border-radius:var(--r-sm);
  cursor:pointer; white-space:nowrap; transition:background var(--t-fast);
}
.btn-buscar:hover { background:var(--rojo-hover); }

/* CATEGORÍAS */
.rep-categorias { padding:3.5rem 2rem 4rem; max-width:1200px; margin:0 auto; }
.rep-categorias h2 { font-family:var(--font-display); font-size:clamp(1.8rem,5vw,2.5rem); color:var(--blanco); margin-bottom:2rem; letter-spacing:0.04em; }
.cat-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:1rem; }
.cat-card {
  display:flex; flex-direction:column; gap:0.5rem;
  padding:1.4rem 1.5rem; background:var(--negro-card);
  border:1px solid var(--gris-borde); border-radius:var(--r-lg);
  text-decoration:none; transition:transform var(--t-base), border-color var(--t-base), box-shadow var(--t-base);
  box-shadow:var(--shadow-card);
}
.cat-card:hover { transform:translateY(-3px); border-color:rgba(215,40,40,0.3); box-shadow:var(--shadow-hover); }
.cat-icon { font-size:1.6rem; line-height:1; margin-bottom:0.25rem; }
.cat-card h3 { font-family:var(--font-display); font-size:1.2rem; letter-spacing:0.04em; color:var(--blanco); }
.cat-card p { font-size:0.78rem; color:var(--gris-muted); line-height:1.45; }

/* MARCAS */
.rep-marcas { background:var(--negro-card); border-top:1px solid var(--gris-borde); border-bottom:1px solid var(--gris-borde); padding:2.5rem 2rem; }
.rep-marcas-inner { max-width:900px; margin:0 auto; text-align:center; }
.rep-marcas h2 { font-family:var(--font-display); font-size:clamp(1.5rem,4vw,2rem); color:var(--blanco); margin-bottom:1.5rem; letter-spacing:0.04em; }
.marcas-chips { display:flex; flex-wrap:wrap; gap:0.6rem; justify-content:center; margin-bottom:1rem; }
.chip {
  padding:0.35rem 1rem; background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.1); border-radius:20px;
  font-size:0.82rem; font-weight:500; color:var(--hueso);
  transition:border-color var(--t-fast), color var(--t-fast);
}
.chip:hover { border-color:var(--rojo); color:var(--blanco); }

/* CTA */
.rep-cta { padding:5rem 2rem; text-align:center; background:var(--negro-deep); }
.rep-cta-inner { max-width:560px; margin:0 auto; }
.rep-cta-inner h2 { font-family:var(--font-display); font-size:clamp(2rem,6vw,3.2rem); color:var(--blanco); margin-bottom:1rem; letter-spacing:0.04em; line-height:1; }
.rep-cta-inner p { font-size:0.95rem; font-weight:300; color:var(--gris-muted); line-height:1.7; margin-bottom:2rem; }
.horario { font-size:0.75rem; color:var(--gris-sub); margin-top:1rem; letter-spacing:0.05em; }

/* RESPONSIVE */
@media(max-width:860px){
  .rep-filtros { grid-template-columns:1fr 1fr; }
  .btn-buscar { grid-column:1/-1; }
}
@media(max-width:640px){
  .rep-hero { padding:3rem 1.2rem 2.5rem; }
  .rep-hero::after { display:none; }
  .rep-filtros { grid-template-columns:1fr; }
  .rep-categorias { padding:2.5rem 1rem 3rem; }
  .cat-grid { grid-template-columns:repeat(2,1fr); gap:0.75rem; }
  .rep-cta { padding:3rem 1rem; }
}
