/* ============================================
   intimacyadvicehub.com — Custom CSS
   Bootstrap 5.3 + Custom Design System
   v2.0 — Brand Refresh (Deep Rose + Soft Purple)
   ============================================ */

/* CSS Variables */
:root {
  --color-primary:          #C2185B;   /* Deep Rose */
  --color-primary-dark:     #880E4F;
  --color-primary-light:    #FCE4EC;
  --color-secondary:        #7B5EA7;   /* Soft Purple */
  --color-secondary-dark:   #5E3B8A;
  --color-secondary-light:  #EDE7F6;
  --color-accent:           #FF6B6B;   /* Warm Coral */
  --color-accent-dark:      #e05252;
  --color-accent-light:     #FFF0F0;
  --color-dark:             #1A1A2E;
  --color-text:             #374151;
  --color-text-muted:       #6B7280;
  --color-border:           #E5E7EB;
  --color-bg:               #F9FAFB;
  --color-white:            #FFFFFF;
  --color-success:          #16A34A;
  --color-warning:          #EA580C;
  --color-danger:           #DC2626;
  --transition:             all .2s ease;
  --radius:                 .75rem;
  --shadow-sm:              0 2px 8px rgba(0,0,0,.06);
  --shadow-md:              0 4px 20px rgba(0,0,0,.10);
  --shadow-lg:              0 8px 30px rgba(0,0,0,.14);
}

/* =====================
   Base & Typography
   ===================== */
*, *::before, *::after { box-sizing: border-box; }

body {
  background-color: var(--color-bg);
  color: var(--color-text);
  scroll-behavior: smooth;
}

html[lang="en"] body {
  font-family: 'Inter', 'Segoe UI', Arial, sans-serif;
  font-size: 1rem; line-height: 1.75;
}

html[lang="bn"] body {
  font-family: 'Hind Siliguri', 'SolaimanLipi', Arial, sans-serif;
  font-size: 1.05rem; line-height: 1.9;
}

h1 {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 2rem; font-weight: 700; color: var(--color-dark); line-height: 1.25;
}
h2 { font-size: 1.5rem;  font-weight: 600; color: var(--color-dark); line-height: 1.3; }
h3 { font-size: 1.25rem; font-weight: 600; color: var(--color-dark); }
h4 { font-size: 1.1rem;  font-weight: 600; }

/* =====================
   Bootstrap Overrides
   ===================== */
.btn-primary         { background: var(--color-primary);       border-color: var(--color-primary);       font-weight: 500; }
.btn-primary:hover   { background: var(--color-primary-dark);   border-color: var(--color-primary-dark); }
.btn-secondary       { background: var(--color-secondary);     border-color: var(--color-secondary);     color: #fff; font-weight: 500; }
.btn-secondary:hover { background: var(--color-secondary-dark); border-color: var(--color-secondary-dark); color: #fff; }
.btn-accent          { background: var(--color-accent);        border-color: var(--color-accent);        color: #fff; font-weight: 500; }
.btn-accent:hover    { background: var(--color-accent-dark);   border-color: var(--color-accent-dark);   color: #fff; }
.text-primary        { color: var(--color-primary)   !important; }
.text-secondary      { color: var(--color-secondary) !important; }
.text-accent         { color: var(--color-accent)    !important; }
.text-accent-dark    { color: var(--color-accent-dark); }
.bg-accent           { background: var(--color-accent)        !important; }
.bg-accent-faint     { background: var(--color-accent-light)  !important; }
.bg-accent-glass     { background: rgba(255,107,107,.20); color: #fff; border: 1px solid rgba(255,255,255,.3); }
.bg-primary-subtle   { background: var(--color-primary-light)  !important; }
.bg-gradient-primary { background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary) 100%) !important; }

/* =====================
   Navbar
   ===================== */
#main-navbar {
  border-bottom: 1px solid var(--color-border);
  box-shadow: var(--shadow-sm);
}
.brand-logo   { font-size: 1.25rem; font-weight: 800; }
.footer-brand { font-size: 1.25rem; font-weight: 800; }

.navbar-nav .nav-link {
  color: var(--color-text);
  font-weight: 500;
  padding: .45rem .75rem;
  border-radius: .375rem;
  transition: var(--transition);
  position: relative;
}
.navbar-nav .nav-link:hover  { color: var(--color-primary); background: var(--color-primary-light); }
.navbar-nav .nav-link.active { color: var(--color-primary); font-weight: 600; }
.navbar-nav .nav-link.active::after {
  content: '';
  position: absolute;
  bottom: -2px; left: .75rem; right: .75rem;
  height: 2px;
  background: var(--color-primary);
  border-radius: 2px;
}

.dropdown-menu {
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
  padding: .5rem;
}
.dropdown-item { border-radius: .5rem; transition: var(--transition); font-size: .92rem; }
.dropdown-item:hover { background: var(--color-primary-light); color: var(--color-primary); }

/* Search expand animation */
#search-wrapper .form-control {
  width: 180px;
  transition: width .3s ease;
  border-radius: .5rem 0 0 .5rem !important;
}
#search-wrapper .form-control:focus {
  width: 280px;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 .2rem rgba(194,24,91,.15);
}

/* Search button — elevated with gradient + glow */
#search-btn {
  background: linear-gradient(145deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  border-color: var(--color-primary-dark);
  border-radius: 0 .5rem .5rem 0 !important;
  padding: 0 .9rem;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18), 0 2px 8px rgba(194,24,91,.4);
  transition: background .2s ease, box-shadow .2s ease, transform .1s ease;
  min-width: 40px;
}
#search-btn:hover,
#search-btn:focus {
  background: linear-gradient(145deg, var(--color-primary-dark) 0%, #6a093a 100%);
  border-color: var(--color-primary-dark);
  box-shadow: 0 4px 14px rgba(194,24,91,.55);
  transform: translateY(-1px);
  outline: none;
}
#search-btn:active {
  transform: translateY(0);
  box-shadow: 0 1px 4px rgba(194,24,91,.35);
}
#search-btn .bi-search {
  font-size: 1rem;
  filter: drop-shadow(0 1px 2px rgba(0,0,0,.25));
}

/* =====================
   Hero Section
   ===================== */
.hero-section {
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary) 100%);
  min-height: 460px;
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
}
.hero-has-bg-image {
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}
.hero-has-bg-image .hero-title { text-shadow: 0 2px 16px rgba(0,0,0,.6); }
.hero-has-bg-image .hero-subtitle { text-shadow: 0 1px 8px rgba(0,0,0,.5); }
.hero-overlay  { width: 100%; position: relative; z-index: 1; background: rgba(0,0,0,.1); }
.min-vh-hero   { min-height: 360px; }
.hero-title    { text-shadow: 0 2px 12px rgba(0,0,0,.25); font-family: 'Playfair Display', Georgia, serif; }
.hero-subtitle { text-shadow: 0 1px 4px rgba(0,0,0,.15); }
.text-white-80 { color: rgba(255,255,255,.85) !important; }

/* Hero Trust Signals */
.hero-trust { margin-top: 1.25rem; }
.hero-trust-item {
  display: inline-flex; align-items: center; gap: .35rem;
  background: rgba(255,255,255,.15); backdrop-filter: blur(4px);
  border: 1px solid rgba(255,255,255,.3);
  color: #fff; font-size: .82rem; font-weight: 500;
  padding: .3rem .75rem; border-radius: 2rem;
}
.hero-trust-item .bi-check-circle-fill { color: #4ade80; }

.hero-icon-ring {
  width: 220px; height: 220px; border-radius: 50%;
  background: rgba(255,255,255,.12);
  display: flex; align-items: center; justify-content: center;
  border: 2px solid rgba(255,255,255,.25);
  box-shadow: 0 0 60px rgba(255,255,255,.1);
}
.hero-big-icon { font-size: 5rem; }

/* =====================
   Section Headers
   ===================== */
.section-label {
  display: block; font-size: .78rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em;
  color: var(--color-primary); margin-bottom: .3rem;
}
.section-title { color: var(--color-dark); font-weight: 700; margin-bottom: 0; }

/* =====================
   Category Cards
   ===================== */
.category-card { transition: var(--transition); cursor: pointer; }
.category-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md) !important; }
.category-card .category-icon { transition: transform .2s; }
.category-card:hover .category-icon { transform: scale(1.15); }
.category-name { font-size: .88rem; }

/* =====================
   Article Cards
   ===================== */
.article-card {
  border-radius: var(--radius);
  overflow: hidden;
  transition: var(--transition);
  background: var(--color-white);
  border: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  position: relative;
}
.article-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }

.article-card-img-wrap {
  position: relative;
  height: 220px;
  overflow: hidden;
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary) 100%);
  flex-shrink: 0;
}
.article-card-img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .4s ease;
  display: block;
}
.article-card:hover .article-card-img { transform: scale(1.06); }

.article-card-badge {
  position: absolute;
  top: .75rem;
  left: .75rem;
  display: inline-flex;
  align-items: center;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  padding: .28rem .65rem;
  border-radius: 2rem;
  border: 1px solid;
  backdrop-filter: blur(4px);
  background: rgba(255,255,255,.82);
  line-height: 1.4;
}

.article-card-body {
  padding: 1.25rem 1.25rem 1rem;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}

.article-card-title {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-dark);
  margin: 0 0 .6rem;
  line-height: 1.4;
}

.article-card-excerpt {
  font-size: .875rem;
  color: var(--color-text-muted);
  line-height: 1.65;
  margin-bottom: auto;
  flex-grow: 1;
}

.article-card-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 1rem;
  padding-top: .75rem;
  border-top: 1px solid var(--color-border);
}

.article-card-meta-item {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  font-size: .78rem;
  color: var(--color-text-muted);
}

.article-title-link { color: inherit; text-decoration: none; }
.article-title-link:hover { color: var(--color-primary); }

/* Category-specific thumbnail gradients */
.card-thumb-sexual-health   { background: linear-gradient(135deg, #C2185B, #E91E63) !important; }
.card-thumb-relationships   { background: linear-gradient(135deg, #7B5EA7, #9C27B0) !important; }
.card-thumb-intimacy-tips   { background: linear-gradient(135deg, #AD1457, #C2185B) !important; }
.card-thumb-sex-education   { background: linear-gradient(135deg, #5E35B1, #7B5EA7) !important; }
.card-thumb-product-reviews { background: linear-gradient(135deg, #4A148C, #7B1FA2) !important; }

/* Large category icon overlay (kept for backward compat) */
.cat-icon-overlay {
  position: absolute; bottom: .5rem; right: .75rem;
  font-size: 3rem; opacity: .25; color: #fff; pointer-events: none; line-height: 1;
}

/* =====================
   Review Cards
   ===================== */
.review-card { transition: var(--transition); border-radius: var(--radius) !important; overflow: hidden; }
.review-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg) !important; }
.review-card-img-wrap { height: 180px; overflow: hidden; background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 100%); }
.review-card-img { width: 100%; height: 100%; object-fit: cover; }
.review-sticky-cta { position: sticky; top: 90px; }

/* Pros & Cons pill-card design */
.pros-cons-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.pros-col { background: #f0fdf4; border: 1px solid #bbf7d0; border-radius: var(--radius); padding: 1.25rem; }
.cons-col { background: #fff5f5; border: 1px solid #fed7d7; border-radius: var(--radius); padding: 1.25rem; }
.pros-heading { color: #16a34a; font-weight: 700; font-size: 1rem; margin-bottom: .75rem; }
.cons-heading { color: #dc2626; font-weight: 700; font-size: 1rem; margin-bottom: .75rem; }
.pro-pill {
  display: flex; align-items: center; gap: .5rem;
  background: #dcfce7; color: #166534;
  padding: .45rem .75rem; border-radius: .5rem; margin-bottom: .5rem; font-size: .9rem;
}
.pro-pill i { color: #16a34a; flex-shrink: 0; }
.con-pill {
  display: flex; align-items: center; gap: .5rem;
  background: #fee2e2; color: #991b1b;
  padding: .45rem .75rem; border-radius: .5rem; margin-bottom: .5rem; font-size: .9rem;
}
.con-pill i { color: #dc2626; flex-shrink: 0; }

/* =====================
   Article Page
   ===================== */
.article-body { font-size: 1.05rem; line-height: 1.9; color: var(--color-text); }
.article-body h2 {
  font-size: 1.4rem; margin-top: 2.25rem; margin-bottom: 1rem;
  padding-bottom: .5rem; border-bottom: 2px solid var(--color-primary-light);
}
.article-body h3 { font-size: 1.2rem; margin-top: 1.75rem; margin-bottom: .75rem; }
.article-body p  { margin-bottom: 1.35rem; }
.article-body ul,
.article-body ol { margin-bottom: 1.35rem; padding-left: 1.75rem; }
.article-body li { margin-bottom: .5rem; }
.article-body img { max-width: 100%; height: auto; border-radius: .5rem; margin: 1.5rem 0; }
.article-body a  { color: var(--color-primary); text-decoration: underline; }
.article-body a:hover { color: var(--color-primary-dark); }
.article-body blockquote {
  border-left: 4px solid var(--color-accent); padding: 1.25rem 1.75rem;
  background: var(--color-accent-light); border-radius: 0 .5rem .5rem 0; margin: 2rem 0; font-style: italic;
}
.article-body strong { color: var(--color-dark); }

.article-hero-img { max-height: 460px; object-fit: cover; width: 100%; border-radius: var(--radius); }
.article-title    { font-size: 1.9rem; line-height: 1.25; font-family: 'Playfair Display', Georgia, serif; }

/* TOC */
.toc-box { border-left: 4px solid var(--color-primary) !important; background: var(--color-primary-light) !important; }
.toc-list li { padding: .15rem 0; }
.toc-list li a { color: var(--color-primary); text-decoration: none; transition: color .2s; font-size: .9rem; }
.toc-list li a:hover { color: var(--color-secondary); text-decoration: underline; }
.toc-sticky { position: sticky; top: 80px; }

/* Enhanced Author Bio Box */
.author-bio-box {
  border-left: 4px solid var(--color-primary) !important;
  background: linear-gradient(135deg, var(--color-primary-light) 0%, #fff 60%) !important;
}
.author-bio-box .author-article-count { font-size: .8rem; color: var(--color-text-muted); margin-top: .25rem; }
.author-box { border: 1px solid var(--color-border); border-radius: var(--radius); padding: 1.25rem; background: var(--color-white); }
.author-avatar { width: 56px; height: 56px; border-radius: 50%; object-fit: cover; border: 2px solid var(--color-primary-light); }

/* =====================
   Article Page V3
   ===================== */
.article-v3-hero {
  position: relative;
  min-height: 58vh;
  display: flex;
  align-items: flex-end;
  background-size: cover;
  background-position: center;
  overflow: hidden;
}

.article-v3-hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(136,14,79,.10) 0%, rgba(136,14,79,.62) 66%, rgba(136,14,79,.84) 100%),
    linear-gradient(135deg, rgba(194,24,91,.26), rgba(123,94,167,.2));
}

.article-v3-hero-content {
  position: relative;
  z-index: 2;
  padding-top: 4rem;
  padding-bottom: 3rem;
  color: #fff;
}

.article-v3-hero-badges {
  display: flex;
  gap: .55rem;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}

.article-v3-chip {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: .3rem .8rem;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-decoration: none;
  text-transform: uppercase;
}

.article-v3-chip-primary {
  background: rgba(212,175,55,.22);
  color: #fff;
  border: 1px solid rgba(212,175,55,.38);
}

.article-v3-chip-light {
  background: rgba(255,255,255,.14);
  color: #fff;
  border: 1px solid rgba(255,255,255,.3);
}

.article-v3-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: clamp(2rem, 5vw, 3.6rem);
  font-weight: 700;
  color: #fff;
  text-shadow: 0 2px 8px rgba(0, 0, 0, .45);
  max-width: 900px;
  line-height: 1.16;
  margin: 0 0 1rem;
  text-wrap: balance;
}

.article-v3-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .85rem 1.35rem;
  font-size: .9rem;
  color: rgba(255,255,255,.92);
}

.article-v3-main {
  background: linear-gradient(180deg, color-mix(in srgb, var(--color-primary-light) 38%, #fff) 0%, #ffffff 32%);
}

.article-v3-sticky-left,
.article-v3-sticky-right {
  position: sticky;
  top: 92px;
}

.article-v3-side-title {
  font-size: 1.02rem;
  margin: 0 0 1rem;
  font-weight: 700;
  color: var(--color-dark);
}

.article-v3-toc-box {
  background: #f4eef1;
  border: 1px solid #ebdfe5;
  border-radius: .9rem;
  padding: 1rem 1rem .9rem;
}

.article-v3-toc-box .toc-list li {
  margin-bottom: .4rem;
}

.article-v3-toc-box .toc-list a {
  color: #6c2f46;
  font-size: .86rem;
  line-height: 1.45;
}

.article-v3-share-mini {
  display: flex;
  gap: .55rem;
}

.article-v3-share-mini a {
  width: 2.1rem;
  height: 2.1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  color: var(--color-primary);
  border: 1px solid #edd7e0;
  background: #fff;
  text-decoration: none;
  transition: var(--transition);
}

.article-v3-share-mini a:hover {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}

.article-v3-lead {
  border-left: 4px solid #d4af37;
  padding-left: 1.1rem;
  font-size: 1.14rem;
  color: #5f6570;
  line-height: 1.9;
  margin-bottom: 2rem;
  font-style: italic;
}

.article-v3-body {
  font-size: 1.03rem;
}

.article-v3-body h2 {
  color: #4d2135;
  border-bottom-color: #eadce4;
}

.article-v3-tags {
  margin-top: 2.25rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--color-border);
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}

.article-v3-tags a {
  font-size: .82rem;
  padding: .42rem .75rem;
  border-radius: .55rem;
  text-decoration: none;
  color: #5c3145;
  background: #f6f0f3;
  border: 1px solid #ebdfe5;
  transition: var(--transition);
}

.article-v3-tags a:hover {
  color: #fff;
  background: var(--color-primary);
  border-color: var(--color-primary);
}

.article-v3-popular,
.article-v3-author {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: .9rem;
  padding: 1rem;
}

.article-v3-popular-list {
  display: grid;
  gap: .9rem;
}

.article-v3-popular-item {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: .7rem;
  text-decoration: none;
  color: inherit;
}

.article-v3-popular-item img {
  width: 96px;
  height: 72px;
  object-fit: cover;
  border-radius: .55rem;
}

.article-v3-popular-item p {
  margin: 0 0 .2rem;
  font-size: .84rem;
  font-weight: 600;
  line-height: 1.45;
  color: var(--color-dark);
}

.article-v3-popular-item small {
  color: var(--color-text-muted);
  font-size: .76rem;
}

.article-v3-newsletter {
  position: relative;
  overflow: hidden;
  background: linear-gradient(145deg, #61283f 0%, #7d3a57 55%, #8d4c69 100%);
  border-radius: 1rem;
  padding: 1.1rem;
  color: #fff;
  box-shadow: 0 12px 26px rgba(78, 28, 50, .2);
}

.article-v3-newsletter h3 {
  font-size: 1.2rem;
  margin-bottom: .45rem;
  color: #fff;
}

.article-v3-newsletter p {
  font-size: .85rem;
  color: rgba(255,255,255,.84);
  margin-bottom: .8rem;
}

.article-v3-newsletter-form {
  display: grid;
  gap: .5rem;
}

.article-v3-newsletter .form-control {
  border-color: rgba(255,255,255,.26);
  background: rgba(255,255,255,.13);
  color: #fff;
}

.article-v3-newsletter .form-control::placeholder {
  color: rgba(255,255,255,.68);
}

.article-v3-newsletter .form-control:focus {
  border-color: rgba(255,255,255,.46);
  box-shadow: 0 0 0 .2rem rgba(255,255,255,.18);
}

.article-v3-author img {
  width: 54px;
  height: 54px;
  border-radius: 50%;
  object-fit: cover;
}

.article-v3-author small {
  color: var(--color-text-muted);
}

.article-v3-author p {
  margin: 0;
  font-size: .85rem;
  color: var(--color-text);
  line-height: 1.65;
}

.article-v3-author-count {
  margin-top: .6rem;
  font-size: .8rem;
  color: var(--color-text-muted);
}

.article-v3-related {
  border-top: 1px solid var(--color-border);
}

.article-v3-review-card {
  position: relative;
  border: 1px solid var(--color-border);
  border-radius: .9rem;
  overflow: hidden;
  background: #fff;
  transition: var(--transition);
}

.article-v3-review-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}

.article-v3-review-img-wrap {
  position: relative;
  height: 190px;
  background: linear-gradient(135deg, #f8e8ef, #f6f0f3);
}

.article-v3-review-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.article-v3-review-rating {
  position: absolute;
  top: .7rem;
  right: .7rem;
  background: rgba(20, 29, 24, .8);
  color: #fff;
  border-radius: 999px;
  padding: .2rem .55rem;
  font-size: .75rem;
  font-weight: 700;
}

.article-v3-review-body {
  padding: .95rem 1rem 1rem;
}

.article-v3-review-body h3 {
  margin: 0 0 .45rem;
  font-size: 1rem;
  line-height: 1.4;
}

.article-v3-review-body h3 a {
  color: var(--color-dark);
}

.article-v3-review-body h3 a:hover {
  color: var(--color-primary);
}

.article-v3-review-body p {
  margin: 0;
  font-size: .85rem;
  color: var(--color-text-muted);
  line-height: 1.6;
}

.article-v3-review-meta {
  margin-top: .8rem;
  padding-top: .6rem;
  border-top: 1px solid var(--color-border);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: .76rem;
  color: var(--color-text-muted);
}

.article-v3-reviews-inline {
  border-top: 0;
  padding: 1rem;
  border-radius: 1rem;
  background: linear-gradient(180deg, #fff 0%, #fcf7fa 100%);
  border: 1px solid rgba(194, 24, 91, .12);
}

.article-v3-reviews-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .8rem;
}

.article-v3-reviews-inline > h2 {
  display: flex;
  align-items: center;
  font-size: 1.05rem;
  letter-spacing: .01em;
}

.article-v3-reviews-controls {
  display: inline-flex;
  gap: .45rem;
}

.article-v3-reviews-nav {
  width: 32px;
  height: 32px;
  border: 1px solid rgba(123, 94, 167, .32);
  border-radius: 999px;
  background: #fff;
  color: var(--color-primary-dark);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition);
}

.article-v3-reviews-nav:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
  transform: translateY(-1px);
}

.article-v3-reviews-nav:disabled {
  opacity: .45;
  cursor: not-allowed;
  transform: none;
}

.article-v3-reviews-viewport {
  overflow: hidden;
  border-radius: .9rem;
}

.article-v3-reviews-track {
  display: flex;
  transition: transform .35s ease;
  will-change: transform;
}

.article-v3-reviews-slide {
  flex: 0 0 100%;
  min-width: 100%;
}

.article-v3-reviews-inline .article-v3-review-card {
  display: grid;
  grid-template-columns: 170px 1fr;
  align-items: stretch;
  border-color: rgba(123, 94, 167, .15);
  box-shadow: 0 8px 22px rgba(25, 18, 40, .05);
  border-radius: .9rem;
}

.article-v3-reviews-inline .article-v3-review-img-wrap {
  height: 100%;
}

.article-v3-reviews-inline .article-v3-review-body {
  padding: .85rem .9rem .9rem;
}

.article-v3-reviews-inline .article-v3-review-body h3 {
  font-size: .95rem;
}

.article-v3-reviews-inline .article-v3-review-body p {
  font-size: .82rem;
}

@media (max-width: 575.98px) {
  .article-v3-reviews-inline {
    padding: .8rem;
  }

  .article-v3-reviews-head {
    gap: .5rem;
  }

  .article-v3-reviews-controls {
    gap: .35rem;
  }

  .article-v3-reviews-nav {
    width: 30px;
    height: 30px;
  }

  .article-v3-reviews-inline .article-v3-review-card {
    grid-template-columns: 1fr;
  }

  .article-v3-reviews-inline .article-v3-review-img-wrap {
    height: 150px;
  }
}

/* =====================
   Review Page V3
   ===================== */
.review-v3-hero {
  position: relative;
  min-height: 48vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  isolation: isolate;
}

.review-v3-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(550px 280px at 90% 14%, rgba(255, 191, 96, .18), transparent 70%);
  pointer-events: none;
  z-index: 1;
}

.review-v3-hero::after {
  content: "";
  position: absolute;
  right: -140px;
  top: 50%;
  width: 420px;
  height: 420px;
  transform: translateY(-50%);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 255, 255, .14) 0%, rgba(255, 255, 255, 0) 68%);
  pointer-events: none;
  z-index: 1;
}

.review-v3-hero--no-image {
  background: linear-gradient(135deg, var(--color-primary-dark) 0%, color-mix(in srgb, var(--color-primary) 74%, var(--color-secondary) 26%) 52%, var(--color-secondary-dark) 100%);
}

.review-v3-hero-inner {
  position: relative;
  z-index: 2;
  padding-top: 4.25rem;
  padding-bottom: 3.25rem;
  color: #fff;
  display: flex;
  align-items: center;
  gap: 3rem;
}

.review-v3-hero-inner--compact {
  max-width: 1120px;
}

.review-v3-hero-text { flex: 1; }

.review-v3-hero .article-v3-title {
  font-size: clamp(2rem, 4.1vw, 4rem);
  line-height: 1.1;
  margin-bottom: .95rem;
  max-width: 14ch;
  text-shadow: 0 8px 22px rgba(0, 0, 0, .34);
}

.review-v3-hero-product {
  flex-shrink: 0;
  width: 220px;
}

.review-v3-hero-product-img {
  width: 100%;
  max-height: 260px;
  object-fit: contain;
  filter: drop-shadow(0 8px 32px rgba(0,0,0,.4));
}

.review-v3-hero-stars {
  display: flex;
  align-items: center;
  gap: .18rem;
}

.review-v3-hero-stars i {
  font-size: 1.75rem;
}

.review-v3-rating-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: .32rem .75rem;
  font-weight: 700;
  font-size: .9rem;
  background: rgba(255, 255, 255, .14);
  border: 1px solid rgba(255, 255, 255, .22);
  color: #fff;
}

.review-v3-hero-sub {
  max-width: 48ch;
  color: rgba(255, 255, 255, .9);
  font-size: 1.03rem;
  line-height: 1.7;
}

.review-v3-buy-btn {
  box-shadow: 0 10px 30px color-mix(in srgb, var(--color-primary) 34%, transparent);
}

.review-v3-score-widget {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: .9rem;
  padding: 1.25rem 1rem;
  text-align: center;
}

.review-v3-score-circle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .1rem;
  background: var(--color-primary);
  color: #fff;
  width: 90px;
  height: 90px;
  border-radius: 50%;
  margin-bottom: .5rem;
}

.review-v3-score-number {
  font-size: 1.75rem;
  font-weight: 800;
  line-height: 1;
}

.review-v3-score-max {
  font-size: .85rem;
  opacity: .8;
}

.review-v3-verdict {
  background: linear-gradient(135deg, #f4eef1 0%, #fdf8f4 100%);
  border: 1px solid #ebdfe5;
  border-radius: .9rem;
  padding: 1.25rem 1.5rem;
}

.review-v3-verdict-score {
  font-size: 2.5rem;
  font-weight: 800;
  color: var(--color-primary);
  line-height: 1;
  min-width: 70px;
  text-align: center;
}

.review-v3-cta-card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: .9rem;
  overflow: hidden;
}

.review-v3-cta-img {
  background: #f8f9fa;
  text-align: center;
  padding: 1rem;
  border-bottom: 1px solid var(--color-border);
}

.review-v3-cta-img img {
  max-height: 140px;
  max-width: 100%;
  object-fit: contain;
}

@media (max-width: 767.98px) {
  .review-v3-hero {
    min-height: auto;
  }

  .review-v3-hero-product { display: none; }

  .review-v3-hero::after {
    display: none;
  }

  .review-v3-hero-inner {
    flex-direction: column;
    gap: 1.35rem;
    align-items: flex-start;
    padding-top: 3.3rem;
    padding-bottom: 2.35rem;
  }

  .review-v3-hero .article-v3-title {
    max-width: 100%;
    font-size: clamp(1.9rem, 8vw, 2.6rem);
  }

  .review-v3-hero-stars i {
    font-size: 1.35rem;
  }

  .review-v3-rating-pill {
    font-size: .82rem;
    padding: .28rem .62rem;
  }

  .review-v3-hero-sub {
    font-size: .97rem;
    line-height: 1.65;
  }

  .review-v3-buy-btn {
    width: 100%;
    text-align: center;
  }
}

/* =====================
   Contact Page V3
   ===================== */
.contact-v3-wrap {
  background: linear-gradient(180deg, #f8faf8 0%, #ffffff 46%);
}

.contact-v3-intro h1 {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: clamp(2rem, 4.2vw, 3.2rem);
  line-height: 1.18;
  margin-bottom: .9rem;
  color: #152018;
}

.contact-v3-intro p {
  font-size: 1.03rem;
  color: #5d6a61;
  line-height: 1.75;
  max-width: 34rem;
  margin-bottom: 1.6rem;
}

.contact-v3-points {
  display: grid;
  gap: .95rem;
  margin-bottom: 1.4rem;
}

.contact-v3-point {
  display: grid;
  grid-template-columns: 50px 1fr;
  gap: .8rem;
  align-items: flex-start;
}

.contact-v3-icon {
  width: 46px;
  height: 46px;
  border-radius: .75rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(95, 148, 102, .14);
  color: #4a7550;
  font-size: 1.12rem;
}

.contact-v3-point h3 {
  font-size: 1rem;
  margin: .12rem 0 .1rem;
  color: #152018;
}

.contact-v3-point p {
  margin: 0;
  color: #617067;
  font-size: .93rem;
}

.contact-v3-photo {
  border-radius: 1rem;
  overflow: hidden;
  border: 1px solid #dce6de;
  box-shadow: 0 10px 24px rgba(35, 55, 44, .08);
}

.contact-v3-photo img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
}

.contact-v3-form-card {
  background: #fff;
  border: 1px solid #dce6de;
  border-radius: 1.2rem;
  box-shadow: 0 18px 42px rgba(35, 55, 44, .10);
  padding: 1.5rem;
}

.contact-v3-form-card .form-label {
  color: #53645a;
  font-size: .88rem;
  font-weight: 600;
  margin-bottom: .45rem;
}

.contact-v3-form-card .form-control {
  border-color: #cad9ce;
  background: #f8fbf8;
  border-radius: .8rem;
  min-height: 48px;
  box-shadow: none;
}

.contact-v3-form-card textarea.form-control {
  min-height: 130px;
}

.contact-v3-form-card .form-control:focus {
  border-color: #6d9e75;
  box-shadow: 0 0 0 .2rem rgba(109, 158, 117, .15);
  background: #fff;
}

.contact-v3-form-card #contact-submit {
  border-radius: .8rem;
  font-weight: 700;
}

.contact-v3-disclaimer {
  text-align: center;
  font-size: .76rem;
  color: #7b8b81;
}

/* =====================
   Breadcrumbs
   ===================== */
.breadcrumb-section { background: var(--color-white); border-bottom: 1px solid var(--color-border); }
.breadcrumb { background: none; padding: 0; margin: 0; font-size: .875rem; }
.breadcrumb-item + .breadcrumb-item::before { color: var(--color-text-muted); }
.breadcrumb-item a { color: var(--color-primary); text-decoration: none; }
.breadcrumb-item a:hover { text-decoration: underline; }
.breadcrumb-item.active { color: var(--color-text-muted); }

/* =====================
   Category Page — Hero
   ===================== */
.cat-page-hero {
  padding: 4rem 0 3.5rem;
  background: linear-gradient(135deg, var(--cat-color, #C2185B) 0%, color-mix(in srgb, var(--cat-color, #C2185B) 60%, #1A1A2E) 100%);
  color: #fff;
  position: relative;
  overflow: hidden;
}
.cat-page-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.18);
  pointer-events: none;
}
.cat-page-hero .container { position: relative; z-index: 1; }

.cat-page-breadcrumb .breadcrumb-item a {
  color: rgba(255,255,255,.75);
  text-decoration: none;
  font-size: .875rem;
  transition: color .2s;
}
.cat-page-breadcrumb .breadcrumb-item a:hover { color: #fff; }
.cat-page-breadcrumb .breadcrumb-item.active { color: rgba(255,255,255,.9); font-size: .875rem; }
.cat-page-breadcrumb .breadcrumb-item + .breadcrumb-item::before { color: rgba(255,255,255,.4); }

.cat-page-hero-body { max-width: 640px; }

.cat-page-hero-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: clamp(2.2rem, 5vw, 3.5rem);
  font-weight: 700;
  margin: 0 0 1rem;
  line-height: 1.15;
}

.cat-page-hero-desc {
  font-size: 1.05rem;
  line-height: 1.7;
  color: rgba(255,255,255,.88);
  margin: 0;
  font-weight: 300;
}

/* =====================
   Category Page — Filter Bar
   ===================== */
.cat-filter-bar-wrap {
  background: var(--color-white);
  border-bottom: 1px solid var(--color-border);
  position: sticky;
  top: 70px;
  z-index: 10;
  box-shadow: 0 2px 8px rgba(0,0,0,.05);
}

.cat-filter-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .75rem 0;
  flex-wrap: wrap;
}

.cat-filter-pills {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
}

.cat-filter-pill {
  display: inline-flex;
  align-items: center;
  padding: .38rem .9rem;
  border-radius: 2rem;
  border: 1.5px solid var(--color-border);
  background: transparent;
  font-size: .83rem;
  font-weight: 500;
  color: var(--color-text);
  text-decoration: none;
  transition: var(--transition);
  line-height: 1.5;
}
.cat-filter-pill:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
  background: var(--color-primary-light);
}
.cat-filter-pill.active {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}

.cat-filter-count {
  font-size: .82rem;
  color: var(--color-text-muted);
  white-space: nowrap;
}

/* =====================
   Category Page — Grid
   ===================== */
.cat-page-grid-wrap {
  padding-top: 2.5rem;
  padding-bottom: 3rem;
}

.cat-empty-state {
  text-align: center;
  padding: 4rem 1rem;
  color: var(--color-text-muted);
}
.cat-empty-state i { font-size: 3rem; display: block; margin-bottom: 1rem; opacity: .5; }

.cat-pagination {
  display: flex;
  justify-content: center;
  margin-top: 3rem;
}

/* Legacy sort-bar (kept for other uses) */
.sort-bar {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: .5rem 1rem;
  display: flex; align-items: center; gap: .5rem; flex-wrap: wrap;
  margin-bottom: 1.25rem;
}
.sort-label { font-size: .82rem; font-weight: 600; color: var(--color-text-muted); white-space: nowrap; }
.sort-btn {
  padding: .3rem .85rem; border-radius: 2rem;
  border: 1.5px solid var(--color-border);
  background: transparent; font-size: .83rem; font-weight: 500;
  color: var(--color-text); cursor: pointer; transition: var(--transition);
  text-decoration: none; display: inline-block; line-height: 1.5;
}
.sort-btn:hover  { background: var(--color-primary-light); border-color: var(--color-primary); color: var(--color-primary); }
.sort-btn.active { background: var(--color-primary); border-color: var(--color-primary); color: #fff; }

/* =====================
   Sidebar
   ===================== */
.sidebar-widget {
  background: var(--color-white); border: 1px solid var(--color-border);
  border-radius: var(--radius); padding: 1.25rem; margin-bottom: 1.5rem;
}
.sidebar-widget h5 {
  font-weight: 700; color: var(--color-dark);
  border-bottom: 2px solid var(--color-primary-light); padding-bottom: .5rem; margin-bottom: 1rem;
}
.sidebar-rank { min-width: 22px; }
.hover-bg-light:hover { background: var(--color-bg); border-radius: .375rem; }

/* =====================
   Newsletter
   ===================== */
.newsletter-section { background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary) 100%); border-radius: var(--radius); }

/* =====================
   Footer
   ===================== */
.footer-dark               { background: var(--color-dark); color: #C8D0E0; }
.footer-dark p             { color: #C8D0E0; }
.footer-dark .text-muted   { color: #C8D0E0 !important; }
.footer-heading            { font-size: .875rem; text-transform: uppercase; letter-spacing: .05em; color: #FFFFFF; }
.footer-links              { list-style: none; padding: 0; margin: 0; }
.footer-links li           { margin-bottom: .5rem; }
.footer-links a            { color: #C8D0E0; text-decoration: none; transition: color .2s; font-size: .9rem; }
.footer-links a:hover      { color: #FFFFFF; }
.footer-social-btn         { border-color: #dbe3f0; color: #ffffff; }
.footer-social-btn:hover,
.footer-social-btn:focus   { background: #ffffff; color: #1a1a2e; border-color: #ffffff; }

/* =====================
   Search Autocomplete
   ===================== */
#search-results .search-result-item {
  padding: .75rem 1rem; border-bottom: 1px solid var(--color-border);
  cursor: pointer; transition: background .15s; font-size: .9rem;
}
#search-results .search-result-item:last-child { border-bottom: none; }
#search-results .search-result-item:hover { background: var(--color-primary-light); }

/* =====================
   Search Page
   ===================== */
.search-page-hero {
  background:
    radial-gradient(420px 220px at 15% 12%, rgba(255,255,255,.18), transparent 68%),
    linear-gradient(135deg, var(--color-primary) 0%, var(--color-secondary) 100%);
  color: #fff;
}

.search-page-title {
  color: #fff;
  font-family: 'Playfair Display', Georgia, serif;
  text-shadow: 0 2px 10px rgba(0,0,0,.18);
}

.search-page-input-group {
  background: rgba(255,255,255,.18);
  border: 1px solid rgba(255,255,255,.28);
  border-radius: .8rem;
  overflow: hidden;
}

.search-page-input-group .form-control {
  background: rgba(255,255,255,.95);
  color: var(--color-dark);
}

.search-page-input-group .form-control::placeholder {
  color: #7c8794;
}

.search-page-input-group .form-control:focus {
  box-shadow: none;
}

.search-page-submit-btn {
  background: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
  color: #fff;
}

.search-page-submit-btn:hover,
.search-page-submit-btn:focus {
  background: #6f0b40;
  border-color: #6f0b40;
  color: #fff;
}

.search-page-meta {
  color: rgba(255,255,255,.82);
}

.search-page-query {
  color: #fff;
}

/* =====================
   Cookie Banner
   ===================== */
#cookie-banner {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 10000;
  background: var(--color-dark); color: #e5e7eb; padding: 1rem 1.5rem;
  border-top: 3px solid var(--color-accent);
  display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap;
}

#cookie-banner .cookie-actions {
  flex-wrap: wrap;
}

#cookie-banner .cookie-actions .btn {
  white-space: nowrap;
}

/* =====================
   Reading Progress
   ===================== */
.reading-progress {
  position: fixed; top: 0; left: 0; height: 3px;
  background: var(--color-primary); z-index: 9999; width: 0%; transition: width .1s linear;
}

/* =====================
   FAQ
   ===================== */
.accordion-item { transition: var(--transition); }
.accordion-item:hover { border-color: var(--color-primary) !important; box-shadow: var(--shadow-sm); }
.accordion-button:not(.collapsed) { background: var(--color-primary-light); color: var(--color-primary); box-shadow: none; }
.accordion-button:focus { box-shadow: 0 0 0 .2rem rgba(194,24,91,.2); }

/* =====================
   Stars / Rating
   ===================== */
.star-rating i { font-size: 1rem; }
.rating-stars  { color: #f59e0b; }

/* =====================
   Pagination
   ===================== */
.pagination .page-link {
  color: var(--color-primary); border-color: var(--color-border);
  border-radius: .375rem; margin: 0 .15rem; transition: var(--transition);
}
.pagination .page-link:hover { background: var(--color-primary-light); border-color: var(--color-primary-light); }
.pagination .page-item.active .page-link   { background: var(--color-primary); border-color: var(--color-primary); color: #fff; }
.pagination .page-item.disabled .page-link { color: var(--color-text-muted); }

/* =====================
   Admin Panel
   ===================== */
.admin-sidebar { min-height: 100vh; background: var(--color-dark); box-shadow: 2px 0 8px rgba(0,0,0,.2); }
.admin-sidebar .sidebar-brand {
  display: flex; align-items: center; gap: .5rem; padding: 1.25rem 1.5rem;
  font-size: 1.15rem; font-weight: 800; color: #fff; text-decoration: none;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.admin-sidebar .sidebar-brand span { color: var(--color-accent); }
.admin-sidebar .nav-section {
  font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em;
  color: #6b7280; padding: 1rem 1.5rem .25rem;
}
.admin-sidebar .nav-link {
  color: #9ca3af; padding: .55rem 1.25rem; border-radius: .5rem;
  margin: .1rem .75rem; transition: var(--transition); font-size: .9rem;
  display: flex; align-items: center; gap: .6rem;
}
.admin-sidebar .nav-link:hover,
.admin-sidebar .nav-link.active { color: #fff; background: rgba(255,255,255,.1); }
.admin-sidebar .nav-link i { width: 1.25rem; text-align: center; }

.admin-topbar {
  background: var(--color-white); border-bottom: 1px solid var(--color-border);
  padding: .75rem 1.5rem; box-shadow: var(--shadow-sm);
}
.admin-card {
  background: var(--color-white); border-radius: var(--radius);
  box-shadow: var(--shadow-sm); border: 1px solid var(--color-border); overflow: hidden;
}

.stat-card        { border-left: 4px solid; border-radius: var(--radius); }
.stat-card-blue   { border-left-color: var(--color-primary); }
.stat-card-pink   { border-left-color: var(--color-accent); }
.stat-card-green  { border-left-color: var(--color-success); }
.stat-card-orange { border-left-color: var(--color-warning); }

/* =====================
   Auth
   ===================== */
.auth-card { max-width: 420px; margin: 4rem auto; }

/* =====================
   Responsive
   ===================== */
@media (max-width: 1199.98px) {
  .hero-icon-ring { width: 160px; height: 160px; }
  .hero-big-icon  { font-size: 3.5rem; }
}

@media (max-width: 991.98px) {
  .hero-section  { min-height: 320px; }
  .min-vh-hero   { min-height: 280px; }
  .hero-title    { font-size: 1.9rem !important; }
  .hero-subtitle { font-size: 1rem !important; }
  #search-wrapper .form-control       { width: 100%; }
  #search-wrapper .form-control:focus { width: 100%; }
  .pros-cons-grid { grid-template-columns: 1fr; }
}

@media (max-width: 767.98px) {
  h1                { font-size: 1.65rem; }
  h2                { font-size: 1.3rem; }
  .article-title    { font-size: 1.4rem; }
  .article-hero-img { max-height: 240px; }
  #cookie-banner    { flex-direction: column; text-align: center; }
  #cookie-banner .cookie-actions { justify-content: center !important; width: 100%; }
  .hero-trust       { justify-content: center; }
  .sort-bar         { justify-content: center; }
}

/* =====================
   Home UI V2
   ===================== */
.home-v2 {
  background: color-mix(in srgb, var(--color-primary-light) 72%, #ffffff);
  padding-bottom: 3rem;
}

.home-v2 .home-hero {
  height: clamp(280px, 42vw, 460px);
  background: color-mix(in srgb, var(--color-primary-light) 55%, #fff7fb);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

@keyframes homeHeroLightFloatLeft {
  0% {
    transform: translate3d(0, 0, 0) scale(1);
    opacity: 0.9;
  }
  50% {
    transform: translate3d(4%, -3%, 0) scale(1.08);
    opacity: 1;
  }
  100% {
    transform: translate3d(0, 0, 0) scale(1);
    opacity: 0.9;
  }
}

@keyframes homeHeroLightFloatRight {
  0% {
    transform: translate3d(0, 0, 0) scale(1);
    opacity: 0.84;
  }
  50% {
    transform: translate3d(-4%, 3%, 0) scale(1.08);
    opacity: 0.98;
  }
  100% {
    transform: translate3d(0, 0, 0) scale(1);
    opacity: 0.84;
  }
}

@keyframes homeHeroImageOverlayPulse {
  0% {
    opacity: 0.3;
  }
  50% {
    opacity: 0.5;
  }
  100% {
    opacity: 0.3;
  }
}

@keyframes homeHeroSearchGlowPulse {
  0% {
    transform: scale(0.96);
    opacity: 0.35;
  }
  50% {
    transform: scale(1.04);
    opacity: 0.78;
  }
  100% {
    transform: scale(0.96);
    opacity: 0.35;
  }
}

/* Left primary blob — blurred pseudo-element for natural bokeh feel */
.home-v2 .home-hero::before {
  content: '';
  position: absolute;
  width: 55%;
  height: 200%;
  top: -50%;
  left: -14%;
  background: radial-gradient(ellipse at 40% 50%,
    color-mix(in srgb, var(--color-primary) 92%, #ffffff) 0%,
    color-mix(in srgb, var(--color-primary) 66%, #ffffff) 30%,
    color-mix(in srgb, var(--color-primary) 20%, #ffffff) 60%,
    transparent 80%);
  border-radius: 52% 48% 55% 45% / 45% 52% 48% 55%;
  filter: blur(38px);
  opacity: 0.9;
  transform-origin: 40% 50%;
  animation: homeHeroLightFloatLeft 10s ease-in-out infinite;
  will-change: transform, opacity;
  z-index: 0;
  pointer-events: none;
}

/* Right accent blob from secondary palette */
.home-v2 .home-hero::after {
  content: '';
  position: absolute;
  width: 52%;
  height: 190%;
  top: -45%;
  right: -12%;
  background: radial-gradient(ellipse at 60% 50%,
    color-mix(in srgb, var(--color-secondary) 86%, #ffffff) 0%,
    color-mix(in srgb, var(--color-secondary) 60%, #ffffff) 30%,
    color-mix(in srgb, var(--color-secondary) 18%, #ffffff) 60%,
    transparent 80%);
  border-radius: 48% 52% 45% 55% / 55% 45% 52% 48%;
  filter: blur(36px);
  opacity: 0.84;
  transform-origin: 60% 50%;
  animation: homeHeroLightFloatRight 12s ease-in-out infinite;
  will-change: transform, opacity;
  z-index: 0;
  pointer-events: none;
}

.home-v2 .home-hero.home-hero-has-bg {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.home-v2 .home-hero.home-hero-has-bg::before { display: none; }
.home-v2 .home-hero.home-hero-has-bg::after {
  inset: 0;
  width: 100%; height: 100%;
  top: 0; right: 0;
  background:
    radial-gradient(circle at 20% 40%, color-mix(in srgb, var(--color-primary) 52%, transparent), transparent 56%),
    radial-gradient(circle at 80% 60%, color-mix(in srgb, var(--color-secondary) 48%, transparent), transparent 58%),
    rgba(0,0,0,.16);
  filter: none;
  border-radius: 0;
  animation: homeHeroImageOverlayPulse 6.5s ease-in-out infinite;
  will-change: opacity;
}

@media (prefers-reduced-motion: reduce) {
  .home-v2 .home-hero::before,
  .home-v2 .home-hero::after,
  .home-v2 .home-hero-search-wrap::before {
    animation: none;
  }
}

.home-v2 .home-hero-search-wrap {
  width: min(700px, 90vw);
  z-index: 2;
  padding-inline: 1rem;
  position: relative;
}

.home-v2 .home-hero-search-wrap::before {
  content: '';
  position: absolute;
  inset: -18px;
  background:
    radial-gradient(circle at 30% 50%, color-mix(in srgb, var(--color-primary) 62%, transparent), transparent 58%),
    radial-gradient(circle at 70% 50%, color-mix(in srgb, var(--color-secondary) 58%, transparent), transparent 60%);
  filter: blur(24px);
  border-radius: 22px;
  z-index: -1;
  pointer-events: none;
  animation: homeHeroSearchGlowPulse 5s ease-in-out infinite;
}

.home-v2 .home-hero-search {
  background: #ffffff;
  border: none;
  border-radius: 0.9rem;
  min-height: 58px;
  box-shadow:
    0 16px 48px color-mix(in srgb, var(--color-primary) 22%, transparent),
    0 4px 16px color-mix(in srgb, var(--color-primary) 12%, transparent);
  display: flex;
  align-items: stretch;
  overflow: hidden;
}

.home-v2 .home-hero-search-icon {
  width: 64px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: stretch;
  background: var(--color-primary);
  color: #fff;
  font-size: 1.35rem;
  border: none;
  padding: 0;
  cursor: pointer;
  border-radius: 0;
  transition: background .18s ease;
}

.home-v2 .home-hero-search-icon:hover {
  background: var(--color-primary-dark);
}

.home-v2 .home-hero-search input {
  border: 0;
  outline: 0;
  background: transparent;
  padding: 1.1rem 1.2rem;
  min-height: 58px;
  line-height: 1.25;
  width: 100%;
  color: #1a2820;
  font-size: 1.05rem;
}

.home-v2 .home-hero-search input::placeholder {
  color: #8c9e94;
}

.home-v2 .home-heading-block {
  text-align: center;
  padding-top: 3rem;
  padding-bottom: 1.4rem;
  min-height: 170px;
}

.home-v2 .home-heading-block h1 {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: clamp(2rem, 3.8vw, 3.3rem);
  margin-bottom: 0.5rem;
  color: #141d18;
}

.home-v2 .home-heading-block p {
  max-width: 760px;
  margin: 0 auto;
  font-size: 1.08rem;
  color: #33443a;
}

.home-v2 .micro-label {
  display: block;
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 700;
  color: #4f6355;
  margin-bottom: 0.6rem;
}

.home-v2 .home-topic-row {
  margin-top: 0.4rem;
}

.home-v2 .topic-pill-track-wrap {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.home-v2 .topic-pill-track {
  flex: 1;
  display: flex;
  gap: 0.55rem;
  overflow-x: auto;
  padding: 0.25rem 0.1rem 0.5rem;
  scrollbar-width: none;
}

.home-v2 .topic-pill-track::-webkit-scrollbar { display: none; }

.home-v2 .pill-scroll-btn {
  flex: 0 0 auto;
  width: 34px; height: 34px;
  border: 1.5px solid #c5d2c5;
  background: #fff;
  border-radius: 50%;
  display: none;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: #4a6b52;
  font-size: 0.9rem;
  transition: all .18s ease;
  box-shadow: 0 1px 4px rgba(0,0,0,.08);
}

.home-v2 .pill-scroll-btn:hover {
  background: #e8f0e8;
  border-color: #7f9b7d;
  color: #2d4d35;
}

.home-v2 .topic-pill {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  text-decoration: none;
  color: #203229;
  border: 1px solid color-mix(in srgb, var(--pill-color) 40%, #d6dfd5);
  background: color-mix(in srgb, var(--pill-color) 8%, #f5f7f3);
  padding: 0.5rem 0.95rem;
  border-radius: 999px;
  font-size: 0.9rem;
  font-weight: 600;
  transition: all .2s ease;
}

.home-v2 .topic-pill:hover {
  transform: translateY(-1px);
  background: color-mix(in srgb, var(--pill-color) 14%, #f4f8f3);
  color: #111;
}

.home-v2 .topic-pill i {
  font-size: 0.86rem;
}

.home-v2 .home-content-stack {
  display: grid;
  gap: 2.3rem;
  margin-top: 1.2rem;
}

.home-v2 .home-section-title {
  margin-bottom: 1rem;
  font-size: clamp(1.5rem, 2.4vw, 2.1rem);
  color: #101915;
}

.home-v2 .article-card,
.home-v2 .home-review-tile {
  border: 1px solid #dae4da !important;
  border-radius: 14px !important;
  box-shadow: 0 8px 22px rgba(42, 55, 48, 0.08) !important;
  background: #fbfdf9;
}

.home-v2 #videos-section .card {
  border: 1px solid #dae4da !important;
  border-radius: 14px !important;
  box-shadow: 0 8px 22px rgba(42, 55, 48, 0.08) !important;
  background: #fbfdf9;
}

.home-v2 #videos-section .home-video-thumb {
  position: relative;
  width: 100%;
  background: #111;
  overflow: hidden;
}

.home-v2 #videos-section .home-video-thumb::before {
  content: "";
  display: block;
  padding-top: 56.25%;
}

.home-v2 #videos-section .home-video-thumb .home-video-thumb-inner {
  position: absolute;
  inset: 0;
}

.home-v2 #videos-section .card .card-body {
  padding: 0.75rem 0.85rem;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.home-v2 #videos-section .card .card-body h3,
.home-v2 #videos-section .card .card-body .h5 {
  margin-bottom: 0;
  font-size: 0.94rem;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.home-v2 #videos-section .card .card-body p {
  margin-bottom: 0;
  color: #4f5f56;
  font-size: 0.8rem;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.home-v2 #videos-section .card .card-body > .small {
  font-size: 0.74rem !important;
  flex-wrap: nowrap !important;
  overflow: hidden;
}

.home-v2 #videos-section .card .card-body > .small > span:first-child {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.home-v2 .article-card .article-card-body {
  padding: 0.9rem 0.95rem;
}

.home-v2 .article-card .article-card-title {
  font-size: 0.98rem;
}

.home-v2 .article-card .article-card-excerpt {
  font-size: 0.82rem;
  color: #4d5e54 !important;
}

.home-v2 .article-card-img-wrap {
  height: 182px;
}

.home-v2 .article-card .article-card-badge {
  font-size: 0.67rem;
  font-weight: 600;
  padding: 0.22rem 0.54rem;
}

.home-v2 .home-review-tile {
  position: relative;
  padding: 0.95rem;
}

.home-v2 .home-review-media {
  height: 168px;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid #ead6e3;
  background: linear-gradient(135deg, color-mix(in srgb, var(--color-primary-light) 72%, #fff) 0%, color-mix(in srgb, var(--color-secondary-light) 78%, #fff) 100%);
}

.home-v2 .home-review-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.home-v2 .home-review-img-fallback {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  font-size: 2rem;
}

.home-v2 .home-review-link {
  text-decoration: none;
  color: #1f2924;
  font-weight: 700;
  display: inline-block;
  margin-bottom: 0.35rem;
}

.home-v2 .home-review-link:hover {
  color: #39553f;
}

.home-v2 .home-review-tile p {
  margin-bottom: 0.45rem;
  color: #4f5f56;
  font-size: 0.84rem;
}

.home-v2 .home-review-stars {
  color: #d4a72c;
  display: flex;
  gap: 0.14rem;
}

@media (max-width: 991.98px) {
  .home-v2 .home-heading-block {
    padding-top: 2.2rem;
  }

  .home-v2 .home-heading-block p {
    font-size: 1rem;
  }

  .home-v2 .article-card-img-wrap {
    height: 196px;
  }

  .home-v2 .home-review-media {
    height: 188px;
  }
}

/* Review tile badges */
.badge {
  --bs-badge-color: #080808;
}

.badge.text-bg-danger-subtle {
  --bs-badge-color: #080808;
  color: #080808 !important;
}

.home-v2 .home-review-tile-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
  margin-bottom: 0.55rem;
}

.home-v2 .home-review-tile-badges .badge {
  font-size: 0.65rem;
  font-weight: 600;
  padding: 0.28rem 0.5rem;
  border-radius: 999px;
}

/* Footer newsletter */
.footer-newsletter-form .form-control {
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.2);
  color: #e5e7eb;
  font-size: 0.875rem;
}
.footer-newsletter-form .form-control::placeholder { color: #9ca3af; }
.footer-newsletter-form .form-control:focus {
  background: rgba(255,255,255,.13);
  border-color: rgba(255,255,255,.35);
  box-shadow: none;
  color: #fff;
}
.footer-newsletter-form .btn-subscribe {
  background: #5a8a5e;
  border-color: #5a8a5e;
  color: #fff;
  font-weight: 600;
  font-size: 0.875rem;
}
.footer-newsletter-form .btn-subscribe:hover {
  background: #4a7550;
  border-color: #4a7550;
}

@media (max-width: 767.98px) {
  .home-v2 {
    padding-bottom: 2rem;
  }

  .home-v2 .home-hero {
    min-height: 280px;
  }

  .home-v2 .home-heading-block {
    min-height: 150px;
  }

  .home-v2 .home-hero-search input {
    font-size: 0.98rem;
    padding: 0.9rem 0.95rem;
    min-height: 52px;
  }

  .home-v2 .home-hero-search-icon {
    width: 54px;
    font-size: 1.2rem;
    padding: 0;
  }

  .home-v2 .home-hero-search {
    min-height: 52px;
  }

  .home-v2 .home-content-stack {
    margin-top: 0.6rem;
    gap: 1.9rem;
  }

  .home-v2 .pill-scroll-btn {
    display: none;
  }
}

/* =====================
   Category Page — Responsive
   ===================== */
@media (max-width: 767.98px) {
  .cat-page-hero {
    padding: 2.5rem 0 2rem;
  }
  .cat-page-hero-title {
    font-size: 2rem;
  }
  .cat-page-hero-desc {
    font-size: .95rem;
  }
  .cat-filter-bar-wrap {
    top: 62px;
  }
  .cat-filter-bar {
    flex-direction: column;
    align-items: flex-start;
    gap: .6rem;
  }
  .cat-filter-count {
    order: -1;
    color: var(--color-text-muted);
  }

  .article-v3-hero {
    min-height: 44vh;
  }

  .article-v3-hero-content {
    padding-top: 2.4rem;
    padding-bottom: 1.8rem;
  }

  .article-v3-title {
    font-size: 1.85rem;
  }

  .article-v3-meta {
    font-size: .82rem;
    gap: .5rem .8rem;
  }

  .article-v3-main {
    padding-top: 1.5rem !important;
  }

  .article-v3-lead {
    font-size: 1rem;
    line-height: 1.75;
  }
}

@media (max-width: 991.98px) {
  .article-v3-sticky-right,
  .article-v3-sticky-left {
    position: static;
    top: auto;
  }
}
