/* CBC Interpreter — Stylesheet v1.0
   Inherits LML theme CSS variables. */

.cbc-page { display:flex; flex-direction:column; gap:20px; }

/* Hero */
.cbc-hero { text-align:center; padding:32px 0 8px; }
.cbc-hero h1 { font-size:clamp(1.875rem,4vw,2.5rem); font-weight:800; color:var(--color-dark,#0f172a); margin:8px 0 10px; letter-spacing:-0.02em; }
.cbc-hero-sub { font-size:var(--text-lg,1.125rem); color:var(--color-text-muted,#64748b); margin:0; }

/* Card */
.cbc-card { background:#fff; border:1.5px solid var(--color-border,#e2e8f0); border-radius:var(--radius-lg,12px); overflow:hidden; }
.cbc-card-header { padding:14px 20px; border-bottom:1px solid var(--color-border-light,#f1f5f9); background:var(--color-surface,#f8fafc); display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px; }
.cbc-card-title { display:flex; align-items:center; gap:8px; font-size:13px; font-weight:700; color:var(--color-text,#1e293b); text-transform:uppercase; letter-spacing:.04em; }
.cbc-card-title svg { stroke:var(--color-primary,#0D7C7C); flex-shrink:0; }

/* Sex toggle */
.cbc-sex-toggle { display:flex; border:1.5px solid var(--color-border,#e2e8f0); border-radius:6px; overflow:hidden; }
.cbc-sex-btn { padding:7px 18px; font-size:13px; font-weight:600; background:#fff; color:var(--color-text-muted,#64748b); border:none; cursor:pointer; transition:all .15s; }
.cbc-sex-btn.active { background:var(--color-primary,#0D7C7C); color:#fff; }

/* Form */
.cbc-form { padding:24px 20px; display:flex; flex-direction:column; gap:20px; }
.cbc-section-label { font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; color:var(--color-primary,#0D7C7C); border-bottom:2px solid var(--color-primary,#0D7C7C); padding-bottom:6px; }
.cbc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.cbc-grid--2 { grid-template-columns:repeat(2,1fr); }
.cbc-field { display:flex; flex-direction:column; gap:5px; }
.cbc-field label { font-size:13px; font-weight:600; color:var(--color-text,#1e293b); }
.cbc-opt { font-size:11px; font-weight:400; color:var(--color-text-muted,#64748b); }
.cbc-input-row { display:flex; align-items:center; gap:8px; }
.cbc-input { height:40px; padding:0 10px; border:1.5px solid var(--color-border,#e2e8f0); border-radius:var(--radius,8px); font-size:15px; font-weight:600; color:var(--color-text,#1e293b); background:#fff; transition:border-color .15s; width:100%; min-width:0; }
.cbc-input:focus { outline:none; border-color:var(--color-primary,#0D7C7C); box-shadow:0 0 0 3px rgba(13,124,124,.12); }
.cbc-input.cbc-input-abnormal { border-color:#f87171; background:#fff9f9; }
.cbc-input.cbc-input-normal { border-color:#86efac; }
.cbc-unit { font-size:11px; font-weight:600; color:var(--color-text-muted,#64748b); white-space:nowrap; flex-shrink:0; }
.cbc-ref { font-size:10px; color:var(--color-text-muted,#64748b); margin:0; }

.cbc-btn-calc { display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:14px 32px; background:var(--color-primary,#0D7C7C); color:#fff; font-size:15px; font-weight:700; border:none; border-radius:var(--radius,8px); cursor:pointer; width:100%; max-width:280px; align-self:center; transition:background .15s; }
.cbc-btn-calc:hover { background:var(--color-primary-dark,#0a5f5f); }

/* Summary banner */
.cbc-summary-banner { border-radius:var(--radius-lg,12px); padding:16px 20px; display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.cbc-summary-banner.all-normal { background:#f0fdf4; border:1.5px solid #86efac; }
.cbc-summary-banner.has-abnormal { background:#fef9ec; border:1.5px solid #fcd34d; }
.cbc-summary-banner.has-critical { background:#fef2f2; border:1.5px solid #fca5a5; }
.cbc-banner-icon { width:40px; height:40px; border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.cbc-banner-title { font-size:16px; font-weight:800; color:var(--color-dark,#0f172a); }
.cbc-banner-sub { font-size:13px; color:var(--color-text-muted,#64748b); margin-top:2px; }
.cbc-flag-chips { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; }
.cbc-flag-chip { padding:3px 10px; border-radius:20px; font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.04em; }
.chip-normal  { background:#dcfce7; color:#166534; }
.chip-low     { background:#fef3c7; color:#92400e; }
.chip-high    { background:#fee2e2; color:#991b1b; }
.chip-critical{ background:#dc2626; color:#fff; }

/* Result panels */
.cbc-panels { display:flex; flex-direction:column; gap:14px; }
.cbc-panel { background:#fff; border:1.5px solid var(--color-border,#e2e8f0); border-radius:var(--radius-lg,12px); overflow:hidden; }
.cbc-panel-header { display:flex; align-items:center; justify-content:space-between; padding:12px 16px; border-bottom:1px solid var(--color-border-light,#f1f5f9); }
.cbc-panel-header.normal   { background:#f0fdf4; }
.cbc-panel-header.abnormal { background:#fffbeb; }
.cbc-panel-header.critical { background:#fef2f2; }
.cbc-panel-title { font-size:14px; font-weight:700; color:var(--color-dark,#0f172a); display:flex; align-items:center; gap:8px; }
.cbc-panel-badge { padding:3px 10px; border-radius:20px; font-size:11px; font-weight:800; text-transform:uppercase; }
.badge-normal  { background:#dcfce7; color:#166534; }
.badge-low     { background:#fef3c7; color:#92400e; }
.badge-high    { background:#fee2e2; color:#991b1b; }
.badge-critical{ background:#dc2626; color:#fff; }
.cbc-panel-body { padding:16px; }
.cbc-panel-values { display:flex; flex-wrap:wrap; gap:12px; margin-bottom:14px; }
.cbc-pval { background:var(--color-surface,#f8fafc); border-radius:8px; padding:10px 14px; text-align:center; min-width:100px; }
.cbc-pval-label { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.05em; color:var(--color-text-muted,#64748b); margin-bottom:4px; }
.cbc-pval-num { font-size:1.4rem; font-weight:900; color:var(--color-dark,#0f172a); line-height:1; }
.cbc-pval-num.val-low { color:#d97706; }
.cbc-pval-num.val-high { color:#dc2626; }
.cbc-pval-num.val-critical { color:#991b1b; }
.cbc-pval-unit { font-size:10px; color:var(--color-text-muted,#64748b); margin-top:2px; }
.cbc-ddx-title { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.04em; color:var(--color-text-muted,#64748b); margin-bottom:8px; }
.cbc-ddx-list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:6px; }
.cbc-ddx-item { font-size:13px; color:var(--color-text,#1e293b); padding:7px 12px; border-radius:6px; border-left:3px solid; line-height:1.5; }
.ddx-primary { background:#fef9ec; border-color:#f59e0b; }
.ddx-secondary { background:#f8fafc; border-color:#cbd5e1; }
.ddx-important { background:#fef2f2; border-color:#f87171; }

/* Actions box */
.cbc-actions-box { background:#fff; border:1.5px solid var(--color-border,#e2e8f0); border-radius:var(--radius-lg,12px); overflow:hidden; }
.cbc-actions-header { padding:12px 16px; border-bottom:1px solid var(--color-border-light,#f1f5f9); background:var(--color-surface,#f8fafc); font-size:13px; font-weight:700; color:var(--color-text,#1e293b); text-transform:uppercase; letter-spacing:.04em; display:flex; align-items:center; gap:8px; }
.cbc-actions-header svg { stroke:var(--color-primary,#0D7C7C); }
.cbc-actions-list { list-style:none; padding:16px 20px; margin:0; display:flex; flex-direction:column; gap:10px; }
.cbc-action-item { display:flex; align-items:flex-start; gap:10px; font-size:14px; color:var(--color-text,#1e293b); line-height:1.5; }
.cbc-action-item::before { content:'→'; color:var(--color-primary,#0D7C7C); font-weight:700; flex-shrink:0; margin-top:1px; }
.cbc-action-item.urgent::before { content:'!'; background:#dc2626; color:#fff; border-radius:50%; width:18px; height:18px; display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:900; flex-shrink:0; margin-top:1px; }

/* Ref table */
.cbc-ref-card { margin-top:0; }
.cbc-ref-table { width:100%; border-collapse:collapse; font-size:13px; }
.cbc-ref-table th { padding:10px 14px; background:var(--color-surface,#f8fafc); font-weight:700; color:var(--color-text-muted,#64748b); text-align:left; border-bottom:1px solid var(--color-border,#e2e8f0); font-size:11px; text-transform:uppercase; letter-spacing:.04em; }
.cbc-ref-table td { padding:11px 14px; border-bottom:1px solid var(--color-border-light,#f1f5f9); color:var(--color-text,#1e293b); vertical-align:top; }
.cbc-ref-table tr:last-child td { border-bottom:none; }
.cbc-pill { display:inline-block; padding:2px 10px; border-radius:20px; font-size:11px; font-weight:800; text-transform:uppercase; }
.cbc-pill--blue   { background:#dbeafe; color:#1d4ed8; }
.cbc-pill--green  { background:#dcfce7; color:#166534; }
.cbc-pill--orange { background:#ffedd5; color:#9a3412; }
.cbc-ref-note { padding:10px 14px; font-size:11px; color:var(--color-text-muted,#64748b); border-top:1px solid var(--color-border-light,#f1f5f9); }

@media(max-width:700px) {
    .cbc-grid { grid-template-columns:1fr 1fr; }
    .cbc-grid--2 { grid-template-columns:1fr; }
}
@media(max-width:480px) {
    .cbc-grid { grid-template-columns:1fr; }
}
