/* css/home-categories.css - modified: plain white full-bleed section + spacing */

/* Theme variables */
:root{
  --bg-1: #fffaf3;
  --g1: #ffd8b8;
  --g2: #ffb3c6;
  --g3: #d8fff0;
  --g4: #e8d9ff;
  --accent: #ff8e9e;
  --muted-text: #17202a;
  --card-radius: 12px;
  --container-max: 1180px;
  --font-family: "Montserrat", "Helvetica Neue", Arial, sans-serif;
}

/* ========== SECTION: plain white full-bleed ==========
   Replaces previous gradient + overlay; keeps typography and spacing
   ======================================================= */
.home-cats-section {
  /* full-bleed white background */
  background: #ffffff !important;
  color: var(--muted-text);
  font-family: var(--font-family);
  position: relative;
  overflow: visible;
  /* vertical spacing scales between mobile and desktop */
  padding-top: clamp(28px, 6vw, 120px) !important;
  padding-bottom: clamp(28px, 4.5vw, 80px) !important;
}

/* remove decorative overlay/pseudo elements */
.home-cats-section::before,
.home-cats-section::after {
  display: none !important;
  content: none !important;
  background: none !important;
}

/* inner container now transparent so whole section reads as single white block */
.home-cats-inner.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: clamp(12px, 3.5vw, 60px) 24px !important; /* increased top padding to move title down */
  box-sizing: border-box;
  background: transparent !important;
  border-radius: 0 !important;
  border: none !important;
  box-shadow: none !important;
}

/* header/title */
.home-cats-header {
  text-align: center;
  margin: 0 0 20px 0;
  padding: 0;
}
.home-cats-title {
  font-family: var(--font-family);
  font-weight: 700;
  letter-spacing: 1.6px;
  font-size: 28px;
  margin: 0 0 6px;
  color: var(--muted-text);
  text-transform: uppercase;
  display: block;
}

/* small playful underline (keeps accent color) */
.home-cats-header::after{
  content: "";
  display: block;
  width: 64px;
  height: 3px;
  margin: 12px auto 0;
  border-radius: 3px;
  background: linear-gradient(90deg, rgba(255,142,158,0), var(--accent), rgba(255,142,158,0));
  opacity: 0.95;
}

/* GRID */
.home-cats-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 22px;
  align-items: stretch;
  justify-items: stretch;
}

/* CARD LINK */
.home-cat {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  background: transparent;
  transition: transform .28s cubic-bezier(.2,.9,.2,1), box-shadow .28s, filter .28s;
  will-change: transform;
  border-radius: var(--card-radius);
  overflow: visible;
}

/* hover effect - gentle lift + brighten */
.home-cat:hover,
.home-cat:focus {
  transform: translateY(-6px);
  box-shadow: 0 22px 50px rgba(23,32,42,0.08);
  filter: brightness(1.02);
}

/* IMAGE CONTAINER: keep the framed look but on white section */
.home-cat-media {
  width: 100%;
  aspect-ratio: 1/1;
  overflow: hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius: calc(var(--card-radius) - 2px);
  box-shadow: 0 8px 22px rgba(23,32,42,0.05);
  border: 8px solid rgba(255,255,255,0.85);
  background: linear-gradient(180deg, rgba(255,255,255,0.9), rgba(255,255,255,0.95));
  box-sizing: border-box;
  position: relative;
}

/* joyful shimmer accent ring */
.home-cat-media::after{
  content: "";
  position: absolute;
  right: 8px;
  top: 8px;
  width: 36px;
  height: 8px;
  border-radius: 8px;
  background: linear-gradient(90deg, rgba(255,255,255,0.6), rgba(255,255,255,0.15));
  transform: rotate(14deg);
  opacity: 0.8;
}

/* image */
.home-cat-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display:block;
  transform-origin: center;
  transition: transform .5s cubic-bezier(.2,.9,.2,1), filter .45s;
  object-position: center center;
  border-radius: calc(var(--card-radius) - 10px);
}
.home-cat:hover .home-cat-media img {
  transform: scale(1.04);
}

/* label: bright, clean, slightly rounded */
.home-cat-label {
  text-align: center;
  padding: 14px 10px;
  font-weight: 600;
  letter-spacing: 2.6px;
  font-size: 13px;
  color: var(--muted-text);
  background: rgba(255,255,255,0.95);
  border-top: 1px solid rgba(0,0,0,0.03);
  margin-top: 10px;
  border-radius: 10px;
  align-self: stretch;
}

/* tiny pastel underline inside the label */
.home-cat-label::after{
  content: "";
  display: block;
  width: 28px;
  height: 3px;
  margin: 10px auto 0;
  border-radius: 3px;
  background: linear-gradient(90deg, var(--g2), var(--g3));
  opacity: 0.95;
}

/* Desktop larger grid */
@media (min-width: 900px) {
  .home-cats-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 28px;
  }


  .home-cat-label {
    padding: 16px 10px;
    font-size: 13px;
    letter-spacing: 2.2px;
  }
}

/* MOBILE tweaks: keep airy, slightly tighter spacing */
@media (max-width: 600px) {
  .home-cats-inner.container {
    max-width: 360px;
    padding: 14px 12px !important;
    margin-left: auto;
    margin-right: auto;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
  }

  .home-cats-title {
    margin-bottom: 12px;
    letter-spacing: 0.6px;
    color: var(--muted-text);
    text-align: center;
  }

  .home-cats-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }

  .home-cat {
    align-items: center;
    background: transparent;
  }

  .home-cat-media {
    border-radius: 8px;
    border: 8px solid rgba(255,255,255,0.92);
    box-shadow: 0 8px 18px rgba(23,32,42,0.04);
    aspect-ratio: 1/1;
    background: rgba(255,255,255,0.98);
  }

  .home-cat-media img {
    border-radius: 6px;
  }

  .home-cat-label {
    padding: 10px 6px;
    font-size: 12px;
    letter-spacing: 3.0px;
    color: var(--muted-text);
    background: transparent;
    border-top: none;
    margin-top: 6px;
  }

  .home-cat:hover,
  .home-cat:focus {
    transform: none;
    box-shadow: none;
  }
}

/* tiny devices */
@media (max-width: 380px) {
  .home-cats-inner.container {
    max-width: 320px;
  }

  .home-cat-label {
    letter-spacing: 3px;
    font-size: 11px;
    padding: 8px 6px;
  }
}

/* Mobile full-width override preserved */
@media (max-width: 640px) {
  .home-cats-inner.container {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    padding: 0 8px !important;
    box-sizing: border-box !important;
    background: transparent !important;
    border-radius: 0 !important;
  }

  .home-cats-title {
    font-size: 22px !important;
    margin: 16px 0 !important;
    text-align: center !important;
  }

  .home-cats-grid {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 6px !important;
    justify-items: center !important;
    align-items: start !important;
    width: 100% !important;
    margin: 0 auto !important;
    padding: 0 !important;
  }

  .home-cat {
    width: 100% !important;
    max-width: none !important;
    text-align: center !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    margin: 0 !important;
  }

  .home-cat-media {
    width: 100% !important;
    aspect-ratio: 1 / 1 !important;
    border-radius: 6px !important;
    border: 5px solid rgba(255,255,255,0.92) !important;
    overflow: hidden !important;
    box-shadow: 0 4px 10px rgba(23,32,42,0.03) !important;
    background: rgba(255,255,255,0.98) !important;
  }

  .home-cat-media img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center center !important;
    display: block !important;
  }

  .home-cat-label {
    font-size: 12px !important;
    letter-spacing: 2.6px !important;
    margin-top: 6px !important;
    text-align: center !important;
    color: var(--muted-text) !important;
    font-weight: 600 !important;
    background: transparent !important;
  }
}

/* Small helper: if you want the inner card instead of full-bleed white,
   uncomment below and remove the transparent inner styles above */
/*
.home-cats-inner.container {
  background: #ffffff !important;
  border: 1px solid rgba(0,0,0,0.04) !important;
  box-shadow: 0 6px 20px rgba(0,0,0,0.04) !important;
  border-radius: 12px !important;
  padding: clamp(18px, 3.5vw, 48px) 24px !important;
}
*/
