/* ==========================================================================
   Lookora — Hub Pages
   File: /assets/css/hub.css

   Compatible with:
   - old hub BEM classes:
     .cd-hub-hero__title, .cd-cluster__title, .cd-hub-blog__item, .cd-hub-stat
   - new generated hub classes:
     .cd-hub-title, .cd-cluster-section, .cd-blog-section, .cd-stat-card
   ========================================================================== */


/* ==========================================================================
   Page shell
   ========================================================================== */

main#main-content {
  width: 100%;
  overflow-x: hidden;
}


/* ==========================================================================
   Breadcrumb
   ========================================================================== */

.cd-breadcrumb {
  width: min(100% - (var(--cd-gutter, 24px) * 2), 1180px);
  margin: var(--cd-space-lg, 32px) auto 0;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  color: var(--cd-text-muted, #766f66);
  font-size: 0.82rem;
  line-height: 1.4;
}

.cd-breadcrumb a {
  color: inherit;
  text-decoration: none;
  transition: color var(--cd-transition, 180ms ease);
}

.cd-breadcrumb a:hover,
.cd-breadcrumb a:focus-visible {
  color: var(--cd-text, #2c2c2c);
}

.cd-breadcrumb a:focus-visible {
  outline: 2px solid var(--cd-accent, #b8795f);
  outline-offset: 4px;
  border-radius: 4px;
}

.cd-breadcrumb span {
  color: var(--cd-text-muted, #766f66);
}


/* ==========================================================================
   Hub hero
   ========================================================================== */

.cd-hub-hero {
  width: min(100% - (var(--cd-gutter, 24px) * 2), 980px);
  margin: var(--cd-space-2xl, 72px) auto var(--cd-space-xl, 56px);
  padding: 0;
  text-align: center;
  border-bottom: 0;
}

.cd-hub-hero__inner {
  width: 100%;
  margin-inline: auto;
}

/* New generated class + old BEM class */
.cd-hub-title,
.cd-hub-hero__title {
  margin: 0;
  color: var(--cd-text, #2c2c2c);
  font-family: var(--cd-font-serif, var(--font-heading, "Cormorant Garamond", serif));
  font-size: clamp(2.8rem, 8vw, 6.2rem);
  font-weight: 300;
  line-height: 0.94;
  letter-spacing: -0.045em;
}

/* New generated class + old BEM class */
.cd-hub-intro,
.cd-hub-hero__intro {
  max-width: 780px;
  margin: var(--cd-space-md, 28px) auto 0;
  color: var(--cd-text-muted, #6f6a61);
  font-size: clamp(1rem, 1.8vw, 1.16rem);
  font-weight: 300;
  line-height: 1.85;
}

/* Shared eyebrow used by hubs */
.cd-eyebrow {
  margin: 0 0 1rem;
  color: var(--cd-accent, var(--accent, #b8795f));
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  line-height: 1.3;
  text-transform: uppercase;
}


/* ==========================================================================
   Stats
   ========================================================================== */

/* New generated wrapper + old wrapper */
.cd-stats-row,
.cd-hub-stats {
  width: min(100% - (var(--cd-gutter, 24px) * 2), 980px);
  margin: 0 auto var(--cd-space-2xl, 84px);
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--cd-space-md, 18px);
}

/* New generated card + old card */
.cd-stat-card,
.cd-hub-stat {
  padding: var(--cd-space-lg, 30px) var(--cd-space-md, 22px);
  text-align: center;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(255, 255, 255, 0.32)),
    var(--cd-surface, var(--surface, #fffaf3));
  border: 1px solid var(--cd-border, var(--border, #e7ded2));
  border-radius: var(--cd-radius-lg, var(--radius, 14px));
  box-shadow: var(--cd-shadow-sm, 0 12px 34px rgba(40, 32, 24, 0.04));
}

/* New generated number + old number */
.cd-stat-number,
.cd-hub-stat__number {
  margin: 0;
  color: var(--cd-accent, var(--accent, #b8795f));
  font-family: var(--cd-font-serif, var(--font-heading, "Cormorant Garamond", serif));
  font-size: clamp(2.2rem, 4vw, 3.2rem);
  font-weight: 300;
  line-height: 1;
}

/* New generated label + old label */
.cd-stat-label,
.cd-hub-stat__label {
  margin-top: 0.65rem;
  color: var(--cd-text-muted, #6f6a61);
  font-size: 0.86rem;
  font-weight: 300;
  line-height: 1.45;
}


/* ==========================================================================
   Section wrappers
   ========================================================================== */

/* New generated wrappers + old wrappers */
.cd-cluster-section,
.cd-blog-section,
.cd-cluster,
.cd-hub-blog {
  width: min(100% - (var(--cd-gutter, 24px) * 2), 1180px);
  margin: 0 auto var(--cd-space-2xl, 96px);
}

/* Old .cd-hub-blog had card styling; keep only when it is the actual component */
.cd-hub-blog {
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
}

/* New generated titles + old titles */
.cd-cluster-title,
.cd-blog-section-title,
.cd-cluster__title,
.cd-hub-blog__title {
  max-width: 780px;
  margin: 0 0 var(--cd-space-lg, 30px);
  padding: 0;
  border-bottom: 0;
  color: var(--cd-text, #2c2c2c);
  font-family: var(--cd-font-serif, var(--font-heading, "Cormorant Garamond", serif));
  font-size: clamp(1.9rem, 4vw, 3.25rem);
  font-weight: 300;
  line-height: 1.05;
  letter-spacing: -0.025em;
}


/* ==========================================================================
   Cluster cards grid
   ========================================================================== */

/* New generated grid + old grid */
.cd-cluster-grid,
.cd-cluster__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--cd-space-md, 22px);
}

/* Card */
.cd-cluster-card {
  min-width: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  color: inherit;
  text-decoration: none;
  background: var(--cd-surface, var(--surface, #fffaf3));
  border: 1px solid var(--cd-border, var(--border, #e7ded2));
  border-radius: var(--cd-radius-lg, var(--radius, 14px));
  box-shadow: var(--cd-shadow-sm, 0 10px 32px rgba(40, 32, 24, 0.04));
  transition:
    transform var(--cd-transition, 180ms ease),
    box-shadow var(--cd-transition, 180ms ease),
    border-color var(--cd-transition, 180ms ease);
}

.cd-cluster-card:hover,
.cd-cluster-card:focus-visible {
  transform: translateY(-4px);
  border-color: rgba(184, 121, 95, 0.38);
  box-shadow: var(--cd-shadow-lg, 0 22px 58px rgba(40, 32, 24, 0.1));
}

.cd-cluster-card:focus-visible {
  outline: 2px solid var(--cd-accent, var(--accent, #b8795f));
  outline-offset: 4px;
}

/* New image wrapper + old media wrapper */
.cd-cluster-card__image,
.cd-cluster-card__media {
  width: 100%;
  aspect-ratio: 4 / 3;
  height: auto;
  overflow: hidden;
  background: var(--cd-bg, var(--bg-secondary, #f3eee6));
}

/* Supports:
   - new HTML: .cd-cluster-card__image > img
   - old HTML: img.cd-cluster-card__image
*/
.cd-cluster-card__image img,
img.cd-cluster-card__image,
.cd-cluster-card__media img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  transform: scale(1.001);
  transition: transform 500ms var(--cd-ease, ease);
}

.cd-cluster-card:hover .cd-cluster-card__image img,
.cd-cluster-card:hover img.cd-cluster-card__image,
.cd-cluster-card:hover .cd-cluster-card__media img {
  transform: scale(1.045);
}

.cd-cluster-card__body {
  flex: 1;
  padding: var(--cd-space-md, 23px);
}

.cd-cluster-card__eyebrow {
  margin: 0 0 0.55rem;
  color: var(--cd-accent, var(--accent, #b8795f));
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  line-height: 1.3;
  text-transform: uppercase;
}

.cd-cluster-card__title {
  margin: 0 0 0.7rem;
  color: var(--cd-text, #2c2c2c);
  font-family: var(--cd-font-serif, var(--font-heading, "Cormorant Garamond", serif));
  font-size: clamp(1.32rem, 2.4vw, 1.62rem);
  font-weight: 300;
  line-height: 1.08;
}

/* New desc class + old description class */
.cd-cluster-card__desc,
.cd-cluster-card__description {
  margin: 0;
  color: var(--cd-text-muted, #6f6a61);
  font-size: 0.94rem;
  font-weight: 300;
  line-height: 1.68;
}

.cd-cluster-card__link {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  margin-top: 1.1rem;
  color: var(--cd-accent-dark, var(--accent-dark, #8b5e3c));
  font-size: 0.88rem;
  font-weight: 700;
  transition: gap var(--cd-transition, 180ms ease);
}

.cd-cluster-card:hover .cd-cluster-card__link,
.cd-cluster-card__link:hover {
  gap: 0.625rem;
}


/* ==========================================================================
   Blog / internal links
   ========================================================================== */

/* New generated links grid + old links grid */
.cd-blog-links,
.cd-hub-blog__links {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--cd-space-md, 18px);
}

/* New generated item + old item */
.cd-blog-link-item,
.cd-hub-blog__item {
  min-width: 0;
  display: flex;
  gap: var(--cd-space-md, 18px);
  align-items: flex-start;
  padding: var(--cd-space-md, 22px);
  color: inherit;
  text-decoration: none;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.62), rgba(255, 255, 255, 0.22)),
    var(--cd-surface, var(--surface, #fffaf3));
  border: 1px solid var(--cd-border, var(--border, #e7ded2));
  border-radius: var(--cd-radius-lg, var(--radius, 14px));
  box-shadow: var(--cd-shadow-sm, 0 10px 30px rgba(40, 32, 24, 0.035));
  transition:
    transform var(--cd-transition, 180ms ease),
    box-shadow var(--cd-transition, 180ms ease),
    border-color var(--cd-transition, 180ms ease);
}

.cd-blog-link-item:hover,
.cd-blog-link-item:focus-visible,
.cd-hub-blog__item:hover,
.cd-hub-blog__item:focus-visible {
  transform: translateY(-3px);
  border-color: rgba(184, 121, 95, 0.34);
  box-shadow: var(--cd-shadow-lg, 0 18px 48px rgba(40, 32, 24, 0.085));
}

.cd-blog-link-item:focus-visible,
.cd-hub-blog__item:focus-visible {
  outline: 2px solid var(--cd-accent, var(--accent, #b8795f));
  outline-offset: 4px;
}

/* New generated icon + old icon */
.cd-blog-link-item__icon,
.cd-hub-blog__icon {
  flex: 0 0 auto;
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  color: var(--cd-accent, var(--accent, #b8795f));
  background: var(--cd-bg, var(--bg-secondary, #f3eee6));
  border-radius: var(--cd-radius-md, 999px);
  font-size: 1.05rem;
  line-height: 1;
}

.cd-blog-link-item__text {
  min-width: 0;
}

/* New generated title + old title */
.cd-blog-link-item__title,
.cd-hub-blog__item-title {
  margin: 0 0 0.45rem;
  color: var(--cd-text, #2c2c2c);
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.35;
}

/* New generated desc + old desc */
.cd-blog-link-item__desc,
.cd-hub-blog__item-description {
  margin: 0;
  color: var(--cd-text-muted, #6f6a61);
  font-size: 0.92rem;
  font-weight: 300;
  line-height: 1.58;
}


/* ==========================================================================
   Responsive
   ========================================================================== */

@media (max-width: 1100px) {
  .cd-cluster-grid,
  .cd-cluster__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .cd-hub-hero {
    margin-top: var(--cd-space-xl, 56px);
    margin-bottom: var(--cd-space-lg, 44px);
  }

  .cd-stats-row,
  .cd-hub-stats {
    grid-template-columns: 1fr;
    margin-bottom: var(--cd-space-xl, 68px);
  }

  .cd-blog-links,
  .cd-hub-blog__links {
    grid-template-columns: 1fr;
  }

  .cd-cluster-section,
  .cd-blog-section,
  .cd-cluster,
  .cd-hub-blog {
    margin-bottom: var(--cd-space-xl, 76px);
  }
}

@media (max-width: 560px) {
  .cd-breadcrumb,
  .cd-hub-hero,
  .cd-stats-row,
  .cd-hub-stats,
  .cd-cluster-section,
  .cd-blog-section,
  .cd-cluster,
  .cd-hub-blog {
    width: min(100% - 36px, 1180px);
  }

  .cd-breadcrumb {
    margin-top: 22px;
    font-size: 0.78rem;
  }

  .cd-hub-hero {
    margin-top: 44px;
    text-align: left;
  }

  .cd-hub-intro,
  .cd-hub-hero__intro {
    margin-top: 24px;
  }

  .cd-cluster-grid,
  .cd-cluster__grid {
    grid-template-columns: 1fr;
  }

  .cd-cluster-card__body,
  .cd-blog-link-item,
  .cd-hub-blog__item {
    padding: 20px;
  }

  .cd-blog-link-item,
  .cd-hub-blog__item {
    gap: 14px;
  }

  .cd-blog-link-item__icon,
  .cd-hub-blog__icon {
    width: 38px;
    height: 38px;
  }
}


/* ==========================================================================
   Reduced motion
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
  .cd-cluster-card,
  .cd-cluster-card__image img,
  img.cd-cluster-card__image,
  .cd-cluster-card__media img,
  .cd-blog-link-item,
  .cd-hub-blog__item {
    transition: none;
  }

  .cd-cluster-card:hover,
  .cd-blog-link-item:hover,
  .cd-hub-blog__item:hover {
    transform: none;
  }

  .cd-cluster-card:hover .cd-cluster-card__image img,
  .cd-cluster-card:hover img.cd-cluster-card__image,
  .cd-cluster-card:hover .cd-cluster-card__media img {
    transform: none;
  }
}
/* =========================================================
   HUB — UPLIFTED LAYOUT STYLES
   ========================================================= */

.cd-hub, .cd-hub-main, .cd-cluster-section, .cd-blog-section { width: min(100%, 1120px); margin-inline: auto; padding-inline: clamp(1rem, 4vw, 2rem); }
.cd-hub-title, .cd-hub-hero__title { font-size: clamp(2rem, 7vw, 4rem); line-height: 1.08; letter-spacing: -0.035em; }
.cd-hub-intro, .cd-hub-hero__intro { max-width: 720px; font-size: clamp(1.05rem, 2.5vw, 1.25rem); line-height: 1.65; }
.cd-cluster-grid, .cd-blog-grid, .cd-stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 240px), 1fr)); gap: clamp(1rem, 3vw, 1.5rem); }
.cd-blog-link-item, .cd-cluster-card, .cd-stat-card { min-width: 0; }
.cd-blog-link-item a, .cd-cluster-card a { overflow-wrap: anywhere; }
@media (max-width: 720px) {
  .cd-hub, .cd-hub-main, .cd-cluster-section, .cd-blog-section { padding-inline: 1rem; }
  .cd-breadcrumb { font-size: 0.85rem; overflow-x: auto; white-space: nowrap; padding-bottom: 0.25rem; }
  .cd-hub-title, .cd-hub-hero__title { font-size: clamp(2rem, 9vw, 2.8rem); }
  .cd-cluster-grid, .cd-blog-grid, .cd-stats-grid { grid-template-columns: 1fr; }
  .cd-blog-link-item, .cd-cluster-card, .cd-stat-card { padding: 1rem; border-radius: 18px; }
}

/* =========================================================
   Lookora editorial hub upgrade
   ========================================================= */

body { background: radial-gradient(circle at 12% 0%, rgba(168, 95, 69, 0.10), transparent 32rem), radial-gradient(circle at 90% 12%, rgba(141, 155, 129, 0.11), transparent 30rem), var(--bg, #fbf7ef); }
.cd-hub, .cd-hub-main { width: min(100%, var(--container, 1180px)); margin-inline: auto; padding-inline: clamp(1rem, 4vw, 2rem); }
.cd-hub-hero, .cd-page-hero { position: relative; overflow: hidden; margin: 1rem auto clamp(2.5rem, 6vw, 5rem); padding: clamp(2.5rem, 7vw, 6rem) clamp(1.2rem, 4vw, 3rem); border-radius: var(--radius-xl, 48px); background: linear-gradient(135deg, rgba(255, 250, 243, 0.94), rgba(243, 234, 220, 0.84)), radial-gradient(circle at top right, rgba(168, 95, 69, 0.16), transparent 22rem); box-shadow: var(--shadow-soft, 0 18px 50px rgba(63, 48, 40, 0.08)); }
.cd-hub-hero::after, .cd-page-hero::after { content: ""; position: absolute; right: -4rem; bottom: -5rem; width: 18rem; height: 18rem; border-radius: 999px; background: rgba(141, 155, 129, 0.16); filter: blur(2px); }
.cd-hub-title, .cd-hub-hero__title, .cd-page-hero h1 { position: relative; z-index: 1; max-width: 880px; margin: 0; font-family: var(--font-heading, serif); font-size: clamp(2.8rem, 8vw, 6.2rem); line-height: 0.92; letter-spacing: -0.065em; }
.cd-hub-intro, .cd-hub-hero__intro, .cd-page-hero p { position: relative; z-index: 1; max-width: 720px; margin-top: 1.25rem; color: var(--text-muted, #75685e); font-size: clamp(1.08rem, 2.4vw, 1.3rem); line-height: 1.68; }
.cd-cluster-section, .cd-blog-section { width: min(100%, var(--container, 1180px)); margin: clamp(2.5rem, 6vw, 5rem) auto 0; }
.cd-cluster-title, .cd-blog-section-title { font-family: var(--font-heading, serif); font-size: clamp(2rem, 5vw, 3.4rem); line-height: 1; letter-spacing: -0.055em; }
.cd-cluster-grid, .cd-blog-grid, .cd-stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr)); gap: clamp(1rem, 2.5vw, 1.5rem); }
.cd-cluster-card, .cd-blog-link-item, .cd-stat-card { min-width: 0; padding: clamp(1.1rem, 3vw, 1.5rem); border: 1px solid var(--border, rgba(63, 48, 40, 0.14)); border-radius: var(--radius-lg, 36px); background: linear-gradient(180deg, rgba(255, 250, 243, 0.96), rgba(243, 234, 220, 0.68)); box-shadow: 0 14px 38px rgba(63, 48, 40, 0.07); transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease; }
.cd-cluster-card:hover, .cd-blog-link-item:hover { transform: translateY(-4px); border-color: rgba(168, 95, 69, 0.25); box-shadow: var(--shadow-hover, 0 24px 70px rgba(63, 48, 40, 0.14)); }
.cd-cluster-card a, .cd-blog-link-item a { color: inherit; text-decoration: none; }
.cd-cluster-card h3, .cd-blog-link-item h3 { margin-top: 0; font-family: var(--font-heading, serif); font-size: clamp(1.35rem, 3vw, 2rem); line-height: 1.06; letter-spacing: -0.04em; }
.cd-cluster-card p, .cd-blog-link-item p { color: var(--text-muted, #75685e); line-height: 1.65; }
.cd-stat-card { text-align: center; background: radial-gradient(circle at top, rgba(168, 95, 69, 0.13), transparent 10rem), var(--surface, #fffaf3); }
.cd-stat-number { display: block; font-family: var(--font-heading, serif); font-size: clamp(2rem, 5vw, 3.25rem); line-height: 1; color: var(--accent, #a85f45); }
.cd-stat-label { display: block; margin-top: 0.45rem; color: var(--text-muted, #75685e); font-weight: 700; }
@media (max-width: 720px) {
  .cd-hub, .cd-hub-main { padding-inline: 1rem; }
  .cd-hub-hero, .cd-page-hero { border-radius: 30px; padding: 2.35rem 1.1rem; }
  .cd-hub-title, .cd-hub-hero__title, .cd-page-hero h1 { font-size: clamp(2.4rem, 13vw, 4rem); }
  .cd-cluster-grid, .cd-blog-grid, .cd-stats-grid { grid-template-columns: 1fr; }
  .cd-cluster-card, .cd-blog-link-item, .cd-stat-card { border-radius: 28px; }
}
