/* ===================================================================
   blog-premium.css   v20260517-premium
   Autark Innovations — Blog Premium Polish Layer
   -------------------------------------------------------------------
   Wirkt OBERHALB von /blog/blog-post-base.css + /premium-overrides.css
   Liefert: Reading-Width 720px, Serif-Display, Gold-Akzent-Linie unter
   H2/H3, Drop-Cap, Sticky TOC, Inline-CTA-Cards, Bottom-CTAs, Premium
   Related-Cards, Author-Skeleton.
   ================================================================= */

@layer premium-blog {

  /* ----- 1) Hero polish ------------------------------------------ */
  .blog-hero {
    padding: 5.5rem 1.5rem 3rem !important;
    background:
      radial-gradient(ellipse at 50% 0%, rgba(201,168,106,0.10), transparent 60%),
      linear-gradient(180deg, rgba(201,168,106,0.04), transparent) !important;
    border-bottom: 1px solid rgba(201,168,106,0.18) !important;
    position: relative;
  }
  .blog-hero::after {
    content:"";
    position:absolute;
    left:50%;
    bottom:-1px;
    transform:translateX(-50%);
    width: 140px;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--pp-gold, #C9A86A), transparent);
  }
  .blog-hero .section-label {
    color: var(--pp-gold, #C9A86A) !important;
    font-size: 0.72rem;
    letter-spacing: 2.5px;
  }
  .blog-hero h1 {
    font-family: var(--font-display, 'Fraunces', Georgia, serif) !important;
    font-weight: 600 !important;
    font-size: clamp(2rem, 4.5vw, 3.2rem) !important;
    line-height: 1.15 !important;
    letter-spacing: -0.01em;
    max-width: 880px;
    margin: 0.4rem auto 1.2rem !important;
    color: #F4EFE6 !important;
  }
  .blog-hero .blog-meta {
    color: rgba(244,239,230,0.62);
    font-size: 0.86rem;
    gap: 1.4rem;
  }
  .blog-hero .blog-meta::before {
    content:"";
    display:inline-block;
    width: 28px; height: 28px;
    border-radius: 50%;
    background:
      radial-gradient(circle at 35% 35%, #D8BC85, #A8884E 70%);
    margin-right: 0.6rem;
    vertical-align: middle;
    box-shadow: 0 2px 6px rgba(201,168,106,0.35);
  }

  /* ----- 2) Layout: Article + Sticky TOC -------------------------- */
  .blog-shell {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 260px;
    gap: 3rem;
    max-width: 1100px;
    margin: 0 auto;
    padding: 2rem 1.5rem 4rem;
  }
  .blog-shell .blog-content {
    max-width: 720px;
    margin: 0;
    padding: 0;
  }
  .blog-toc {
    position: sticky;
    top: 90px;
    align-self: start;
    padding: 1.4rem 1.2rem;
    background: rgba(22,26,33,0.55);
    border: 1px solid rgba(201,168,106,0.18);
    border-radius: 14px;
    font-size: 0.86rem;
    max-height: calc(100vh - 110px);
    overflow-y: auto;
  }
  .blog-toc h4 {
    margin: 0 0 0.8rem;
    font-size: 0.72rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--pp-gold, #C9A86A);
    font-weight: 700;
    font-family: var(--font-body, 'Inter', sans-serif);
  }
  .blog-toc ul { list-style:none; margin:0; padding:0; }
  .blog-toc li { margin: 0.45rem 0; line-height: 1.4; }
  .blog-toc li.is-h3 { padding-left: 0.9rem; font-size: 0.8rem; }
  .blog-toc a {
    color: rgba(244,239,230,0.74);
    text-decoration: none;
    border-left: 2px solid transparent;
    padding-left: 0.55rem;
    display: block;
    transition: all .2s ease;
  }
  .blog-toc a:hover {
    color: var(--pp-gold-soft, #D8BC85);
    border-left-color: var(--pp-gold, #C9A86A);
  }
  @media (max-width: 960px) {
    .blog-shell { grid-template-columns: 1fr; gap: 1.5rem; }
    .blog-toc { display: none; }
  }

  /* ----- 3) Typography: Serif H2/H3 with gold rule ---------------- */
  .blog-content h2 {
    font-family: var(--font-display, 'Fraunces', Georgia, serif) !important;
    font-weight: 600 !important;
    font-size: clamp(1.5rem, 2.4vw, 1.9rem) !important;
    color: #F4EFE6 !important;
    margin-top: 2.6rem !important;
    margin-bottom: 0.4rem !important;
    padding-bottom: 0.55rem;
    position: relative;
    letter-spacing: -0.005em;
  }
  .blog-content h2::after {
    content:"";
    display:block;
    width: 56px;
    height: 2px;
    margin-top: 0.55rem;
    background: linear-gradient(90deg, var(--pp-gold, #C9A86A), transparent);
    border-radius: 2px;
  }
  .blog-content h3 {
    font-family: var(--font-display, 'Fraunces', Georgia, serif) !important;
    font-weight: 600 !important;
    font-size: clamp(1.15rem, 1.6vw, 1.35rem) !important;
    color: #F4EFE6 !important;
    margin-top: 1.8rem !important;
    margin-bottom: 0.5rem !important;
    padding-left: 0.85rem;
    border-left: 3px solid var(--pp-gold-deep, #A8884E);
  }

  /* ----- 4) Body reading polish ----------------------------------- */
  .blog-content,
  .blog-content p,
  .blog-content li {
    font-size: 1.02rem;
    line-height: 1.78;
    color: rgba(244,239,230,0.90);
  }
  .blog-content p { margin: 0.95rem 0; }
  .blog-content a {
    color: var(--pp-gold-soft, #D8BC85);
    text-decoration: underline;
    text-decoration-color: rgba(201,168,106,0.35);
    text-underline-offset: 3px;
    transition: color .15s;
  }
  .blog-content a:hover { color: var(--pp-gold, #C9A86A); text-decoration-color: var(--pp-gold, #C9A86A); }
  .blog-content strong { color: #F4EFE6; }
  .blog-content img { max-width: 100%; height: auto; border-radius: 12px; }

  /* Drop-Cap nur fuer den ersten <p> nach H1 oder Breadcrumb */
  .blog-content .lead-p::first-letter,
  .blog-content > p.lead-p::first-letter,
  .blog-content > .breadcrumb + p::first-letter {
    font-family: var(--font-display, 'Fraunces', Georgia, serif);
    float: left;
    font-size: 3.6rem;
    line-height: 0.95;
    padding: 0.25rem 0.6rem 0 0;
    color: var(--pp-gold, #C9A86A);
    font-weight: 600;
  }

  /* ----- 5) Info & Price-Table polish ----------------------------- */
  .blog-content .info-box {
    background: linear-gradient(180deg, rgba(201,168,106,0.07), rgba(201,168,106,0.02)) !important;
    border: 1px solid rgba(201,168,106,0.22) !important;
    border-left: 3px solid var(--pp-gold, #C9A86A) !important;
    border-radius: 12px !important;
    padding: 1.1rem 1.3rem !important;
    margin: 1.4rem 0 !important;
  }
  .blog-content .price-table {
    width: 100%;
    border-collapse: collapse;
    margin: 1.4rem 0;
    font-size: 0.92rem;
    background: rgba(22,26,33,0.45);
    border: 1px solid rgba(201,168,106,0.16);
    border-radius: 12px;
    overflow: hidden;
  }
  .blog-content .price-table th {
    background: rgba(201,168,106,0.08);
    color: var(--pp-gold-soft, #D8BC85);
    font-weight: 700;
    padding: 0.7rem 0.85rem;
    text-align: left;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 1px;
  }
  .blog-content .price-table td {
    padding: 0.65rem 0.85rem;
    border-top: 1px solid rgba(201,168,106,0.10);
    color: rgba(244,239,230,0.86);
  }
  .blog-content .price-table .highlight {
    color: var(--pp-gold, #C9A86A);
  }

  /* ----- 6) Inline Premium CTA Card ------------------------------- */
  .blog-content .premium-cta,
  .blog-content .cta-box {
    margin: 2rem 0 !important;
    padding: 1.6rem 1.5rem !important;
    background:
      radial-gradient(ellipse at top right, rgba(201,168,106,0.12), transparent 70%),
      linear-gradient(135deg, rgba(22,26,33,0.85), rgba(11,13,17,0.85)) !important;
    border: 1px solid rgba(201,168,106,0.28) !important;
    border-radius: 14px !important;
    text-align: left !important;
    position: relative;
    overflow: hidden;
  }
  .blog-content .premium-cta::before,
  .blog-content .cta-box::before {
    content:"";
    position:absolute; left:0; top:0; bottom:0;
    width: 3px;
    background: linear-gradient(180deg, var(--pp-gold, #C9A86A), var(--pp-gold-deep, #A8884E));
  }
  .blog-content .premium-cta h3,
  .blog-content .cta-box h3 {
    font-family: var(--font-display, 'Fraunces', Georgia, serif) !important;
    font-weight: 600 !important;
    color: #F4EFE6 !important;
    margin: 0 0 0.4rem !important;
    font-size: 1.2rem !important;
    border-left: 0 !important;
    padding-left: 0 !important;
  }
  .blog-content .premium-cta p,
  .blog-content .cta-box p {
    color: rgba(244,239,230,0.78) !important;
    margin: 0 0 1rem !important;
    font-size: 0.95rem !important;
  }
  .blog-content .premium-cta .btn-primary,
  .blog-content .cta-box .btn-primary,
  .blog-content .premium-cta a.cta-link {
    display: inline-flex !important;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1.3rem !important;
    background: linear-gradient(135deg, var(--pp-gold, #C9A86A), var(--pp-gold-deep, #A8884E)) !important;
    color: #0A0B0D !important;
    font-weight: 700 !important;
    text-decoration: none !important;
    border-radius: 10px !important;
    font-size: 0.9rem !important;
    transition: transform .2s ease, box-shadow .2s ease;
    border: 0 !important;
  }
  .blog-content .premium-cta .btn-primary:hover,
  .blog-content .cta-box .btn-primary:hover,
  .blog-content .premium-cta a.cta-link:hover {
    transform: translateY(-1px);
    box-shadow: 0 8px 24px rgba(201,168,106,0.30);
  }
  .blog-content .premium-cta .cta-secondary {
    display: inline-flex !important;
    align-items: center;
    gap: 0.4rem;
    padding: 0.7rem 1.2rem;
    margin-left: 0.4rem;
    color: var(--pp-gold-soft, #D8BC85) !important;
    text-decoration: none;
    font-weight: 600;
    font-size: 0.88rem;
    border: 1px solid rgba(201,168,106,0.32);
    border-radius: 10px;
  }

  /* ----- 7) Bottom-CTA ------------------------------------------- */
  .blog-bottom-cta {
    margin: 3rem auto 1rem;
    max-width: 720px;
    padding: 2.2rem 1.8rem;
    background:
      radial-gradient(ellipse at top right, rgba(201,168,106,0.10), transparent 70%),
      linear-gradient(135deg, rgba(17,20,26,0.92), rgba(11,13,17,0.92));
    border: 1px solid rgba(201,168,106,0.26);
    border-radius: 16px;
    text-align: center;
  }
  .blog-bottom-cta .eyebrow {
    display: inline-block;
    color: var(--pp-gold, #C9A86A);
    font-size: 0.72rem;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    font-weight: 700;
    margin-bottom: 0.6rem;
  }
  .blog-bottom-cta h3 {
    font-family: var(--font-display, 'Fraunces', Georgia, serif);
    font-size: clamp(1.3rem, 2vw, 1.7rem);
    color: #F4EFE6;
    margin: 0 0 0.6rem;
    font-weight: 600;
    border-left: 0;
    padding-left: 0;
  }
  .blog-bottom-cta p {
    color: rgba(244,239,230,0.76);
    margin: 0 0 1.4rem;
    font-size: 0.96rem;
  }
  .blog-bottom-cta .btn-group {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.7rem;
    justify-content: center;
  }
  .blog-bottom-cta .btn-primary {
    padding: 0.85rem 1.5rem;
    background: linear-gradient(135deg, var(--pp-gold, #C9A86A), var(--pp-gold-deep, #A8884E));
    color: #0A0B0D;
    font-weight: 700;
    text-decoration: none;
    border-radius: 12px;
    font-size: 0.95rem;
    transition: transform .2s ease, box-shadow .2s ease;
  }
  .blog-bottom-cta .btn-primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 28px rgba(201,168,106,0.32);
  }
  .blog-bottom-cta .btn-secondary {
    padding: 0.85rem 1.5rem;
    background: rgba(244,239,230,0.04);
    border: 1px solid rgba(201,168,106,0.28);
    color: #F4EFE6;
    font-weight: 600;
    text-decoration: none;
    border-radius: 12px;
    font-size: 0.95rem;
    transition: all .2s ease;
  }
  .blog-bottom-cta .btn-secondary:hover {
    border-color: var(--pp-gold, #C9A86A);
    background: rgba(201,168,106,0.08);
  }

  /* ----- 8) Related Cards ---------------------------------------- */
  .blog-related-section {
    margin: 3rem auto 1rem;
    max-width: 720px;
  }
  .blog-related-section h3 {
    font-family: var(--font-display, 'Fraunces', Georgia, serif);
    font-size: 1.3rem;
    color: #F4EFE6;
    margin: 0 0 1rem;
    padding-left: 0;
    border-left: 0;
    font-weight: 600;
  }
  .blog-related-section h3::after {
    content:"";
    display:block;
    width: 48px;
    height: 2px;
    margin-top: 0.5rem;
    background: linear-gradient(90deg, var(--pp-gold, #C9A86A), transparent);
  }
  .blog-related-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
  }
  .blog-related-card {
    background: rgba(22,26,33,0.55);
    border: 1px solid rgba(201,168,106,0.16);
    border-radius: 12px;
    padding: 1rem 1.1rem;
    text-decoration: none;
    display: block;
    transition: all .2s ease;
  }
  .blog-related-card:hover {
    border-color: rgba(201,168,106,0.42);
    transform: translateY(-2px);
    box-shadow: 0 10px 28px rgba(201,168,106,0.14);
  }
  .blog-related-card .tag {
    font-size: 0.66rem;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--pp-gold, #C9A86A);
    margin-bottom: 0.35rem;
  }
  .blog-related-card .title {
    color: #F4EFE6 !important;
    font-size: 0.92rem;
    font-weight: 600;
    line-height: 1.35;
  }

  /* ----- 9) Hide legacy duplicate related-blocks ----------------- */
  .blog-content + div[style*="rgba(37,99,235,0.05)"],
  .blog-content + div[style*="rgba(79,143,255,0.08)"],
  body > div[style*="rgba(37,99,235,0.05)"],
  body > div[style*="rgba(79,143,255,0.08)"] {
    display: none !important;
  }

  /* ----- 10) Listing-Page polish (blog.html) --------------------- */
  .blog-grid .blog-card {
    background: rgba(22,26,33,0.55) !important;
    border: 1px solid rgba(201,168,106,0.14) !important;
    transition: all .2s ease;
  }
  .blog-grid .blog-card:hover {
    border-color: rgba(201,168,106,0.40) !important;
    box-shadow: 0 14px 36px rgba(201,168,106,0.16) !important;
    transform: translateY(-3px);
  }
  .blog-grid .blog-card-tag {
    color: var(--pp-gold, #C9A86A) !important;
  }
  .blog-grid .blog-card-arrow {
    color: var(--pp-gold-soft, #D8BC85) !important;
  }
  .blog-grid .blog-cat-h {
    font-family: var(--font-display, 'Fraunces', Georgia, serif) !important;
    color: var(--pp-gold, #C9A86A) !important;
    border-left-color: var(--pp-gold, #C9A86A) !important;
    text-transform: none !important;
    font-size: 1.4rem !important;
    font-weight: 600 !important;
    letter-spacing: -0.005em !important;
  }
  .filter-tabs .filter-tab.active,
  .filter-tabs .filter-tab:hover {
    border-color: var(--pp-gold, #C9A86A) !important;
    background: rgba(201,168,106,0.08) !important;
    color: #F4EFE6 !important;
  }

} /* @layer */
