/* ── Post-Mortem Library case studies ── */

/* Tags */
.cs-tags{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.cs-tag{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;padding:3px 8px;border-radius:4px}
.cs-tag--domain{background:var(--primary-light);color:var(--primary)}
.cs-tag--type{background:var(--gray-100);color:var(--gray-500)}
.cs-tag--source{background:var(--accent-light);color:var(--accent)}
.cs-back{font-size:13px;color:var(--gray-400);text-decoration:none}
.cs-back:hover{color:var(--gray-600)}

/* Meta strip */
.cs-meta{display:flex;flex-wrap:wrap;gap:24px;margin-top:32px;padding-top:24px;border-top:1px solid var(--gray-200)}
.cs-meta-item{flex-shrink:0}
.cs-meta-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.05em;color:var(--gray-400);margin-bottom:4px}
.cs-meta-value{font-size:14px;font-weight:600;color:var(--gray-700)}

/* Body prose */
.cs-body{font-size:17px;line-height:1.7;color:var(--gray-700)}
.cs-body p{margin-bottom:20px}

/* Impact stats */
.cs-impact{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--gray-200);border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden}
.cs-impact-item{background:#fff;padding:28px 24px}
.cs-impact-number{font-family:'Instrument Serif',serif;font-size:36px;line-height:1;margin-bottom:8px}
.cs-impact-desc{font-size:13px;color:var(--gray-500);line-height:1.5}

/* Pull quote */
.cs-quote{margin-top:24px;border-left:3px solid var(--gray-300);padding-left:20px}
.cs-quote-text{font-size:15px;color:var(--gray-600);line-height:1.6;font-style:italic}
.cs-quote-attr{font-size:13px;color:var(--gray-400);margin-top:8px}

/* Chat annotation */
.cs-chat{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden}
.cs-chat-header{padding:12px 20px;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;gap:10px;background:var(--gray-50)}
.cs-chat-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}
.cs-chat-avatar--bot{background:var(--primary);color:#fff}
.cs-chat-avatar--user{background:var(--gray-300);color:var(--gray-600)}
.cs-chat-name{font-size:13px;font-weight:600;color:var(--gray-700)}
.cs-chat-time{font-size:11px;color:var(--gray-400);margin-left:auto}
.cs-chat-row{padding:20px;display:flex;gap:12px}
.cs-chat-bubble{border-radius:var(--radius-md);padding:12px 16px;max-width:80%;font-size:14px;line-height:1.6}
.cs-chat-bubble--user{background:var(--gray-50);color:var(--gray-700)}
.cs-chat-bubble--bot{background:var(--primary-light);color:var(--gray-700);position:relative}
.cs-chat-badge{position:absolute;top:-10px;right:12px;background:var(--red);color:#fff;font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:0.05em}
.cs-chat-hl{background:rgba(200,56,40,0.12);border-radius:3px;padding:1px 4px;border-bottom:2px solid var(--red)}
.cs-chat-key{padding:16px 20px;border-top:1px solid var(--gray-100);background:var(--gray-50);font-size:12px;color:var(--gray-500);line-height:1.6}

/* Criteria cards */
.cs-criteria{display:flex;flex-direction:column;gap:16px}
.cs-criterion{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:24px 28px}
.cs-criterion-inner{display:flex;align-items:start;gap:16px}
.cs-criterion-id{flex-shrink:0;font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;color:var(--primary);background:var(--primary-light);padding:4px 8px;border-radius:4px;letter-spacing:0.03em;text-decoration:none;transition:background 0.2s}
.cs-criterion-id:hover{background:var(--primary);color:#fff;text-decoration:none}
.cs-criterion-title{font-size:16px;font-weight:600;color:var(--gray-900);margin-bottom:8px}
.cs-criterion-desc{font-size:14px;color:var(--gray-500);line-height:1.55;margin-bottom:12px}
.cs-criterion-instruction{background:var(--gray-50);border-radius:var(--radius-sm);padding:12px 16px;border:1px solid var(--gray-100)}
.cs-criterion-instruction-label{font-size:12px;color:var(--gray-400);margin-bottom:4px;font-weight:600;text-transform:uppercase;letter-spacing:0.05em}
.cs-criterion-instruction-text{font-size:13px;color:var(--gray-700);line-height:1.5;font-family:'Inter',sans-serif}

/* Interactive demo */
.cs-demo{background:var(--gray-900);color:#fff;background-image:radial-gradient(rgba(255,255,255,0.03) 1px,transparent 1px);background-size:20px 20px}
.cs-demo .section-label::before{background:var(--primary-light) !important}
.cs-demo-label{color:var(--primary-light) !important}
.cs-demo-input{width:100%;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.15);border-radius:var(--radius-md);padding:16px;color:#fff;font-family:'Inter',sans-serif;font-size:14px;line-height:1.6;resize:vertical;transition:border-color 0.2s}
.cs-demo-input:focus{border-color:var(--primary);outline:none}
.cs-demo-btn-run{background:var(--primary);color:#fff;border:none;padding:10px 20px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:background 0.2s}
.cs-demo-btn-run:hover{background:var(--primary-dark)}
.cs-demo-btn-run:disabled{opacity:0.5;cursor:default}
.cs-demo-btn-sample{background:transparent;color:rgba(255,255,255,0.5);border:1px solid rgba(255,255,255,0.15);padding:10px 20px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;transition:all 0.2s}
.cs-demo-btn-sample:hover{color:rgba(255,255,255,0.8);border-color:rgba(255,255,255,0.3)}
.cs-demo-verdict{padding:16px 20px;border-radius:var(--radius-md);margin-bottom:16px;display:flex;align-items:center;gap:12px}
.cs-demo-verdict--pass{background:rgba(45,122,95,0.15);border:1px solid rgba(45,122,95,0.3)}
.cs-demo-verdict--fail{background:rgba(200,56,40,0.15);border:1px solid rgba(200,56,40,0.3)}
.cs-demo-flag{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);border-radius:var(--radius-md);padding:16px 20px}
.cs-demo-flag-id{flex-shrink:0;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;color:var(--accent);background:rgba(200,132,42,0.15);padding:3px 7px;border-radius:4px;letter-spacing:0.03em}
.cs-demo-flag-reason{font-size:13px;color:rgba(255,255,255,0.8);line-height:1.5}

/* Source citations */
.cs-sources{background:var(--gray-50);border:1px solid var(--gray-100);border-radius:var(--radius-lg);padding:24px 28px}
.cs-sources-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--gray-400);margin-bottom:16px}
.cs-sources-list{display:flex;flex-wrap:wrap;gap:12px}
.cs-source{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--gray-600);background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-sm);padding:8px 14px;text-decoration:none;transition:all 0.2s}
.cs-source:hover{border-color:var(--primary);color:var(--primary);text-decoration:none}

/* Index cards */
.cs-card-link{text-decoration:none;color:inherit;display:block}
.cs-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden;transition:transform 0.2s var(--ease),box-shadow 0.2s var(--ease);height:100%;display:flex;flex-direction:column}
.cs-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px -8px rgba(0,0,0,0.12)}
.cs-card-body{padding:24px 24px 0;flex:1}
.cs-card-footer{margin-top:auto;padding:16px 24px;border-top:1px solid var(--gray-100);display:flex;justify-content:space-between;align-items:center}
.cs-card-meta{font-size:11px;color:var(--gray-400)}
.cs-card-cta{font-size:13px;font-weight:600;color:var(--primary)}
.cs-card-title{font-family:'Instrument Serif',serif;font-size:24px;line-height:1.2;color:var(--gray-900);margin-bottom:12px;font-weight:400}
.cs-card-desc{font-size:13px;color:var(--gray-500);line-height:1.55;margin-bottom:16px}

/* Method grid */
.cs-method{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--gray-200);border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden;margin-top:32px}
.cs-method-item{background:#fff;padding:32px 28px}
.cs-method-num{font-family:'Instrument Serif',serif;font-size:32px;color:var(--primary);line-height:1;margin-bottom:16px;font-style:italic}

/* Upcoming card */
.cs-upcoming{padding:16px 20px;border:1px dashed var(--gray-200);border-radius:var(--radius-md);display:flex;justify-content:space-between;align-items:center}
.cs-upcoming-title{font-size:14px;font-weight:600;color:var(--gray-600)}
.cs-upcoming-desc{font-size:12px;color:var(--gray-400)}
.cs-upcoming-soon{font-size:11px;color:var(--gray-400);font-style:italic}

/* Hero stats */
.cs-stats{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-bottom:48px}
.cs-stat-num{font-family:'Instrument Serif',serif;font-size:42px;line-height:1;margin-bottom:12px}
.cs-stat-desc{font-size:14px;color:var(--gray-500);line-height:1.5}

/* Anti-portfolio quote */
.cs-manifesto{border-left:3px solid var(--primary);padding-left:20px}
.cs-manifesto-text{font-family:'Instrument Serif',serif;font-size:22px;line-height:1.4;color:var(--gray-900);font-style:italic}

/* Timeline */
.cs-timeline{position:relative;padding-left:32px;margin-top:32px}
.cs-timeline::before{content:'';position:absolute;left:12px;top:8px;bottom:8px;width:2px;background:var(--gray-200)}
.cs-timeline-item{position:relative;padding-bottom:28px}
.cs-timeline-item:last-child{padding-bottom:0}
.cs-timeline-dot{position:absolute;left:-26px;top:4px;width:12px;height:12px;border-radius:50%;background:#fff;border:2px solid var(--gray-300);z-index:1}
.cs-timeline-dot--active{border-color:var(--primary);background:var(--primary)}
.cs-timeline-dot--fail{border-color:var(--red);background:var(--red)}
.cs-timeline-date{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;color:var(--gray-400);letter-spacing:0.03em;margin-bottom:4px}
.cs-timeline-event{font-size:14px;color:var(--gray-700);line-height:1.55}
.cs-timeline-event strong{color:var(--gray-900);font-weight:600}

/* Impact bar chart */
.cs-impact-bar{margin-top:32px}
.cs-impact-bar-item{margin-bottom:20px}
.cs-impact-bar-label{font-size:13px;font-weight:600;color:var(--gray-700);margin-bottom:8px;display:flex;justify-content:space-between;align-items:baseline}
.cs-impact-bar-value{font-family:'Instrument Serif',serif;font-size:22px;color:var(--gray-900)}
.cs-impact-bar-track{height:8px;background:var(--gray-100);border-radius:4px;overflow:hidden}
.cs-impact-bar-fill{height:100%;border-radius:4px;transition:width 0.8s var(--ease)}
.cs-impact-bar-fill--red{background:var(--red)}
.cs-impact-bar-fill--primary{background:var(--primary)}
.cs-impact-bar-fill--accent{background:var(--accent)}
.cs-impact-bar-desc{font-size:12px;color:var(--gray-400);margin-top:4px}

/* Source outlet strip */
.cs-outlets{display:flex;flex-wrap:wrap;gap:16px;align-items:center;margin-top:20px}
.cs-outlet{font-family:'Instrument Serif',serif;font-size:18px;color:var(--gray-400);letter-spacing:-0.01em;transition:color 0.2s}
.cs-outlet:hover{color:var(--gray-700)}

/* Section divider */
.cs-divider{height:1px;background:var(--gray-100);margin:0;border:none}

/* Mobile responsive */
@media(max-width:640px){
  .cs-impact,.cs-method{grid-template-columns:1fr}
  .cs-stats{grid-template-columns:1fr}
  .cs-chat-bubble{max-width:95%}
  .cs-demo-btn-run,.cs-demo-btn-sample{width:100%;text-align:center}
  .cs-timeline{padding-left:20px}
  .cs-timeline-line{left:10px}
  .cs-timeline-dot{width:10px;height:10px;left:-15px}
}