/* ============================================================
   soap.css — SOAP Notes module
   Zero gradients. Tokens only.
   ============================================================ */

.cc-hidden { display: none !important; }

/* Layout */
.cc-soap-shell { display: block; }

.cc-soap-layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--cc-space-6);
}

@media (min-width: 960px) {
    .cc-soap-layout {
        grid-template-columns: 65% 35%;
    }
}

/* Tabs */
.cc-soap-tabs {
    display: flex;
    gap: var(--cc-space-1);
    background: var(--cc-surface-subtle);
    padding: var(--cc-space-1);
    border-radius: var(--cc-radius-md);
    margin-bottom: var(--cc-space-4);
    overflow-x: auto;
}

.cc-soap-tab {
    display: inline-flex;
    align-items: center;
    gap: var(--cc-space-2);
    padding: var(--cc-space-2) var(--cc-space-4);
    border: 0;
    background: transparent;
    color: var(--cc-text-secondary);
    border-radius: var(--cc-radius-sm);
    cursor: pointer;
    font-weight: 500;
    white-space: nowrap;
    transition: background 120ms ease, color 120ms ease;
}

.cc-soap-tab:hover {
    color: var(--cc-text-primary);
}

.cc-soap-tab-active {
    background: var(--cc-surface);
    color: var(--cc-text-primary);
    box-shadow: var(--cc-shadow-sm);
}

.cc-soap-tab-letter {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border-radius: 6px;
    background: var(--cc-brand-primary);
    color: var(--cc-text-on-primary);
    font-weight: 700;
    font-size: 12px;
}

.cc-soap-panel { margin-bottom: var(--cc-space-4); }

/* Pain scale */
.cc-pain-scale {
    display: grid;
    grid-template-columns: repeat(11, 1fr);
    gap: var(--cc-space-1);
}

.cc-pain-btn {
    padding: var(--cc-space-2) 0;
    border: 1px solid var(--cc-border);
    background: var(--cc-surface);
    color: var(--cc-text-primary);
    border-radius: var(--cc-radius-sm);
    cursor: pointer;
    font-weight: 600;
    transition: background 120ms ease, border-color 120ms ease, color 120ms ease;
}

.cc-pain-btn:hover {
    border-color: var(--cc-brand-primary);
}

.cc-pain-btn-active {
    background: var(--cc-brand-primary);
    color: var(--cc-text-on-primary);
    border-color: var(--cc-brand-primary);
}

@media (max-width: 640px) {
    .cc-pain-scale { grid-template-columns: repeat(6, 1fr); }
}

/* Spine map */
.cc-spine-map {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: var(--cc-space-2);
    margin-bottom: var(--cc-space-3);
}

.cc-spine-region {
    display: flex;
    align-items: center;
    gap: var(--cc-space-2);
    padding: var(--cc-space-3);
    border: 1px solid var(--cc-border);
    border-radius: var(--cc-radius-md);
    cursor: pointer;
    background: var(--cc-surface);
    transition: border-color 120ms ease, background 120ms ease;
}

.cc-spine-region:hover {
    border-color: var(--cc-brand-primary);
}

.cc-spine-check {
    width: 18px;
    height: 18px;
    cursor: pointer;
    accent-color: var(--cc-brand-primary);
}

.cc-spine-region:has(.cc-spine-check:checked) {
    background: var(--cc-brand-subtle);
    border-color: var(--cc-brand-primary);
}

.cc-spine-label {
    display: flex;
    flex-direction: column;
    line-height: 1.2;
}

.cc-spine-name {
    font-weight: 600;
    color: var(--cc-text-primary);
}

.cc-spine-range {
    font-size: 12px;
    color: var(--cc-text-secondary);
}

/* CPT auto-map card */
.cc-cpt-result {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--cc-space-3);
    padding: var(--cc-space-3) var(--cc-space-4);
    background: var(--cc-surface-subtle);
    border: 1px solid var(--cc-border);
    border-radius: var(--cc-radius-md);
    flex-wrap: wrap;
}

.cc-cpt-result-label {
    font-size: 12px;
    color: var(--cc-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.cc-cpt-result-value {
    font-family: var(--cc-font-heading);
    font-size: 28px;
    font-weight: 700;
    color: var(--cc-brand-primary);
}

.cc-cpt-result-hint {
    font-size: 12px;
    color: var(--cc-text-secondary);
}

/* Form grids */
.cc-form-grid-2 {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--cc-space-3);
}

@media (min-width: 720px) {
    .cc-form-grid-2 { grid-template-columns: 1fr 1fr; }
}

/* ICD-10 search */
.cc-icd-search {
    position: relative;
}

.cc-icd-results {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    z-index: 20;
    margin-top: var(--cc-space-1);
    background: var(--cc-surface);
    border: 1px solid var(--cc-border);
    border-radius: var(--cc-radius-md);
    box-shadow: var(--cc-shadow-md);
    max-height: 320px;
    overflow-y: auto;
}

.cc-icd-results-open { display: block; }

.cc-icd-result {
    display: grid;
    grid-template-columns: 70px 1fr auto;
    gap: var(--cc-space-2);
    align-items: center;
    width: 100%;
    padding: var(--cc-space-2) var(--cc-space-3);
    border: 0;
    background: transparent;
    cursor: pointer;
    text-align: left;
    border-bottom: 1px solid var(--cc-border-subtle);
}

.cc-icd-result:last-child { border-bottom: 0; }

.cc-icd-result:hover {
    background: var(--cc-surface-subtle);
}

.cc-icd-result-code {
    font-family: var(--cc-font-mono, monospace);
    font-weight: 600;
    color: var(--cc-brand-primary);
}

.cc-icd-result-desc {
    color: var(--cc-text-primary);
    font-size: 14px;
}

.cc-icd-badge {
    font-size: 11px;
    padding: 2px 6px;
    background: var(--cc-brand-subtle);
    color: var(--cc-brand-primary);
    border-radius: var(--cc-radius-sm);
    font-weight: 600;
}

.cc-icd-empty {
    padding: var(--cc-space-3);
    color: var(--cc-text-secondary);
    font-size: 14px;
    text-align: center;
}

.cc-icd-selected {
    margin-top: var(--cc-space-2);
    min-height: 0;
}

.cc-icd-tag {
    display: inline-flex;
    align-items: center;
    gap: var(--cc-space-2);
    padding: var(--cc-space-1) var(--cc-space-3);
    background: var(--cc-brand-subtle);
    color: var(--cc-brand-primary);
    border-radius: var(--cc-radius-full, 999px);
    font-weight: 600;
}

.cc-icd-tag-code {
    font-family: var(--cc-font-mono, monospace);
}

.cc-icd-tag-remove {
    border: 0;
    background: transparent;
    color: var(--cc-brand-primary);
    cursor: pointer;
    font-size: 18px;
    line-height: 1;
    padding: 0 var(--cc-space-1);
}

/* Compliance checklist */
.cc-soap-sidebar { min-width: 0; }

.cc-soap-compliance { }

.cc-compliance-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--cc-space-2);
}

.cc-compliance-item {
    display: flex;
    align-items: center;
    gap: var(--cc-space-2);
    padding: var(--cc-space-2);
    border-radius: var(--cc-radius-sm);
    color: var(--cc-text-secondary);
    font-size: 14px;
}

.cc-compliance-item i { color: var(--cc-text-muted); }

.cc-compliance-item-ok {
    color: var(--cc-text-primary);
}

.cc-compliance-item-ok i { color: var(--cc-success); }

.cc-compliance-score {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: var(--cc-space-3);
    padding-top: var(--cc-space-3);
    border-top: 1px solid var(--cc-border-subtle);
}

.cc-compliance-score-value {
    font-family: var(--cc-font-heading);
    font-size: 20px;
    font-weight: 700;
    color: var(--cc-text-primary);
}

/* Lock banner */
.cc-lock-banner {
    display: flex;
    align-items: center;
    gap: var(--cc-space-3);
    padding: var(--cc-space-3) var(--cc-space-4);
    background: var(--cc-success-subtle, var(--cc-surface-subtle));
    border: 1px solid var(--cc-success, var(--cc-border));
    border-left: 4px solid var(--cc-success, var(--cc-brand-primary));
    border-radius: var(--cc-radius-md);
    color: var(--cc-text-primary);
}

.cc-lock-banner i { color: var(--cc-success, var(--cc-brand-primary)); }

/* Read-only detail */
.cc-soap-readonly {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--cc-space-2) var(--cc-space-4);
    margin: 0;
}

@media (min-width: 720px) {
    .cc-soap-readonly { grid-template-columns: 220px 1fr; }
}

.cc-soap-readonly dt {
    font-size: 13px;
    font-weight: 600;
    color: var(--cc-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.cc-soap-readonly dd {
    margin: 0;
    color: var(--cc-text-primary);
    white-space: pre-wrap;
}

.cc-btn-disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

@media print {
    .cc-sidebar, .cc-topbar, .cc-page-footer, .cc-soap-tabs,
    .cc-soap-sidebar, .cc-lock-banner + *, .cc-btn {
        display: none !important;
    }
    .cc-soap-panel { display: block !important; }
    .cc-main, .cc-page-content { padding: 0 !important; }
}

@media (max-width: 720px) {
    .cc-soap-tabs { flex-wrap: wrap; }
}
