/* Codeswap — main stylesheet
   Mobile-first, system fonts, CSS variables for theming.
   Total target: < 25KB. Tool-specific styles in separate files. */

:root {
    /* Light theme — default */
    --c-bg:        #ffffff;
    --c-bg-soft:   #f7f8fa;
    --c-bg-mute:   #eef1f5;
    --c-fg:        #0f172a;
    --c-fg-soft:   #334155;
    --c-fg-mute:   #64748b;
    --c-border:    #e2e8f0;
    --c-border-strong: #cbd5e1;
    --c-accent:    #2563eb;
    --c-accent-h:  #1d4ed8;
    --c-accent-soft:#dbeafe;
    --c-on-accent: #ffffff;
    --c-success:   #059669;
    --c-success-bg:#d1fae5;
    --c-success-fg:#065f46;
    --c-warn:      #d97706;
    --c-warn-bg:   #fef3c7;
    --c-warn-fg:   #92400e;
    --c-danger:    #dc2626;
    --c-danger-bg: #fee2e2;
    --c-danger-fg: #991b1b;
    --c-info-bg:   #dbeafe;
    --c-info-fg:   #1e40af;
    --c-code-bg:   #0f172a;
    --c-code-fg:   #e2e8f0;
    --c-mark-bg:   #fef08a;
    --c-mark-fg:   #713f12;
    --c-diff-add-bg: rgba(34, 197, 94, .12);
    --c-diff-add-fg: #15803d;
    --c-diff-del-bg: rgba(239, 68, 68, .12);
    --c-diff-del-fg: #b91c1c;

    /* Type */
    --font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace;

    /* Spacing */
    --gap-1: .25rem;
    --gap-2: .5rem;
    --gap-3: .75rem;
    --gap-4: 1rem;
    --gap-5: 1.5rem;
    --gap-6: 2rem;
    --gap-8: 3rem;

    /* Radii */
    --r-sm: 4px;
    --r-md: 8px;
    --r-lg: 12px;

    --shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.05);
    --shadow-md: 0 4px 12px rgba(15, 23, 42, 0.08);

    --container: 72rem;
    --container-narrow: 48rem;
}

/* Dark theme — applied via [data-theme="dark"] OR system preference (unless [data-theme="light"]) */
[data-theme="dark"] {
    --c-bg:        #0b1220;
    --c-bg-soft:   #111c30;
    --c-bg-mute:   #1e293b;
    --c-fg:        #f1f5f9;
    --c-fg-soft:   #cbd5e1;
    --c-fg-mute:   #94a3b8;
    --c-border:    #1e293b;
    --c-border-strong: #334155;
    --c-accent:    #60a5fa;
    --c-accent-h:  #93c5fd;
    --c-accent-soft:#1e3a8a;
    --c-on-accent: #f8fafc;
    --c-success:   #22c55e;
    --c-success-bg:rgba(34, 197, 94, .15);
    --c-success-fg:#86efac;
    --c-warn:      #fbbf24;
    --c-warn-bg:   rgba(251, 191, 36, .15);
    --c-warn-fg:   #fde68a;
    --c-danger:    #f87171;
    --c-danger-bg: rgba(248, 113, 113, .15);
    --c-danger-fg: #fca5a5;
    --c-info-bg:   rgba(96, 165, 250, .15);
    --c-info-fg:   #93c5fd;
    --c-code-bg:   #020617;
    --c-code-fg:   #e2e8f0;
    --c-mark-bg:   rgba(254, 240, 138, .35);
    --c-mark-fg:   #fef9c3;
    --c-diff-add-bg: rgba(34, 197, 94, .18);
    --c-diff-add-fg: #86efac;
    --c-diff-del-bg: rgba(239, 68, 68, .18);
    --c-diff-del-fg: #fca5a5;
    color-scheme: dark;
}

@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]):not([data-theme="dark"]) {
        --c-bg:        #0b1220;
        --c-bg-soft:   #111c30;
        --c-bg-mute:   #1e293b;
        --c-fg:        #f1f5f9;
        --c-fg-soft:   #cbd5e1;
        --c-fg-mute:   #94a3b8;
        --c-border:    #1e293b;
        --c-border-strong: #334155;
        --c-accent:    #60a5fa;
        --c-accent-h:  #93c5fd;
        --c-accent-soft:#1e3a8a;
        --c-on-accent: #f8fafc;
        --c-success:   #22c55e;
        --c-success-bg:rgba(34, 197, 94, .15);
        --c-success-fg:#86efac;
        --c-warn:      #fbbf24;
        --c-warn-bg:   rgba(251, 191, 36, .15);
        --c-warn-fg:   #fde68a;
        --c-danger:    #f87171;
        --c-danger-bg: rgba(248, 113, 113, .15);
        --c-danger-fg: #fca5a5;
        --c-info-bg:   rgba(96, 165, 250, .15);
        --c-info-fg:   #93c5fd;
        --c-code-bg:   #020617;
        --c-code-fg:   #e2e8f0;
        --c-mark-bg:   rgba(254, 240, 138, .35);
        --c-mark-fg:   #fef9c3;
        --c-diff-add-bg: rgba(34, 197, 94, .18);
        --c-diff-add-fg: #86efac;
        --c-diff-del-bg: rgba(239, 68, 68, .18);
        --c-diff-del-fg: #fca5a5;
        color-scheme: dark;
    }
}
[data-theme="light"] { color-scheme: light; }

/* Reset */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
    margin: 0;
    font: 16px/1.6 var(--font-sans);
    color: var(--c-fg);
    background: var(--c-bg);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: var(--c-accent); text-decoration: none; }
a:hover, a:focus-visible { text-decoration: underline; color: var(--c-accent-h); }

h1, h2, h3, h4 { line-height: 1.25; margin: 0 0 var(--gap-4); font-weight: 700; letter-spacing: -0.02em; }
h1 { font-size: clamp(1.75rem, 4vw, 2.5rem); }
h2 { font-size: clamp(1.4rem, 3vw, 1.85rem); margin-top: var(--gap-8); }
h3 { font-size: 1.2rem; margin-top: var(--gap-5); }
p, ul, ol, table, pre { margin: 0 0 var(--gap-4); }
ul, ol { padding-left: 1.5em; }
li { margin-bottom: var(--gap-2); }
strong { font-weight: 700; color: var(--c-fg); }

code, kbd, pre, samp { font-family: var(--font-mono); font-size: 0.9em; }
code { background: var(--c-bg-mute); padding: 0.1em 0.35em; border-radius: var(--r-sm); }
pre {
    background: var(--c-code-bg); color: var(--c-code-fg);
    padding: var(--gap-4); border-radius: var(--r-md);
    overflow-x: auto; font-size: 13px; line-height: 1.5;
}
pre code { background: transparent; padding: 0; }

table { width: 100%; border-collapse: collapse; }
th, td { padding: var(--gap-3); border: 1px solid var(--c-border); text-align: left; vertical-align: top; }
th { background: var(--c-bg-soft); font-weight: 600; }

/* Accessibility */
.skip-to-content {
    position: absolute; left: -9999px;
    background: var(--c-accent); color: white;
    padding: var(--gap-3) var(--gap-4);
    border-radius: var(--r-md);
    z-index: 1000;
}
.skip-to-content:focus { left: var(--gap-4); top: var(--gap-4); text-decoration: none; }
:focus-visible { outline: 2px solid var(--c-accent); outline-offset: 2px; border-radius: var(--r-sm); }

/* Layout */
.container { max-width: var(--container); margin: 0 auto; padding: 0 var(--gap-4); }
.container-narrow { max-width: var(--container-narrow); margin: 0 auto; padding: 0 var(--gap-4); }

/* Header */
.site-header {
    background: var(--c-bg);
    border-bottom: 1px solid var(--c-border);
    position: sticky; top: 0; z-index: 50;
    backdrop-filter: saturate(180%) blur(6px);
}
.site-header .container { display: flex; align-items: center; gap: var(--gap-5); padding-top: var(--gap-3); padding-bottom: var(--gap-3); }
.brand { font-weight: 800; font-size: 1.15rem; color: var(--c-fg); display: inline-flex; align-items: center; gap: var(--gap-2); }
.brand:hover { text-decoration: none; }
.brand-mark { width: 28px; height: 28px; background: var(--c-accent); color: white; border-radius: 6px; display: inline-grid; place-items: center; font-weight: 900; font-size: 14px; }
.nav-main { display: flex; gap: var(--gap-4); margin-left: auto; flex-wrap: wrap; align-items: center; }
.nav-main a { color: var(--c-fg-soft); font-weight: 500; font-size: 0.95rem; padding: var(--gap-2) var(--gap-3); border-radius: var(--r-sm); }
.nav-main a:hover, .nav-main a.active { color: var(--c-fg); background: var(--c-bg-mute); text-decoration: none; }
.nav-toggle { display: none; background: none; border: 1px solid var(--c-border); padding: 6px 10px; border-radius: var(--r-sm); cursor: pointer; color: var(--c-fg); margin-left: auto; }
.theme-toggle { background: none; border: 1px solid var(--c-border); padding: 6px 10px; border-radius: var(--r-sm); cursor: pointer; color: var(--c-fg); }

@media (max-width: 720px) {
    .nav-toggle { display: inline-flex; }
    .nav-main { display: none; flex-basis: 100%; flex-direction: column; align-items: stretch; gap: 0; padding-top: var(--gap-3); }
    .nav-main.open { display: flex; }
    .nav-main a { padding: var(--gap-3); border-radius: 0; border-bottom: 1px solid var(--c-border); }
}

/* Main */
main { display: block; padding: var(--gap-6) 0; min-height: 60vh; }

/* Footer */
.site-footer {
    margin-top: var(--gap-8);
    background: var(--c-bg-soft);
    border-top: 1px solid var(--c-border);
    padding: var(--gap-6) 0;
    color: var(--c-fg-soft);
    font-size: 0.93rem;
}
.footer-grid { display: grid; grid-template-columns: 1.2fr repeat(3, 1fr); gap: var(--gap-5); margin-bottom: var(--gap-5); }
.footer-grid h4 { font-size: 0.95rem; margin-bottom: var(--gap-3); color: var(--c-fg); }
.footer-grid ul { list-style: none; padding: 0; margin: 0; }
.footer-grid li { margin-bottom: var(--gap-2); }
.footer-grid a { color: var(--c-fg-soft); }
.footer-meta { display: flex; justify-content: space-between; padding-top: var(--gap-4); border-top: 1px solid var(--c-border); flex-wrap: wrap; gap: var(--gap-3); font-size: 0.85rem; }
@media (max-width: 720px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .footer-grid { grid-template-columns: 1fr; } }

/* Buttons */
.btn {
    display: inline-flex; align-items: center; gap: var(--gap-2);
    padding: 10px 18px; font-size: 0.95rem; font-weight: 500;
    border-radius: var(--r-md); border: 1px solid var(--c-border-strong);
    background: var(--c-bg); color: var(--c-fg); cursor: pointer;
    text-decoration: none; transition: background 0.15s, border-color 0.15s;
    min-height: 44px;
}
.btn:hover { background: var(--c-bg-mute); text-decoration: none; }
.btn-primary { background: var(--c-accent); color: white; border-color: var(--c-accent); }
.btn-primary:hover { background: var(--c-accent-h); border-color: var(--c-accent-h); color: white; }
.btn-ghost { background: transparent; border-color: transparent; color: var(--c-fg-soft); }
.btn-sm { padding: 6px 12px; min-height: 36px; font-size: 0.85rem; }
.btn-danger { background: var(--c-danger); color: white; border-color: var(--c-danger); }
.btn:disabled { opacity: 0.6; cursor: not-allowed; }

/* Form */
input[type="text"], input[type="email"], input[type="url"], input[type="number"], input[type="password"], textarea, select {
    width: 100%; padding: 10px 12px; font: inherit; color: var(--c-fg);
    background: var(--c-bg); border: 1px solid var(--c-border-strong); border-radius: var(--r-md);
    min-height: 44px;
}
textarea { min-height: 120px; font-family: var(--font-mono); font-size: 13px; line-height: 1.5; resize: vertical; }
label { display: block; margin-bottom: var(--gap-2); font-weight: 500; font-size: 0.93rem; }
.form-row { margin-bottom: var(--gap-4); }
.form-row-inline { display: flex; gap: var(--gap-3); align-items: center; flex-wrap: wrap; }

/* Cards */
.card { background: var(--c-bg); border: 1px solid var(--c-border); border-radius: var(--r-md); padding: var(--gap-5); box-shadow: var(--shadow-sm); }
.card-hover:hover { box-shadow: var(--shadow-md); transform: translateY(-1px); transition: 0.15s; }

/* Breadcrumb */
.breadcrumb { font-size: 0.88rem; color: var(--c-fg-mute); margin-bottom: var(--gap-4); }
.breadcrumb ol { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: var(--gap-2); }
.breadcrumb .sep { color: var(--c-fg-mute); }
.breadcrumb a { color: var(--c-fg-soft); }

/* Tool page layout */
.tool-page { max-width: var(--container-narrow); margin: 0 auto; }
.tool-page > h1 { margin-bottom: var(--gap-3); }
.tool-page .intro { font-size: 1.08rem; color: var(--c-fg-soft); margin-bottom: var(--gap-5); }

/* Tool UI */
.tool-ui { background: var(--c-bg-soft); border: 1px solid var(--c-border); border-radius: var(--r-lg); padding: var(--gap-5); margin-bottom: var(--gap-6); }
.tool-modes { display: flex; gap: var(--gap-2); border-bottom: 1px solid var(--c-border); margin-bottom: var(--gap-4); flex-wrap: wrap; }
.tool-modes button { background: transparent; border: none; padding: 8px 14px; cursor: pointer; color: var(--c-fg-soft); font: inherit; border-bottom: 2px solid transparent; margin-bottom: -1px; min-height: 36px; }
.tool-modes button[aria-selected="true"] { color: var(--c-accent); border-bottom-color: var(--c-accent); font-weight: 500; }
.tool-actions { display: flex; gap: var(--gap-2); flex-wrap: wrap; margin: var(--gap-4) 0; }
.tool-options { display: flex; gap: var(--gap-3); flex-wrap: wrap; align-items: center; margin: var(--gap-3) 0; font-size: 0.93rem; }
.tool-options label { display: inline-flex; align-items: center; gap: var(--gap-2); margin: 0; font-weight: normal; }
.tool-options select, .tool-options input { width: auto; min-width: 100px; min-height: 36px; }
.advanced-options { margin: var(--gap-3) 0; }
.advanced-options summary { cursor: pointer; color: var(--c-fg-soft); font-size: 0.9rem; user-select: none; padding: var(--gap-2) 0; }
.advanced-options summary:hover { color: var(--c-fg); }
.advanced-options > div { padding-top: var(--gap-3); border-top: 1px solid var(--c-border); margin-top: var(--gap-2); }
.advanced-options label { font-size: 0.9rem; display: flex; align-items: center; gap: var(--gap-2); }

/* Result */
output, .result {
    display: block; background: var(--c-bg); border: 1px solid var(--c-border);
    border-radius: var(--r-md); padding: var(--gap-4); margin-top: var(--gap-3);
    min-height: 44px;
}
.result-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: var(--gap-3); margin-top: var(--gap-3); }
.metric { background: var(--c-bg); border: 1px solid var(--c-border); border-radius: var(--r-md); padding: var(--gap-3); }
.metric .label { font-size: 0.8rem; color: var(--c-fg-mute); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: var(--gap-1); }
.metric .value { font-size: 1.6rem; font-weight: 700; color: var(--c-fg); }
.metric .sub { font-size: 0.8rem; color: var(--c-fg-mute); margin-top: var(--gap-1); }

/* Examples library */
.examples { margin-bottom: var(--gap-5); }
.example-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--gap-3); }
.example-card { background: var(--c-bg); border: 1px solid var(--c-border); border-radius: var(--r-md); padding: var(--gap-3); cursor: pointer; text-align: left; font: inherit; color: var(--c-fg); }
.example-card:hover { border-color: var(--c-accent); }
.example-card strong { display: block; margin-bottom: var(--gap-1); }
.example-card span { font-size: 0.85rem; color: var(--c-fg-mute); }

/* History */
.history ul { list-style: none; padding: 0; }
.history li { padding: var(--gap-3); border: 1px solid var(--c-border); border-radius: var(--r-md); margin-bottom: var(--gap-2); display: flex; justify-content: space-between; align-items: center; gap: var(--gap-3); }
.history li button { background: none; border: none; color: var(--c-fg-mute); cursor: pointer; padding: 4px 8px; }

/* FAQ */
.faq { margin-top: var(--gap-6); }
.faq-list { border-top: 1px solid var(--c-border); }
.faq-item { border-bottom: 1px solid var(--c-border); padding: var(--gap-3) 0; }
.faq-item summary { cursor: pointer; padding: var(--gap-2) 0; list-style: none; }
.faq-item summary h3 { display: inline; font-size: 1.05rem; margin: 0; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::before { content: "+ "; color: var(--c-fg-mute); font-weight: 700; }
.faq-item[open] summary::before { content: "− "; }
.faq-answer { padding: var(--gap-2) 0 var(--gap-3); color: var(--c-fg-soft); }

/* Related tools / tool grid */
.tool-grid { list-style: none; padding: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: var(--gap-3); }
.tool-card { margin: 0; }
.tool-card a { display: block; padding: var(--gap-4); background: var(--c-bg); border: 1px solid var(--c-border); border-radius: var(--r-md); color: var(--c-fg); text-decoration: none; transition: 0.15s; }
.tool-card a:hover { border-color: var(--c-accent); text-decoration: none; box-shadow: var(--shadow-sm); }
.tool-card strong { display: block; margin-bottom: var(--gap-1); color: var(--c-fg); }
.tool-card span { font-size: 0.88rem; color: var(--c-fg-mute); }

/* Hero (homepage) */
.hero { text-align: center; padding: var(--gap-8) 0; }
.hero h1 { font-size: clamp(2rem, 5vw, 3rem); margin-bottom: var(--gap-4); }
.hero p { font-size: 1.15rem; color: var(--c-fg-soft); max-width: 38rem; margin: 0 auto var(--gap-5); }
.hero-actions { display: flex; gap: var(--gap-3); justify-content: center; flex-wrap: wrap; }

/* Section */
.section { padding: var(--gap-6) 0; }
.section-title { display: flex; align-items: baseline; justify-content: space-between; gap: var(--gap-3); margin-bottom: var(--gap-5); flex-wrap: wrap; }
.section-title h2 { margin: 0; }
.section-title a { font-size: 0.9rem; }

/* Category badges */
.badge { display: inline-block; padding: 2px 8px; font-size: 0.75rem; border-radius: 999px; background: var(--c-accent-soft); color: var(--c-accent-h); font-weight: 500; }
.badge-mute { background: var(--c-bg-mute); color: var(--c-fg-soft); }

/* Data tables (model specs etc.) */
.data-table { font-size: 0.92rem; }
.data-table th { width: 30%; }
.data-table td .badge { margin-right: var(--gap-1); }

/* TOC */
.toc { background: var(--c-bg-soft); border: 1px solid var(--c-border); border-radius: var(--r-md); padding: var(--gap-3) var(--gap-4); margin: var(--gap-4) 0; font-size: 0.92rem; }
.toc summary { cursor: pointer; font-weight: 500; }
.toc ol { padding-left: 1.2em; margin: var(--gap-2) 0 0; }
.toc li { margin-bottom: var(--gap-1); }

/* Ad slots */
.ad-slot { margin: var(--gap-5) 0; min-height: 90px; background: var(--c-bg-mute); border-radius: var(--r-md); display: grid; place-items: center; color: var(--c-fg-mute); font-size: 0.8rem; }
.ad-slot:empty::before { content: ""; }

/* Token visualization — pastel palette that adapts to dark mode */
.token-vis { font-family: var(--font-mono); font-size: 14px; line-height: 1.8; padding: var(--gap-3); background: var(--c-bg); border: 1px solid var(--c-border); border-radius: var(--r-md); word-break: break-word; }
.token { display: inline; padding: 2px 4px; margin: 0 1px; border-radius: 3px; }
.token-0 { background: var(--tok-0-bg); color: var(--tok-0-fg); }
.token-1 { background: var(--tok-1-bg); color: var(--tok-1-fg); }
.token-2 { background: var(--tok-2-bg); color: var(--tok-2-fg); }
.token-3 { background: var(--tok-3-bg); color: var(--tok-3-fg); }
.token-4 { background: var(--tok-4-bg); color: var(--tok-4-fg); }
.token-5 { background: var(--tok-5-bg); color: var(--tok-5-fg); }
:root {
    --tok-0-bg: #fee2e2; --tok-0-fg: #991b1b;
    --tok-1-bg: #fef3c7; --tok-1-fg: #92400e;
    --tok-2-bg: #d1fae5; --tok-2-fg: #065f46;
    --tok-3-bg: #dbeafe; --tok-3-fg: #1e40af;
    --tok-4-bg: #ede9fe; --tok-4-fg: #5b21b6;
    --tok-5-bg: #fce7f3; --tok-5-fg: #9d174d;
}
[data-theme="dark"], :root:not([data-theme="light"]) {
    /* slightly handled — explicit dark overrides */
}
[data-theme="dark"] {
    --tok-0-bg: rgba(239, 68, 68, .25);  --tok-0-fg: #fecaca;
    --tok-1-bg: rgba(245, 158, 11, .25); --tok-1-fg: #fde68a;
    --tok-2-bg: rgba(34, 197, 94, .25);  --tok-2-fg: #bbf7d0;
    --tok-3-bg: rgba(59, 130, 246, .25); --tok-3-fg: #bfdbfe;
    --tok-4-bg: rgba(168, 85, 247, .25); --tok-4-fg: #ddd6fe;
    --tok-5-bg: rgba(236, 72, 153, .25); --tok-5-fg: #fbcfe8;
}
@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]):not([data-theme="dark"]) {
        --tok-0-bg: rgba(239, 68, 68, .25);  --tok-0-fg: #fecaca;
        --tok-1-bg: rgba(245, 158, 11, .25); --tok-1-fg: #fde68a;
        --tok-2-bg: rgba(34, 197, 94, .25);  --tok-2-fg: #bbf7d0;
        --tok-3-bg: rgba(59, 130, 246, .25); --tok-3-fg: #bfdbfe;
        --tok-4-bg: rgba(168, 85, 247, .25); --tok-4-fg: #ddd6fe;
        --tok-5-bg: rgba(236, 72, 153, .25); --tok-5-fg: #fbcfe8;
    }
}
mark { background: var(--c-mark-bg); color: var(--c-mark-fg); padding: 1px 3px; border-radius: 3px; }

/* Copy button */
.copy-btn { background: var(--c-bg); border: 1px solid var(--c-border); padding: 4px 10px; font-size: 0.8rem; border-radius: var(--r-sm); cursor: pointer; color: var(--c-fg-soft); }
.copy-btn:hover { color: var(--c-fg); border-color: var(--c-border-strong); }
.copy-btn.copied { background: var(--c-success); color: white; border-color: var(--c-success); }

/* Notices */
.notice { padding: var(--gap-3) var(--gap-4); border-radius: var(--r-md); margin: var(--gap-3) 0; font-size: 0.93rem; border: 1px solid; }
.notice-info    { background: var(--c-info-bg);    color: var(--c-info-fg);    border-color: var(--c-accent); }
.notice-error   { background: var(--c-danger-bg);  color: var(--c-danger-fg);  border-color: var(--c-danger); }
.notice-success { background: var(--c-success-bg); color: var(--c-success-fg); border-color: var(--c-success); }
.notice-warn    { background: var(--c-warn-bg);    color: var(--c-warn-fg);    border-color: var(--c-warn); }
.notice code { background: rgba(0,0,0,.1); }
[data-theme="dark"] .notice code, @media (prefers-color-scheme: dark) { :root:not([data-theme="light"]) .notice code { background: rgba(255,255,255,.1); } }

/* Selection */
::selection { background: var(--c-accent); color: var(--c-on-accent); }

/* Diff lines (used by text-diff) */
.diff-add { background: var(--c-diff-add-bg); color: var(--c-diff-add-fg); }
.diff-del { background: var(--c-diff-del-bg); color: var(--c-diff-del-fg); }
.diff-neutral { color: var(--c-fg-mute); }
.diff-pre { background: var(--c-code-bg); color: var(--c-code-fg); padding: 1rem; border-radius: var(--r-md); overflow-x: auto; font-size: 13px; line-height: 1.6; }
.diff-summary strong.add { color: var(--c-success); }
.diff-summary strong.del { color: var(--c-danger); }

/* Tags (small badges with semantic color) */
.tag { display: inline-block; padding: 2px 8px; font-size: .75rem; border-radius: 999px; font-weight: 500; }
.tag-success { background: var(--c-success-bg); color: var(--c-success-fg); }
.tag-error   { background: var(--c-danger-bg);  color: var(--c-danger-fg); }
.tag-warn    { background: var(--c-warn-bg);    color: var(--c-warn-fg); }
.tag-info    { background: var(--c-info-bg);    color: var(--c-info-fg); }
.tag-mute    { background: var(--c-bg-mute);    color: var(--c-fg-soft); }

/* Badges contrast — dark-friendly */
.badge { background: var(--c-accent-soft); color: var(--c-accent-h); }
[data-theme="dark"] .badge { background: rgba(96, 165, 250, .2); color: #bfdbfe; }
@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) .badge { background: rgba(96, 165, 250, .2); color: #bfdbfe; }
}

/* Theme toggle button — icon-based, tri-state */
.theme-toggle {
    background: transparent;
    border: 1px solid var(--c-border-strong);
    color: var(--c-fg-soft);
    padding: 0;
    width: 36px; height: 36px;
    border-radius: var(--r-md);
    cursor: pointer;
    display: inline-grid;
    place-items: center;
    transition: background .15s, color .15s, border-color .15s;
}
.theme-toggle:hover { background: var(--c-bg-mute); color: var(--c-fg); border-color: var(--c-accent); }
.theme-toggle svg { width: 18px; height: 18px; }
.theme-toggle [data-icon] { display: none; }
.theme-toggle[data-mode="auto"]  [data-icon="auto"]  { display: block; }
.theme-toggle[data-mode="light"] [data-icon="light"] { display: block; }
.theme-toggle[data-mode="dark"]  [data-icon="dark"]  { display: block; }

/* Comparison tables */
.compare-table th { background: var(--c-bg-soft); }
.compare-table .winner { background: var(--c-accent-soft); font-weight: 600; }
.compare-table .neutral { color: var(--c-fg-mute); }

/* Pricing strip */
.price-strip { display: flex; gap: var(--gap-4); flex-wrap: wrap; padding: var(--gap-4); background: var(--c-bg-soft); border-radius: var(--r-md); margin-bottom: var(--gap-4); }
.price-strip > div { flex: 1 1 140px; }
.price-strip .label { font-size: 0.8rem; color: var(--c-fg-mute); text-transform: uppercase; letter-spacing: 0.05em; }
.price-strip .value { font-size: 1.4rem; font-weight: 700; color: var(--c-fg); }

/* Print */
@media print {
    .site-header, .site-footer, .ad-slot, .tool-actions, .nav-main { display: none; }
}
