/* KOZO WORKS® — Page CSS: proyectos */

/* Header negro en esta página — logo y toggle en #1a1a1a */
  body.at-top:not(.menu-open) .header__logo-mask { background-color: #1a1a1a; }
  body.at-top:not(.menu-open) .header__toggle    { color: #1a1a1a; }


  /* =============================================================
     PROYECTOS — page layout CSS
     ============================================================= */

  /* ── Hero ── */
  .pg-hero {
    padding: calc(var(--header-h) + var(--sp-lg)) var(--sp-pad) var(--sp-lg);
    border-bottom: 1px solid var(--c-line);
    display: grid;
    grid-template-columns: 3fr 2fr;
    gap: var(--sp-md);
    align-items: end;
  }

  .pg-hero__headline { margin-left: -0.03em; }

  .pg-hero__right {
    display: flex;
    flex-direction: column;
    gap: clamp(20px, 3vw, 32px);
    padding-bottom: 8px;
  }

  /* ── Filtros ── */
  .pg-filters {
    padding: clamp(16px, 2vw, 24px) var(--sp-pad);
    display: flex;
    gap: clamp(24px, 4vw, 48px);
    align-items: center;
  }

  .pg-filter {
    font-size: 11px;
    font-weight: var(--fw-black);
    text-transform: uppercase;
    letter-spacing: var(--ls-loose);
    color: var(--c-text);
    opacity: 0.35;
    cursor: pointer;
    background: none;
    border: none;
    padding: 0;
    font-family: var(--ff-primary);
    transition: opacity var(--dur-fast) ease;
  }
  .pg-filter:hover     { opacity: 0.7; }
  .pg-filter.is-active { opacity: 1; }

  /* ── CATEGORIA — réplica exacta Basic/DEPT ──
     Grid 2 col: izquierda sticky (contador top + cuerpo centro)
     derecha: 2 cards ancho completo, imagen + texto              */

  .pg-category {
    display: grid;
    grid-template-columns: clamp(220px, 32vw, 420px) 1fr;
    border-bottom: 1px solid var(--c-line);
    border-top: 1px solid var(--c-line);
    transition: border-color var(--dur-mid) ease;
    padding: var(--sp-sm) 0;
  }

  /* Columna izquierda */
  .pg-category__left {
    padding: 0 var(--sp-sm) 0 var(--sp-pad);
    border-right: 1px solid var(--c-line);
    display: flex;
    flex-direction: column;
    position: sticky;
    top: calc(var(--header-h) + var(--sp-sm));
    align-self: start;
    transition: border-color var(--dur-mid) ease;
    height: 100%;
  }

  /* Contador: 01 izq — /02 der */
  .pg-category__counter {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }

  /* Titulo + desc + btn */
  .pg-category__body {
    display: flex;
    flex-direction: column;
    gap: clamp(16px, 2.5vw, 28px);
        height: 100%;
    justify-content: center;
  }

  /* Columna derecha: 2 cards */
  .pg-category__right {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: start;
    padding: 0 var(--sp-pad) 0 var(--sp-sm);
    gap: clamp(16px, 2vw, 24px);
  }

  .pg-card {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: var(--c-text);
    overflow: hidden;
    transition: border-color var(--dur-mid) ease;
  }

  /* Imagen 4:3 */
  .pg-card__img {
    width: 100%;
    aspect-ratio: 5 / 6;
    overflow: hidden;
    background: var(--c-surface);
    transition: background-color var(--dur-mid) ease;
  }

  .pg-card__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.7s var(--ease-out);
  }

  .pg-card:hover .pg-card__img img { transform: scale(1.03); }

  /* Texto debajo — nombre subrayado + descripcion uppercase */
  .pg-card__body {
    padding: clamp(16px, 2vw, 24px) clamp(20px, 2.5vw, 32px) 0 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
    border-top: 1px solid var(--c-line);
    transition: border-color var(--dur-mid) ease;
    height: 100%;
    justify-content: flex-start;
  }

  .pg-card__name {
    font-size: clamp(14px, 1.3vw, 18px);
    font-weight: var(--fw-black);
    letter-spacing: var(--ls-mid);
    text-transform: uppercase;
    text-decoration: underline;
    text-underline-offset: 3px;
    line-height: 1.2;
    color: var(--c-text);
  }

  .pg-card__desc {
    font-size: clamp(13px, 1.1vw, 15px);
    font-weight: var(--fw-regular);
    line-height: 1.5;
    opacity: 0.75;
    letter-spacing: var(--ls-body);
  }

  /* Placeholder KW */
  .pg-card--cta .pg-card__img {
    background: var(--c-menu-bg);
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .pg-card--cta .pg-card__kw {
    font-size: clamp(64px, 10vw, 120px);
    font-weight: var(--fw-black);
    color: var(--c-menu-text);
    opacity: 0.1;
    letter-spacing: var(--ls-tight);
    line-height: 1;
    user-select: none;
  }

  /* ── CTA final ── */
  .pg-cta {
    padding: var(--sp-lg) var(--sp-pad);
    border-bottom: 1px solid var(--c-line);
    display: grid;
    grid-template-columns: 3fr 2fr;
    gap: var(--sp-md);
    align-items: end;
    transition: border-color var(--dur-mid) ease;
  }

  .pg-cta__headline { margin-left: -0.03em; }

  .pg-cta__right {
    display: flex;
    flex-direction: column;
    gap: clamp(20px, 3vw, 32px);
    padding-bottom: 8px;
  }

  /* ── Responsive <= 900px ── */
  @media (max-width: 900px) {
    .pg-hero              { grid-template-columns: 1fr; gap: 32px; }
    .pg-category          { grid-template-columns: 1fr; border-top: none; }
    .pg-category__left    {
      position: static;
      border-right: none;
      gap: 24px;
    }
    /* Cards: lista horizontal scrolleable en móvil */
    .pg-category__right   {
      display: flex;
      overflow-x: auto;
      -webkit-overflow-scrolling: touch;
      scrollbar-width: none;
      -ms-overflow-style: none;
      padding: var(--sp-md) var(--sp-pad);
      gap: clamp(12px, 3vw, 20px);
      grid-template-columns: unset;
      padding-bottom: var(--sp-lg);
    }
    .pg-category__right::-webkit-scrollbar { display: none; }
    .pg-category__right::after {
      content: '';
      min-width: var(--sp-pad);
      flex-shrink: 0;
    }
    .pg-card {
      flex: 0 0 78%;
    }
    .pg-cta               { grid-template-columns: 1fr; gap: 24px; }
  }

  @media (max-width: 480px) {
    .pg-card { flex: 0 0 88%; }
  }