/*
 * Rinato Studio — Blog Stylesheet
 *
 * This stylesheet is loaded AFTER style.css specifically on blog/post/archive
 * pages. It uses high specificity and !important on critical layout
 * properties so it can never be overridden by a misbehaving cache,
 * Gutenberg block default, or a conflicting plugin.
 *
 * Most properties are scoped under .rinato-blog-body so they only apply
 * to pages where this template is actually used.
 */

/* ============================================================
   1. PAGE FRAME — make absolutely sure header doesn't overlap
   ============================================================ */

/* The first page section on blog/post/archive pages must clear the fixed header */
body.single-post .rinato-blog-hero,
body.blog .rinato-blog-hero,
body.archive .rinato-blog-hero,
body.category .rinato-blog-hero,
body.tag .rinato-blog-hero,
body.author .rinato-blog-hero,
body.date .rinato-blog-hero {
  padding-top: 200px !important;
  padding-bottom: 40px !important;
  position: relative !important;
  z-index: 1 !important;
  text-align: center !important;
  background: var(--bg, #FCFCFA) !important;
  overflow: hidden !important;
}

@media (max-width: 780px) {
  body.single-post .rinato-blog-hero,
  body.blog .rinato-blog-hero,
  body.archive .rinato-blog-hero,
  body.category .rinato-blog-hero,
  body.tag .rinato-blog-hero,
  body.author .rinato-blog-hero,
  body.date .rinato-blog-hero {
    padding-top: 130px !important;
  }
}

/* Hero category badge */
.rinato-blog-hero__category {
  display: inline-block !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: #FF1A0D !important;
  text-decoration: none !important;
  padding: 6px 14px !important;
  border: 1px solid #FF1A0D !important;
  border-radius: 100px !important;
  margin-bottom: 24px !important;
  transition: all 0.25s ease !important;
}
.rinato-blog-hero__category:hover {
  background: #FF1A0D !important;
  color: #fff !important;
}

/* Hero title — explicit pixel sizes so user font-size settings don't blow it up */
.rinato-blog-hero__title {
  font-family: 'Schibsted Grotesk', Georgia, serif !important;
  font-weight: 400 !important;
  font-size: clamp(32px, 5vw, 56px) !important;
  line-height: 1.1 !important;
  letter-spacing: -0.022em !important;
  color: #111110 !important;
  max-width: 720px !important;
  margin: 0 auto 28px !important;
  padding: 0 !important;
}
.rinato-blog-hero__title em {
  font-style: italic !important;
  font-weight: 400 !important;
}

/* Hero meta strip */
.rinato-blog-hero__meta {
  display: inline-flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 10px !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
  color: #7A7269 !important;
}
.rinato-blog-hero__meta-item {
  font-style: italic !important;
  font-family: 'Schibsted Grotesk', Georgia, serif !important;
  font-weight: 400 !important;
  font-size: 15px !important;
}
.rinato-blog-hero__meta-dot {
  opacity: 0.5 !important;
}

/* ============================================================
   2. ARTICLE BODY — guarantee correct font sizes
   ============================================================ */

.rinato-blog-prose {
  max-width: 800px !important;
  margin: 0 auto !important;
  padding: 40px 24px !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 17px !important;
  line-height: 1.75 !important;
  color: #111110 !important;
  font-weight: 400 !important;
}

/* All paragraphs in the prose, including Gutenberg-styled ones */
.rinato-blog-prose p,
.rinato-blog-prose .wp-block-paragraph,
.rinato-blog-prose [class*="has-"][class*="-font-size"] {
  font-size: 17px !important;
  line-height: 1.75 !important;
  font-family: 'Inter', sans-serif !important;
  color: #111110 !important;
  margin: 0 0 1.5em !important;
}

/* Headings inside post content - reset all six explicitly */
.rinato-blog-prose h1 { font-size: 32px !important; }
.rinato-blog-prose h2 { font-size: 28px !important; }
.rinato-blog-prose h3 { font-size: 22px !important; }
.rinato-blog-prose h4 { font-size: 18px !important; }
.rinato-blog-prose h5 { font-size: 16px !important; }
.rinato-blog-prose h6 { font-size: 14px !important; text-transform: uppercase !important; letter-spacing: 0.08em !important; }

.rinato-blog-prose h1,
.rinato-blog-prose h2,
.rinato-blog-prose h3,
.rinato-blog-prose h4,
.rinato-blog-prose h5,
.rinato-blog-prose h6 {
  font-family: 'Schibsted Grotesk', Georgia, serif !important;
  font-weight: 400 !important;
  letter-spacing: -0.015em !important;
  color: #111110 !important;
  margin: 2em 0 0.65em !important;
  line-height: 1.25 !important;
}
.rinato-blog-prose h1 em,
.rinato-blog-prose h2 em,
.rinato-blog-prose h3 em,
.rinato-blog-prose h4 em,
.rinato-blog-prose h5 em,
.rinato-blog-prose h6 em {
  font-style: italic !important;
  font-weight: 400 !important;
  color: #FF1A0D !important;
}

/* Drop cap on first paragraph of post body */
.rinato-blog-prose > p:first-of-type::first-letter {
  font-family: 'Schibsted Grotesk', Georgia, serif !important;
  font-style: italic !important;
  font-weight: 400 !important;
  font-size: 64px !important;
  line-height: 0.85 !important;
  float: left !important;
  padding: 4px 8px 0 0 !important;
  color: #FF1A0D !important;
}

.rinato-blog-prose strong { font-weight: 600 !important; color: #111110 !important; }
.rinato-blog-prose em { font-style: italic !important; }

/* Links */
.rinato-blog-prose a {
  color: #FF1A0D !important;
  text-decoration: underline !important;
  text-decoration-thickness: 1px !important;
  text-underline-offset: 3px !important;
}

/* Lists */
.rinato-blog-prose ul,
.rinato-blog-prose ol {
  padding-left: 1.5em !important;
  margin: 0 0 1.5em !important;
}
.rinato-blog-prose li {
  margin-bottom: 0.5em !important;
  font-size: 17px !important;
  line-height: 1.75 !important;
}
.rinato-blog-prose ul li::marker { color: #FF1A0D !important; }

/* Blockquote */
.rinato-blog-prose blockquote {
  border-left: 3px solid #FF1A0D !important;
  padding: 8px 0 8px 24px !important;
  margin: 32px 0 !important;
  font-family: 'Schibsted Grotesk', Georgia, serif !important;
  font-style: italic !important;
  font-weight: 400 !important;
  font-size: 22px !important;
  line-height: 1.45 !important;
  color: #111110 !important;
}

/* Images */
.rinato-blog-prose img {
  max-width: 100% !important;
  height: auto !important;
  border-radius: 8px !important;
  display: block !important;
  margin: 32px auto !important;
}

/* HR */
.rinato-blog-prose hr {
  border: none !important;
  height: 1px !important;
  background: linear-gradient(90deg, transparent 0%, #EDE5D8 50%, transparent 100%) !important;
  margin: 48px 0 !important;
}

/* ============================================================
   3. FEATURED IMAGE
   ============================================================ */

.rinato-blog-featured-image {
  max-width: 920px !important;
  margin: 0 auto 32px !important;
  padding: 0 24px !important;
}
.rinato-blog-featured-image img {
  width: 100% !important;
  height: auto !important;
  border-radius: 16px !important;
  display: block !important;
  box-shadow: 0 20px 60px rgba(26, 22, 18, 0.08) !important;
}

/* ============================================================
   4. BLOG LISTING — featured post
   ============================================================ */

.rinato-blog-list {
  max-width: 1240px !important;
  margin: 0 auto !important;
  padding: 60px 24px !important;
}

/* Featured post: side-by-side layout */
.rinato-blog-featured {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 48px !important;
  align-items: center !important;
  margin-bottom: 80px !important;
  padding-bottom: 60px !important;
  border-bottom: 1px solid #EDE5D8 !important;
}
@media (max-width: 880px) {
  .rinato-blog-featured {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }
}
.rinato-blog-featured__visual {
  position: relative !important;
  width: 100% !important;
  aspect-ratio: 4 / 3 !important;
  max-height: 480px !important;
  overflow: hidden !important;
  border-radius: 12px !important;
  background: #F6F1EB !important;
  box-shadow: 0 8px 30px rgba(26, 22, 18, 0.06) !important;
}
@media (max-width: 880px) {
  .rinato-blog-featured__visual {
    aspect-ratio: 16 / 9 !important;
    max-height: 320px !important;
  }
}
.rinato-blog-featured__visual img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}
.rinato-blog-featured__placeholder {
  position: absolute !important;
  inset: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background:
    radial-gradient(ellipse at 30% 30%, rgba(255,208,85,0.18) 0%, transparent 60%),
    linear-gradient(135deg, #F6F1EB 0%, #f0e8dc 100%) !important;
}
.rinato-blog-featured__placeholder img {
  width: 80px !important;
  height: 80px !important;
  max-width: 80px !important;
  max-height: 80px !important;
  opacity: 0.22 !important;
  object-fit: contain !important;
}
.rinato-blog-featured__title {
  font-family: 'Schibsted Grotesk', Georgia, serif !important;
  font-weight: 400 !important;
  font-size: clamp(26px, 3.4vw, 40px) !important;
  line-height: 1.15 !important;
  letter-spacing: -0.018em !important;
  color: #111110 !important;
  margin: 12px 0 !important;
}
.rinato-blog-featured__title em { font-style: italic !important; font-weight: 400 !important; }
.rinato-blog-featured__excerpt {
  font-family: 'Inter', sans-serif !important;
  font-size: 16px !important;
  line-height: 1.65 !important;
  color: #4A443D !important;
  margin: 0 0 20px !important;
}

/* ============================================================
   5. BLOG LISTING — card grid
   ============================================================ */

.rinato-blog-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
  gap: 32px !important;
  margin-bottom: 48px !important;
}
@media (min-width: 1080px) {
  .rinato-blog-grid {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}
@media (min-width: 620px) and (max-width: 1079px) {
  .rinato-blog-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 619px) {
  .rinato-blog-grid {
    grid-template-columns: 1fr !important;
  }
}

.rinato-blog-card {
  display: flex !important;
  flex-direction: column !important;
}
.rinato-blog-card a {
  text-decoration: none !important;
  color: inherit !important;
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1) !important;
}
.rinato-blog-card a:hover {
  transform: translateY(-4px) !important;
}
.rinato-blog-card__visual {
  position: relative !important;
  width: 100% !important;
  aspect-ratio: 4 / 3 !important;
  max-height: 240px !important;
  overflow: hidden !important;
  border-radius: 8px !important;
  background: #F6F1EB !important;
  margin-bottom: 16px !important;
}
.rinato-blog-card__visual img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}
.rinato-blog-card__placeholder {
  position: absolute !important;
  inset: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background:
    radial-gradient(ellipse at 70% 30%, rgba(255,208,85,0.14) 0%, transparent 55%),
    linear-gradient(135deg, #F6F1EB 0%, #f2eadd 100%) !important;
}
.rinato-blog-card__placeholder img {
  width: 56px !important;
  height: 56px !important;
  max-width: 56px !important;
  max-height: 56px !important;
  opacity: 0.18 !important;
  object-fit: contain !important;
}
.rinato-blog-card__meta {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 8px !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 12px !important;
  color: #7A7269 !important;
  margin-bottom: 10px !important;
}
.rinato-blog-card__category {
  font-weight: 500 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  font-size: 10px !important;
  color: #FF1A0D !important;
}
.rinato-blog-card__title {
  font-family: 'Schibsted Grotesk', Georgia, serif !important;
  font-weight: 400 !important;
  font-size: 20px !important;
  line-height: 1.25 !important;
  letter-spacing: -0.012em !important;
  color: #111110 !important;
  margin: 0 0 10px !important;
}
.rinato-blog-card__excerpt {
  font-family: 'Inter', sans-serif !important;
  font-size: 15px !important;
  line-height: 1.65 !important;
  color: #4A443D !important;
  margin: 0 0 16px !important;
  flex: 1 !important;
}
.rinato-blog-card__readmore {
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #FF1A0D !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
}

/* ============================================================
   6. EMPTY STATE
   ============================================================ */

.rinato-blog-empty {
  text-align: center !important;
  padding: 80px 24px !important;
  max-width: 540px !important;
  margin: 0 auto !important;
}
.rinato-blog-empty img {
  width: 70px !important;
  height: 70px !important;
  opacity: 0.65 !important;
  margin: 0 auto 24px !important;
  display: block !important;
}
.rinato-blog-empty__title {
  font-family: 'Schibsted Grotesk', Georgia, serif !important;
  font-weight: 300 !important;
  font-size: clamp(28px, 3.4vw, 40px) !important;
  line-height: 1.1 !important;
  color: #111110 !important;
  margin-bottom: 16px !important;
}
.rinato-blog-empty__title em {
  font-style: italic !important;
  font-weight: 400 !important;
  color: #FF1A0D !important;
}
.rinato-blog-empty p {
  font-size: 16px !important;
  line-height: 1.7 !important;
  color: #4A443D !important;
  margin-bottom: 32px !important;
}

/* ============================================================
   7. PAGINATION
   ============================================================ */

.rinato-blog-pagination {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 8px !important;
  margin-top: 40px !important;
  padding-top: 40px !important;
  border-top: 1px solid #EDE5D8 !important;
  flex-wrap: wrap !important;
}
.rinato-blog-pagination .page-numbers {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 36px !important;
  height: 36px !important;
  padding: 0 14px !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  color: #4A443D !important;
  text-decoration: none !important;
  border-radius: 6px !important;
  border: 1px solid transparent !important;
  transition: all 0.2s ease !important;
}
.rinato-blog-pagination a.page-numbers:hover {
  color: #FF1A0D !important;
  border-color: #EDE5D8 !important;
  background: #F6F1EB !important;
}
.rinato-blog-pagination .page-numbers.current {
  color: #FF1A0D !important;
  border-color: #FF1A0D !important;
  background: rgba(255, 26, 13, 0.04) !important;
}
