/* Blogs page creative typography and layout */

/* Minimal typography scoped to blogs page */
.blogs-page {
  font-family: 'Albert Sans', sans-serif;
}

.blogs-page main > .wrap {
  max-width: var(--wrap);
  margin: 0 auto;
  padding: 0 1rem;
}

/* Page title */
.blogs-page h1,
.blogs-page .blogs-title {
  font-family: inherit;
  font-weight: 800;
  letter-spacing: .2px;
  text-transform: uppercase;
}

/* Blog tiles */
#blogs-grid {
  display: grid;
  gap: 1.35rem;
  grid-template-columns: minmax(0, 1fr);
}

#blogs-grid .card {
  display: grid;
  grid-template-columns: 1fr;
  border: 1px solid color-mix(in srgb, var(--border), var(--brand) 8%);
  background: color-mix(in srgb, var(--card), var(--brand) 2%);
  box-shadow: none;
  overflow: hidden;
  transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
  min-height: 100%;
}

#blogs-grid .card:hover {
  transform: translateY(-6px);
  border-color: color-mix(in srgb, var(--brand), var(--border) 30%);
  box-shadow: 0 18px 38px rgba(15, 23, 42, .18);
}

#blogs-grid .card-media {
  position: relative;
  overflow: hidden;
}

#blogs-grid .card-media::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(15, 23, 42, .1) 0%, rgba(15, 23, 42, .35) 100%);
  opacity: 0;
  transition: opacity .3s ease;
}

#blogs-grid .card:hover .card-media::after {
  opacity: 1;
}

#blogs-grid .card-media img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  aspect-ratio: 16 / 11;
  transform: scale(1.02);
  transition: transform .4s ease;
  border-bottom: none;
}

#blogs-grid .card:hover .card-media img {
  transform: scale(1.08);
}

#blogs-grid .card-body {
  display: flex;
  flex-direction: column;
  gap: .65rem;
  padding: 1.35rem 1.5rem 1.5rem;
}

#blogs-grid .card-title {
  font-family: 'Montserrat', 'Albert Sans', sans-serif;
  font-weight: 700;
  font-size: clamp(1.15rem, 2.4vw, 1.4rem);
  letter-spacing: .01em;
}

#blogs-grid .card-body .muted {
  font-size: .8rem;
  letter-spacing: .12em;
  text-transform: uppercase;
}

#blogs-grid .card-body p {
  margin: 0;
  line-height: 1.6;
}

#blogs-grid .card-body .btn {
  align-self: flex-start;
  margin-top: auto;
  padding-left: 0;
}

@media (min-width: 720px) {
  #blogs-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  #blogs-grid .card {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  #blogs-grid .card-body {
    padding: 1.15rem 1.25rem 1.35rem;
  }

  #blogs-grid .card-title {
    font-size: clamp(1.05rem, 4vw, 1.25rem);
  }
}

/* Modal reading experience */
#blog-modal .modal-content {
  background: linear-gradient(160deg,
      color-mix(in srgb, var(--card), var(--brand) 12%) 0%,
      color-mix(in srgb, var(--card), transparent 90%) 55%,
      var(--card) 100%);
  padding: clamp(1.75rem, 3.4vw, 2.75rem) clamp(1.5rem, 4vw, 3.25rem);
  gap: clamp(1.25rem, 2.5vw, 1.75rem);
  max-height: calc(100vh - 8vh);
  overflow: hidden;
}

#blog-modal .modal-head {
  display: grid;
  gap: .5rem;
  border-bottom: 1px solid color-mix(in srgb, var(--border), var(--brand) 10%);
  padding-bottom: clamp(.85rem, 1.5vw, 1.15rem);
}

#blog-modal .modal-head .muted {
  color: color-mix(in srgb, var(--muted), var(--brand) 12%);
  font-size: .78rem;
}

#blog-modal .modal-head #modal-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  margin: 0;
  letter-spacing: normal;
  text-transform: none;
}

#blog-modal .modal-head .meta-pill {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .2rem .65rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--brand), transparent 82%);
  color: color-mix(in srgb, var(--brand), var(--text) 60%);
  font-weight: 600;
  letter-spacing: .15em;
  text-transform: uppercase;
}

#blog-modal .modal-head h2 {
  font-family: 'Montserrat', 'Albert Sans', sans-serif;
  font-size: clamp(1.55rem, 3.4vw, 2.15rem);
  font-weight: 750;
  margin: 0;
  line-height: 1.25;
}

#blog-modal .modal-head #modal-subtitle {
  font-size: .95rem;
  color: var(--muted);
}

#blog-modal .modal-body {
  position: relative;
  max-height: calc(100vh - 8vh - clamp(160px, 20vh, 260px));
  overflow-y: auto;
  padding-right: clamp(.5rem, 1vw, .75rem);
}

#blog-modal .modal-body::-webkit-scrollbar {
  width: 8px;
}

#blog-modal .modal-body::-webkit-scrollbar-thumb {
  background: color-mix(in srgb, var(--brand), transparent 70%);
  border-radius: 999px;
}

#blog-modal .modal-body p {
  margin: 0 0 1.25rem;
  line-height: 1.8;
  font-size: 1rem;
}

#blog-modal .modal-body .lead {
  font-size: clamp(1.08rem, 2.5vw, 1.22rem);
  font-weight: 500;
  color: color-mix(in srgb, var(--text), var(--brand) 6%);
}

#blog-modal .modal-body strong {
  font-weight: 700;
}

#blog-modal .modal-body blockquote {
  margin: 1.5rem 0;
  padding: 1.2rem 1.4rem;
  border-left: 4px solid color-mix(in srgb, var(--brand), transparent 40%);
  background: color-mix(in srgb, var(--card), var(--brand) 8%);
  border-radius: .75rem;
  font-size: 1.05rem;
  line-height: 1.7;
}

#blog-modal .modal-body a {
  color: var(--brand);
  text-decoration-thickness: 2px;
}

#blog-modal .modal-body .modal-list {
  margin: 0 0 1.35rem 1.05rem;
  padding: 0 0 0 .25rem;
  display: grid;
  gap: .4rem;
  line-height: 1.7;
  list-style: disc;
}

#blog-modal .modal-body .modal-list--ordered {
  list-style: decimal;
}

#blog-modal .modal-body .modal-list li::marker {
  color: color-mix(in srgb, var(--brand), var(--text) 25%);
}

#blog-modal .modal-body::before,
#blog-modal .modal-body::after {
  content: '';
  position: sticky;
  display: block;
  left: 0;
  right: 0;
  height: 24px;
  pointer-events: none;
  z-index: 1;
}

#blog-modal .modal-body::before {
  top: 0;
  background: linear-gradient(180deg, color-mix(in srgb, var(--card), transparent 15%) 0%, transparent 100%);
}

#blog-modal .modal-body::after {
  bottom: 0;
  background: linear-gradient(0deg, color-mix(in srgb, var(--card), transparent 15%) 0%, transparent 100%);
}

@media (max-width: 600px) {
  #blog-modal .modal-content {
    padding: 1.5rem 1.1rem 1.75rem;
    max-height: calc(100vh - 6vh);
  }

  #blog-modal .modal-body {
    max-height: calc(100vh - 6vh - 140px);
  }
}

/* Respect dark theme variables */
.modal-dialog { background: var(--card); color: var(--text); }

/* Blog hero */
.blog-hero { overflow: hidden; border-radius: var(--radius); }
.blog-hero-inner {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 1rem;
  padding: 1.25rem;
  background: linear-gradient(135deg,
      color-mix(in srgb, var(--card), var(--brand) 12%),
      color-mix(in srgb, var(--card), var(--brand) 4%)
    );
  background-size: cover;
  background-position: center;
  aspect-ratio: 16 / 9;
  min-height: 220px;
  box-shadow: 0 18px 36px rgba(0,0,0,.12);
  color: #fff;
  position: relative;
  isolation: isolate;
}
@media (max-width: 800px){ .blog-hero-inner { grid-template-columns: 1fr; } }
.blog-hero .hero-title { font-family: 'Montserrat', 'Albert Sans', sans-serif; font-size: clamp(1.2rem, 3vw, 1.8rem); line-height: 1.28; margin: .25rem 0; color: #fff; transition: color .2s ease; letter-spacing: .01em; }
.badge { display: inline-block; padding: .25rem .6rem; border-radius: 999px; background: color-mix(in srgb, var(--brand), var(--card) 88%); color: var(--brand); border: 1px solid color-mix(in srgb, var(--brand), transparent 55%); font-size: .8rem; transition: color .2s ease, background-color .2s ease, border-color .2s ease; }
.blog-hero .hero-title,
.blog-hero .hero-title a { color: #fff; transition: color .2s ease; }
.blog-hero .muted { color: rgba(255,255,255,.78); transition: color .2s ease; }
.hero-actions { margin-top: 1.15rem; }
.hero-meta { display: flex; align-items: flex-end; justify-content: flex-end; gap: .75rem; flex-wrap: wrap; color: rgba(255,255,255,.72); transition: color .2s ease; }

.blog-hero-inner.theme-dark {
  --hero-ink: #fff;
  --hero-muted: rgba(255, 255, 255, .72);
  --hero-pill-bg: rgba(255, 255, 255, .16);
  --hero-pill-border: rgba(255, 255, 255, .32);
  --hero-pill-color: #fff;
  --hero-btn-bg: rgba(255, 255, 255, .16);
  --hero-btn-border: rgba(255, 255, 255, .4);
  --hero-btn-color: #fff;
  --hero-btn-hover-bg: #ffd54a;
  --hero-btn-hover-border: #ffd54a;
  --hero-btn-hover-color: #0f172a;
  color: var(--hero-ink);
}

.blog-hero-inner.theme-light {
  --hero-ink: var(--text);
  --hero-muted: color-mix(in srgb, var(--muted), transparent 5%);
  --hero-pill-bg: color-mix(in srgb, var(--brand), transparent 88%);
  --hero-pill-border: color-mix(in srgb, var(--brand), transparent 55%);
  --hero-pill-color: var(--brand);
  --hero-btn-bg: var(--brand);
  --hero-btn-border: var(--brand);
  --hero-btn-color: #fff;
  --hero-btn-hover-bg: #ffffff;
  --hero-btn-hover-border: #ffffff;
  --hero-btn-hover-color: #d90429;
  color: var(--hero-ink);
}

.blog-hero-inner.theme-dark::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(7, 16, 32, .6), rgba(7, 16, 32, .45));
  z-index: -1;
}

.blog-hero-inner .muted,
.blog-hero-inner .hero-meta { color: var(--hero-muted, var(--muted)); }

.blog-hero-inner .badge {
  background: var(--hero-pill-bg, color-mix(in srgb, var(--brand), var(--card) 88%));
  color: var(--hero-pill-color, var(--brand));
  border-color: var(--hero-pill-border, color-mix(in srgb, var(--brand), transparent 55%));
}

.blog-hero-inner .btn.btn-primary {
  background: var(--hero-btn-bg, var(--brand));
  border-color: var(--hero-btn-border, var(--brand));
  color: var(--hero-btn-color, #fff);
  transition: background-color .22s ease, color .22s ease, border-color .22s ease, transform .22s ease, box-shadow .22s ease;
}

.blog-hero-inner .btn.btn-primary:hover,
.blog-hero-inner .btn.btn-primary:focus-visible {
  background: var(--hero-btn-hover-bg, color-mix(in srgb, var(--hero-btn-bg, var(--brand)), #ffffff 12%));
  border-color: var(--hero-btn-hover-border, var(--hero-btn-border, var(--brand)));
  color: var(--hero-btn-hover-color, var(--hero-btn-color, #fff));
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(15, 23, 42, .18);
}

/* Toolbar */
.blog-toolbar { display: grid; grid-template-columns: minmax(0, 1.6fr) minmax(0, 1.4fr) auto auto; align-items: end; gap: .75rem 1rem; margin: .75rem 0 1rem; }
.chips { display: flex; gap: .5rem; flex-wrap: wrap; }
.chip { background: var(--card); color: var(--text); border: 1px solid var(--border); padding: .4rem .7rem; border-radius: 999px; cursor: pointer; transition: background-color .2s ease, color .2s ease, border-color .2s ease, box-shadow .2s ease; }
.chip:hover,
.chip:focus-visible { background: color-mix(in srgb, var(--brand), var(--card) 78%); color: var(--brand); border-color: color-mix(in srgb, var(--brand), transparent 52%); box-shadow: 0 6px 12px rgba(15, 23, 42, .08); outline: none; }
.chip.is-active { background: var(--border); }
.sort { display: inline-flex; gap: .5rem; align-items: center; }
.sort select { background: var(--card); color: var(--text); border: 1px solid var(--border); padding: .35rem .5rem; border-radius: .5rem; transition: border-color .2s ease, box-shadow .2s ease, background-color .2s ease; }
.sort select:hover,
.sort select:focus-visible { border-color: color-mix(in srgb, var(--brand), transparent 45%); box-shadow: 0 0 0 4px color-mix(in srgb, var(--brand), transparent 88%); outline: none; }
.blog-toolbar .search-status { justify-self: end; text-align: right; }

@media (max-width: 1100px) {
  .blog-hero-inner {
    grid-template-columns: 3fr 2fr;
    gap: .9rem;
    padding: 1.15rem;
  }
  #blogs-grid {
    gap: 1.15rem;
  }
}

@media (max-width: 900px) {
  .blog-hero-inner {
    grid-template-columns: 1fr;
    aspect-ratio: 4 / 3;
  }
  .hero-meta {
    justify-content: flex-start;
  }
}

@media (max-width: 720px) {
  .blog-toolbar {
    grid-template-columns: 1fr;
    align-items: stretch;
  }
  .blog-toolbar .chips {
    justify-content: flex-start;
  }
  .blog-toolbar .search-status {
    justify-self: start;
    text-align: left;
  }
  .sort {
    justify-content: space-between;
  }
  #blogs-grid .card-body .btn {
    align-self: stretch;
    justify-content: center;
  }
}

@media (max-width: 640px) {
  .blog-hero-inner {
    aspect-ratio: auto;
    min-height: 0;
    padding: 1.05rem;
  }
  .hero-actions {
    margin-top: .75rem;
  }
  .hero-meta {
    align-items: center;
    gap: .5rem;
  }
  #blogs-grid {
    gap: 1rem;
  }
  #blogs-grid .card {
    grid-template-columns: 1fr;
  }
  #blogs-grid .card-body {
    padding: 1.2rem 1.25rem 1.4rem;
  }
  #blogs-grid .card-body .btn {
    width: 100%;
  }
}

@media (max-width: 480px) {
  .blog-toolbar {
    gap: .5rem;
  }
  .blog-toolbar .chips,
  .sort {
    width: 100%;
  }
  .sort select {
    flex: 1 1 auto;
  }
  .hero-meta {
    flex-direction: column;
    align-items: flex-start;
  }
  .blog-hero-inner {
    border-radius: calc(var(--radius) * .85);
  }
  #blogs-grid {
    gap: .85rem;
  }
  #blogs-grid .card-body {
    padding: 1.1rem 1.2rem 1.3rem;
  }
}
