/* ============================================================
   OXALIS — BLOG ROOT PAGE CSS
   Built from Figma: Blog Root Page
   ============================================================ */

/* ─── PAGE WRAPPER ─────────────────────────────────────────── */
.ox-blog-page {
  background: #13252A;
}

/* ─── HERO ──────────────────────────────────────────────────── */
.ox-blog-hero {
  background: #13252A;
  padding: 0 179px;
  box-sizing: border-box;
  display: flow-root;
}
.ox-blog-hero__inner {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 24px;
  padding: 80px 0 48px;
}
.ox-blog-hero__h1 {
  font-family: 'Tenez', serif;
  font-weight: 400;
  font-size: 68px;
  line-height: 105%;
  letter-spacing: -0.02em;
  color: #F3F4F4;
  margin: 0;
}
.ox-blog-hero__divider {
  width: 100%;
  height: 1px;
  background: var(--c-border, #717C7F);
  border: none;
  margin: 0;
}
.ox-blog-hero__intro {
  font-family: 'Figtree', sans-serif;
  font-weight: 300;
  font-size: 18px;
  line-height: 160%;
  color: #F3F4F4;
  margin: 0;
  max-width: 800px;
}

/* Search form */
.ox-blog-hero__search {
  display: flex;
  flex-direction: column;
  gap: 12px;
  width: 100%;
  max-width: 565px;
}
.ox-blog-hero__search-label {
  font-family: 'Figtree', sans-serif;
  font-weight: 300;
  font-size: 14px;
  line-height: 105%;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #F3F4F4;
}
.ox-blog-hero__search-input {
  box-sizing: border-box;
  width: 100%;
  max-width: 565px;
  height: 34px;
  background: #1F3035;
  border: 1px solid #717C7F;
  color: #F3F4F4;
  font-family: 'Figtree', sans-serif;
  font-size: 16px;
  padding: 0 12px;
  outline: none;
}
.ox-blog-hero__search-input:focus { border-color: #FF6600; }
.ox-blog-hero__search-btn {
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  padding: 12px 16px;
  gap: 12px;
  width: fit-content;
  background: #1F3035;
  border: 1px solid #FF6600;
  cursor: pointer;
  text-decoration: none;
}
.ox-blog-hero__search-btn-label {
  font-family: 'Figtree', sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 19px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #F3F4F4;
}
.ox-blog-hero__search-btn:hover { background: #263e44; }

/* ─── ARTICLE GRID ──────────────────────────────────────────── */
.ox-blog-grid {
  background: #13252A;
  padding: 0 179px;
  box-sizing: border-box;
  display: flow-root;
}
.ox-blog-grid__row {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  gap: 24px;
  margin-bottom: 32px;
}

/* ─── ARTICLE CARD ──────────────────────────────────────────── */
.ox-blog-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  flex: 1;
  text-decoration: none;
  color: inherit;
}
.ox-blog-card__image-wrap {
  position: relative;
  width: 100%;
  overflow: hidden;
  background: #1F3035;
  border: 1px solid #1F3035;
  aspect-ratio: 369 / 270;
}
.ox-blog-card__image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.ox-blog-card__content {
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: 32px;
  gap: 24px;
  width: 100%;
  flex: 1;
  background: #1F3035;
  border-bottom: 4px solid #03D8D8;
}
.ox-blog-card__tags {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 0;
}
.ox-blog-card__tag {
  box-sizing: border-box;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: 8px 16px;
  height: 34px;
  background: #13252A;
  border: 1px solid #717C7F;
  margin-right: -1px;
  font-family: 'Figtree', sans-serif;
  font-weight: 300;
  font-size: 14px;
  line-height: 18px;
  text-align: center;
  color: #F3F4F4;
  text-decoration: none;
  white-space: nowrap;
}
.ox-blog-card__meta {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 10px;
  font-family: 'Figtree', sans-serif;
  font-weight: 300;
  font-size: 14px;
  line-height: 18px;
  color: #F3F4F4;
}
.ox-blog-card__meta-sep {
  opacity: 0.4;
}
.ox-blog-card__body {
  display: flex;
  flex-direction: column;
  gap: 15px;
  flex: 1;
  width: 100%;
}
.ox-blog-card__title {
  font-family: 'Tenez', serif;
  font-weight: 400;
  font-size: 32px;
  line-height: 105%;
  text-transform: capitalize;
  color: #F3F4F4;
  margin: 0;
  flex: 1;
}
.ox-blog-card__excerpt {
  font-family: 'Figtree', sans-serif;
  font-weight: 300;
  font-size: 18px;
  line-height: 160%;
  color: #F3F4F4;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.ox-blog-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: 'Figtree', sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 19px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #F3F4F4;
  text-decoration: none;
}
.ox-blog-card__cta:hover { opacity: 0.75; }

/* ─── PAGINATION ────────────────────────────────────────────── */
.ox-blog-pagination {
  background: var(--c-dark, #13252A);
  padding: 48px 179px 80px;
  box-sizing: border-box;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-end;
  gap: 0;
}
.ox-blog-pagination .page-numbers {
  box-sizing: border-box;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 44px;
  height: 44px;
  background: var(--c-dark, #13252A);
  border: 1px solid var(--c-border, #717C7F);
  font-family: 'Figtree', sans-serif;
  font-weight: 300;
  font-size: 14px;
  line-height: 18px;
  color: var(--c-white, #F3F4F4);
  text-decoration: none;
  margin-right: -1px;
}
.ox-blog-pagination .page-numbers.current {
  font-weight: 700;
}
.ox-blog-pagination .page-numbers:hover {
  font-weight: 700;
}
.ox-blog-pagination .page-numbers.dots {
  pointer-events: none;
}
.ox-blog-pagination .prev,
.ox-blog-pagination .next {
  background: var(--c-dark-mid, #1F3035);
  border: 1px solid #FF6600;
  color: var(--c-white, #F3F4F4);
}
/* Figma shows arrows after page numbers, WP outputs prev first */
.ox-blog-pagination .prev {
  order: 98;
  margin-left: 64px;
  margin-right: -1px;
}
.ox-blog-pagination .next {
  order: 99;
}

/* ─── FANCY-STROKE SPACERS ──────────────────────────────────── */
.ox-blog-spacer {
  padding: 0 179px;
  box-sizing: border-box;
}
.ox-blog-spacer .ox-fancy-stroke {
  margin: 48px 0;
}

/* ─── NO RESULTS ────────────────────────────────────────────── */
.ox-blog-no-results {
  padding: 80px 179px;
  box-sizing: border-box;
  font-family: 'Figtree', sans-serif;
  font-weight: 300;
  font-size: 18px;
  color: #F3F4F4;
}

/* ============================================================
   Responsive — added 2026-05-06, follows unified scale
   1100 / 900 / 600 / 480
   ============================================================ */

@media (max-width: 1100px) {
  .ox-blog-hero          { padding-inline: 80px; }
  .ox-blog-grid          { padding-inline: 80px; }
  .ox-blog-pagination    { padding-inline: 80px; }
  .ox-blog-spacer        { padding-inline: 80px; }
  .ox-blog-no-results    { padding-inline: 80px; }
}

@media (max-width: 900px) {
  /* Side padding — tablet */
  .ox-blog-hero          { padding-inline: 48px; }
  .ox-blog-grid          { padding-inline: 48px; }
  .ox-blog-pagination    { padding-inline: 48px; }
  .ox-blog-spacer        { padding-inline: 48px; }
  .ox-blog-no-results    { padding-inline: 48px; }

  /* Hero type */
  .ox-blog-hero__h1      { font-size: 48px; }

  /* Collapse 3-up card rows to 2-up */
  .ox-blog-grid__row {
    flex-wrap: wrap;
  }
  .ox-blog-card {
    flex: 0 0 calc(50% - 12px);
  }

  /* Card title */
  .ox-blog-card__title   { font-size: 26px; }

  /* Pagination prev margin */
  .ox-blog-pagination .prev { margin-left: 32px; }
}

@media (max-width: 600px) {
  /* Side padding — phablet */
  .ox-blog-hero          { padding-inline: 24px; }
  .ox-blog-grid          { padding-inline: 24px; }
  .ox-blog-pagination    { padding-inline: 24px; }
  .ox-blog-spacer        { padding-inline: 24px; }
  .ox-blog-no-results    { padding-inline: 24px; }

  /* Hero */
  .ox-blog-hero__inner   { padding: 48px 0 32px; }
  .ox-blog-hero__h1      { font-size: 40px; }
  .ox-blog-hero__intro   { font-size: 16px; }

  /* Single-column cards */
  .ox-blog-grid__row {
    flex-direction: column;
    gap: 24px;
  }
  .ox-blog-card {
    flex: 1 1 100%;
  }

  /* Card content padding */
  .ox-blog-card__content { padding: 24px; gap: 16px; }
  .ox-blog-card__title   { font-size: 24px; }
  .ox-blog-card__excerpt { font-size: 16px; }

  /* Tags wrap */
  .ox-blog-card__tags    { flex-wrap: wrap; gap: 4px; }
  .ox-blog-card__tag     { margin-right: 0; }

  /* Meta wrap on narrow cards */
  .ox-blog-card__meta    { flex-wrap: wrap; gap: 6px; }

  /* Pagination */
  .ox-blog-pagination {
    flex-wrap: wrap;
    justify-content: center;
    gap: 4px;
    padding-block: 32px 48px;
  }
  .ox-blog-pagination .prev { margin-left: 16px; }
  .ox-blog-pagination .page-numbers { margin-right: 0; }

  /* Spacer */
  .ox-blog-spacer .ox-fancy-stroke { margin: 32px 0; }

  /* No results */
  .ox-blog-no-results { padding-block: 48px; }

  /* Search button tap target */
  .ox-blog-hero__search-btn { min-height: 44px; }

  /* CTA tap target */
  .ox-blog-card__cta { min-height: 44px; align-items: center; }
}

@media (max-width: 480px) {
  /* Side padding — mobile */
  .ox-blog-hero          { padding-inline: 16px; }
  .ox-blog-grid          { padding-inline: 16px; }
  .ox-blog-pagination    { padding-inline: 16px; }
  .ox-blog-spacer        { padding-inline: 16px; }
  .ox-blog-no-results    { padding-inline: 16px; }

  /* Hero */
  .ox-blog-hero__inner   { padding: 32px 0 24px; gap: 16px; }
  .ox-blog-hero__h1      { font-size: 36px; }

  /* Card grid spacing */
  .ox-blog-grid__row     { gap: 16px; margin-bottom: 16px; }
  .ox-blog-card__content { padding: 20px; gap: 12px; }
  .ox-blog-card__title   { font-size: 22px; }

  /* Pagination */
  .ox-blog-pagination    { padding-block: 24px 40px; }
  .ox-blog-pagination .prev { margin-left: 8px; }

  /* Spacer */
  .ox-blog-spacer .ox-fancy-stroke { margin: 24px 0; }

  /* Search input height for tap target */
  .ox-blog-hero__search-input { height: 44px; }
}