/* ==========================================================================
   Blogline Homepage — shared frontend scaffolding
   Grid, rows, columns, sticky, hide-on-mobile, menu module.
   Loaded on the builder homepage by core.php (blgn_homepage_frontend_assets).
   ========================================================================== */
/* ============================================
   Homepage Builder — front-end (append to style.css)
   ============================================ */
.blgn-hp { display: flex; flex-direction: column; gap: 24px; }
.blgn-hp-row { display: grid; gap: var(--blgn-hp-gap, 24px); grid-template-columns: repeat(12, 1fr); }
.blgn-hp-col { min-width: 0; grid-column: span var(--blgn-hp-span, 12); }
@media (max-width: 781px) {
  .blgn-hp-row { grid-template-columns: 1fr; }
  .blgn-hp-col { grid-column: 1 / -1; }
}

/* Section + heading blocks */
.blgn-hp-section-title {
  font-size: 20px; font-weight: 800; margin: 0 0 14px; color: var(--blgn-text);
  padding-left: 12px; border-left: 4px solid var(--blgn-primary); line-height: 1.2;
}
.blgn-hp-heading { margin: 0 0 12px; color: var(--blgn-text); font-weight: 800; }
.blgn-hp-heading--left { text-align: left; }
.blgn-hp-heading--center { text-align: center; }
.blgn-hp-heading--right { text-align: right; }
.blgn-hp-html { margin: 0 0 8px; }

/* Post list grid */
.blgn-hp-list { display: grid; gap: var(--blgn-gap, 16px); grid-template-columns: 1fr; }
.blgn-hp-cols-1 { grid-template-columns: 1fr; }

/* Card */
.blgn-hp-card {
  background: var(--blgn-bg); border-radius: var(--blgn-radius, 12px); overflow: hidden;
  box-shadow: var(--blgn-shadow);
}
.blgn-hp-card__thumb { display: block; aspect-ratio: 16/9; overflow: hidden; background: var(--blgn-surface); }
.blgn-hp-card__thumb img { width: 100%; height: 100%; object-fit: cover; }
.blgn-hp-card__body { padding: 14px 16px 16px; }
.blgn-hp-card__title { font-size: 17px; line-height: 1.35; margin: 6px 0 8px; font-weight: 700; }
.blgn-hp-card__title a { color: var(--blgn-text); }
.blgn-hp-card__title a:hover { color: var(--blgn-primary); text-decoration: none; }
.blgn-hp-card__meta { font-size: 13px; color: var(--blgn-text-muted); display: flex; gap: 10px; flex-wrap: wrap; }
.blgn-hp-card__excerpt { margin: 10px 0 0; color: var(--blgn-text-muted); font-size: 14px; line-height: 1.55; }
.blgn-hp-card__more {
  display: inline-block; margin-top: 12px; font-size: 13px; font-weight: 600; color: var(--blgn-primary);
}
.blgn-hp-card__more:hover { color: var(--blgn-primary-dark); }

/* Standard multi-column on desktop */
@media (min-width: 700px) {
  .blgn-hp-list--standard.blgn-hp-cols-2,
  .blgn-hp-list--overlay.blgn-hp-cols-2,
  .blgn-hp-list--text.blgn-hp-cols-2 { grid-template-columns: repeat(2, 1fr); }
  .blgn-hp-list--standard.blgn-hp-cols-3,
  .blgn-hp-list--overlay.blgn-hp-cols-3,
  .blgn-hp-list--text.blgn-hp-cols-3 { grid-template-columns: repeat(3, 1fr); }
  .blgn-hp-list--standard.blgn-hp-cols-4,
  .blgn-hp-list--overlay.blgn-hp-cols-4,
  .blgn-hp-list--text.blgn-hp-cols-4 { grid-template-columns: repeat(4, 1fr); }
}

/* Horizontal card: image beside text */
.blgn-hp-list--horizontal .blgn-hp-card { display: flex; align-items: stretch; }
.blgn-hp-list--horizontal .blgn-hp-card__thumb { flex: 0 0 40%; aspect-ratio: auto; min-height: 100%; }
.blgn-hp-list--horizontal .blgn-hp-card__body { flex: 1; min-width: 0; align-self: center; }
.blgn-hp-list--horizontal.blgn-hp-list--img-right .blgn-hp-card { flex-direction: row-reverse; }
@media (max-width: 540px) {
  .blgn-hp-list--horizontal .blgn-hp-card { flex-direction: column; }
  .blgn-hp-list--horizontal.blgn-hp-list--img-right .blgn-hp-card { flex-direction: column; }
  .blgn-hp-list--horizontal .blgn-hp-card__thumb { flex-basis: auto; aspect-ratio: 16/9; }
}

/* Overlay card: text over image */
.blgn-hp-list--overlay .blgn-hp-card { position: relative; }
.blgn-hp-list--overlay .blgn-hp-card__thumb { aspect-ratio: 4/3; }
.blgn-hp-list--overlay .blgn-hp-card__thumb::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.78) 0%, rgba(0,0,0,.15) 55%, transparent 100%);
}
.blgn-hp-list--overlay .blgn-hp-card__body {
  position: absolute; left: 0; right: 0; bottom: 0; z-index: 2; padding: 16px;
}
.blgn-hp-list--overlay .blgn-hp-card__title a,
.blgn-hp-list--overlay .blgn-hp-card__meta,
.blgn-hp-list--overlay .blgn-hp-card__meta a { color: #fff; }
.blgn-hp-card__cat-badge {
  position: absolute; top: 12px; left: 12px; z-index: 3;
  background: var(--blgn-primary); color: #fff; font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .04em; padding: 4px 10px; border-radius: 6px;
}

/* Text-only card */
.blgn-hp-list--text .blgn-hp-card { box-shadow: none; border: 1px solid var(--blgn-border); }

/* Mobile spacing for builder rows */
@media (max-width: 640px) {
  .blgn-hp { gap: 14px; }
  .blgn-hp-row { gap: 14px; }
}

/* ============================================
   Homepage Builder — Tur A additions
   ============================================ */
/* Hide-on-mobile */
@media (max-width: 781px) {
  .blgn-hp-block--hide-mobile { display: none !important; }
}

/* Popular Posts */
.blgn-hp-popular { list-style: none; margin: 0; padding: 0; counter-reset: blgnpop; }
.blgn-hp-popular__item {
  display: flex; align-items: center; gap: 12px; padding: 12px 0;
  border-bottom: 1px solid var(--blgn-border);
}
.blgn-hp-popular__item:last-child { border-bottom: 0; }
.blgn-hp-popular__rank {
  flex: 0 0 auto; width: 28px; height: 28px; border-radius: 8px;
  background: var(--blgn-surface); color: var(--blgn-primary); font-weight: 800; font-size: 14px;
  display: flex; align-items: center; justify-content: center;
}
.blgn-hp-popular__thumb { flex: 0 0 56px; width: 56px; height: 56px; border-radius: 8px; overflow: hidden; }
.blgn-hp-popular__thumb img { width: 100%; height: 100%; object-fit: cover; }
.blgn-hp-popular__body { min-width: 0; }
.blgn-hp-popular__title { display: block; font-weight: 600; font-size: 14px; line-height: 1.35; color: var(--blgn-text); }
.blgn-hp-popular__title:hover { color: var(--blgn-primary); }
.blgn-hp-popular__date { font-size: 12px; color: var(--blgn-text-muted); }

/* Category Grid */
.blgn-hp-catgrid { display: grid; gap: var(--blgn-gap, 16px); grid-template-columns: 1fr; }
@media (min-width: 700px) {
  .blgn-hp-catgrid.blgn-hp-cols-2 { grid-template-columns: repeat(2, 1fr); }
  .blgn-hp-catgrid.blgn-hp-cols-3 { grid-template-columns: repeat(3, 1fr); }
  .blgn-hp-catgrid.blgn-hp-cols-4 { grid-template-columns: repeat(4, 1fr); }
}

/* Coming-soon notice (admin preview only) */
.blgn-hp-soon {
  border: 1px dashed var(--blgn-border); border-radius: var(--blgn-radius, 12px);
  padding: 24px; text-align: center; color: var(--blgn-text-muted); font-size: 14px;
  background: var(--blgn-surface);
}

/* Builder takes the full content width on the front page (no sidebar) */
.blgn-layout--full { display: block; }
.blgn-layout--full .blgn-content-area { flex: 1 1 100%; width: 100%; max-width: 100%; }

/* ============================================
   Menu Module + Sticky columns (Tur B)
   ============================================ */
/* Sticky column (desktop only) */
@media (min-width: 782px) {
  .blgn-hp-col--sticky { align-self: start; position: sticky; top: var(--blgn-hp-sticky-top, 90px); }
}

/* Menu module */
.blgn-menumod {
  --blgn-mm-bg: #11151d;
  --blgn-mm-text: #c7cedb;
  --blgn-mm-active: var(--blgn-primary, #2563eb);
  --blgn-mm-radius: var(--blgn-radius, 10px);
  background: var(--blgn-mm-bg);
  border-radius: var(--blgn-radius, 12px);
  padding: 10px;
}
.blgn-menumod--light {
  --blgn-mm-bg: #ffffff;
  --blgn-mm-text: #3a3f48;
  border: 1px solid var(--blgn-border, #e6e8ec);
}
.blgn-menumod__list { list-style: none; margin: 0; padding: 0; }
.blgn-menumod__item { margin: 0; }
.blgn-menumod__item--extra { display: none; }
.blgn-menumod.is-expanded .blgn-menumod__item--extra { display: block; }
.blgn-menumod__link {
  display: flex; align-items: center; gap: 12px;
  padding: 11px 14px; border-radius: var(--blgn-mm-radius);
  color: var(--blgn-mm-text); text-decoration: none; font-weight: 500;
  transition: background .15s, color .15s;
}
.blgn-menumod__link:hover { text-decoration: none; }
.blgn-menumod__ic { display: inline-flex; flex: 0 0 auto; }
.blgn-menumod__ic .blgn-ic { width: 18px; height: 18px; }
.blgn-menumod__label { flex: 1; min-width: 0; }
.blgn-menumod__count {
  font-size: 12px; font-weight: 600; opacity: .65;
  background: rgba(127,127,127,.16); padding: 1px 8px; border-radius: 999px;
}
.blgn-menumod__link.is-active {
  background: var(--blgn-mm-active); color: #fff;
}
.blgn-menumod__link.is-active .blgn-menumod__ic { color: #fff !important; }
.blgn-menumod__link.is-active .blgn-menumod__count { background: rgba(255,255,255,.22); opacity: 1; }

/* Hover styles */
.blgn-menumod--hover-fill .blgn-menumod__link:not(.is-active):hover { background: rgba(127,127,127,.12); }
.blgn-menumod--hover-highlight .blgn-menumod__link:not(.is-active):hover { color: var(--blgn-mm-active); }
.blgn-menumod--hover-none .blgn-menumod__link:hover { background: none; }

/* Sizes */
.blgn-menumod--size-small .blgn-menumod__link { padding: 8px 12px; font-size: 13px; }
.blgn-menumod--size-small .blgn-menumod__ic .blgn-ic { width: 16px; height: 16px; }
.blgn-menumod--size-large .blgn-menumod__link { padding: 13px 16px; font-size: 16px; }
.blgn-menumod--size-large .blgn-menumod__ic .blgn-ic { width: 20px; height: 20px; }

/* Divider */
.blgn-menumod__divider { height: 1px; background: rgba(127,127,127,.18); margin: 8px 12px; list-style: none; }

/* More button */
.blgn-menumod__more {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  width: 100%; margin-top: 6px; padding: 9px; cursor: pointer;
  background: none; border: 0; color: var(--blgn-mm-text); font-weight: 600; font-size: 13px;
  border-radius: var(--blgn-mm-radius); opacity: .8; transition: opacity .15s, background .15s;
}
.blgn-menumod__more:hover { opacity: 1; background: rgba(127,127,127,.1); }
.blgn-menumod__more .blgn-ic { width: 16px; height: 16px; transition: transform .2s; }
.blgn-menumod.is-expanded .blgn-menumod__more .blgn-ic { transform: rotate(180deg); }