:root { font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif; color: #0f172a; }
body { margin: 0; background: #f5f7fb; line-height: 1.7; }
.container { max-width: 1180px; margin: 0 auto; padding: 0 18px; }
.fsd-hero { background: linear-gradient(120deg, #0f6efc, #5b1bff); color: #fff; padding: 56px 0 48px; }
.fsd-hero-grid { display: grid; grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr); gap: 26px; align-items: center; }
.wc-eyebrow { letter-spacing: 0.2em; text-transform: uppercase; font-size: 0.78rem; margin: 0 0 8px; }
.fsd-hero h1 { margin: 0 0 12px; font-size: clamp(2.1rem, 4vw, 3rem); }
.fsd-subtitle { margin: 0 0 12px; opacity: 0.95; }
.wc-bullets { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 12px; }
.wc-bullets span { padding: 8px 12px; border-radius: 999px; background: rgba(255, 255, 255, 0.16); font-weight: 700; }
.wc-hero-card { background: rgba(255, 255, 255, 0.12); border: 1px solid rgba(255, 255, 255, 0.25); border-radius: 20px; padding: 22px; box-shadow: 0 18px 44px rgba(0, 0, 0, 0.18); }
.wc-hero-badge { display: inline-block; background: rgba(255, 255, 255, 0.2); padding: 6px 12px; border-radius: 12px; font-weight: 700; }
.fsd-main { padding: 40px 0 60px; }
.fsd-grid { display: grid; gap: 18px; }
.card { background: #fff; border-radius: 18px; padding: 20px; box-shadow: 0 18px 44px rgba(15, 23, 42, 0.08); border: 1px solid #e2e8f0; overflow: hidden; }
.card-head { display: flex; justify-content: space-between; gap: 12px; align-items: flex-start; flex-wrap: wrap; }
.card-head.small h3 { margin: 0; }
.chip-row { display: flex; flex-wrap: wrap; gap: 8px; }
.chip { padding: 6px 10px; border-radius: 999px; background: #eef2ff; color: #1d4ed8; font-weight: 700; font-size: 0.9rem; }
.label-row { display: flex; justify-content: space-between; align-items: center; font-weight: 700; gap: 10px; }
.muted { color: #64748b; }
.tiny { font-size: 0.9rem; }
.primary-btn, .secondary-btn, .ghost-btn { border: none; border-radius: 12px; padding: 10px 14px; font-weight: 800; cursor: pointer; transition: transform 0.15s ease, box-shadow 0.15s ease; }
.primary-btn { background: linear-gradient(135deg, #1d4ed8, #2563eb); color: #fff; box-shadow: 0 12px 30px rgba(37, 99, 235, 0.35); }
.secondary-btn { background: #f8fafc; border: 1px solid #dbeafe; color: #0f172a; }
.ghost-btn { background: #fff; border: 1px solid #dbeafe; color: #0f6efc; }
.ghost-btn.sm { padding: 8px 10px; font-size: 0.95rem; }
.ghost-btn:hover, .secondary-btn:hover, .primary-btn:hover { transform: translateY(-1px); }
.cta-row { margin-top: 10px; display: flex; gap: 10px; flex-wrap: wrap; }
.stack-on-mobile { display: flex; gap: 10px; }
.fsd-layout { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr); gap: 14px; margin-top: 16px; align-items: start; }
.fsd-dropzone { border: 1.5px dashed #94a3b8; border-radius: 14px; padding: 16px; text-align: center; background: #f8fafc; display: grid; gap: 6px; justify-items: center; }
.fsd-dropzone.dragging { border-color: #2563eb; background: #eef2ff; }
.fsd-dropzone input[type='file'] { display: none; }
.drop-title { margin: 0; font-weight: 800; }
.fsd-preview { margin-top: 12px; }
.fsd-preview-frame { position: relative; width: 100%; background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 12px; overflow: hidden; min-height: 260px; display: grid; place-items: center; }
.fsd-preview-frame img { max-width: 100%; display: block; }
.fsd-preview-frame canvas { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; }
.fsd-result-card { background: #f8fafc; }
.fsd-shape-row { display: grid; grid-template-columns: minmax(0, 0.7fr) minmax(0, 1fr); gap: 12px; align-items: center; }
.fsd-shape-label { font-size: 2rem; font-weight: 800; }
.fsd-confidence { display: grid; gap: 6px; }
.confidence-bar { background: #e2e8f0; border-radius: 999px; height: 10px; overflow: hidden; }
.confidence-bar span { display: block; height: 100%; width: 0; background: linear-gradient(135deg, #22c55e, #16a34a); transition: width 0.2s ease; }
.fsd-tips { display: grid; gap: 6px; }
.fsd-tips .tip { background: #fff; border: 1px solid #dbeafe; border-radius: 10px; padding: 8px; }
.fsd-reference { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 10px; margin-top: 10px; }
.ref-card { background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 12px; padding: 10px; text-align: center; }
.ref-icon { font-size: 1.6rem; margin-bottom: 6px; }
.info-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 12px; }
.info-card { background: #fff; border-radius: 16px; padding: 16px; border: 1px solid #e2e8f0; box-shadow: 0 12px 28px rgba(15, 23, 42, 0.06); }
.related-links { display: flex; flex-wrap: wrap; gap: 10px; }
.related-links a { padding: 8px 12px; border-radius: 999px; border: 1px solid #dbeafe; color: #1d4ed8; text-decoration: none; background: #eef2ff; font-weight: 700; }
.fsd-steps { margin: 0; padding-left: 18px; display: grid; gap: 8px; }
.fsd-list { margin: 0; padding-left: 18px; display: grid; gap: 6px; }
.faq-tabs { display: flex; gap: 10px; margin-bottom: 10px; flex-wrap: wrap; }
.faq-tab { border: 1px solid #dbeafe; background: #f8fafc; border-radius: 10px; padding: 8px 12px; cursor: pointer; font-weight: 700; color: #0f172a; }
.faq-tab.active { background: #1d4ed8; color: #fff; border-color: #1d4ed8; }
.faq-panel { display: grid; gap: 10px; }
.faq-panel.hidden { display: none; }
.faq-item { border: 1px solid #e2e8f0; border-radius: 12px; padding: 12px; background: #f8fafc; }
.fsd-hero-card { color: #fff; }
.fsd-hero-card p { margin: 8px 0 0; }
#hpdf-download-all[disabled] { opacity: 0.5; cursor: not-allowed; }

@media (max-width: 960px) {
  body { overflow-x: hidden; }
  .fsd-hero-grid { grid-template-columns: 1fr; }
  .fsd-hero { padding: 32px 0; }
  .fsd-main { padding: 20px 0 36px; }
  .card { padding: 16px; border-radius: 16px; }
  .fsd-layout { grid-template-columns: 1fr; }
}

@media (max-width: 720px) {
  .chip-row { gap: 6px; }
  .stack-on-mobile { flex-direction: column; width: 100%; }
.fsd-queue-item, .fsd-result { grid-template-columns: 64px 1fr; grid-template-rows: auto auto; }
.fsd-actions, .fsd-result .actions { grid-column: 1 / -1; justify-items: start; }
#fsd-download-all { position: sticky; bottom: 12px; width: 100%; }
}
