/*
Theme Name: Heimvorteil24
Theme URI: https://heimvorteil24.de
Author: Lauktien & Friends
Description: Custom Theme für heimvorteil24.de — D3 Dossier-Stil mit D1 Editorial-Akzenten. Smart Home, Küche, Kaffee.
Version: 1.0.0
Requires at least: 6.4
Tested up to: 6.9
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: heimvorteil24
*/

/* ==========================================================
   FONTS
   ========================================================== */
@import url("https://fonts.googleapis.com/css2?family=Instrument+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap");

/* ==========================================================
   DESIGN TOKENS
   ========================================================== */
:root {
  --hv-gold-900: #8b6a3b;
  --hv-gold-700: #a7875a;
  --hv-gold-500: #c8a374;
  --hv-gold-300: #e3c8a3;
  --hv-gold-100: #f1e4cf;
  --hv-gold-50:  #f8ecd9;
  --hv-cream-50:  #fff9f0;
  --hv-cream-100: #fdf3e3;
  --hv-cream-200: #f8ecd9;
  --hv-cream-25:  #f9f3ea;
  --hv-offwhite:  #fffdf8;
  --hv-paper:     #ffffff;
  --hv-ink-900: #1f1a14;
  --hv-ink-700: #3a322a;
  --hv-ink-500: #5c5148;
  --hv-ink-300: #8a7f74;
  --hv-ink-200: #bcb1a4;
  --hv-check:   #4f9b5c;
  --hv-price:   #c19a5b;
  --border:        #ece2d1;
  --border-strong: #d9c7a8;
  --font-serif: "Playfair Display", Georgia, "Times New Roman", serif;
  --font-hand:  "Lumios Marker", "Caveat", cursive;
  --font-sans:  "Instrument Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --shadow-card:  0 10px 30px -16px rgba(90,63,25,.18), 0 2px 6px -2px rgba(90,63,25,.06);
  --shadow-hover: 0 14px 40px -16px rgba(90,63,25,.28), 0 3px 8px -2px rgba(90,63,25,.08);
  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 14px;
  --r-pill: 999px;
}

/* ==========================================================
   GLOBAL BASE
   ========================================================== */
*, *::before, *::after { box-sizing: border-box; }

body {
  margin: 0;
  background: var(--hv-cream-50);
  color: var(--hv-ink-500);
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

/* Blurry warm background */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  background:
    radial-gradient(ellipse at 15% 25%, rgba(200,163,116,.18) 0%, transparent 55%),
    radial-gradient(ellipse at 85% 75%, rgba(200,163,116,.14) 0%, transparent 50%),
    radial-gradient(ellipse at 50% 50%, rgba(248,236,217,.3) 0%, transparent 70%);
  z-index: -1;
  pointer-events: none;
}

a { color: var(--hv-gold-700); text-decoration: none; transition: color .15s; }
a:hover { color: var(--hv-gold-900); }

img { max-width: 100%; height: auto; }

/* ==========================================================
   TYPOGRAPHY
   ========================================================== */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-serif);
  color: var(--hv-ink-700);
  line-height: 1.15;
  letter-spacing: -0.005em;
  margin-top: 0;
}
h1 { font-size: 40px; font-weight: 700; margin-bottom: 16px; }
h2 { font-size: 30px; font-weight: 700; line-height: 1.3; margin-bottom: 16px; }
h3 { font-size: 22px; font-weight: 600; margin-bottom: 12px; }
h4 { font-size: 18px; font-weight: 600; }

p { color: var(--hv-ink-500); line-height: 1.7; margin: 0 0 16px; }

.eyebrow, .hv-eyebrow {
  font-family: var(--font-sans);
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--hv-gold-700);
  font-size: 13px;
  font-weight: 600;
}

.lead {
  font-size: 18px;
  line-height: 1.55;
  color: var(--hv-ink-500);
}

/* ==========================================================
   LAYOUT — D3 Boxed Dossier
   ========================================================== */
.hv-site-wrapper {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.hv-main-box {
  max-width: 1100px;
  margin: 24px auto 40px;
  background: var(--hv-paper);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  position: relative;
  z-index: 1;
  width: 100%;
}

.hv-content-inner {
  padding: 48px 64px 64px;
}

/* ==========================================================
   HEADER
   ========================================================== */
.hv-header {
  position: relative;
  z-index: 100;
  background: var(--hv-cream-50);
  padding: 14px 40px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid rgba(139,106,59,.08);
}

.hv-header__logo img {
  height: 52px;
  display: block;
}

.hv-nav {
  display: flex;
  gap: 30px;
  font-family: var(--font-serif);
  font-size: 17px;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
}

.hv-nav > li {
  position: relative;
}

.hv-nav > li > a {
  color: var(--hv-gold-700);
  padding: 10px 2px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  transition: color .15s;
}
.hv-nav > li > a:hover { color: var(--hv-gold-900); }

.hv-nav .caret {
  font-size: .75em;
  opacity: .65;
  transition: transform .2s;
}
.hv-nav > li:hover .caret { transform: rotate(180deg); }

/* Dropdown */
.hv-nav .sub-menu {
  position: absolute;
  top: calc(100% + 6px);
  left: -16px;
  background: #fff;
  border-radius: var(--r-md);
  padding: 10px;
  min-width: 260px;
  box-shadow: var(--shadow-card);
  border: 1px solid var(--border);
  z-index: 10;
  list-style: none;
  margin: 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  transition: opacity .15s, transform .15s, visibility .15s;
}
.hv-nav > li:hover > .sub-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.hv-nav .sub-menu a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border-radius: 7px;
  font-family: var(--font-sans);
  font-size: 15px;
  color: var(--hv-ink-700);
  white-space: nowrap;
  transition: background .12s;
}
.hv-nav .sub-menu a:hover {
  background: var(--hv-cream-50);
  color: var(--hv-gold-900);
}

/* Mobile menu toggle */
.hv-menu-toggle {
  display: none;
  background: none;
  border: none;
  font-size: 24px;
  color: var(--hv-gold-700);
  cursor: pointer;
  padding: 8px;
}

/* ==========================================================
   FOOTER
   ========================================================== */
.hv-footer {
  position: relative;
  z-index: 2;
  background: var(--hv-cream-100);
  padding: 36px 64px 28px;
  color: var(--hv-ink-300);
  font-size: 13px;
  border-top: 1px solid rgba(139,106,59,.08);
}

.hv-footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 48px;
  max-width: 1000px;
  margin: 0 auto 24px;
}

.hv-footer__brand img {
  height: 44px;
  margin-bottom: 10px;
}
.hv-footer__brand p {
  margin: 8px 0 0;
  color: var(--hv-ink-500);
  font-size: 13px;
  max-width: 260px;
  line-height: 1.55;
}

.hv-footer h5 {
  font-family: var(--font-serif);
  color: var(--hv-ink-700);
  margin: 0 0 10px;
  font-size: 14px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .1em;
}

.hv-footer ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.hv-footer li { margin: 6px 0; }
.hv-footer a { color: var(--hv-ink-500); }
.hv-footer a:hover { color: var(--hv-gold-700); }

.hv-footer__bar {
  max-width: 1000px;
  margin: 0 auto;
  padding-top: 18px;
  border-top: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
  color: var(--hv-ink-300);
}

/* ==========================================================
   BREADCRUMBS
   ========================================================== */
.hv-breadcrumb {
  font-size: 13px;
  color: var(--hv-ink-300);
  margin-bottom: 18px;
}
.hv-breadcrumb a { color: var(--hv-gold-700); }
.hv-breadcrumb .sep { margin: 0 8px; opacity: .5; }

/* ==========================================================
   ARTICLE / ENTRY STYLES
   ========================================================== */
.hv-article-header {
  margin-bottom: 32px;
}
.hv-article-header .eyebrow {
  margin-bottom: 14px;
}
.hv-article-meta {
  font-size: 14px;
  color: var(--hv-ink-300);
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 14px;
}
.hv-article-meta .author-dot {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--hv-gold-300);
  display: grid;
  place-items: center;
  color: var(--hv-gold-900);
  font-family: var(--font-serif);
  font-weight: 700;
  font-size: 13px;
}

/* Featured image */
.hv-featured-image {
  margin: 0 -64px 32px;
  overflow: hidden;
}
.hv-featured-image img {
  width: 100%;
  height: auto;
  display: block;
}

/* Entry content */
.entry-content {
  max-width: 720px;
}

.entry-content p {
  font-size: 17px;
  line-height: 1.75;
  color: var(--hv-ink-500);
  margin-bottom: 20px;
}

.entry-content h2 {
  margin-top: 48px;
}

.entry-content h3 {
  margin-top: 36px;
}

/* Blockquote / Pull-Quote */
.entry-content blockquote,
.wp-block-quote {
  padding: 26px 28px;
  border-left: 3px solid var(--hv-gold-500);
  background: var(--hv-cream-25);
  border-radius: 0 var(--r-md) var(--r-md) 0;
  margin: 28px 0;
}
.entry-content blockquote p {
  font-family: var(--font-hand);
  font-size: 24px;
  color: var(--hv-gold-700);
  line-height: 1.4;
  margin: 0;
}
.entry-content blockquote cite {
  display: block;
  font-family: var(--font-sans);
  font-size: 12px;
  color: var(--hv-ink-300);
  font-style: normal;
  margin-top: 10px;
}

/* ==========================================================
   ARCHIVE / CATEGORY PAGES
   ========================================================== */
.hv-archive-header {
  padding-bottom: 24px;
  border-bottom: 2px solid var(--hv-ink-900);
  margin-bottom: 28px;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}
.hv-archive-header h1 {
  margin: 8px 0 10px;
}
.hv-archive-header .hv-archive-meta {
  text-align: right;
  font-size: 12px;
  color: var(--hv-ink-300);
}
.hv-archive-header .hv-archive-count {
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 700;
  color: var(--hv-ink-900);
}

/* Post cards on archive */
.hv-post-list {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.hv-post-card {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 24px;
  align-items: center;
  background: var(--hv-paper);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 20px 24px;
  transition: box-shadow .2s, transform .2s;
}
.hv-post-card:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-2px);
}

.hv-post-card__thumb {
  border-radius: var(--r-md);
  overflow: hidden;
  aspect-ratio: 16/10;
}
.hv-post-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hv-post-card__content .eyebrow { margin-bottom: 4px; }
.hv-post-card__title {
  font-family: var(--font-serif);
  font-size: 20px;
  font-weight: 700;
  color: var(--hv-ink-700);
  margin: 0 0 8px;
  line-height: 1.25;
}
.hv-post-card__title a { color: inherit; }
.hv-post-card__title a:hover { color: var(--hv-gold-900); }

.hv-post-card__excerpt {
  font-size: 14px;
  color: var(--hv-ink-300);
  line-height: 1.5;
  margin: 0;
}

/* ==========================================================
   ANIMATED GOLD BUTTON (shared)
   ========================================================== */
@keyframes hv-wabern {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

.hv-btn {
  font-family: var(--font-sans);
  font-size: 15px;
  font-weight: 500;
  color: #fff;
  border: 0;
  border-radius: var(--r-md);
  padding: 12px 22px;
  cursor: pointer;
  background-image: linear-gradient(100deg, #bc9768 0%, #d6b184 30%, #e6c294 50%, #d6b184 70%, #bc9768 100%);
  background-size: 220% 100%;
  background-position: 0% 50%;
  animation: hv-wabern 5.5s ease-in-out infinite;
  box-shadow: 0 2px 0 0 rgba(139,106,59,.35), 0 4px 10px -2px rgba(139,106,59,.35);
  transition: filter .2s, box-shadow .2s, transform .1s;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  letter-spacing: .01em;
  text-decoration: none;
}
.hv-btn:hover {
  filter: saturate(1.15) brightness(1.06);
  box-shadow: 0 2px 0 0 rgba(139,106,59,.45), 0 6px 14px -2px rgba(200,163,116,.6);
  color: #fff;
}
.hv-btn:active { transform: translateY(1px); }
.hv-btn.block { width: 100%; justify-content: center; }
.hv-btn.ghost {
  background: transparent;
  color: var(--hv-gold-900);
  animation: none;
  border: 1px solid var(--border-strong);
  box-shadow: none;
}
.hv-btn.ghost:hover { background: var(--hv-cream-50); filter: none; box-shadow: none; }

/* ==========================================================
   SHORTCODES
   ========================================================== */

/* ── hv_table — Vergleichs-Card-Grid ── */
.hv-cards {
  display: grid;
  grid-template-columns: 1fr 1.06fr 1fr;
  gap: 18px;
  margin: 2.5em 0;
  align-items: stretch;
  font-family: var(--font-sans);
}

.hv-card {
  background: var(--hv-paper);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-card);
  display: flex;
  flex-direction: column;
  border: 1px solid var(--border);
  transition: box-shadow .2s, transform .2s;
  overflow: hidden;
}
.hv-card:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-2px);
}

.hv-card__hd {
  height: 72px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 0 14px;
  background: var(--hv-cream-200);
  text-align: center;
}
.hv-card--hl { margin-top: -10px; }
.hv-card--hl .hv-card__hd {
  height: 82px;
  background: var(--hv-gold-500);
}

.hv-badge {
  display: block;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: rgba(255,255,255,.92);
  margin-bottom: 5px;
}

.hv-card__title {
  display: block;
  font-family: var(--font-serif);
  font-size: 16px;
  font-weight: 600;
  color: var(--hv-ink-700);
  line-height: 1.3;
}
.hv-card--hl .hv-card__title { color: #fff; }

.hv-card__features {
  list-style: none;
  padding: 14px 18px;
  margin: 0;
  font-size: 14px;
  color: var(--hv-ink-500);
  flex: 1;
}
.hv-card__features li {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 4px 0;
}

.hv-card__feat-check {
  width: 18px;
  height: 18px;
  display: inline-grid;
  place-items: center;
  border-radius: var(--r-pill);
  background: #c6e5cb;
  color: #3d7a48;
  font-size: 11px;
  font-weight: 900;
  flex-shrink: 0;
}

.hv-card__price {
  font-family: var(--font-serif);
  font-weight: 700;
  color: var(--hv-price);
  font-size: 22px;
  text-align: center;
  padding: 12px 0 4px;
  border-top: 1px dashed var(--border);
}

.hv-card__btn {
  width: 100%;
  text-align: center;
  padding: 14px 18px 20px;
}

/* AAWP button inside cards */
.hv-card__btn .aawp-button,
.hv-card__btn a.aawp-button {
  display: inline-block !important;
  font-family: var(--font-sans) !important;
  font-size: 15px !important;
  font-weight: 500 !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: var(--r-md) !important;
  padding: 12px 22px !important;
  background-image: linear-gradient(100deg, #bc9768 0%, #d6b184 30%, #e6c294 50%, #d6b184 70%, #bc9768 100%) !important;
  background-size: 220% 100%;
  animation: hv-wabern 5.5s ease-in-out infinite;
  box-shadow: 0 2px 0 0 rgba(139,106,59,.35), 0 4px 10px -2px rgba(139,106,59,.35) !important;
  transition: filter .2s, box-shadow .2s !important;
  text-decoration: none !important;
  width: 100%;
  box-sizing: border-box;
}
.hv-card__btn .aawp-button:hover,
.hv-card__btn a.aawp-button:hover {
  filter: saturate(1.15) brightness(1.06) !important;
  border: 0 !important;
}

/* ── hv_order_btn — Zentrierter Amazon-Button ── */
.hv-order-btn-wrap {
  text-align: center;
  margin: 1.8em 0;
}
.hv-order-btn {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: 15px;
  font-weight: 500;
  color: #fff;
  border: 0;
  border-radius: var(--r-md);
  padding: 12px 28px;
  background-image: linear-gradient(100deg, #bc9768 0%, #d6b184 30%, #e6c294 50%, #d6b184 70%, #bc9768 100%);
  background-size: 220% 100%;
  animation: hv-wabern 5.5s ease-in-out infinite;
  box-shadow: 0 2px 0 0 rgba(139,106,59,.35), 0 4px 10px -2px rgba(139,106,59,.35);
  transition: filter .2s, box-shadow .2s, transform .1s;
  text-decoration: none;
}
.hv-order-btn:hover {
  filter: saturate(1.15) brightness(1.06);
  box-shadow: 0 2px 0 0 rgba(139,106,59,.45), 0 6px 14px -2px rgba(200,163,116,.6);
  color: #fff;
}

/* ── hv_imgrow — Produktbild-Reihe ── */
.hv-imgrow {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: nowrap;
  margin: 1.8em 0 .6em;
}
.hv-imgrow__label {
  width: 100%;
  text-align: center;
  font-size: 13px;
  color: var(--hv-ink-300);
  text-transform: uppercase;
  letter-spacing: .12em;
  margin-bottom: 12px;
}
.hv-imgrow a {
  display: block;
  max-width: 280px;
  flex: 1;
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  transition: transform .2s, box-shadow .2s;
}
.hv-imgrow a:hover {
  transform: scale(1.03);
  box-shadow: var(--shadow-hover);
}
.hv-imgrow img {
  width: 100%;
  height: auto;
  display: block;
}

/* ── hv_quote — Handschrift-Zitat ── */
.hv-quote {
  font-family: var(--font-hand);
  font-size: 28px;
  color: var(--hv-gold-700);
  line-height: 1.35;
  text-align: center;
  padding: 1.2rem 2rem 1.6rem;
  margin: 2em auto;
  max-width: 760px;
  display: block;
  transform: rotate(-2deg);
}

/* ── hv_pros_cons — Stärken/Schwächen-Card ── */
.hv-pc {
  background: var(--hv-paper);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  margin: 1.5em 0 2em;
  border: 1px solid var(--border);
}
.hv-pc__header {
  background: var(--hv-cream-200);
  padding: 16px 24px;
  font-family: var(--font-serif);
  font-size: 17px;
  font-weight: 600;
  color: var(--hv-ink-700);
}
.hv-pc__body { padding: 18px 24px; }
.hv-pc__cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px 0;
}
.hv-pc__col { padding-right: 16px; }
.hv-pc__col--cons {
  padding-right: 0;
  padding-left: 16px;
  border-left: 1px solid var(--border);
}
.hv-pc__item {
  display: flex;
  align-items: baseline;
  gap: 10px;
  font-size: 15px;
  color: var(--hv-ink-500);
  padding: 4px 0;
}
.hv-pc__icon { font-weight: 900; font-size: 14px; flex-shrink: 0; }
.hv-pc__item--pro .hv-pc__icon { color: var(--hv-check); }
.hv-pc__item--con .hv-pc__icon { color: #c0392b; }
.hv-pc__fuer {
  text-align: center;
  padding: 14px 18px;
  border-top: 1px solid var(--border);
  font-size: 14px;
  color: var(--hv-ink-500);
}
.hv-pc__fuer .hv-pc__icon { color: var(--hv-gold-700); }

/* ── hv_wave — Wellenlinie ── */
.hv-wave {
  height: 24px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 16'%3E%3Cpath d='M2 8Q12 0 22 8t20 0 20 0 20 0 20 0 16 0' fill='none' stroke='%23c8a374' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E") repeat-x center;
  opacity: .7;
  margin: 2.5em auto;
  max-width: 200px;
}

/* ==========================================================
   AAWP PLUGIN OVERRIDES
   ========================================================== */
.aawp { font-family: var(--font-sans) !important; }

.aawp .aawp-product {
  border: 1px solid var(--border) !important;
  border-radius: var(--r-lg) !important;
  box-shadow: var(--shadow-card) !important;
  font-family: var(--font-sans) !important;
}
.aawp .aawp-product__title {
  font-family: var(--font-serif) !important;
  font-weight: 600 !important;
  color: var(--hv-ink-700) !important;
}
.aawp .aawp-product__price--current {
  color: var(--hv-price) !important;
  font-family: var(--font-serif) !important;
  font-weight: 700 !important;
}

.aawp a.aawp-button,
.aawp .aawp-product .aawp-product__footer a.aawp-button {
  background-image: linear-gradient(100deg, #bc9768 0%, #d6b184 30%, #e6c294 50%, #d6b184 70%, #bc9768 100%) !important;
  background-size: 220% 100% !important;
  animation: hv-wabern 5.5s ease-in-out infinite !important;
  border: 0 !important;
  border-radius: var(--r-md) !important;
  color: #fff !important;
  font-family: var(--font-sans) !important;
  font-weight: 500 !important;
  font-size: 15px !important;
  padding: 12px 22px !important;
  box-shadow: 0 2px 0 0 rgba(139,106,59,.35), 0 4px 10px -2px rgba(139,106,59,.35) !important;
  text-decoration: none !important;
}
.aawp a.aawp-button:hover {
  filter: saturate(1.15) brightness(1.06) !important;
}

.aawp .aawp-table th {
  background: var(--hv-cream-200) !important;
  font-family: var(--font-serif) !important;
  color: var(--hv-ink-700) !important;
  border-color: var(--border) !important;
}
.aawp .aawp-table td {
  border-color: var(--border) !important;
  color: var(--hv-ink-500) !important;
}

/* Star rating */
.aawp .aawp-product__rating { color: var(--hv-gold-500) !important; }

/* ==========================================================
   RELATED ARTICLES
   ========================================================== */
.related-articles {
  background: var(--hv-cream-25);
  padding: 1.2rem 1.5rem;
  border-radius: var(--r-lg);
  border: 1px solid var(--border);
  margin-top: 2rem;
}
.related-articles h3 {
  margin-top: 0;
  font-size: 1rem;
}

/* ==========================================================
   AFFILIATE DISCLAIMER
   ========================================================== */
.hv-affiliate-note {
  display: block;
  font-style: italic;
  font-size: 12px;
  color: var(--hv-ink-300);
  text-align: center;
  padding-top: 1.5em;
  border-top: 1px solid var(--border);
  margin-top: 2em;
}

/* ==========================================================
   PAGINATION
   ========================================================== */
.hv-pagination {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 40px;
  padding-top: 24px;
  border-top: 1px solid var(--border);
}
.hv-pagination a,
.hv-pagination span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  border-radius: var(--r-md);
  font-family: var(--font-serif);
  font-size: 15px;
  font-weight: 600;
  color: var(--hv-ink-700);
  border: 1px solid var(--border);
  transition: all .15s;
}
.hv-pagination a:hover {
  background: var(--hv-cream-50);
  border-color: var(--border-strong);
}
.hv-pagination .current {
  background: var(--hv-gold-500);
  color: #fff;
  border-color: var(--hv-gold-500);
}

/* ==========================================================
   RESPONSIVE
   ========================================================== */
@media (max-width: 1140px) {
  .hv-main-box {
    margin: 16px;
    border-radius: var(--r-md);
  }
  .hv-content-inner {
    padding: 32px 32px 40px;
  }
  .hv-featured-image {
    margin: 0 -32px 24px;
  }
}

@media (max-width: 768px) {
  .hv-header {
    padding: 12px 20px;
  }
  .hv-header__logo img { height: 40px; }
  .hv-nav { display: none; }
  .hv-menu-toggle { display: block; }
  .hv-nav.open {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--hv-cream-50);
    padding: 20px;
    border-bottom: 1px solid var(--border);
    box-shadow: var(--shadow-card);
    gap: 0;
  }
  .hv-nav.open > li > a { padding: 12px 0; }
  .hv-nav.open .sub-menu {
    position: static;
    opacity: 1;
    visibility: visible;
    transform: none;
    box-shadow: none;
    border: none;
    padding: 0 0 0 16px;
  }

  .hv-main-box {
    margin: 8px;
    border-radius: var(--r-sm);
  }
  .hv-content-inner {
    padding: 24px 20px 32px;
  }
  .hv-featured-image { margin: 0 -20px 20px; }

  .hv-cards {
    grid-template-columns: 1fr !important;
    gap: 14px;
  }
  .hv-card--hl { order: -1; margin-top: 0; }

  .hv-pc__cols { grid-template-columns: 1fr; }
  .hv-pc__col--cons {
    padding-left: 0;
    border-left: none;
    border-top: 1px solid var(--border);
    padding-top: 8px;
    margin-top: 8px;
  }

  .hv-imgrow { flex-wrap: wrap; }
  .hv-imgrow a { max-width: 100%; }

  .hv-quote { font-size: 22px; transform: rotate(-1deg); }

  h1 { font-size: 28px !important; }
  h2 { font-size: 24px !important; }

  .hv-footer__grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .hv-footer { padding: 24px 20px; }
  .hv-footer__bar { flex-direction: column; gap: 8px; text-align: center; }

  .hv-archive-header { flex-direction: column; align-items: flex-start; gap: 12px; }
  .hv-archive-header .hv-archive-meta { text-align: left; }

  .hv-post-card {
    grid-template-columns: 1fr;
    gap: 14px;
  }
}

@media (max-width: 480px) {
  .hv-content-inner { padding: 16px 16px 24px; }
  .hv-featured-image { margin: 0 -16px 16px; }
  h1 { font-size: 24px !important; }
}


/* ===== [hv_highlight] — Auf einen Blick Redesign ===== */
.hv-hl{background:var(--bg-card,#fff);border-radius:20px;box-shadow:var(--shadow-card,0 10px 30px -16px rgba(90,63,25,.18),0 2px 6px -2px rgba(90,63,25,.06));overflow:hidden;font-family:var(--font-sans,"Instrument Sans",system-ui,sans-serif);display:grid;grid-template-columns:220px 1fr;border:1px solid var(--border,#ece2d1);max-width:780px;margin:32px auto}
.hv-hl__rail{padding:28px 22px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;border-right:1px solid var(--border,#ece2d1);border-radius:20px 0 0 20px}
.hv-hl--winner .hv-hl__rail{background:linear-gradient(180deg,var(--hv-gold-50,#f8ecd9),var(--hv-cream-100,#fdf3e3))}
.hv-hl--normal .hv-hl__rail{background:var(--hv-cream-50,#fff9f0)}
.hv-hl__eyebrow{font-family:var(--font-sans,"Instrument Sans",system-ui,sans-serif);text-transform:uppercase;letter-spacing:.14em;color:var(--hv-gold-700,#a7875a);font-size:12px;font-weight:600}
.hv-hl__score{font-family:var(--font-serif,"Playfair Display",Georgia,serif);font-weight:700;font-size:64px;line-height:1;margin-top:8px;letter-spacing:-.02em}
.hv-hl--winner .hv-hl__score{color:var(--hv-gold-900,#8b6a3b)}
.hv-hl--normal .hv-hl__score{color:var(--hv-ink-700,#3a322a)}
.hv-hl__score-sub{color:var(--fg2,#5c5148);font-size:13px}
.hv-hl__badge{margin-top:6px;padding:5px 10px;border-radius:999px;font-size:10px;letter-spacing:.16em;font-family:var(--font-serif,"Playfair Display",Georgia,serif);font-weight:700}
.hv-hl--winner .hv-hl__badge{background:var(--hv-gold-500,#c8a374);color:#fff}
.hv-hl--normal .hv-hl__badge{background:var(--hv-cream-200,#f8ecd9);color:var(--hv-ink-700,#3a322a);border:1px solid var(--border-strong,#d9c7a8)}
.hv-hl__squig{margin-top:14px;color:var(--hv-gold-700,#a7875a);opacity:.8;display:block}
.hv-hl__hand{font-family:var(--font-hand,"Lumios Marker","Caveat",cursive);color:var(--hv-gold-700,#a7875a);font-size:22px;margin-top:4px;line-height:1.1}
.hv-hl__body{padding:26px 28px}
.hv-hl__name{font-family:var(--font-serif,"Playfair Display",Georgia,serif)!important;font-weight:700!important;font-size:22px!important;color:var(--hv-ink-700,#3a322a)!important;margin:0 0 4px!important;line-height:1.2!important;letter-spacing:normal!important;padding:0!important}
.hv-hl__sub{color:var(--fg3,#8a7f74);font-size:13px;margin-bottom:16px;line-height:1.45}
.hv-hl__cols{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:18px}
.hv-hl__col-head{font-size:11px;text-transform:uppercase;letter-spacing:.14em;font-weight:600;margin-bottom:10px}
.hv-hl__col-head--pro{color:#3d7a48}
.hv-hl__col-head--con{color:#a8493a}
.hv-hl__list{list-style:none;padding:0;margin:0;display:grid;gap:7px}
.hv-hl__li{display:flex;gap:8px;font-size:13.5px;color:var(--hv-ink-700,#3a322a);align-items:center;line-height:1.4}
.hv-hl__icon{flex:0 0 18px;display:flex;align-items:center}
.hv-hl__empfehlung{font-size:14px;color:var(--hv-ink-500,#5c5148);line-height:1.55;padding:14px 0 0;margin-bottom:16px;border-top:1px dashed var(--border,#ece2d1)}
.hv-hl__foot{display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:1px dashed var(--border,#ece2d1)}
.hv-hl__price{font-family:var(--font-serif,"Playfair Display",Georgia,serif);color:var(--hv-price,#c19a5b);font-weight:700;font-size:22px}
.hv-hl__cta{display:inline-flex!important;align-items:center;justify-content:center;height:48px;padding:0 22px;border:0;border-radius:10px;background:var(--btn-primary-bg,#c8a374)!important;color:#fff!important;font-family:var(--font-sans,"Instrument Sans",system-ui,sans-serif);font-size:15px;font-weight:600;text-decoration:none!important;transition:background 150ms ease-out,transform 150ms ease-out;cursor:pointer;white-space:nowrap}
.hv-hl__cta:hover{background:var(--btn-primary-bg-hover,#a7875a)!important;color:#fff!important;text-decoration:none!important}
.hv-hl__cta:active{transform:scale(.98)}
@media(max-width:680px){.hv-hl{grid-template-columns:1fr}.hv-hl__rail{border-right:none;border-bottom:1px solid var(--border,#ece2d1);border-radius:20px 20px 0 0;padding:22px 20px;flex-direction:row;flex-wrap:wrap;justify-content:center;gap:8px 16px}.hv-hl__eyebrow{order:0;width:100%}.hv-hl__score{font-size:42px;margin-top:0}.hv-hl__score-sub{font-size:12px}.hv-hl__squig{display:none}.hv-hl__hand{font-size:18px}.hv-hl__cols{grid-template-columns:1fr;gap:16px}.hv-hl__foot{flex-direction:column;gap:12px;align-items:stretch}.hv-hl__cta{width:100%;text-align:center;justify-content:center}}