/* =============================================
   MAIGHTYLABS — ARTICLE DETAIL STYLES
   Passend zum Homepage-Design-System
   ============================================= */

/* ── Article Hero — light, passend zur Startseite ── */
.article-hero{ position:relative; padding-top:clamp(96px, 12vw, 148px); padding-bottom:clamp(48px,7vw,88px); overflow:hidden; }
.article-hero .hero-bg{ position:absolute; inset:0; overflow:hidden; z-index:0; }
.article-hero > .wrap{ width:100%; max-width:var(--maxw,1200px); padding:0; margin-inline:auto; box-sizing:border-box; position:relative; z-index:1; }
.article-hero .article-hero-inner{ position:relative; z-index:1; max-width:var(--maxw,1200px); margin-inline:auto; padding-inline:var(--pad, clamp(20px,5vw,64px)); width:100%; box-sizing:border-box; }
.article-hero h1{
  font-size:clamp(2rem, 4.5vw, 3.4rem); font-weight:700; letter-spacing:-.03em;
  margin:16px 0 24px; max-width:20ch; color:var(--ink);
}
.article-hero .post-tag{ background:var(--bg-soft); color:var(--blue); }
.article-hero .meta-chip{ color:var(--muted); }
.article-hero .meta-chip svg{ opacity:.6; }
.article-hero .meta-chip--cat{ background:var(--blue); color:#fff; }
.back-link{ display:inline-flex; align-items:center; gap:.5em; font-size:.85rem; font-weight:500; color:var(--muted); transition:color .2s; margin-bottom:24px; }
.back-link:hover{ color:var(--blue); }
.post-tags{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:16px; }
.post-tag{ font-family:var(--mono); font-size:.7rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; background:var(--bg-tint); color:var(--blue); padding:4px 10px; border-radius:999px; }
.post-meta-row{ display:flex; gap:12px; flex-wrap:wrap; align-items:center; }
.meta-chip{ display:inline-flex; align-items:center; gap:.4em; font-family:var(--mono); font-size:.78rem; color:var(--muted); }
.meta-chip svg{ opacity:.6; }
.meta-chip--cat{ background:var(--blue); color:#fff; padding:3px 10px; border-radius:999px; }

/* ── Article Layout ── */
.article-layout{
  padding-block: clamp(48px, 7vw, 80px);
  padding-inline: var(--pad, clamp(20px, 5vw, 64px));
  box-sizing:border-box;
  width:100%;
  overflow-x:hidden;
}
/* wrap: max-width + centering, no extra padding that would compound */
.article-layout > .wrap{ width:100%; max-width:var(--maxw,1200px); padding:0; margin-inline:auto; box-sizing:border-box; overflow:hidden; }
.article-grid{
  display:grid; grid-template-columns:220px 1fr; gap:56px;
  min-width:0;
}

/* ── TOC Sidebar ── */
.article-toc{ }
.toc-sticky{
  position:sticky; top:88px;
  background:var(--bg); border:1px solid var(--line);
  border-radius:var(--r); padding:24px;
  max-height:calc(100vh - 108px); overflow-y:auto;
}
.toc-title{
  font-family:var(--mono); font-size:.72rem;
  letter-spacing:.1em; text-transform:uppercase;
  color:var(--muted); margin-bottom:14px;
}
.toc-list{
  list-style:none; padding:0; margin:0; counter-reset:toc;
  display:flex; flex-direction:column; gap:4px;
}
.toc-list li{
  counter-increment:toc;
  font-size:.88rem; color:var(--body);
  padding:4px 0 4px 24px; position:relative;
  transition:color .2s;
}
.toc-list li::before{
  content:counter(toc) ". ";
  position:absolute; left:0; color:var(--muted); font-family:var(--mono); font-size:.76rem;
}
.toc-list li a{ color:inherit; transition:color .2s; }
.toc-list li a:hover{ color:var(--blue); }
.toc-list li.is-active a{ color:var(--blue); font-weight:600; }
.toc-list li.is-active::before{ color:var(--blue); }
.toc-share{ margin-top:20px; padding-top:16px; border-top:1px solid var(--line); }
.share-label{
  font-family:var(--mono); font-size:.72rem;
  letter-spacing:.1em; text-transform:uppercase;
  color:var(--muted); margin-bottom:10px;
}
.share-buttons{ display:flex; flex-direction:column; gap:6px; }
.share-btn{
  display:flex; align-items:center; gap:.5em;
  padding:7px 10px; border-radius:var(--r-sm); border:1px solid var(--line-2);
  background:var(--bg); color:var(--body); font-size:.8rem; font-weight:500;
  cursor:pointer; transition:.2s;
}
.share-btn:hover{ border-color:var(--blue); color:var(--blue); }

/* ── Main Content Column ── */
.article-main{ overflow:hidden; min-width:0; }
.key-insight{
  display:grid; grid-template-columns:auto 1fr; gap:16px;
  background:var(--bg-soft); border:1px solid var(--line);
  border-left:4px solid var(--blue); border-radius:var(--r);
  padding:20px 24px; margin-bottom:36px;
}
.key-insight-icon{ font-size:1.5rem; margin-top:2px; }
.key-insight-label{
  font-family:var(--mono); font-size:.72rem;
  letter-spacing:.1em; text-transform:uppercase;
  color:var(--blue); margin-bottom:6px;
}
.key-insight p{ font-size:.95rem; color:var(--ink-2); line-height:1.65; margin:0; }
.article-stats{
  display:grid; grid-template-columns:repeat(3, minmax(0, 1fr)); gap:12px;
  margin:0 0 36px; padding:18px; border:1px solid var(--line); border-radius:var(--r);
  background:linear-gradient(135deg, rgba(91,155,247,.08), rgba(124,58,237,.05));
}
.article-stat{
  display:flex; flex-direction:column; gap:4px; min-width:0;
  padding:14px; border-radius:calc(var(--r) - 4px); background:rgba(255,255,255,.62);
  border:1px solid rgba(91,155,247,.12);
}
.article-stat span{ font-family:var(--mono); font-size:.68rem; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); }
.article-stat strong{ font-size:1.45rem; line-height:1.1; color:var(--ink); }
.article-stat small{ font-size:.78rem; color:var(--muted); line-height:1.35; }

/* ── Prose / Article Body ── */
.prose{
  font-size:1.05rem; line-height:1.78; color:var(--body);
  word-break:break-word; overflow-wrap:break-word; max-width:100%;
}
.prose h2{
  font-size:clamp(1.4rem, 2.5vw, 1.85rem);
  font-weight:700; letter-spacing:-.025em;
  color:var(--ink); margin:2em 0 .6em;
  padding-top:.8em; border-top:1px solid var(--line);
}
.prose h3{
  font-size:clamp(1.15rem, 1.8vw, 1.35rem);
  font-weight:600; color:var(--ink); margin:1.6em 0 .4em;
}
.prose p{ margin:0 0 1.2em; }
.prose a{ color:var(--blue); text-decoration:underline; text-underline-offset:3px; }
.prose a:hover{ color:var(--blue-deep); }
.prose strong{ font-weight:600; color:var(--ink-2); }
.prose ul,.prose ol{
  margin:0 0 1.2em 1.4em; display:flex; flex-direction:column; gap:6px;
}
.prose li{ }
.prose blockquote{
  border-left:4px solid var(--blue); padding:.8em 1.2em;
  margin:1.6em 0; background:var(--bg-soft); border-radius:0 var(--r) var(--r) 0;
  font-style:italic; color:var(--ink-2);
}
.prose blockquote p{ margin:0; }
.prose code{
  font-family:var(--mono); font-size:.85em;
  background:var(--bg-tint); color:var(--blue-deep);
  padding:2px 6px; border-radius:4px;
}
.prose pre{
  background:var(--dark); color:var(--blue-bright);
  padding:20px 24px; border-radius:var(--r);
  overflow-x:auto; margin:1.6em 0;
  font-family:var(--mono); font-size:.88rem; line-height:1.65;
}
.prose pre code{ background:none; color:inherit; padding:0; font-size:inherit; }
.prose img{ border-radius:var(--r); margin:1.6em 0; max-width:100%; }

/* ── Callout Boxes (generiert vom LLM) ── */
#article-callout{
  display:flex; flex-direction:column; gap:16px;
  margin:2em 0;
}
.callout{
  border-radius:var(--r); padding:16px 20px; margin:20px 0;
  font-size:.95rem; line-height:1.6;
  border-left:4px solid; 
  display: grid; 
  grid-template-columns: auto 1fr; 
  gap: 12px;
  align-items: start;
}
.callout p, .callout strong, .callout a {
  margin-top: 0;
  margin-bottom: 0;
}
.callout-key{ background:rgba(62,123,247,.07); border-color:var(--blue); }
.callout-key::before{ content:'💡'; font-size:1.2rem; line-height:1.6; }
.callout-tip{ background:rgba(46,204,113,.07); border-color:#2ecc71; }
.callout-tip::before{ content:'✅'; font-size:1.2rem; line-height:1.6; }
.callout-invite{ background:rgba(122,173,255,.09); border-color:var(--blue); }
.callout-invite::before{ content:'🚀'; font-size:1.2rem; line-height:1.6; }
.callout-warning{ background:rgba(241,196,15,.07); border-color:#f1c40f; }
.callout-warning::before{ content:'⚠️'; font-size:1.2rem; line-height:1.6; }
.callout, .callout p, .callout a { color:var(--ink-2); }
.callout strong { color:var(--ink); }

/* ── Pros / Cons ── */
.pros-cons{
  display:grid; grid-template-columns:1fr 1fr; gap:16px;
  margin:1.8em 0;
}
.pros-cons h4{ font-size:.88rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; margin-bottom:12px; }
.pros-cons h4.pros-title{ color:#2ecc71; }
.pros-cons h4.cons-title{ color:#e74c3c; }
.pros-cons ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px; }
.pros-cons li{ display:flex; align-items:flex-start; gap:8px; font-size:.92rem; color:var(--ink-2); line-height:1.55; }
.pros-cons li::before{ content:''; flex-shrink:0; width:16px; height:16px; margin-top:2px; }
.pros-cons.pros li::before{ content:'✔'; color:#2ecc71; font-size:.85rem; }
.pros-cons.cons li::before{ content:'✖'; color:#e74c3c; font-size:.85rem; }
.pros-box{ background:rgba(46,204,113,.05); border:1px solid rgba(46,204,113,.2); border-radius:var(--r); padding:18px 20px; }
.cons-box{ background:rgba(231,76,60,.05); border:1px solid rgba(231,76,60,.2); border-radius:var(--r); padding:18px 20px; }

/* ── Data Table (Chart-like) ── */
.table-scroll{
  overflow-x:auto; -webkit-overflow-scrolling:touch;
  margin:1.6em 0; border-radius:var(--r);
  box-shadow:0 0 0 1px var(--line);
}
.table-scroll::-webkit-scrollbar{ height:4px; }
.table-scroll::-webkit-scrollbar-track{ background:var(--bg-soft); border-radius:4px; }
.table-scroll::-webkit-scrollbar-thumb{ background:var(--line-2); border-radius:4px; }
.prose table{
  width:100%; border-collapse:collapse;
  font-size:.92rem; white-space:nowrap;
}
.prose th{
  background:var(--bg-soft); font-family:var(--mono); font-size:.76rem;
  letter-spacing:.06em; text-transform:uppercase; color:var(--muted);
  padding:12px 16px; text-align:left; border-bottom:2px solid var(--line);
  white-space:nowrap;
}
.prose td{
  padding:11px 16px; border-bottom:1px solid var(--line);
  color:var(--ink-2);
}
.prose tr:last-child td{ border-bottom:none; }
.prose tr:hover td{ background:rgba(91,155,247,.04); }
.prose td.num{ font-family:var(--mono); text-align:right; color:var(--blue); }
.prose td.positive{ color:#2ecc71; font-weight:600; }
.prose td.negative{ color:#e74c3c; font-weight:600; }

/* ── Article body links ── */
.prose a{
  color:var(--blue); text-decoration:none; font-weight:500;
  border-bottom:2px solid rgba(91,155,247,.3);
  transition:border-color .15s,color .15s;
}
.prose a:hover{
  border-color:var(--blue); color:#2563eb;
}
/* ── Charts (Chart.js) ── */
.prose .chart-wrap{
  background:var(--bg-soft); border:1px solid var(--line);
  border-radius:var(--r); padding:20px 24px 24px; margin:1.6em 0;
  text-align:center;
}
.prose .chart-wrap canvas{
  max-width:100%; height:auto !important;
}
.prose .chart-title{
  font-family:var(--mono); font-size:.76rem;
  letter-spacing:.08em; text-transform:uppercase;
  color:var(--muted); margin-bottom:16px;
}
.prose .chart-note{
  font-size:.72rem; color:var(--muted); margin-top:8px;
  font-family:var(--mono);
}

/* ── FAQ Section ── */
.faq-section{
  border-top:2px solid var(--line); padding-top:40px; margin-top:48px;
}
.faq-header{ margin-bottom:28px; }
.faq-header .eyebrow{ margin-bottom:8px; }
.faq-header .h3{ margin:0; }
.faq-list{ display:flex; flex-direction:column; gap:12px; }
.faq-item{
  border:1px solid var(--line); border-radius:var(--r);
  overflow:hidden; transition:border-color .2s;
}
.faq-item:hover{ border-color:var(--blue-soft); }
.faq-q{
  width:100%; padding:16px 20px;
  background:var(--bg-soft); border:none; text-align:left;
  font-family:var(--sans); font-size:.97rem; font-weight:600; color:var(--ink);
  cursor:pointer; display:flex; justify-content:space-between; align-items:center;
  gap:12px; transition:background .2s;
}
.faq-q:hover{ background:var(--bg-tint); }
.faq-q::after{ content:'+'; font-size:1.2rem; color:var(--blue); flex-shrink:0; }
.faq-item.open .faq-q::after{ content:'−'; }
.faq-a{
  padding:0 20px 16px;
  font-size:.92rem; color:var(--body); line-height:1.7;
  display:none;
}
.faq-item.open .faq-a{ display:block; }

/* ── Author Box ── */
.author-box{
  display:flex; gap:16px; align-items:flex-start;
  background:var(--bg-soft); border:1px solid var(--line);
  border-radius:var(--r-lg); padding:24px; margin-top:40px;
}
.author-avatar{
  width:48px; height:48px; border-radius:50%;
  background:var(--blue); color:#fff;
  display:grid; place-items:center;
  font-family:var(--display); font-weight:700; font-size:1.1rem;
  flex-shrink:0;
}
.author-info h4{ font-size:1rem; margin:0 0 6px; }
.author-info p{ font-size:.88rem; color:var(--body); margin:0; line-height:1.6; }

/* ── Related Section ── */
.related-section{ padding-block: clamp(48px, 7vw, 80px); background:var(--bg-soft); border-top:1px solid var(--line); }
.related-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
}
.related-card{
  background:var(--bg); border:1px solid var(--line);
  border-radius:var(--r-lg); overflow:hidden;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
  position:relative;
}
.related-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow); }
/* Make entire card clickable via the h4 a stretch */
.related-body h4 a::after{
  content:''; position:absolute; inset:0; z-index:1;
}
.related-img{
  height:130px; background:var(--bg-tint);
  display:flex; align-items:center; justify-content:center;
  position:relative;
}
.related-img::after{
  content:''; position:absolute; inset:0;
  background:radial-gradient(circle at 50% 50%, rgba(91,155,247,.2), transparent 70%);
  pointer-events:none;
}
.related-icon{ font-size:2rem; opacity:.35; }
.related-body{ padding:18px; }
.related-body h4{ font-size:.97rem; margin:0 0 6px; }
.related-body h4 a{ color:var(--ink); transition:color .2s; }
.related-body h4 a:hover{ color:var(--blue); }
.related-meta{ font-family:var(--mono); font-size:.7rem; color:var(--muted); }

/* ── Footer Override (match homepage) ── */
.article-footer{ margin-top:0; }

/* ── Responsive ── */
@media (max-width:900px){
  .article-grid{ grid-template-columns:1fr; }
  .article-toc{ display:none; }
  .related-grid{ grid-template-columns:repeat(2,1fr); }
  /* prose overflow guard for tablet */
  .prose{ word-break:break-word; overflow-wrap:break-word; max-width:100%; overflow-x:hidden; }
  .prose *{ max-width:100%; }
}
@media (max-width:600px){
  .article-grid{ grid-template-columns:1fr; }
  .article-toc{ display:none; }
  .related-grid{ grid-template-columns:repeat(2,1fr); }
  .related-section{ padding-inline:var(--pad, clamp(20px,5vw,64px)); }
  .related-section .wrap{ max-width:100%; }
  .related-grid{ grid-template-columns:1fr; gap:16px; }
  .article-stats{ grid-template-columns:1fr; }
  .article-stat strong{ font-size:1.25rem; }
  .key-insight{ grid-template-columns:1fr; }
  .key-insight-icon{ display:none; }
  .author-box{ flex-direction:column; }
  .article-hero-text h1{ max-width:100%; }
  .post-meta-row{ gap:8px; }
  .callout{ padding:12px 16px; gap:8px; grid-template-columns:1fr; text-align:center; }
  .callout-key::before, .callout-tip::before, .callout-invite::before, .callout-warning::before{ display:block; font-size:1.5rem; margin-bottom:4px; }
  /* prose: prevent overflow from long strings and ensure all children respect viewport */
  .prose{ word-break:break-word; overflow-wrap:break-word; max-width:100%; overflow-x:hidden; }
  .prose *{ max-width:100%; overflow-x:auto; }
  .prose img,.prose video{ max-width:100%; height:auto; display:block; }
  .table-scroll{ display:block; overflow-x:auto; -webkit-overflow-scrolling:touch; }
  .article-main{ overflow:hidden; min-width:0; }
}

/* ── Post CTA Block ── */
.post-cta{
  background:linear-gradient(135deg,#0f2447 0%,#1b3fa8 60%,#2d5be3 100%);
  border-radius:var(--r-xl,16px); padding:clamp(24px,4vw,40px);
  color:#fff; text-align:center;
  margin:clamp(32px,5vw,48px) auto; max-width:780px;
}
.post-cta .eyebrow{ color:rgba(255,255,255,.65); font-size:.8rem; letter-spacing:.1em; text-transform:uppercase; margin-bottom:12px; }
.post-cta h3{ font-size:clamp(1.5rem,3vw,2rem); color:#fff; margin:0 0 10px; }
.post-cta p{ color:rgba(255,255,255,.85); max-width:52ch; margin:0 auto 20px; font-size:1rem; line-height:1.5; }
.post-cta .cta-tags{ display:flex; flex-wrap:wrap; justify-content:center; gap:8px; margin-bottom:20px; }
.post-cta .cta-tag{ background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.2); border-radius:20px; padding:4px 14px; font-size:.8rem; color:rgba(255,255,255,.9); }
.post-cta .btn--light{ display:inline-block; background:#fff; color:#1b3fa8; font-weight:600; padding:12px 28px; border-radius:8px; text-decoration:none; font-size:.95rem; transition:.2s; }
.post-cta .btn--light:hover{ background:#f0f4ff; transform:translateY(-1px); }
