/*
 * DIVADOSE — Blog Post Templates Companion Styles
 * Paste at the bottom of style.css, OR enqueue as a separate file.
 *
 * Covers all custom templates:
 *   single-food-listicle.php
 *   single-recipe.php
 *   single-travel-listicle.php
 *   single-location.php
 *   single-lifestyle-listicle.php
 */

/* ============================================================
   SHARED: BREADCRUMB
============================================================ */
.ddose-breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px;
  font-size: 0.78rem;
  color: var(--color-text-light);
  margin-bottom: 14px;
}
.ddose-breadcrumb a {
  color: var(--color-text-light);
  transition: color var(--trans);
}
.ddose-breadcrumb a:hover { color: var(--color-primary); }
.ddose-breadcrumb-sep { opacity: 0.4; }
.ddose-breadcrumb-current { color: var(--color-text-mid); }

/* ============================================================
   SHARED: POST HERO BLOCK
   (sits above the full-width image strip)
============================================================ */
.ddose-post-hero {
  background: var(--color-bg-alt);
  border-bottom: 1px solid var(--color-border);
  padding: 32px 0 28px;
}

/* Niche-specific hero accent bars */
.ddose-food-hero     { border-top: 3px solid #c0616b; }   /* brand primary */
.ddose-recipe-hero   { border-top: 3px solid #c0616b; }
.ddose-travel-hero   { border-top: 3px solid #4A7C9E; }   /* travel teal-blue */
.ddose-location-hero { border-top: 3px solid #4A7C9E; }
.ddose-lifestyle-hero{ border-top: 3px solid #9b6b9e; }   /* lifestyle mauve */

.ddose-post-title {
  font-size: clamp(1.6rem, 3.5vw, 2.4rem);
  font-weight: 700;
  line-height: 1.22;
  color: var(--color-text);
  margin: 10px 0 12px;
}

.ddose-post-intro {
  font-size: 1rem;
  color: var(--color-text-mid);
  line-height: 1.7;
  max-width: 680px;
  margin-bottom: 14px;
}

/* Hero badges row */
.ddose-hero-badges {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 8px;
}

/* Listicle count pill */
.ddose-count-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--color-primary);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  padding: 3px 11px;
  border-radius: 20px;
  text-transform: uppercase;
}

/* Area / destination pill */
.ddose-area-pill, .ddose-niche-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--color-bg-dark);
  color: rgba(255,255,255,0.85);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  padding: 3px 11px;
  border-radius: 20px;
}

/* Travel category badge variant */
.cat-badge-travel {
  background: #4A7C9E !important;
}

/* Difficulty pill */
.ddose-diff-pill {
  display: inline-flex;
  align-items: center;
  font-size: 0.72rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 20px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.ddose-diff-easy   { background: #d4edda; color: #155724; }
.ddose-diff-medium { background: #fff3cd; color: #856404; }
.ddose-diff-hard   { background: #f8d7da; color: #721c24; }

/* Meta row */
.ddose-meta-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 0.82rem;
  color: var(--color-text-light);
  margin-top: 4px;
}
.ddose-meta-author {
  display: flex;
  align-items: center;
  gap: 7px;
}
.ddose-meta-avatar {
  width: 32px !important;
  height: 32px !important;
  border-radius: 50% !important;
  object-fit: cover;
  border: 2px solid var(--color-border);
}
.ddose-meta-dot { opacity: 0.35; }

/* ============================================================
   SHARED: HERO IMAGE STRIP (full-width below hero block)
============================================================ */
.ddose-hero-image-strip {
  width: 100%;
  max-height: 480px;
  overflow: hidden;
  background: var(--color-bg-dark);
  border-bottom: 1px solid var(--color-border);
}
.ddose-hero-img {
  width: 100%;
  max-height: 480px;
  object-fit: cover;
  display: block;
}

/* ============================================================
   SHARED: JUMP / TABLE OF CONTENTS MENU
============================================================ */
.ddose-jump-menu {
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: 18px 20px;
  margin: 28px 0;
  background: var(--color-bg-alt);
}
.ddose-jump-menu-header {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text);
  margin-bottom: 12px;
}
.ddose-jump-icon { font-size: 0.95rem; }
.ddose-food-jump   .ddose-jump-icon { color: var(--color-primary); }
.ddose-travel-jump .ddose-jump-icon { color: #4A7C9E; }
.ddose-lifestyle-jump .ddose-jump-icon { color: #9b6b9e; }

.ddose-jump-list {
  list-style: decimal;
  padding-left: 22px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px 24px;
}
.ddose-jump-list li {
  font-size: 0.85rem;
  line-height: 1.55;
}
.ddose-jump-list a {
  color: var(--color-text-mid);
  transition: color var(--trans);
}
.ddose-jump-list a:hover { color: var(--color-primary); }

@media (max-width: 600px) {
  .ddose-jump-list { grid-template-columns: 1fr; }
}

/* ============================================================
   SHARED: LISTICLE BODY — H2 item headings get a number badge
============================================================ */
.ddose-listicle-heading {
  display: flex;
  align-items: baseline;
  gap: 10px;
  font-size: 1.35rem;
  font-weight: 700;
  margin: 36px 0 14px;
  padding-top: 12px;
  border-top: 2px solid var(--color-border);
  color: var(--color-text);
  scroll-margin-top: 80px;
}
/* Counter approach: CSS counters add numbers automatically */
.ddose-listicle-body { counter-reset: listicle-item; }
.ddose-listicle-body .ddose-listicle-heading::before {
  counter-increment: listicle-item;
  content: counter(listicle-item);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  height: 34px;
  border-radius: 50%;
  font-size: 0.88rem;
  font-weight: 700;
  flex-shrink: 0;
  line-height: 1;
}
.ddose-food-body     .ddose-listicle-heading::before { background: var(--color-primary); color: #fff; }
.ddose-travel-body   .ddose-listicle-heading::before { background: #4A7C9E; color: #fff; }
.ddose-lifestyle-body .ddose-listicle-heading::before { background: #9b6b9e; color: #fff; }

/* Travel H2 gets a globe accent */
.ddose-travel-heading {
  scroll-margin-top: 80px;
}

/* Location section heading — no counter, just accent line */
.ddose-location-section-heading {
  font-size: 1.35rem;
  font-weight: 700;
  margin: 36px 0 14px;
  padding-left: 14px;
  border-left: 3px solid #4A7C9E;
  color: var(--color-text);
  scroll-margin-top: 80px;
}

/* ============================================================
   FOOD: RECIPE STATS CARD
============================================================ */
.ddose-recipe-card {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 20px 24px;
  margin: 28px 0;
  background: var(--color-bg-alt);
}
.ddose-recipe-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  justify-content: space-around;
  text-align: center;
}
.ddose-recipe-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 12px 16px;
  border-right: 1px solid var(--color-border);
  flex: 1;
  min-width: 90px;
}
.ddose-recipe-stat:last-child { border-right: none; }
.ddose-recipe-stat i { color: var(--color-primary); font-size: 1.1rem; margin-bottom: 2px; }
.ddose-stat-value { font-size: 1rem; font-weight: 700; color: var(--color-text); }
.ddose-stat-label { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--color-text-light); }

@media (max-width: 500px) {
  .ddose-recipe-stats { gap: 0; }
  .ddose-recipe-stat { border-right: none; border-bottom: 1px solid var(--color-border); flex: 0 0 50%; }
  .ddose-recipe-stat:nth-last-child(-n+2) { border-bottom: none; }
}

/* ============================================================
   TRAVEL: LOCATION QUICK FACTS CARD
============================================================ */
.ddose-location-facts {
  background: var(--color-bg-alt);
  border: 1px solid var(--color-border);
  border-left: 3px solid #4A7C9E;
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 18px 20px;
  margin: 28px 0;
}
.ddose-facts-title {
  font-size: 0.88rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: #4A7C9E;
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 7px;
}
.ddose-facts-list {
  list-style: none;
  font-size: 0.88rem;
  color: var(--color-text-mid);
}
.ddose-facts-list li {
  padding: 5px 0;
  border-bottom: 1px solid var(--color-border);
}
.ddose-facts-list li:last-child { border-bottom: none; }
.ddose-facts-list strong { color: var(--color-text); font-weight: 600; }

/* ============================================================
   SHARED: CALLOUT BOX
============================================================ */
.ddose-callout {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 16px 20px;
  border-radius: var(--radius);
  margin: 28px 0;
  font-size: 0.9rem;
  line-height: 1.65;
}
.ddose-callout i { font-size: 1.1rem; flex-shrink: 0; margin-top: 2px; }
.ddose-callout p { margin: 0; }

.ddose-food-callout   { background: #fff5f5; border: 1px solid #f8c8c8; color: #7a2a2a; }
.ddose-food-callout i { color: var(--color-primary); }
.ddose-travel-callout { background: #eef5fb; border: 1px solid #b8d4ea; color: #1d3a52; }
.ddose-travel-callout i { color: #4A7C9E; }

/* ============================================================
   SHARED: PINTEREST SAVE BLOCK
============================================================ */
.ddose-pin-block {
  background: #fff0f3;
  border: 1px solid #f5c0cb;
  border-radius: var(--radius);
  padding: 20px;
  margin: 32px 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
}
.ddose-pin-label {
  font-size: 0.9rem;
  font-weight: 600;
  color: #7a1a2a;
  margin: 0;
}
.ddose-pin-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #e60023;
  color: #fff;
  font-size: 0.85rem;
  font-weight: 700;
  padding: 9px 20px;
  border-radius: 4px;
  transition: background var(--trans);
  text-decoration: none;
}
.ddose-pin-btn:hover { background: #b8001c; color: #fff; }
.ddose-pin-btn i { font-size: 1rem; }
.ddose-pin-preview-img {
  max-width: 200px;
  border-radius: var(--radius);
  border: 1px solid var(--color-border);
}

/* ============================================================
   RESPONSIVE ADJUSTMENTS
============================================================ */
@media (max-width: 768px) {
  .ddose-post-hero { padding: 24px 0 20px; }
  .ddose-post-title { font-size: clamp(1.4rem, 5vw, 2rem); }
  .ddose-hero-img { max-height: 280px; }
  .ddose-jump-list { grid-template-columns: 1fr; }
  .ddose-recipe-stat { min-width: 70px; padding: 10px 10px; }
  .ddose-pin-preview-img { max-width: 140px; }
}

@media (max-width: 480px) {
  .ddose-post-title { font-size: 1.4rem; }
  .ddose-meta-row { font-size: 0.76rem; gap: 5px; }
  .ddose-hero-badges { gap: 4px; }
  .ddose-listicle-heading { font-size: 1.15rem; }
  .ddose-listicle-heading::before { min-width: 28px; height: 28px; font-size: 0.78rem; }
}
