/* AI Schema Builder & Entity Graph Checker
   v0.3.3
   Refined, restrained styling. Uses CSS variables so the tool adapts to its host theme.
   Default is light. Dark mode triggers on:
   - explicit class .ssasb--theme-dark (set via shortcode attribute theme="dark")
   - parent class hooks: html.dark, html[data-theme="dark"], body.dark-mode, body.dark, etc.
   - system preference: @media (prefers-color-scheme: dark)
   The user can force light with .ssasb--theme-light to override any auto-detection. */

[x-cloak] { display: none !important; }

/* ============== LIGHT THEME (default) ============== */
.ssasb {
    --ssasb-bg-outer:      #f7f7f4;
    --ssasb-bg-panel:      #ffffff;
    --ssasb-bg-input:      #ffffff;
    --ssasb-bg-code:       #f7f7f4;
    --ssasb-bg-tag:        rgba(0, 0, 0, 0.06);
    --ssasb-bg-hover:      #f1efe8;

    --ssasb-text:          #1a1a1a;
    --ssasb-text-muted:    #5f5e5a;

    --ssasb-border-soft:   rgba(0, 0, 0, 0.08);
    --ssasb-border-medium: rgba(0, 0, 0, 0.15);

    --ssasb-accent:        #185fa5;
    --ssasb-accent-strong: #0c447c;
    --ssasb-accent-bg:     #e6f1fb;
    --ssasb-accent-border: rgba(24, 95, 165, 0.4);

    --ssasb-success:       #27500a;
    --ssasb-success-bg:    #eaf3de;

    --ssasb-warn:          #633806;
    --ssasb-warn-bg:       #faeeda;

    --ssasb-danger:        #791f1f;
    --ssasb-danger-strong: #a32d2d;
    --ssasb-danger-bg:     #fcebeb;

    --ssasb-focus-ring:    rgba(24, 95, 165, 0.1);
}

/* ============== DARK THEME ============== */
/* Dark mode triggers via three independent paths, each setting the same variables. */

/* Path 1: prefers-color-scheme — only if user hasn't forced light mode */
@media (prefers-color-scheme: dark) {
    .ssasb:not(.ssasb--theme-light) {
        --ssasb-bg-outer:      #1a2233;
        --ssasb-bg-panel:      #242d40;
        --ssasb-bg-input:      #1a2233;
        --ssasb-bg-code:       rgba(255, 255, 255, 0.04);
        --ssasb-bg-tag:        rgba(255, 255, 255, 0.08);
        --ssasb-bg-hover:      rgba(255, 255, 255, 0.06);

        --ssasb-text:          #e8eaed;
        --ssasb-text-muted:    #94a3b8;

        --ssasb-border-soft:   rgba(255, 255, 255, 0.08);
        --ssasb-border-medium: rgba(255, 255, 255, 0.16);

        --ssasb-accent:        #60a5fa;
        --ssasb-accent-strong: #93c5fd;
        --ssasb-accent-bg:     rgba(96, 165, 250, 0.12);
        --ssasb-accent-border: rgba(96, 165, 250, 0.5);

        --ssasb-success:       #86efac;
        --ssasb-success-bg:    rgba(134, 239, 172, 0.14);

        --ssasb-warn:          #fcd34d;
        --ssasb-warn-bg:       rgba(252, 211, 77, 0.14);

        --ssasb-danger:        #f87171;
        --ssasb-danger-strong: #fca5a5;
        --ssasb-danger-bg:     rgba(248, 113, 113, 0.14);

        --ssasb-focus-ring:    rgba(96, 165, 250, 0.18);
    }
}

/* Common parent dark-mode hooks — covers most WordPress dark themes */
html.dark .ssasb:not(.ssasb--theme-light),
html[data-theme="dark"] .ssasb:not(.ssasb--theme-light),
html[data-color-mode="dark"] .ssasb:not(.ssasb--theme-light),
html[data-mode="dark"] .ssasb:not(.ssasb--theme-light),
body.dark-mode .ssasb:not(.ssasb--theme-light),
body.dark .ssasb:not(.ssasb--theme-light),
body[data-theme="dark"] .ssasb:not(.ssasb--theme-light),
body[data-color-mode="dark"] .ssasb:not(.ssasb--theme-light),
[data-bs-theme="dark"] .ssasb:not(.ssasb--theme-light),
.ssasb.ssasb--theme-dark {
    --ssasb-bg-outer:      #1a2233;
    --ssasb-bg-panel:      #242d40;
    --ssasb-bg-input:      #1a2233;
    --ssasb-bg-code:       rgba(255, 255, 255, 0.04);
    --ssasb-bg-tag:        rgba(255, 255, 255, 0.08);
    --ssasb-bg-hover:      rgba(255, 255, 255, 0.06);

    --ssasb-text:          #e8eaed;
    --ssasb-text-muted:    #94a3b8;

    --ssasb-border-soft:   rgba(255, 255, 255, 0.08);
    --ssasb-border-medium: rgba(255, 255, 255, 0.16);

    --ssasb-accent:        #60a5fa;
    --ssasb-accent-strong: #93c5fd;
    --ssasb-accent-bg:     rgba(96, 165, 250, 0.12);
    --ssasb-accent-border: rgba(96, 165, 250, 0.5);

    --ssasb-success:       #86efac;
    --ssasb-success-bg:    rgba(134, 239, 172, 0.14);

    --ssasb-warn:          #fcd34d;
    --ssasb-warn-bg:       rgba(252, 211, 77, 0.14);

    --ssasb-danger:        #f87171;
    --ssasb-danger-strong: #fca5a5;
    --ssasb-danger-bg:     rgba(248, 113, 113, 0.14);

    --ssasb-focus-ring:    rgba(96, 165, 250, 0.18);
}

/* ============== LAYOUT ============== */
.ssasb {
    box-sizing: border-box;
    max-width: 920px;
    margin: 2rem auto;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
    color: var(--ssasb-text);
    background: var(--ssasb-bg-outer);
    border-radius: 12px;
    padding: 1.5rem;
    line-height: 1.55;
}
.ssasb *, .ssasb *::before, .ssasb *::after { box-sizing: border-box; }

/* Header */
.ssasb-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1rem;
    gap: 1rem;
}
.ssasb-title { font-size: 18px; font-weight: 500; margin: 0; color: var(--ssasb-text); }
.ssasb-subtitle { font-size: 13px; color: var(--ssasb-text-muted); margin: 2px 0 0; }
.ssasb-version {
    font-size: 11px;
    padding: 4px 10px;
    background: var(--ssasb-bg-panel);
    border: 1px solid var(--ssasb-border-soft);
    color: var(--ssasb-text-muted);
    border-radius: 8px;
    white-space: nowrap;
}
.ssasb-header-actions {
    display: flex;
    gap: 8px;
    align-items: center;
}
.ssasb-reset-link {
    font-size: 11px;
    padding: 4px 10px;
    background: transparent;
    border: 1px solid var(--ssasb-border-medium);
    color: var(--ssasb-text-muted);
    border-radius: 8px;
    cursor: pointer;
    font-family: inherit;
    transition: all 0.12s ease;
}
.ssasb-reset-link:hover {
    background: var(--ssasb-danger-bg);
    color: var(--ssasb-danger);
    border-color: var(--ssasb-danger);
}

/* Mode toggle */
.ssasb-modes {
    display: inline-flex;
    background: var(--ssasb-bg-panel);
    border: 1px solid var(--ssasb-border-soft);
    border-radius: 8px;
    padding: 3px;
    margin-bottom: 1rem;
}
.ssasb-mode {
    background: transparent;
    border: 0;
    padding: 6px 14px;
    font-size: 12px;
    color: var(--ssasb-text-muted);
    cursor: pointer;
    border-radius: 6px;
    font-family: inherit;
}
.ssasb-mode.is-active { background: var(--ssasb-accent-bg); color: var(--ssasb-accent); font-weight: 500; }

/* Fetch bar */
.ssasb-fetch-bar {
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
    padding: 12px;
    background: var(--ssasb-bg-panel);
    border: 1px solid var(--ssasb-border-soft);
    border-radius: 8px;
    margin-bottom: 1rem;
}
.ssasb-fetch-bar label { font-size: 12px; color: var(--ssasb-text-muted); white-space: nowrap; }
.ssasb-fetch-bar input {
    flex: 1;
    min-width: 200px;
    padding: 8px 10px;
    border: 1px solid var(--ssasb-border-medium);
    border-radius: 6px;
    font-size: 13px;
    font-family: inherit;
    background: var(--ssasb-bg-input);
    color: var(--ssasb-text);
}
.ssasb-fetch-bar button, .ssasb-actions button {
    padding: 8px 14px;
    background: var(--ssasb-bg-panel);
    border: 1px solid var(--ssasb-border-medium);
    border-radius: 6px;
    font-size: 13px;
    color: var(--ssasb-text);
    cursor: pointer;
    font-family: inherit;
    transition: background 0.12s ease;
}
.ssasb-fetch-bar button:hover, .ssasb-actions button:hover { background: var(--ssasb-bg-hover); }
.ssasb-fetch-bar button:disabled { opacity: 0.5; cursor: wait; }

/* Type tabs */
.ssasb-type-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 1rem;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--ssasb-border-soft);
}
.ssasb-type-tab {
    font-size: 12px;
    padding: 6px 12px;
    background: var(--ssasb-bg-panel);
    border: 1px solid var(--ssasb-border-soft);
    color: var(--ssasb-text-muted);
    border-radius: 8px;
    cursor: pointer;
    font-family: inherit;
}
.ssasb-type-tab.is-active { background: var(--ssasb-accent-bg); color: var(--ssasb-accent); font-weight: 500; }
.ssasb-type-tab.is-disabled { opacity: 0.55; cursor: not-allowed; }

/* Section panels */
.ssasb-form, .ssasb-preview, .ssasb-citate, .ssasb-export,
.ssasb-detected, .ssasb-conflicts, .ssasb-visible-match {
    background: var(--ssasb-bg-panel);
    border: 1px solid var(--ssasb-border-soft);
    border-radius: 8px;
    padding: 14px;
    margin-bottom: 12px;
}
.ssasb-form h4, .ssasb-preview h4, .ssasb-citate h4, .ssasb-export h4,
.ssasb-detected h4, .ssasb-conflicts h4, .ssasb-visible-match h4 {
    font-size: 13px;
    font-weight: 500;
    margin: 0 0 12px;
    color: var(--ssasb-text-muted);
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 12px;
}
.ssasb-meta { font-size: 11px; color: var(--ssasb-text-muted); opacity: 0.75; font-weight: 400; }
.ssasb-meta.sev-high { color: var(--ssasb-danger); opacity: 1; font-weight: 500; font-size: 18px; }
.ssasb-meta.sev-medium { color: var(--ssasb-warn); opacity: 1; font-weight: 500; font-size: 18px; }
.ssasb-meta.sev-low { color: var(--ssasb-success); opacity: 1; font-weight: 500; font-size: 18px; }
.ssasb-meta-inline {
    font-size: 10px;
    color: var(--ssasb-text-muted);
    opacity: 0.75;
    font-weight: 400;
    margin-left: 6px;
    text-transform: lowercase;
}

/* Form fields */
.ssasb-form label {
    display: block;
    font-size: 11px;
    color: var(--ssasb-text-muted);
    margin-bottom: 12px;
}
.ssasb-form input,
.ssasb-form textarea,
.ssasb-form select {
    display: block;
    width: 100%;
    padding: 8px 10px;
    margin-top: 4px;
    border: 1px solid var(--ssasb-border-medium);
    border-radius: 6px;
    font-size: 13px;
    box-sizing: border-box;
    font-family: inherit;
    background: var(--ssasb-bg-input);
    color: var(--ssasb-text);
}
.ssasb-form textarea { resize: vertical; line-height: 1.5; }
.ssasb-form input:focus, .ssasb-form textarea:focus, .ssasb-form select:focus {
    outline: none;
    border-color: var(--ssasb-accent);
    box-shadow: 0 0 0 2px var(--ssasb-focus-ring);
}
.ssasb-form .req { color: var(--ssasb-danger-strong); }
.ssasb-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.ssasb-form-row label { margin-bottom: 0; }

/* Code preview */
.ssasb-preview pre, .ssasb-export-output pre {
    font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Courier New", monospace;
    font-size: 11px;
    line-height: 1.6;
    background: var(--ssasb-bg-code);
    border-radius: 6px;
    padding: 10px 12px;
    margin: 0;
    overflow-x: auto;
    white-space: pre-wrap;
    word-break: break-word;
    color: var(--ssasb-text);
}

/* CITATE pillars */
.ssasb-pillars {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 10px;
}
.ssasb-pillar {
    text-align: center;
    padding: 8px 4px;
    border-radius: 6px;
}
.ssasb-pillar.sev-high { background: var(--ssasb-danger-bg); color: var(--ssasb-danger); }
.ssasb-pillar.sev-medium { background: var(--ssasb-warn-bg); color: var(--ssasb-warn); }
.ssasb-pillar.sev-low { background: var(--ssasb-success-bg); color: var(--ssasb-success); }
.ssasb-pillar-key { display: block; font-size: 10px; }
.ssasb-pillar-score { display: block; font-size: 13px; font-weight: 500; margin-top: 2px; }

/* Nudges */
.ssasb-nudges {
    list-style: none;
    padding: 0;
    margin: 8px 0 0;
}
.ssasb-nudges li {
    font-size: 12px;
    padding: 6px 10px;
    border-radius: 6px;
    margin-bottom: 4px;
    display: flex;
    gap: 8px;
    align-items: flex-start;
    line-height: 1.5;
}
.ssasb-nudges li.sev-high { background: var(--ssasb-danger-bg); color: var(--ssasb-danger); }
.ssasb-nudges li.sev-medium { background: var(--ssasb-warn-bg); color: var(--ssasb-warn); }
.ssasb-nudges li.sev-low { background: var(--ssasb-accent-bg); color: var(--ssasb-accent); }
.ssasb-pillar-tag { font-weight: 500; min-width: 22px; }

/* Export */
.ssasb-platform-row {
    display: flex;
    align-items: flex-end;
    gap: 12px;
    margin-bottom: 12px;
    flex-wrap: wrap;
}
.ssasb-platform-row label {
    font-size: 12px;
    color: var(--ssasb-text-muted);
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.ssasb-platform-row select {
    padding: 7px 10px;
    border: 1px solid var(--ssasb-border-medium);
    border-radius: 6px;
    font-size: 13px;
    min-width: 240px;
    background: var(--ssasb-bg-input);
    font-family: inherit;
    color: var(--ssasb-text);
}
.ssasb-detected-chip {
    font-size: 11px;
    padding: 4px 10px;
    background: var(--ssasb-success-bg);
    color: var(--ssasb-success);
    border-radius: 6px;
}
.ssasb-export-output { margin-bottom: 12px; }

.ssasb-export-instructions h5 {
    font-size: 13px;
    font-weight: 500;
    margin: 0 0 10px;
    color: var(--ssasb-text-muted);
}
.ssasb-ins {
    padding: 10px 12px;
    border: 1px solid var(--ssasb-border-soft);
    border-radius: 6px;
    margin-bottom: 6px;
}
.ssasb-ins.is-recommended {
    border-color: var(--ssasb-accent-border);
    background: var(--ssasb-accent-bg);
}
.ssasb-ins-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    margin-bottom: 4px;
    flex-wrap: wrap;
}
.ssasb-ins-label { font-size: 13px; font-weight: 500; color: var(--ssasb-text); }
.ssasb-ins.is-recommended .ssasb-ins-label { color: var(--ssasb-accent-strong); }
.ssasb-ins-scope {
    font-size: 10px;
    padding: 2px 8px;
    background: var(--ssasb-bg-tag);
    color: var(--ssasb-text-muted);
    border-radius: 6px;
    font-weight: 500;
    letter-spacing: 0.5px;
}
.ssasb-ins.is-recommended .ssasb-ins-scope {
    background: var(--ssasb-accent);
    color: var(--ssasb-bg-panel);
}
.ssasb-ins-path {
    font-size: 12px;
    font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Courier New", monospace;
    margin: 0 0 4px;
    color: var(--ssasb-text-muted);
}
.ssasb-ins.is-recommended .ssasb-ins-path { color: var(--ssasb-accent); }
.ssasb-ins-note { font-size: 11px; margin: 0; opacity: 0.85; line-height: 1.5; color: var(--ssasb-text-muted); }
.ssasb-ins.is-recommended .ssasb-ins-note { color: var(--ssasb-accent); }

.ssasb-warnings { margin: 10px 0; }
.ssasb-warning {
    padding: 10px 12px;
    background: var(--ssasb-warn-bg);
    color: var(--ssasb-warn);
    border-radius: 6px;
    font-size: 12px;
    margin: 0 0 6px;
    line-height: 1.5;
}

.ssasb-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 10px;
}

/* Audit panels */
.ssasb-audit-grid {
    display: grid;
    gap: 12px;
}
.ssasb-detected ul, .ssasb-conflicts ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.ssasb-detected li, .ssasb-conflicts li {
    font-size: 12px;
    padding: 8px 10px;
    background: var(--ssasb-bg-code);
    border-radius: 6px;
    margin-bottom: 6px;
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    align-items: center;
    line-height: 1.5;
    color: var(--ssasb-text);
}
.ssasb-detected li .ssasb-status { margin-left: auto; font-size: 11px; }
.ssasb-detected li .ssasb-status.ok { color: var(--ssasb-success); }
.ssasb-detected li .ssasb-status.err { color: var(--ssasb-danger); }
.ssasb-detected li .ssasb-source { color: var(--ssasb-text-muted); }
.ssasb-detected li .ssasb-type { font-weight: 500; }
.ssasb-conflicts li.sev-high { background: var(--ssasb-danger-bg); color: var(--ssasb-danger); }
.ssasb-conflicts li.sev-medium { background: var(--ssasb-warn-bg); color: var(--ssasb-warn); }
.ssasb-conflicts li.sev-low { background: var(--ssasb-accent-bg); color: var(--ssasb-accent); }
.ssasb-sev {
    font-weight: 500;
    text-transform: capitalize;
    min-width: 56px;
    font-size: 11px;
    letter-spacing: 0.3px;
}
.ssasb-empty {
    background: transparent !important;
    color: var(--ssasb-text-muted) !important;
    opacity: 0.7;
    font-style: italic;
}
.ssasb-stub-note {
    font-size: 12px;
    color: var(--ssasb-text-muted);
    margin: 0;
    padding: 10px 12px;
    background: var(--ssasb-bg-code);
    border-radius: 6px;
    line-height: 1.5;
}

/* Article: section sub-headings, publisher mode toggle */
.ssasb-section-h5 {
    font-size: 11px;
    font-weight: 500;
    color: var(--ssasb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.6px;
    margin: 14px 0 8px;
    padding-top: 8px;
    border-top: 1px solid var(--ssasb-border-soft);
}
.ssasb-publisher-mode {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 10px;
}
.ssasb-radio {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 10px 12px;
    background: var(--ssasb-bg-code);
    border: 1px solid var(--ssasb-border-soft);
    border-radius: 6px;
    margin-bottom: 0;
    cursor: pointer;
    font-size: 12px;
    color: var(--ssasb-text);
}
.ssasb-radio.is-disabled { opacity: 0.55; cursor: not-allowed; }
.ssasb-radio input[type="radio"] {
    margin-top: 2px;
    accent-color: var(--ssasb-accent);
}
.ssasb-radio-text {
    display: flex;
    flex-direction: column;
    gap: 3px;
    font-size: 12px;
    line-height: 1.5;
}
.ssasb-radio-text strong { color: var(--ssasb-text); font-weight: 500; }
.ssasb-link-chip {
    display: inline-block;
    font-size: 11px;
    padding: 2px 8px;
    border-radius: 4px;
    width: fit-content;
}
.ssasb-link-chip.ok { background: var(--ssasb-success-bg); color: var(--ssasb-success); }
.ssasb-link-chip.warn { background: var(--ssasb-warn-bg); color: var(--ssasb-warn); }

/* Type-specific notes */
.ssasb-type-note {
    background: var(--ssasb-accent-bg);
    color: var(--ssasb-accent);
    border-radius: 8px;
    padding: 12px 14px;
    margin-bottom: 12px;
    font-size: 12px;
    line-height: 1.55;
}
.ssasb-type-note p { margin: 0; }
.ssasb-type-note strong { color: var(--ssasb-accent-strong); }

/* HowTo steps */
.ssasb-howto-steps {
    margin-top: 4px;
}
.ssasb-howto-steps h5 {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 12px;
    font-weight: 500;
    color: var(--ssasb-text-muted);
    margin: 8px 0 8px;
}
.ssasb-howto-step {
    background: var(--ssasb-bg-code);
    border: 1px solid var(--ssasb-border-soft);
    border-radius: 6px;
    padding: 10px 12px;
    margin-bottom: 8px;
}
.ssasb-step-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 6px;
}
.ssasb-step-num {
    font-size: 11px;
    font-weight: 500;
    color: var(--ssasb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.4px;
}
.ssasb-step-controls { display: flex; gap: 4px; }
.ssasb-howto-step input,
.ssasb-howto-step textarea {
    margin-bottom: 6px;
    padding: 6px 8px;
    border: 1px solid var(--ssasb-border-medium);
    border-radius: 4px;
    font-size: 12px;
    font-family: inherit;
    width: 100%;
    box-sizing: border-box;
    background: var(--ssasb-bg-input);
    color: var(--ssasb-text);
}
.ssasb-howto-step textarea { resize: vertical; line-height: 1.5; }
.ssasb-howto-step .ssasb-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
.ssasb-howto-step .ssasb-form-row input { margin-bottom: 0; }

.ssasb-add-btn {
    font-size: 11px;
    padding: 4px 10px;
    background: var(--ssasb-bg-panel);
    border: 1px solid var(--ssasb-border-medium);
    border-radius: 4px;
    cursor: pointer;
    color: var(--ssasb-accent);
    font-family: inherit;
}
.ssasb-mini-btn {
    font-size: 12px;
    padding: 2px 8px;
    background: var(--ssasb-bg-panel);
    border: 1px solid var(--ssasb-border-medium);
    border-radius: 4px;
    cursor: pointer;
    color: var(--ssasb-text-muted);
    font-family: inherit;
    line-height: 1;
    min-width: 22px;
}
.ssasb-mini-btn:disabled { opacity: 0.35; cursor: not-allowed; }
.ssasb-mini-btn.ssasb-remove-btn { color: var(--ssasb-danger); }

/* Bulk paste panel (FAQ form) */
.ssasb-bulk-paste {
    background: var(--ssasb-bg-code);
    border: 1px solid var(--ssasb-border-soft);
    border-radius: 6px;
    padding: 12px;
    margin-bottom: 10px;
}
.ssasb-bulk-help {
    font-size: 11px;
    color: var(--ssasb-text-muted);
    margin: 0 0 8px;
    line-height: 1.55;
}
.ssasb-bulk-paste textarea {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid var(--ssasb-border-medium);
    border-radius: 4px;
    font-size: 12px;
    font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Courier New", monospace;
    background: var(--ssasb-bg-input);
    color: var(--ssasb-text);
    box-sizing: border-box;
    margin-bottom: 8px;
    resize: vertical;
    line-height: 1.5;
}
.ssasb-bulk-paste textarea:focus {
    outline: none;
    border-color: var(--ssasb-accent);
    box-shadow: 0 0 0 2px var(--ssasb-focus-ring);
}
.ssasb-bulk-error {
    font-size: 11px;
    color: var(--ssasb-danger);
    background: var(--ssasb-danger-bg);
    padding: 6px 10px;
    border-radius: 4px;
    margin-bottom: 8px;
    line-height: 1.5;
}
.ssasb-bulk-actions {
    display: flex;
    gap: 6px;
}
.ssasb-bulk-actions button {
    font-size: 12px;
    padding: 6px 14px;
    background: var(--ssasb-bg-panel);
    border: 1px solid var(--ssasb-border-medium);
    border-radius: 4px;
    cursor: pointer;
    color: var(--ssasb-text);
    font-family: inherit;
}
.ssasb-bulk-actions button:hover { background: var(--ssasb-bg-hover); }
.ssasb-bulk-actions button:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}
.ssasb-bulk-success {
    font-size: 11px;
    color: var(--ssasb-success);
    background: var(--ssasb-success-bg);
    padding: 6px 10px;
    border-radius: 4px;
    margin-bottom: 8px;
}

/* Responsive */
@media (max-width: 600px) {
    .ssasb { padding: 1rem; }
    .ssasb-form-row { grid-template-columns: 1fr; }
    .ssasb-pillars { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .ssasb-platform-row select { min-width: 100%; }
}
