/* LLM Research Lab - Academic Research Design System */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --ink:#1a1a2e;
  --mid:#4a4a6a;
  --light:#8888a8;
  --accent:#2d5be3;
  --accent2:#1a3a8a;
  --accent-light:#e8eeff;
  --accent-fade:rgba(45,91,227,.08);
  --bg:#fafbfd;
  --card:#fff;
  --border:#e8eaf0;
  --border-strong:#d0d4de;
  --radius:10px;
  --radius-sm:6px;
  --max:1080px;
  --serif:'Georgia','Times New Roman','Cambria',serif;
  --sans:-apple-system,'Segoe UI','Helvetica Neue',Arial,sans-serif;
  --mono:'SF Mono','Fira Code','Consolas',monospace;
  --success:#16a34a;
  --success-bg:#f0fdf4;
  --warning:#d97706;
  --warning-bg:#fffbeb;
  --danger:#dc2626;
  --danger-bg:#fef2f2;
  --shadow-sm:0 1px 3px rgba(0,0,0,.04);
  --shadow-md:0 4px 16px rgba(0,0,0,.06);
  --shadow-lg:0 8px 30px rgba(0,0,0,.08);
  --transition:0.25s cubic-bezier(.4,0,.2,1);
}

/* BASE */
body{font-family:var(--serif);color:var(--ink);background:var(--bg);line-height:1.78;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
h1,h2,h3,h4,h5,h6{font-family:var(--sans);line-height:1.25;letter-spacing:-0.02em;color:var(--ink)}
a{color:var(--accent);text-decoration:none;border-bottom:1px solid transparent;transition:border-color var(--transition),color var(--transition)}
a:hover{border-bottom-color:var(--accent);color:var(--accent2)}
a:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}
.container{max-width:var(--max);margin:0 auto;padding:0 24px}
img{max-width:100%;height:auto;display:block}
::selection{background:var(--accent-light);color:var(--accent2)}
hr{border:0;height:1px;background:var(--border);margin:48px 0}

/* SKIP LINK (a11y) */
.skip-link{position:absolute;top:-100%;left:16px;background:var(--accent);color:#fff;padding:8px 16px;border-radius:var(--radius-sm);z-index:9999;font-family:var(--sans);font-size:.85rem}
.skip-link:focus{top:16px}

/* NAV */
nav{background:#fff;border-bottom:1px solid var(--border);padding:18px 0;position:sticky;top:0;z-index:100;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:rgba(255,255,255,.92);box-shadow:var(--shadow-sm)}
nav .container{display:flex;align-items:center;justify-content:space-between}
.logo{font-family:var(--sans);font-size:1.15rem;font-weight:700;color:var(--ink);letter-spacing:-0.03em;border:none}
.logo:hover{border:none}
.logo span{color:var(--accent)}
nav ul{list-style:none;display:flex;gap:28px}
nav ul a{color:var(--mid);font-family:var(--sans);font-size:.9rem;border:none;padding:4px 0;position:relative}
nav ul a:hover{color:var(--ink);border:none}
nav ul a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--accent);transition:width var(--transition)}
nav ul a:hover::after{width:100%}

/* BREADCRUMBS */
.breadcrumbs{padding:16px 0 0;font-family:var(--sans);font-size:.82rem;color:var(--light)}
.breadcrumbs a{color:var(--light);border:none}
.breadcrumbs a:hover{color:var(--accent)}
.breadcrumbs .sep{margin:0 8px;color:var(--border-strong)}
.breadcrumb{padding:16px 0 0;font-family:var(--sans);font-size:.82rem;color:var(--light)}
.breadcrumb a{color:var(--light);border:none}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb span{margin:0 6px;color:var(--border-strong)}

/* HERO */
.hero{padding:80px 0 60px;text-align:center;background:linear-gradient(180deg,var(--bg) 0%,#fff 100%)}
.hero .label{display:inline-block;background:var(--accent);color:#fff;font-family:var(--sans);font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:5px 14px;border-radius:20px;margin-bottom:20px;box-shadow:0 2px 8px rgba(45,91,227,.25)}
.hero h1{font-size:clamp(2.2rem,5vw,3.2rem);max-width:780px;margin:0 auto 20px}
.hero p{font-size:1.15rem;color:var(--mid);max-width:620px;margin:0 auto;line-height:1.7}

/* STATS BAR */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1px;background:var(--border);border-radius:var(--radius);overflow:hidden;margin:0 auto 80px;max-width:900px;box-shadow:var(--shadow-md)}
.stat{background:var(--card);padding:32px 24px;text-align:center;transition:background var(--transition)}
.stat:hover{background:var(--accent-fade)}
.stat .num{font-family:var(--sans);font-size:2rem;font-weight:700;color:var(--accent)}
.stat .desc{font-size:.85rem;color:var(--mid);margin-top:4px;font-family:var(--sans)}

/* STAT CARDS (inline data viz) */
.stat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin:32px 0}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;text-align:center;transition:box-shadow var(--transition),transform var(--transition)}
.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.stat-card .stat-card-value{font-family:var(--sans);font-size:2.2rem;font-weight:700;color:var(--accent);line-height:1.1}
.stat-card .stat-card-label{font-family:var(--sans);font-size:.8rem;color:var(--mid);margin-top:6px;text-transform:uppercase;letter-spacing:.06em}
.stat-card .stat-card-delta{font-family:var(--sans);font-size:.78rem;margin-top:4px;font-weight:600}
.stat-card .stat-card-delta.up{color:var(--success)}
.stat-card .stat-card-delta.down{color:var(--danger)}
.stat-card .stat-card-delta.neutral{color:var(--light)}

/* STAT HIGHLIGHT BOX */
.stat-highlight{background:var(--accent-light);border-left:4px solid var(--accent);border-radius:0 var(--radius) var(--radius) 0;padding:24px 28px;margin:32px 0;display:flex;gap:24px;align-items:center}
.stat-highlight .stat-highlight-value{font-family:var(--sans);font-size:2.4rem;font-weight:700;color:var(--accent);white-space:nowrap}
.stat-highlight .stat-highlight-text{color:var(--mid);font-size:.95rem;line-height:1.6}
.stat-highlight .stat-highlight-text strong{color:var(--ink)}

/* SVG BAR CHART */
.chart-container{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;margin:32px 0;box-shadow:var(--shadow-sm)}
.chart-container .chart-title{font-family:var(--sans);font-size:1rem;font-weight:600;margin-bottom:4px;color:var(--ink)}
.chart-container .chart-subtitle{font-family:var(--sans);font-size:.8rem;color:var(--light);margin-bottom:20px}
.chart-container svg{width:100%;height:auto;display:block}
.chart-container svg text{font-family:var(--sans);fill:var(--mid)}
.chart-container svg .bar{fill:var(--accent);rx:3;transition:opacity var(--transition)}
.chart-container svg .bar:hover{opacity:.85}
.chart-container svg .bar-bg{fill:#f0f2f5;rx:3}
.chart-container svg .bar-label{font-size:12px;fill:var(--ink)}
.chart-container svg .bar-value{font-size:12px;font-weight:600;fill:var(--accent)}
.chart-container svg .axis-label{font-size:11px;fill:var(--light)}
.chart-container svg .bar-secondary{fill:#7ba1f7;rx:3}

/* SECTIONS */
section{padding:60px 0}
section h2{font-size:1.9rem;margin-bottom:12px}
section .lead{font-size:1.05rem;color:var(--mid);max-width:680px;margin-bottom:40px;line-height:1.7}

/* CARDS */
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:32px;transition:box-shadow var(--transition),transform var(--transition)}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.card .tag{font-family:var(--sans);font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.card h3{font-size:1.2rem;margin-bottom:10px}
.card p{color:var(--mid);font-size:.95rem;margin-bottom:14px}
.card a{font-weight:600;font-size:.9rem;font-family:var(--sans)}

/* ARTICLE CONTENT */
.article-content{max-width:720px;margin:0 auto}
.article-content h2{font-size:1.6rem;margin:48px 0 16px;padding-top:8px;border-top:1px solid var(--border)}
.article-content h2:first-child{border-top:none;padding-top:0;margin-top:0}
.article-content h3{font-size:1.25rem;margin:36px 0 12px;color:var(--ink)}
.article-content h4{font-size:1.05rem;margin:28px 0 10px;color:var(--mid)}
.article-content p{margin-bottom:20px;color:var(--ink);font-size:1.02rem}
.article-content ul,.article-content ol{margin:0 0 20px 24px;color:var(--mid)}
.article-content li{margin-bottom:8px;line-height:1.7}
.article-content li strong{color:var(--ink)}
.article-content blockquote{border-left:3px solid var(--accent);padding:16px 24px;margin:28px 0;background:var(--accent-light);border-radius:0 var(--radius) var(--radius) 0;font-style:italic;color:var(--mid)}
.article-content blockquote p:last-child{margin-bottom:0}
.article-content .cite{font-size:.8rem;color:var(--light);font-style:normal;display:block;margin-top:8px}

/* DATA TABLES */
.article-content table{width:100%;border-collapse:collapse;margin:28px 0;font-size:.9rem;box-shadow:var(--shadow-sm);border-radius:var(--radius);overflow:hidden}
.article-content th,.article-content td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border)}
.article-content th{font-family:var(--sans);font-weight:600;background:#f5f7fa;color:var(--ink);font-size:.82rem;text-transform:uppercase;letter-spacing:.03em}
.article-content td{color:var(--mid)}
.article-content tr:last-child td{border-bottom:none}
.article-content tr:hover td{background:var(--accent-fade)}
.article-content td:first-child{font-weight:500;color:var(--ink)}

/* DATA TABLE SCROLL */
.data-table-scroll{overflow-x:auto;margin:28px 0;-webkit-overflow-scrolling:touch}

/* RESOURCE CARDS */
.resource-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;margin-bottom:24px;transition:box-shadow var(--transition),border-color var(--transition)}
.resource-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong)}
.resource-tag{display:inline-block;background:var(--accent);color:#fff;font-family:var(--sans);font-size:.65rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;border-radius:4px;margin-right:8px;margin-bottom:12px}
.resource-title{font-size:1.1rem;font-weight:600;margin-bottom:8px;font-family:var(--sans)}
.resource-desc{color:var(--mid);font-size:.9rem;margin-bottom:12px;line-height:1.65}
.resource-meta{font-size:.8rem;color:var(--light);font-family:var(--sans)}

/* REPORT META BAR */
.report-meta{display:flex;gap:32px;margin:40px 0;padding:24px;background:#f5f7fa;border-radius:var(--radius);font-size:.9rem;border:1px solid var(--border)}
.report-meta div{flex:1}
.report-meta strong{color:var(--ink);display:block;margin-bottom:4px;font-family:var(--sans);font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}
.report-meta span{color:var(--mid)}

/* PUBLICATION METADATA */
.pub-meta{font-family:var(--sans);font-size:.82rem;color:var(--light);margin-bottom:32px;padding-bottom:16px;border-bottom:1px solid var(--border);display:flex;gap:24px;flex-wrap:wrap}
.pub-meta span{display:flex;align-items:center;gap:6px}
.pub-meta a{color:var(--light);border:none}
.pub-meta a:hover{color:var(--accent)}

/* METHODOLOGY SECTION */
.methodology{background:#f8f9fb;border:1px solid var(--border);border-radius:var(--radius);padding:32px;margin:40px 0}
.methodology h3{font-size:1.1rem;margin-bottom:12px;color:var(--accent2)}
.methodology p{font-size:.92rem;color:var(--mid);margin-bottom:16px}
.methodology p:last-child{margin-bottom:0}
.methodology ul{margin:0 0 16px 20px;font-size:.92rem;color:var(--mid)}
.methodology li{margin-bottom:6px}

/* CALLOUT / NOTE BOXES */
.callout{border-radius:var(--radius);padding:20px 24px;margin:28px 0;font-size:.92rem;line-height:1.65}
.callout-info{background:var(--accent-light);border-left:4px solid var(--accent)}
.callout-success{background:var(--success-bg);border-left:4px solid var(--success)}
.callout-warning{background:var(--warning-bg);border-left:4px solid var(--warning)}
.callout-danger{background:var(--danger-bg);border-left:4px solid var(--danger)}
.callout strong{display:block;font-family:var(--sans);margin-bottom:4px}

/* CHART PLACEHOLDER (legacy) */
.chart-placeholder{background:#f5f7fa;border:1px solid var(--border);border-radius:var(--radius);padding:40px;text-align:center;color:var(--mid);margin:28px 0;font-style:italic}

/* FAQ SECTION */
.faq-section{margin:48px 0}
.faq-section h2{font-size:1.6rem;margin-bottom:24px;border-top:none;padding-top:0}
.faq-item{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;overflow:hidden;transition:border-color var(--transition)}
.faq-item:hover{border-color:var(--border-strong)}
.faq-item.open{border-color:var(--accent);box-shadow:0 2px 12px rgba(45,91,227,.08)}
.faq-question{padding:20px 24px;font-family:var(--sans);font-weight:600;font-size:1rem;cursor:pointer;background:var(--card);display:flex;justify-content:space-between;align-items:center;user-select:none;transition:background var(--transition)}
.faq-question:hover{background:#fafbff}
.faq-question::after{content:'+';font-size:1.2rem;color:var(--accent);font-weight:300;transition:transform .2s;flex-shrink:0;margin-left:16px}
.faq-item.open .faq-question::after{transform:rotate(45deg)}
.faq-answer{padding:0 24px 20px;color:var(--mid);font-size:.95rem;line-height:1.7;display:none}
.faq-item.open .faq-answer{display:block}
.faq-answer a{color:var(--accent)}

/* KEY FINDINGS LIST */
.key-findings{list-style:none;padding:0;margin:28px 0}
.key-findings li{padding:16px 20px 16px 56px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;position:relative;font-size:.95rem;color:var(--mid);line-height:1.6}
.key-findings li::before{content:attr(data-num);position:absolute;left:16px;top:14px;font-family:var(--sans);font-weight:700;font-size:1.1rem;color:var(--accent);width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--accent-light);border-radius:50%}
.key-findings li strong{color:var(--ink)}

/* COMPARISON TABLE (for tool comparisons) */
.comparison-table{width:100%;border-collapse:collapse;margin:28px 0;font-size:.85rem}
.comparison-table th{background:var(--accent);color:#fff;padding:12px 14px;text-align:left;font-family:var(--sans);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}
.comparison-table td{padding:12px 14px;border-bottom:1px solid var(--border);vertical-align:top}
.comparison-table tr:hover td{background:var(--accent-fade)}
.comparison-table tr:last-child td{border-bottom:none}
.comparison-table .check{color:var(--success);font-weight:700}
.comparison-table .x{color:var(--light)}

/* TAGS / BADGES */
.badge{display:inline-block;font-family:var(--sans);font-size:.68rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:3px 8px;border-radius:4px}
.badge-primary{background:var(--accent);color:#fff}
.badge-secondary{background:var(--accent-light);color:var(--accent)}
.badge-success{background:var(--success-bg);color:var(--success)}
.badge-warning{background:var(--warning-bg);color:var(--warning)}

/* FOOTER */
footer{background:var(--ink);color:#ccc;padding:60px 0 40px;margin-top:80px;font-size:.85rem}
footer .container{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:32px;align-items:start}
footer a{color:#aaa;border:none}
footer a:hover{color:#fff}
footer .f-brand{color:#fff;font-family:var(--sans);font-weight:700;font-size:1.15rem;margin-bottom:10px;letter-spacing:-0.02em}
footer p{max-width:400px;line-height:1.6}
footer h4{color:#fff;font-family:var(--sans);font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px}
footer ul{list-style:none}
footer ul li{margin-bottom:8px}
footer .footer-bottom{grid-column:1 / -1;border-top:1px solid rgba(255,255,255,.1);padding-top:24px;margin-top:16px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
footer .footer-bottom .trust-signals{display:flex;gap:20px;font-size:.78rem;color:#888}
footer .footer-bottom .trust-signals span{display:flex;align-items:center;gap:6px}
footer .footer-license{font-size:.78rem;color:#888}
footer .footer-license a{color:#aaa}
footer .footer-contact{font-family:var(--sans);font-size:.82rem;color:#aaa;margin-top:12px}
footer .footer-contact a{color:#ddd}

/* 404 PAGE */
.error-page{text-align:center;padding:120px 24px 80px}
.error-page h1{font-size:6rem;color:var(--accent);font-family:var(--sans);margin-bottom:16px;line-height:1}
.error-page h2{font-size:1.5rem;margin-bottom:16px}
.error-page p{color:var(--mid);max-width:480px;margin:0 auto 32px}
.error-page a.btn{display:inline-block;background:var(--accent);color:#fff;padding:12px 28px;border-radius:var(--radius-sm);font-family:var(--sans);font-weight:600;font-size:.9rem;border:none;box-shadow:0 2px 8px rgba(45,91,227,.25);transition:background var(--transition),box-shadow var(--transition)}
.error-page a.btn:hover{background:var(--accent2);box-shadow:0 4px 16px rgba(45,91,227,.3)}

/* CTA BUTTON */
.btn{display:inline-block;background:var(--accent);color:#fff;padding:12px 28px;border-radius:var(--radius-sm);font-family:var(--sans);font-weight:600;font-size:.9rem;border:none;cursor:pointer;box-shadow:0 2px 8px rgba(45,91,227,.2);transition:all var(--transition)}
.btn:hover{background:var(--accent2);color:#fff;box-shadow:0 4px 16px rgba(45,91,227,.3);transform:translateY(-1px);border:none}
.btn-outline{background:transparent;color:var(--accent);border:2px solid var(--accent);box-shadow:none}
.btn-outline:hover{background:var(--accent);color:#fff}

/* TOC (Table of Contents) */
.toc{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:24px 28px;margin:32px 0}
.toc h4{font-family:var(--sans);font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;color:var(--light);margin-bottom:12px}
.toc ol{margin:0;padding-left:20px;counter-reset:toc-counter}
.toc li{margin-bottom:8px;font-size:.9rem;font-family:var(--sans)}
.toc a{color:var(--mid);border:none}
.toc a:hover{color:var(--accent)}

/* PRINT STYLES */
@media print{
  nav,.breadcrumbs,.breadcrumb{display:none}
  footer{display:none}
  .hero{padding:32px 0;background:none}
  body{font-size:11pt;line-height:1.5;color:#000}
  a{color:#000;border-bottom:1px solid #999}
  .card,.stat-card,.chart-container,.resource-card{break-inside:avoid}
  .article-content table{font-size:9pt}
}

/* RESPONSIVE */
@media(max-width:768px){
  nav ul{gap:16px;font-size:.8rem}
  .hero{padding:48px 0 36px}
  .hero h1{font-size:1.8rem}
  .stats{grid-template-columns:1fr 1fr}
  .stat-cards{grid-template-columns:1fr 1fr}
  .card-grid{grid-template-columns:1fr}
  .report-meta{flex-direction:column;gap:16px}
  .stat-highlight{flex-direction:column;text-align:center}
  footer .container{grid-template-columns:1fr 1fr;gap:24px}
  footer .footer-bottom{flex-direction:column;text-align:center}
  .pub-meta{flex-direction:column;gap:8px}
  .comparison-table{font-size:.78rem}
  .comparison-table th,.comparison-table td{padding:8px 10px}
}
@media(max-width:480px){
  nav .container{flex-direction:column;gap:12px}
  nav ul{flex-wrap:wrap;justify-content:center;gap:12px}
  .stats{grid-template-columns:1fr}
  .stat-cards{grid-template-columns:1fr}
  .article-content h2{font-size:1.3rem}
  .article-content h3{font-size:1.1rem}
  footer .container{grid-template-columns:1fr}
  .chart-container{padding:16px}
  .methodology{padding:20px}
}
