/* ============================================================
   Pixellize Tools — shared stylesheet
   All tool shortcodes use .pxt-tool-wrap as root.
   Add tool-specific rules in clearly marked sections below.
   ============================================================ */

/* ── Wrapper ────────────────────────────────────────────── */

.btn-primary{
    --bs-btn-bg: #754ffe !important;
    --bs-btn-border-color: #754ffe !important;
    --bs-btn-hover-bg: #6343d8 !important;
    --bs-btn-hover-border-color: #6343d8 !important;
    --bs-btn-active-bg: #6343d8 !important;
    --bs-btn-active-border-color: #6343d8 !important;
    --bs-btn-disabled-bg: #754ffe !important;
    --bs-btn-disabled-border-color: #754ffe !important;
}

/* ── Universal tool button hover protection ─────────────────
   Targets ANY tool wrap (`<div id="xxxWrap">`) and protects
   .btn-primary, .btn-outline-secondary, .btn-success, .btn-danger
   from being broken by Astra theme defaults.
   Every new tool inherits this — no per-tool overrides needed. */
[id$="Wrap"] .btn-primary,
[id$="Wrap"] .btn-primary:link,
[id$="Wrap"] .btn-primary:visited {
    background: #754ffe !important;
    background-color: #754ffe !important;
    border-color: #754ffe !important;
    color: #fff !important;
}
[id$="Wrap"] .btn-primary:hover,
[id$="Wrap"] .btn-primary:focus,
[id$="Wrap"] .btn-primary:active,
[id$="Wrap"] .btn-primary:focus-visible {
    background: #6343d8 !important;
    background-color: #6343d8 !important;
    border-color: #6343d8 !important;
    color: #fff !important;
    box-shadow: 0 4px 12px rgba(117,79,254,.25) !important;
    transform: translateY(-1px);
}
[id$="Wrap"] .btn-primary:disabled,
[id$="Wrap"] .btn-primary.disabled {
    background: #754ffe !important;
    background-color: #754ffe !important;
    border-color: #754ffe !important;
    color: #fff !important;
    opacity: .55 !important;
    transform: none !important;
    box-shadow: none !important;
    cursor: not-allowed;
}

[id$="Wrap"] .btn-outline-secondary,
[id$="Wrap"] .btn-outline-secondary:link,
[id$="Wrap"] .btn-outline-secondary:visited {
    background: transparent !important;
    background-color: transparent !important;
    border-color: #cbd5e1 !important;
    color: #475569 !important;
}
[id$="Wrap"] .btn-outline-secondary:hover,
[id$="Wrap"] .btn-outline-secondary:focus,
[id$="Wrap"] .btn-outline-secondary:focus-visible {
    background: #f1f5f9 !important;
    background-color: #f1f5f9 !important;
    border-color: #94a3b8 !important;
    color: #1e293b !important;
}
[id$="Wrap"] .btn-outline-secondary:disabled {
    opacity: .55 !important;
    cursor: not-allowed;
}

[id$="Wrap"] .btn-success,
[id$="Wrap"] .btn-success:link,
[id$="Wrap"] .btn-success:visited {
    background: #16a34a !important;
    background-color: #16a34a !important;
    border-color: #16a34a !important;
    color: #fff !important;
}
[id$="Wrap"] .btn-success:hover,
[id$="Wrap"] .btn-success:focus,
[id$="Wrap"] .btn-success:active {
    background: #15803d !important;
    background-color: #15803d !important;
    border-color: #15803d !important;
    color: #fff !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(22,163,74,.25) !important;
}
[id$="Wrap"] .btn-success:disabled {
    opacity: .55 !important;
    transform: none !important;
    box-shadow: none !important;
    cursor: not-allowed;
}

/* Dark-mode button tweaks for outline secondary */
[data-theme="dark"] [id$="Wrap"] .btn-outline-secondary,
[data-theme="dark"] [id$="Wrap"] .btn-outline-secondary:link {
    border-color: rgba(117,79,254,.3) !important;
    color: #cbd5e1 !important;
}
[data-theme="dark"] [id$="Wrap"] .btn-outline-secondary:hover,
[data-theme="dark"] [id$="Wrap"] .btn-outline-secondary:focus {
    background: rgba(117,79,254,.1) !important;
    border-color: rgba(117,79,254,.5) !important;
    color: #fff !important;
}
.pxt-tool-wrap {
    max-width: 900px;
    margin: 0 auto;
    padding: 24px 16px;
    font-family: inherit;
}

/* ── Input area ─────────────────────────────────────────── */

.pxt-input-area .input-group {
    display: flex;
    align-items: stretch;
}

.pxt-input-area .input-group .form-control {
    border-radius: 8px 0 0 8px;
    border: 1px solid #cbd5e1;
    border-right: none;
    font-size: 1rem;
    padding: 12px 16px;
    transition: border-color .2s, box-shadow .2s;
    flex: 1;
}

.pxt-input-area .input-group .btn {
    border-radius: 0 8px 8px 0;
    white-space: nowrap;
}

.pxt-input-area .input-group .form-control:focus {
    border-color: #754ffe;
    box-shadow: 0 0 0 3px rgba(117, 79, 254, .15);
    outline: none;
}

.pxt-input-area .btn-primary {
    background: #754ffe;
    border-color: #754ffe;
    border-radius: 8px;
    font-weight: 600;
    transition: background .2s, transform .1s;
}

.pxt-input-area .btn-primary:hover {
    background: #5f3edb;
    border-color: #5f3edb;
    transform: translateY(-1px);
}

/* ── Alerts ─────────────────────────────────────────────── */
.pxt-alert {
    border-radius: 8px;
    padding: 12px 16px;
    margin-bottom: 16px;
    font-size: .95rem;
}

.pxt-alert-danger {
    background: #fef2f2;
    border: 1px solid #fca5a5;
    color: #b91c1c;
}

.pxt-alert-success {
    background: #f0fdf4;
    border: 1px solid #86efac;
    color: #15803d;
}

/* ── Result / output box ────────────────────────────────── */
.pxt-result-box {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 12px;
    padding: 24px;
    margin-top: 24px;
}

/* ── Cards (generic) ────────────────────────────────────── */
.pxt-tool-wrap .card {
    border-radius: 10px;
    overflow: hidden;
}

.pxt-tool-wrap .card-body {
    min-height: 150px;
    background: #f8f9fa;
}

.pxt-tool-wrap .card-footer {
    background: #fff;
    border-top: 1px solid #f1f5f9;
    padding: 12px 16px;
}

/* ── Buttons ────────────────────────────────────────────── */
.pxt-tool-wrap .btn {
    border-radius: 8px;
    font-weight: 500;
    transition: background .2s, transform .1s, box-shadow .2s;
}

.pxt-tool-wrap .btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0,0,0,.1);
}

.pxt-tool-wrap .btn-primary {
    background: #754ffe;
    border-color: #754ffe;
}

.pxt-tool-wrap .btn-primary:hover {
    background: #5f3edb;
    border-color: #5f3edb;
}

/* ── Copy / action feedback ─────────────────────────────── */
.pxt-copy-btn.copied {
    background: #16a34a;
    border-color: #16a34a;
    color: #fff;
}

/* ── Textarea / code output ─────────────────────────────── */
.pxt-tool-wrap textarea.pxt-output {
    width: 100%;
    font-family: 'Courier New', monospace;
    font-size: .875rem;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    padding: 12px;
    resize: vertical;
    background: #f8fafc;
}

/* ── Spinner ────────────────────────────────────────────── */
.pxt-spinner {
    display: inline-block;
    width: 20px;
    height: 20px;
    border: 3px solid rgba(117,79,254,.2);
    border-top-color: #754ffe;
    border-radius: 50%;
    animation: pxt-spin .7s linear infinite;
    vertical-align: middle;
    margin-right: 8px;
}

@keyframes pxt-spin { to { transform: rotate(360deg); } }

/* ============================================================
   GLOBAL DARK MODE — Bootstrap form controls + shared classes
   Scoped to [data-theme="dark"] so light mode is untouched.
   ============================================================ */

/* ── Inputs & textareas ── */
[data-theme="dark"] .form-control {
    background-color: var(--clr-surface, #1e1c35);
    border-color: var(--clr-border, #2d2b4e);
    color: var(--clr-text, #e2e2f0);
}
[data-theme="dark"] .form-control:focus {
    background-color: var(--clr-surface, #1e1c35);
    border-color: var(--clr-primary, #754ffe);
    color: var(--clr-text, #e2e2f0);
    box-shadow: 0 0 0 3px rgba(117,79,254,.2);
}
[data-theme="dark"] .form-control::placeholder {
    color: var(--clr-muted, #6b7280);
}
[data-theme="dark"] .form-control[readonly],
[data-theme="dark"] .form-control:disabled {
    background-color: var(--clr-card, #1d1c35);
    border-color: var(--clr-border, #2d2b4e);
    color: var(--clr-text, #e2e2f0);
    opacity: 1;
}

/* ── Selects ── */
[data-theme="dark"] .form-select {
    background-color: var(--clr-surface, #1e1c35);
    border-color: var(--clr-border, #2d2b4e);
    color: var(--clr-text, #e2e2f0);
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%239ca3af' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
}
[data-theme="dark"] .form-select:focus {
    border-color: var(--clr-primary, #754ffe);
    box-shadow: 0 0 0 3px rgba(117,79,254,.2);
}
[data-theme="dark"] .form-select option {
    background-color: var(--clr-surface, #1e1c35);
    color: var(--clr-text, #e2e2f0);
}

/* ── Labels & help text ── */
[data-theme="dark"] label,
[data-theme="dark"] .form-label,
[data-theme="dark"] .t2p-label,
[data-theme="dark"] .aib-form-label,
[data-theme="dark"] .mtg-label,
[data-theme="dark"] .asc-badge {
    color: var(--clr-heading, #e0deff);
}
[data-theme="dark"] .form-text {
    color: var(--clr-muted, #9ca3af);
}

/* ── Input group addon ── */
[data-theme="dark"] .input-group-text {
    background-color: var(--clr-card, #1d1c35);
    border-color: var(--clr-border, #2d2b4e);
    color: var(--clr-text, #e2e2f0);
}

/* ── Checkboxes / radios / switches ── */
[data-theme="dark"] .form-check-input {
    background-color: var(--clr-surface, #1e1c35);
    border-color: var(--clr-border, #3d3b5e);
}
[data-theme="dark"] .form-check-input:checked {
    background-color: var(--clr-primary, #754ffe);
    border-color: var(--clr-primary, #754ffe);
}
[data-theme="dark"] .form-check-input:focus {
    box-shadow: 0 0 0 3px rgba(117,79,254,.2);
}
[data-theme="dark"] .form-check-label {
    color: var(--clr-text, #e2e2f0);
}

/* ── btn-check labels (used in btn-group radio groups) ── */
[data-theme="dark"] .btn-outline-secondary {
    border-color: var(--clr-border, #3d3b5e);
    color: var(--clr-text, #e2e2f0);
}

/* ── Generic Bootstrap cards used inside tools ── */
[data-theme="dark"] .card {
    background-color: var(--clr-card, #1d1c35);
    border-color: var(--clr-border, #2d2b4e);
    color: var(--clr-text, #e2e2f0);
}
[data-theme="dark"] .card-header {
    background-color: var(--clr-surface, #16152e);
    border-color: var(--clr-border, #2d2b4e);
    color: var(--clr-heading, #e0deff);
}
[data-theme="dark"] .card-body  { background-color: var(--clr-card, #1d1c35); }
[data-theme="dark"] .card-footer {
    background-color: var(--clr-surface, #16152e);
    border-color: var(--clr-border, #2d2b4e);
}

/* ── Shared plugin components ── */
[data-theme="dark"] .pxt-input-area .input-group .form-control {
    background-color: var(--clr-surface, #1e1c35);
    border-color: var(--clr-border, #2d2b4e);
    color: var(--clr-text, #e2e2f0);
}
[data-theme="dark"] .pxt-result-box {
    background: var(--clr-card, #1d1c35);
    border-color: var(--clr-border, #2d2b4e);
    color: var(--clr-text, #e2e2f0);
}
[data-theme="dark"] .pxt-alert-danger {
    background: rgba(239,68,68,.12);
    border-color: rgba(252,165,165,.3);
    color: #fca5a5;
}
[data-theme="dark"] .pxt-alert-success {
    background: rgba(34,197,94,.12);
    border-color: rgba(134,239,172,.3);
    color: #86efac;
}

/* ── Text utilities that appear in tools ── */
[data-theme="dark"] .text-muted        { color: var(--clr-muted, #9ca3af) !important; }
[data-theme="dark"] .border-top,
[data-theme="dark"] .border-bottom,
[data-theme="dark"] .border-end,
[data-theme="dark"] .border           { border-color: var(--clr-border, #2d2b4e) !important; }
[data-theme="dark"] .bg-light         { background-color: var(--clr-surface, #16152e) !important; }
[data-theme="dark"] .bg-white         { background-color: var(--clr-card, #1d1c35) !important; }

/* ============================================================
   Tool: YouTube Thumbnail Downloader (#ytd)
   ============================================================ */

/* HD featured card */
.ytd-featured-card {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 14px;
    overflow: hidden;
    background: var(--clr-card, #fff);
    margin-bottom: 4px;
}
.ytd-featured-img-wrap {
    position: relative;
    width: 100%;
    overflow: hidden;
    background: #0f172a;
    line-height: 0;
}
.ytd-featured-img {
    width: 100%;
    display: block;
    transition: transform .35s ease;
}
.ytd-featured-card:hover .ytd-featured-img { transform: scale(1.02); }
.ytd-featured-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    padding: 14px 18px;
    flex-wrap: wrap;
}
.ytd-featured-meta {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

/* Thumbnail grid cards */
.ytd-thumb-card {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    overflow: hidden;
    background: var(--clr-card, #fff);
    height: 100%;
    display: flex;
    flex-direction: column;
    transition: box-shadow .2s, border-color .2s;
}
.ytd-thumb-card:hover {
    box-shadow: 0 4px 16px rgba(117,79,254,.12);
    border-color: rgba(117,79,254,.3);
}
.ytd-thumb-img-wrap {
    position: relative;
    overflow: hidden;
    background: #0f172a;
    line-height: 0;
    aspect-ratio: 4 / 3;
}
.ytd-thumb-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .3s ease;
}
.ytd-thumb-card:hover .ytd-thumb-img { transform: scale(1.04); }
.ytd-thumb-footer {
    padding: 10px 12px 12px;
    display: flex;
    flex-direction: column;
    flex: 1;
}

/* Shared labels */
.ytd-qlabel {
    font-size: .8rem;
    font-weight: 700;
    color: var(--clr-heading, #1e1b4b);
    display: block;
}
.ytd-res {
    font-size: .7rem;
    color: var(--clr-muted, #6b7280);
    display: block;
}

/* Quality flag badges (overlay) */
.ytd-quality-flag {
    position: absolute;
    top: 10px;
    left: 10px;
    padding: .2rem .55rem;
    border-radius: 6px;
    font-size: .65rem;
    font-weight: 800;
    letter-spacing: .05em;
    text-transform: uppercase;
    color: #fff;
    line-height: 1;
}
.ytd-flag-hd  { background: #754ffe; }
.ytd-flag-hq  { background: #0ea5e9; }
.ytd-flag-sd  { background: #10b981; }
.ytd-flag-mq  { background: #f59e0b; color: #1e1b4b; }
.ytd-flag-def { background: #6b7280; }

/* dark mode */
[data-theme="dark"] .ytd-featured-card { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .ytd-thumb-card    { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .ytd-qlabel        { color: var(--clr-text, #e2e2f0); }

input[type="url"], input[type="text"] {
  min-height: 50px;
}

/* ============================================================
   Tool: YouTube Tags Extractor (#ytag-wrap)
   ============================================================ */
#ytag-error {
    display: none;
    margin-top: 1rem;
    padding: .85rem 1rem;
    background: #fef2f2;
    border: 1px solid #fca5a5;
    border-radius: 10px;
    color: #991b1b;
    font-size: .875rem;
    font-weight: 500;
}

#ytag-results {
    display: none;
    margin-top: 1.5rem;
    border: 1.5px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}

#ytag-video-info {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
    background: var(--clr-bg-2, #f8f7ff);
}
#ytag-thumb {
    width: 112px; height: 63px;
    border-radius: 8px; object-fit: cover;
    flex-shrink: 0;
    background: var(--clr-border, #e5e7eb);
}
#ytag-video-meta   { flex: 1; min-width: 0;     text-align: left;}
#ytag-video-title  { font-size: .9rem; font-weight: 700; color: var(--clr-text, #111); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-bottom: .3rem; }
#ytag-video-channel{ font-size: .78rem; color: var(--clr-muted, #6b7280); margin-bottom: .2rem; }
#ytag-video-views  { font-size: .75rem; color: var(--clr-muted, #9ca3af); }

#ytag-stats { display: flex; border-bottom: 1px solid var(--clr-border, #e5e7eb); }
.ytag-stat { flex: 1; text-align: center; padding: .85rem .5rem; border-right: 1px solid var(--clr-border, #e5e7eb); }
.ytag-stat:last-child { border-right: none; }
.ytag-stat-num { font-size: 1.35rem; font-weight: 800; color: var(--clr-text, #111); line-height: 1; }
.ytag-stat-lbl { font-size: .62rem; font-weight: 600; color: var(--clr-muted, #9ca3af); text-transform: uppercase; letter-spacing: .06em; margin-top: .25rem; }

#ytag-char-wrap { padding: .85rem 1.25rem; border-bottom: 1px solid var(--clr-border, #e5e7eb); }
#ytag-char-label { display: flex; justify-content: space-between; font-size: .72rem; font-weight: 600; color: var(--clr-muted, #6b7280); margin-bottom: .4rem; }
#ytag-char-track { height: 6px; background: var(--clr-border, #f3f4f6); border-radius: 10px; overflow: hidden; }
#ytag-char-fill  { height: 100%; border-radius: 10px; transition: width .4s ease, background .3s; background: #22c55e; }

#ytag-actions { display: flex; gap: .5rem; flex-wrap: wrap; padding: .85rem 1.25rem; border-bottom: 1px solid var(--clr-border, #e5e7eb); background: var(--clr-bg-2, #f8f7ff); }

#ytag-chips-wrap { padding: 1rem 1.25rem; }
#ytag-chips-title { font-size: .68rem; font-weight: 700; color: var(--clr-muted, #9ca3af); text-transform: uppercase; letter-spacing: .07em; margin-bottom: .75rem; }
#ytag-chips { display: flex; flex-wrap: wrap; gap: .5rem; }

.ytag-chip {
    display: inline-flex; align-items: center; gap: .35rem;
    padding: .3rem .85rem; border-radius: 100px;
    font-size: .82rem; font-weight: 500;
    background: var(--clr-primary-glow, rgba(117,79,254,.1));
    color: var(--clr-primary, #754ffe);
    border: 1px solid rgba(117,79,254,.2);
    cursor: pointer; user-select: none;
    transition: background .12s, border-color .12s, transform .1s;
}
.ytag-chip:hover  { background: rgba(117,79,254,.18); border-color: #754ffe; transform: translateY(-1px); }
.ytag-chip.copied { background: #dcfce7; border-color: #86efac; color: #166534; }
.ytag-chip-num { font-size: .62rem; font-weight: 700; color: var(--clr-muted,#9ca3af); background: var(--clr-border,#e5e7eb); border-radius: 10px; padding: 1px 5px; line-height: 1.4; }

#ytag-export-wrap { padding: 0 1.25rem 1rem; }
#ytag-export {
    width: 100%; padding: .75rem 1rem;
    border: 1.5px solid var(--clr-border, #e5e7eb);
    border-radius: 10px; font-size: .8rem;
    color: var(--clr-text, #374151);
    background: var(--clr-bg, #fff);
    resize: vertical; min-height: 80px;
    font-family: inherit; line-height: 1.6; outline: none;
    transition: border-color .2s;
}
#ytag-export:focus { border-color: #754ffe; }

#ytag-notags { display: none; padding: 1.25rem; text-align: center; color: var(--clr-muted,#9ca3af); font-size: .875rem; }

.ytag-spin {
    display: inline-block; width: 15px; height: 15px;
    border: 2.5px solid rgba(255,255,255,.35); border-top-color: #fff;
    border-radius: 50%; animation: ytag-rot .7s linear infinite;
    vertical-align: middle; margin-right: .25rem;
}
@keyframes ytag-rot { to { transform: rotate(360deg); } }

#ytag-toast {
    position: fixed; bottom: 1.5rem; left: 50%; transform: translateX(-50%);
    background: #1f2937; color: #fff;
    padding: .6rem 1.4rem; border-radius: 8px;
    font-size: .83rem; font-weight: 600;
    z-index: 9999; pointer-events: none; opacity: 0;
    transition: opacity .2s; white-space: nowrap;
}

[data-theme="dark"] #ytag-error  { background: rgba(239,68,68,.12); border-color: rgba(252,165,165,.3); color: #fca5a5; }
[data-theme="dark"] #ytag-results { border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .ytag-chip   { background: rgba(117,79,254,.15); border-color: rgba(117,79,254,.3); }
[data-theme="dark"] .ytag-chip.copied { background: rgba(34,197,94,.15); border-color: rgba(134,239,172,.3); color: #86efac; }
[data-theme="dark"] #ytag-export { background: var(--clr-card, #1d1c35); color: var(--clr-text, #e2e2f0); }

/* ============================================================
   Tool: XML Sitemap Generator (#pxSitemap)
   ============================================================ */

/* Progress bar */
.pxs-progress-wrap {
    margin: 1rem 0;
}
.pxs-progress-track {
    height: 6px;
    background: var(--clr-border, #e5e7eb);
    border-radius: 10px;
    overflow: hidden;
    margin-bottom: .4rem;
}
.pxs-progress-bar {
    height: 100%;
    background: linear-gradient(90deg, #754ffe, #9b7ffe);
    border-radius: 10px;
    transition: width .3s ease;
}
.pxs-progress-label {
    font-size: .75rem;
    font-weight: 600;
    color: var(--clr-muted, #6b7280);
}

/* Row fade-in animation */
.pxs-row-new {
    opacity: 0;
    transform: translateY(4px);
    transition: opacity .2s ease, transform .2s ease;
}
.pxs-row-visible {
    opacity: 1;
    transform: none;
}
.pxs-meta-card {
    background: var(--clr-bg-2, #f8f7ff);
    border: 1.5px solid var(--clr-border, #e5e7eb);
    border-radius: 14px;
    padding: 1.25rem 1.5rem;
    margin-top: 1.5rem;
}

.pxs-meta-row {
    display: flex;
    gap: 2rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
        justify-content: center;
}

.pxs-meta-item {
    display: flex;
    flex-direction: column;
    gap: .2rem;
}

.pxs-meta-label {
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--clr-muted, #9ca3af);
}

.pxs-meta-value {
    font-size: .95rem;
    font-weight: 600;
    color: var(--clr-text, #111);
}

.pxs-meta-count {
    font-size: 1.4rem;
    font-weight: 800;
    color: var(--clr-primary, #754ffe);
}

.pxs-actions {
    display: flex;
    gap: .6rem;
    flex-wrap: wrap;
        justify-content: center;
}

.pxs-table-wrap {
    border: 1.5px solid var(--clr-border, #e5e7eb);
    border-radius: 14px;
    overflow: hidden;
}

.pxs-table-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: .85rem 1.25rem;
    background: var(--clr-bg-2, #f8f7ff);
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
}

.pxs-table-title {
    font-size: .82rem;
    font-weight: 700;
    color: var(--clr-text, #111);
    white-space: nowrap;
}

.pxs-table-search {
    max-width: 220px;
    border-color: var(--clr-border, #e5e7eb) !important;
    border-radius: 8px !important;
    font-size: .82rem !important;
}

.pxs-table-search:focus {
    border-color: var(--clr-primary, #754ffe) !important;
    box-shadow: 0 0 0 3px rgba(117,79,254,.12) !important;
}

.pxs-table-scroll {
    max-height: 420px;
    overflow-y: auto;
}

#pxSitemapTable thead th {
    position: sticky;
    top: 0;
    background: var(--clr-bg, #fff);
    font-size: .75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--clr-muted, #6b7280);
    border-bottom: 1.5px solid var(--clr-border, #e5e7eb);
    padding: .75rem 1rem;
    text-align: left !important;
}

#pxSitemapTable tbody td {
    font-size: .82rem;
    padding: .65rem 1rem;
    color: var(--clr-text, #374151);
    border-color: var(--clr-border, #e5e7eb);
    text-align: left;
}

.pxs-url-link {
    color: var(--clr-primary, #754ffe) !important;
    text-decoration: none !important;
    word-break: break-all;
}
.pxs-url-link:hover { text-decoration: underline !important; }

.pxs-priority {
    display: inline-block;
    padding: .15rem .55rem;
    background: var(--clr-primary-glow, rgba(117,79,254,.1));
    color: var(--clr-primary, #754ffe);
    border-radius: 100px;
    font-size: .75rem;
    font-weight: 700;
}

/* dark mode */
[data-theme="dark"] .pxs-meta-card { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .pxs-table-wrap { border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .pxs-table-header { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] #pxSitemapTable thead th { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] #pxSitemapTable tbody td { border-color: var(--clr-border, #2d2b4e); color: var(--clr-text, #e2e2f0); }

/* ══════════════════════════════════════════════════════════
   Video Sitemap Generator  (#pxVsg)
   ══════════════════════════════════════════════════════════ */

/* Stats bar */
.pvsg-stats {
    display: flex;
    gap: 12px;
    margin-bottom: 16px;
}
.pvsg-stat {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 14px 8px;
    background: var(--clr-surface, #f8f7ff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
}
.pvsg-stat-num {
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--clr-primary, #754ffe);
    line-height: 1;
}
.pvsg-stat-lbl {
    font-size: .72rem;
    color: var(--clr-muted, #6b7280);
    text-transform: uppercase;
    letter-spacing: .04em;
}

/* Terminal log */
.pvsg-log {
    background: #0f172a;
    border: 1px solid #1e293b;
    border-radius: 10px;
    padding: 14px 16px;
    font-family: 'Fira Code', 'Cascadia Code', monospace;
    font-size: .78rem;
    line-height: 1.7;
    color: #94a3b8;
    max-height: 220px;
    overflow-y: auto;
    margin-bottom: 16px;
        text-align: left !important;
}
.pvsg-log-line { color: #94a3b8; }
.pvsg-log-time { color: #475569; margin-right: .5rem; }
.pvsg-log-success { color: #4ade80; }
.pvsg-log-error   { color: #f87171; }

/* Complete card */
.pvsg-complete-card {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 18px 20px;
    background: var(--clr-surface, #f8f7ff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    margin-bottom: 4px;
        text-align: left !important;
}
.pvsg-complete-icon {
    font-size: 2rem;
    color: #22c55e;
    line-height: 1;
}
.pvsg-complete-title {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--clr-heading, #1e1b4b);
}
.pvsg-complete-sub {
    font-size: .85rem;
    color: var(--clr-muted, #6b7280);
}

/* XML preview */
.pvsg-xml-wrap {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    overflow: hidden;
        text-align: left !important;
}
.pvsg-xml-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 16px;
    background: var(--clr-surface, #f8f7ff);
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
    font-size: .8rem;
    font-weight: 600;
    color: var(--clr-muted, #6b7280);
}
.pvsg-xml-pre {
    background: #0f172a;
    color: #94a3b8;
    font-family: 'Fira Code', 'Cascadia Code', monospace;
    font-size: .76rem;
    line-height: 1.7;
    padding: 16px;
    margin: 0;
    max-height: 280px;
    overflow: auto;
    white-space: pre;
}

/* Alert */
.pxt-alert { padding: .75rem 1rem; border-radius: 8px; font-size: .88rem; margin-bottom: 14px; }
.pxt-alert-danger { background: rgba(239,68,68,.08); border: 1px solid rgba(239,68,68,.25); color: #dc2626; }

/* dark mode */
[data-theme="dark"] .pvsg-stat { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .pvsg-complete-card { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .pvsg-complete-title { color: var(--clr-text, #e2e2f0); }
[data-theme="dark"] .pvsg-xml-wrap { border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .pvsg-xml-header { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }

/* ══════════════════════════════════════════════════════════
   WordPress Theme Detector  (#pxWtd)
   ══════════════════════════════════════════════════════════ */

/* Outer result card */
.pxwtd-result-card {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
    margin-bottom: 20px;
}

/* Screenshot banner */
.pxwtd-banner {
    position: relative;
    width: 100%;
    height: 200px;
    overflow: hidden;
    background: var(--clr-surface, #f0edff);
}
.pxwtd-banner-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.pxwtd-banner-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(15,10,40,.55) 0%, transparent 55%);
    display: flex;
    align-items: flex-end;
    padding: 14px 16px;
}
.pxwtd-wp-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: .25rem .75rem;
    background: rgba(255,255,255,.18);
    border: 1px solid rgba(255,255,255,.3);
    backdrop-filter: blur(6px);
    border-radius: 100px;
    font-size: .72rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: .04em;
    text-transform: uppercase;
}

/* Info body */
.pxwtd-info {
    padding: 20px 22px 22px;
}
.pxwtd-info-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 4px;
}
.pxwtd-info-left { flex: 1; min-width: 0; }
.pxwtd-theme-name {
    font-size: 1.3rem;
    font-weight: 800;
    color: var(--clr-heading, #1e1b4b);
    margin: 0 0 2px;
    line-height: 1.25;
}
.pxwtd-version-badge {
    display: inline-block;
    padding: .25rem .7rem;
    background: rgba(117,79,254,.1);
    color: var(--clr-primary, #754ffe);
    border-radius: 100px;
    font-size: .72rem;
    font-weight: 700;
    white-space: nowrap;
    flex-shrink: 0;
    margin-top: 4px;
}
.pxwtd-author {
    font-size: .82rem;
    color: var(--clr-muted, #6b7280);
    margin: 0 0 10px;
}
.pxwtd-author strong { color: var(--clr-text, #374151); }
.pxwtd-desc {
    font-size: .84rem;
    color: var(--clr-muted, #6b7280);
    line-height: 1.65;
    margin-bottom: 14px;
}

/* Meta pills */
.pxwtd-meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 4px;
}
.pxwtd-meta-pill {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: .28rem .75rem;
    background: var(--clr-surface, #f8f7ff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 100px;
    font-size: .75rem;
    color: var(--clr-muted, #6b7280);
}
.pxwtd-meta-pill strong { color: var(--clr-text, #374151); }
.pxwtd-meta-pill .bi-wordpress { color: #3858e9; }
.pxwtd-meta-green {
    background: rgba(34,197,94,.08);
    border-color: rgba(34,197,94,.25);
    color: #16a34a;
}
.pxwtd-meta-green .bi { color: #16a34a; }

/* Tags */
.pxwtd-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 14px;
}
.pxwtd-tag {
    display: inline-block;
    padding: .18rem .6rem;
    background: var(--clr-surface, #f8f7ff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 100px;
    font-size: .68rem;
    color: var(--clr-muted, #6b7280);
}

/* Plugins section header */
.pxwtd-section-head {
    display: flex;
    align-items: center;
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--clr-muted, #6b7280);
    padding: 10px 0 12px;
    border-top: 1px solid var(--clr-border, #e5e7eb);
    margin-top: 4px;
    margin-bottom: 2px;
}

/* Plugin card */
.pxwtd-plugin-card {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 14px;
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    height: 100%;
    transition: box-shadow .2s, border-color .2s;
}
.pxwtd-plugin-card:hover {
    box-shadow: 0 4px 16px rgba(117,79,254,.1);
    border-color: rgba(117,79,254,.3);
}
.pxwtd-plugin-head {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 2px;
}
.pxwtd-plugin-icon {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    object-fit: contain;
    flex-shrink: 0;
    background: var(--clr-surface, #f8f7ff);
    padding: 2px;
}
.pxwtd-plugin-head-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.pxwtd-plugin-name {
    font-size: .84rem;
    font-weight: 700;
    color: var(--clr-heading, #1e1b4b);
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.pxwtd-plugin-ver {
    display: inline-block;
    padding: .1rem .4rem;
    background: var(--clr-surface, #f3f4f6);
    border-radius: 5px;
    font-size: .65rem;
    font-weight: 700;
    color: var(--clr-muted, #6b7280);
    width: fit-content;
}
.pxwtd-plugin-author {
    font-size: .73rem;
    color: var(--clr-muted, #9ca3af);
}
.pxwtd-plugin-meta {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 2px;
}
.pxwtd-stars { font-size: .72rem; }
.pxwtd-stars .bi-star-fill { color: #f59e0b; }
.pxwtd-stars .bi-star       { color: #d1d5db; }
.pxwtd-plugin-installs {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: .68rem;
    color: var(--clr-muted, #9ca3af);
}
.pxwtd-plugin-installs .bi { font-size: .65rem; }
.pxwtd-plugin-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    margin-top: auto;
    padding-top: 8px;
    font-size: .75rem;
    font-weight: 600;
    color: var(--clr-primary, #754ffe);
    text-decoration: none;
}
.pxwtd-plugin-link:hover { text-decoration: underline; }

.pxwtd-empty {
    font-size: .85rem;
    color: var(--clr-muted, #6b7280);
    font-style: italic;
    padding: 10px 0 16px;
}

/* dark mode */
[data-theme="dark"] .pxwtd-result-card  { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .pxwtd-banner       { background: #12112a; }
[data-theme="dark"] .pxwtd-theme-name   { color: var(--clr-text, #e2e2f0); }
[data-theme="dark"] .pxwtd-meta-pill    { background: #12112a; border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .pxwtd-section-head { border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .pxwtd-plugin-card  { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .pxwtd-plugin-name  { color: var(--clr-text, #e2e2f0); }
[data-theme="dark"] .pxwtd-plugin-icon  { background: #12112a; }
[data-theme="dark"] .pxwtd-plugin-ver   { background: #12112a; }
[data-theme="dark"] .pxwtd-tag          { background: #12112a; border-color: var(--clr-border, #2d2b4e); }

.btn-outline-primary {
    --bs-btn-color: #754ffe !important;
    --bs-btn-border-color: #754ffe !important;
    --bs-btn-hover-bg: #754ffe !important;
    --bs-btn-hover-border-color: #754ffe !important;
    --bs-btn-active-bg: #754ffe !important;
    --bs-btn-active-border-color: #754ffe !important;
    --bs-btn-disabled-color: #754ffe !important;
    --bs-btn-disabled-border-color: #754ffe !important;
}

.btn-outline-primary{
    color:#754ffe !important;

}

.btn-outline-primary:hover{
    color:#FFF !important;

}

/* ══════════════════════════════════════════════════════════
   Add Image Border  (#aibWrap)
   ══════════════════════════════════════════════════════════ */

/* Upload zone */
.aib-upload-zone {
    border: 2px dashed var(--clr-border, #cbd5e1);
    border-radius: 16px;
    padding: 56px 24px 44px;
    text-align: center;
    background: var(--clr-surface, #f8f7ff);
    transition: border-color .2s, background .2s;
}
.aib-upload-zone.aib-dz-over {
    border-color: var(--clr-primary, #754ffe);
    background: rgba(117,79,254,.05);
}
.aib-upload-icon-wrap {
    width: 72px;
    height: 72px;
    border-radius: 18px;
    background: rgba(117,79,254,.1);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    color: var(--clr-primary, #754ffe);
    margin: 0 auto 18px;
}
.aib-upload-title {
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--clr-heading, #1e1b4b);
    margin-bottom: 6px;
}
.aib-upload-sub {
    font-size: .84rem;
    color: var(--clr-muted, #6b7280);
    margin-bottom: 22px;
}
.aib-upload-privacy {
    font-size: .72rem;
    color: var(--clr-muted, #9ca3af);
    margin-top: 14px;
    margin-bottom: 0;
}
.aib-upload-privacy .bi { color: #16a34a; }

/* Editor outer wrapper */
#aibEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}

/* Editor flex layout */
.aib-editor-wrap {
    display: flex;
    align-items: stretch;
    min-height: 460px;
}
.aib-preview-side {
    flex: 1;
    min-width: 0;
    border-right: 1px solid var(--clr-border, #e5e7eb);
    display: flex;
}
.aib-preview-panel {
    flex: 1;
    overflow: auto;
    max-height: 100%;
    padding: 24px;
    display: flex;
    align-items: safe center;
    justify-content: safe center;
    background-color: #e2e8f0;
    background-image:
        linear-gradient(45deg, #cbd5e1 25%, transparent 25%, transparent 75%, #cbd5e1 75%),
        linear-gradient(45deg, #cbd5e1 25%, transparent 25%, transparent 75%, #cbd5e1 75%);
    background-size: 22px 22px;
    background-position: 0 0, 11px 11px;
}
#aibCanvas {
    max-width: 100%;
    max-height: 492px;
    width: auto;
    height: auto;
    display: block;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
}

/* Controls sidebar */
.aib-sidebar {
    width: 270px;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    background: var(--clr-card, #fff);
}
.aib-sidebar-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 18px;
    border-bottom: 1px solid var(--clr-border, #f1f5f9);
    background: var(--clr-surface, #f8f7ff);
}
.aib-sidebar-title {
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--clr-muted, #6b7280);
}
.aib-change-btn {
    font-size: .72rem;
    font-weight: 600;
    color: var(--clr-primary, #754ffe);
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    text-decoration: none;
    line-height: 1;
    transition: opacity .15s;
}
.aib-change-btn:hover,
.aib-change-btn:focus {
    color: var(--clr-primary, #754ffe);
    background: none;
    border: none;
    outline: none;
    box-shadow: none;
    text-decoration: none;
    opacity: .75;
    transform: none;
}

/* Sidebar actions */
.aib-sidebar-actions {
    padding: 14px 18px;
    margin-top: auto;
}

/* Head actions group */
.aib-head-actions {
    display: flex;
    align-items: center;
    gap: 10px;
}

/* Fullscreen close button (hidden by default) */
.aib-fs-close {
    display: none;
    position: absolute;
    top: 14px;
    right: 14px;
    z-index: 10;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: none;
    background: rgba(0,0,0,.45);
        padding: 18px;
    color: #fff;
    font-size: 1rem;
    cursor: pointer;
    align-items: center;
    justify-content: center;
    transition: background .15s;
}
.aib-fs-close:hover { background: rgba(0,0,0,.7); }

/* Fullscreen overlay */
#aibWrap.aib-fullscreen {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: var(--clr-card, #fff);
    display: flex;
    flex-direction: column;
    padding: 0;
    margin: 0;
    max-width: none;
}
#aibWrap.aib-fullscreen #aibEditor {
    flex: 1;
    border: none;
    border-radius: 0;
    overflow: hidden;
    display: flex !important;
    flex-direction: column;
}
#aibWrap.aib-fullscreen .aib-editor-wrap {
    flex: 1;
    min-height: unset;
}
#aibWrap.aib-fullscreen .aib-preview-side {
    position: relative;
}
#aibWrap.aib-fullscreen .aib-fs-close {
    display: flex;
}

/* Sidebar scroll in fullscreen — applies to every tool */
.aib-fullscreen .aib-sidebar {
    overflow-y: auto;
    min-height: 0;
    max-height: 100vh;
}
.aib-fullscreen .aib-sidebar-head {
    position: sticky;
    top: 0;
    z-index: 2;
    flex-shrink: 0;
}
/* Prevent children from shrinking so content overflows and scrollbar appears */
.aib-fullscreen .aib-form-group,
.aib-fullscreen .aib-sidebar-actions {
    flex-shrink: 0;
}

/* Form groups */
.aib-form-group {
    padding: 14px 18px;
    border-bottom: 1px solid var(--clr-border, #f1f5f9);
}
.aib-form-group.ny{padding: 6px 0px !important;}
.aib-form-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}
.aib-form-label {
    font-size: .75rem;
    font-weight: 600;
    color: var(--clr-muted, #6b7280);
    display: block;
    margin-bottom: 8px;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.aib-form-row .aib-form-label { margin-bottom: 0; }
.aib-form-val {
    font-size: .72rem;
    font-weight: 700;
    padding: .15rem .5rem;
    background: rgba(117,79,254,.1);
    color: var(--clr-primary, #754ffe);
    border-radius: 100px;
}

/* Range slider */
/* Neutralise Bootstrap form-range so our styles take full control */
.aib-range.form-range {
    background: transparent;
    height: auto;
    padding: 0;
}
.aib-range.form-range:focus { box-shadow: none; }
.aib-range.form-range::-webkit-slider-thumb { margin-top: -7px; }

/* Range slider — custom cross-browser */
.aib-range {
    -webkit-appearance: none;
    appearance: none;
    width: 100%;
    height: 4px;
    background: var(--clr-border, #e2e8f0);
    border-radius: 100px;
    outline: none;
    cursor: pointer;
    margin: 8px 0 4px;
    padding: 0;
    border: none;
}

/* Webkit track (Chrome/Safari) */
.aib-range::-webkit-slider-runnable-track {
    height: 4px;
    border-radius: 100px;
    background: var(--clr-border, #e2e8f0);
}

/* Firefox track */
.aib-range::-moz-range-track {
    height: 4px;
    border-radius: 100px;
    background: var(--clr-border, #e2e8f0);
    border: none;
}

/* Webkit thumb */
.aib-range::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #754ffe;
    border: 3px solid #fff;
    box-shadow: 0 0 0 1.5px #754ffe, 0 2px 6px rgba(117,79,254,.35);
    margin-top: -7px;
    cursor: pointer;
    transition: transform .15s, box-shadow .15s;
}
.aib-range::-webkit-slider-thumb:hover {
    transform: scale(1.2);
    box-shadow: 0 0 0 1.5px #754ffe, 0 2px 10px rgba(117,79,254,.5);
}

/* Firefox thumb */
.aib-range::-moz-range-thumb {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #754ffe;
    border: 3px solid #fff;
    box-shadow: 0 0 0 1.5px #754ffe, 0 2px 6px rgba(117,79,254,.35);
    cursor: pointer;
    transition: transform .15s, box-shadow .15s;
}
.aib-range::-moz-range-thumb:hover {
    transform: scale(1.2);
}

/* Firefox progress fill */
.aib-range::-moz-range-progress {
    height: 4px;
    border-radius: 100px;
    background: #754ffe;
}

/* Focus ring */
.aib-range:focus-visible {
    outline: none;
}
.aib-range:focus-visible::-webkit-slider-thumb {
    box-shadow: 0 0 0 3px rgba(117,79,254,.3), 0 0 0 1.5px #754ffe;
}

/* Dark mode track */
[data-theme="dark"] .aib-range::-webkit-slider-runnable-track { background: rgba(255,255,255,.1); }
[data-theme="dark"] .aib-range::-moz-range-track              { background: rgba(255,255,255,.1); }
[data-theme="dark"] .aib-range                                 { background: rgba(255,255,255,.1); }
[data-theme="dark"] .aib-range::-webkit-slider-thumb          { border-color: var(--clr-card, #1d1c35); }
[data-theme="dark"] .aib-range::-moz-range-thumb              { border-color: var(--clr-card, #1d1c35); }

.aib-range-ticks {
    display: flex;
    justify-content: space-between;
    font-size: .62rem;
    color: var(--clr-muted, #9ca3af);
    margin-top: 2px;
}

/* Color controls */
.aib-color-row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 10px;
}
.aib-color-picker {
    width: 44px;
    height: 44px;
    min-height: unset;
    border: 2px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    padding: 3px;
    cursor: pointer;
    flex-shrink: 0;
    background: none;
    transition: border-color .2s;
}
.aib-color-picker:hover { border-color: var(--clr-primary, #754ffe); }
.aib-color-hex {
    font-family: 'Fira Code', monospace;
    font-size: .85rem;
    letter-spacing: .06em;
    text-transform: uppercase;
    height: 44px !important;
    min-height: unset !important;
    flex: 1;
    padding: 0 10px;
}

/* Preset swatches */
.aib-swatches {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 6px;
    margin-top: 8px;
}
.aib-swatch {
    width: 100%;
    height: 22px;
    border-radius: 5px;
    border: 2px solid transparent;
    cursor: pointer;
    outline: none;
    padding: 0;
    box-shadow: 0 1px 3px rgba(0,0,0,.18);
    transition: transform .12s, box-shadow .12s;
    /* reset Bootstrap btn hover */
    background-image: none !important;
}
.aib-swatch:hover,
.aib-swatch:focus {
    transform: scale(1.12) !important;
    box-shadow: 0 0 0 2px #754ffe !important;
    outline: none;
}
.aib-swatch.aib-swatch-active {
    box-shadow: 0 0 0 2.5px #754ffe, 0 0 0 4.5px rgba(117,79,254,.25) !important;
    transform: scale(1.08);
}
.aib-swatch-white  { background: #ffffff !important; border-color: #cbd5e1; }
.aib-swatch-black  { background: #000000 !important; }
.aib-swatch-purple { background: #754ffe !important; }
.aib-swatch-blue   { background: #3b82f6 !important; }
.aib-swatch-green  { background: #10b981 !important; }
.aib-swatch-red    { background: #ef4444 !important; }

/* Position hint */
.aib-pos-hint {
    font-size: .73rem;
    color: var(--clr-muted, #6b7280);
    margin: 8px 0 0;
    line-height: 1.5;
}

/* Pos toggle active state */
.aib-pos-btn.active {
    background: var(--clr-primary, #754ffe) !important;
    border-color: var(--clr-primary, #754ffe) !important;
    color: #fff !important;
}

/* Responsive — stack vertically on small screens */
@media (max-width: 640px) {
    .aib-editor-wrap   { flex-direction: column; min-height: unset; }
    .aib-preview-side  { border-right: none; border-bottom: 1px solid var(--clr-border, #f1f5f9); min-height: 260px; }
    .aib-sidebar       { width: 100%; }
}

/* Dark mode */
[data-theme="dark"] #aibEditor              { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .aib-upload-zone        { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .aib-upload-title       { color: var(--clr-text, #e2e2f0); }
[data-theme="dark"] .aib-upload-icon-wrap   { background: rgba(117,79,254,.2); }
[data-theme="dark"] .aib-sidebar            { background: var(--clr-card, #1d1c35); }
[data-theme="dark"] .aib-sidebar-head       { background: var(--clr-surface, #16152e); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .aib-form-group         { border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .aib-preview-side       { border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .aib-preview-panel      { background-color: #1a1a2e; background-image: linear-gradient(45deg,#252540 25%,transparent 25%,transparent 75%,#252540 75%), linear-gradient(45deg,#252540 25%,transparent 25%,transparent 75%,#252540 75%); }
[data-theme="dark"] .aib-color-picker     { border-color: var(--clr-border, #2d2b4e); }

/* ============================================================
   Tool: Add PDF Page Numbers (#ppnWrap)
   ============================================================ */

/* Editor card — matches #aibEditor */
#ppnEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}

/* Override preview panel: dark PDF-viewer background, vertical scroll */
#ppnWrap .aib-preview-panel {
    background-color: #525659;
    background-image: none;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    gap: 16px;
        max-height: 633px;
    padding: 16px;
}

/* Individual page card */
.ppn-page-wrapper {
    position: relative;
    background: #fff;
    box-shadow: 0 4px 20px rgba(0,0,0,.4);
    border-radius: 2px;
    width: 100%;
    flex-shrink: 0;
}

.ppn-page-wrapper:not(:first-child) {
    margin-top: 20px;
}

/* Page number overlay */
.ppn-number-overlay {
    position: absolute;
    pointer-events: none;
    white-space: nowrap;
    font-family: Helvetica, Arial, sans-serif;
    font-weight: 700;
    line-height: 1;
}

/* Loader inside preview */
.ppn-loader {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    color: #fff;
    padding: 48px 0;
    font-size: .9rem;
    opacity: .85;
}

/* 9-point position grid */
.ppn-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 5px;
    width: 90px;
    padding: 5px;
    background: var(--clr-surface, #f8f7ff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
}
.ppn-grid-item {
    aspect-ratio: 1;
    border-radius: 4px;
    background: var(--clr-border, #e2e8f0);
    cursor: pointer;
    border: 2px solid transparent;
    padding: 0;
    transition: background .15s, border-color .15s;
}
.ppn-grid-item:hover,
.ppn-grid-item:focus {
    background: rgba(117,79,254,.25) !important;
    border-color: rgba(117,79,254,.5) !important;
    outline: none;
    transform: none;
    box-shadow: none;
}
.ppn-grid-item.active {
    background: #754ffe !important;
    border-color: #6343d8 !important;
}

/* Two-column control row */
.ppn-two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}
.ppn-two-col-wide {
    grid-template-columns: 2fr 1fr;
}
.ppn-num-input {
    font-size: .9rem;
    height: 36px !important;
    min-height: unset !important;
    padding: 4px 8px;
}

/* Fullscreen — mirrors #aibWrap.aib-fullscreen */
#ppnWrap.aib-fullscreen {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: var(--clr-card, #fff);
    display: flex;
    flex-direction: column;
    padding: 0;
    margin: 0;
    max-width: none;
}
#ppnWrap.aib-fullscreen #ppnEditor {
    flex: 1;
    min-height: 0;
    border: none;
    border-radius: 0;
    overflow: hidden;
    display: flex !important;
    flex-direction: column;
}
#ppnWrap.aib-fullscreen .aib-editor-wrap {
    flex: 1;
    min-height: 0;
}
#ppnWrap.aib-fullscreen .aib-preview-side {
    position: relative;
    min-height: 0;
    overflow: hidden;
}
#ppnWrap.aib-fullscreen .aib-fs-close { display: flex; }
#ppnWrap.aib-fullscreen .ppn-preview-panel {
    max-height: none;
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    height: 100%;
}

/* Format select */
.ppn-select {
    font-size: .85rem;
    border-color: var(--clr-border, #e5e7eb);
    border-radius: 8px;
    padding: 7px 10px;
}
.ppn-select:focus {
    border-color: #754ffe;
    box-shadow: 0 0 0 3px rgba(117,79,254,.15);
    outline: none;
}

/* Start number input */
#ppnStartNum {
    font-size: .9rem;
    height: 40px !important;
    min-height: unset !important;
}

/* Dark mode */
[data-theme="dark"] #ppnEditor                  { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] #ppnWrap .aib-preview-panel  { background-color: #2a2a3e; }
[data-theme="dark"] .ppn-grid                   { background: var(--clr-surface, #16152e); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .ppn-grid-item              { background: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .ppn-select                 { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); color: var(--clr-text, #e2e2f0); }
[data-theme="dark"] .aib-preview-panel    { border-color: var(--clr-border, #2d2b4e); background-color: #1a1a2e; background-image: linear-gradient(45deg, #161528 25%, transparent 25%, transparent 75%, #161528 75%), linear-gradient(45deg, #161528 25%, transparent 25%, transparent 75%, #161528 75%); }

/* ============================================================
   Tool: H1 Checker (#h1cWrap)
   ============================================================ */

/* Status card */
.h1c-status-card {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 22px 24px;
    border-radius: 14px;
    border: 1px solid var(--clr-border, #e5e7eb);
    background: var(--clr-card, #fff);
    margin-bottom: 16px;
}
.h1c-status-icon-wrap {
    width: 60px;
    height: 60px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 1.75rem;
}
.h1c-status-body { flex: 1; min-width: 0; }
.h1c-status-badge {
    display: inline-block;
    font-size: .65rem;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
    padding: .2rem .6rem;
    border-radius: 100px;
    margin-bottom: 6px;
}
.h1c-status-title {
    font-size: 1.15rem;
    font-weight: 700;
    margin: 0 0 4px;
    color: var(--clr-heading, #1e1b4b);
}
.h1c-status-sub {
    font-size: .85rem;
    color: var(--clr-muted, #6b7280);
    margin: 0;
}

/* Status variants */
.h1c-card-good    { border-color: #bbf7d0; background: #f0fdf4; }
.h1c-card-warning { border-color: #fde68a; background: #fffbeb; }
.h1c-card-missing,
.h1c-card-error   { border-color: #fecaca; background: #fef2f2; }

.h1c-icon-good    { background: #dcfce7; color: #16a34a; }
.h1c-icon-warning { background: #fef3c7; color: #d97706; }
.h1c-icon-missing,
.h1c-icon-error   { background: #fee2e2; color: #dc2626; }

.h1c-badge-good    { background: #dcfce7; color: #16a34a; }
.h1c-badge-warning { background: #fef3c7; color: #d97706; }
.h1c-badge-missing,
.h1c-badge-error   { background: #fee2e2; color: #dc2626; }

/* H1 content block */
.h1c-content-wrap {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    padding: 16px 20px;
    margin-bottom: 16px;
}
.h1c-section-label {
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--clr-muted, #6b7280);
    margin-bottom: 10px;
}
.h1c-content-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.h1c-content-item {
    padding: 10px 14px;
    background: var(--clr-surface, #f8f7ff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    font-size: .92rem;
    font-weight: 500;
    color: var(--clr-heading, #1e1b4b);
    word-break: break-word;
}
.h1c-content-empty { color: var(--clr-muted, #9ca3af); font-style: italic; }

/* Details card */
.h1c-details-card {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    overflow: hidden;
    margin-bottom: 16px;
}
.h1c-detail-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    padding: 12px 20px;
    border-bottom: 1px solid var(--clr-border, #f1f5f9);
}
.h1c-detail-row:last-child { border-bottom: none; }
.h1c-detail-label {
    font-size: .82rem;
    font-weight: 600;
    color: var(--clr-muted, #6b7280);
    white-space: nowrap;
}
.h1c-detail-val {
    font-size: .9rem;
    color: var(--clr-heading, #1e1b4b);
    font-weight: 500;
    text-align: right;
}
.h1c-code {
    display: inline-block;
    padding: .15rem .55rem;
    border-radius: 6px;
    font-family: 'Fira Code', monospace;
    font-size: .8rem;
    font-weight: 700;
}
.h1c-code-ok    { background: #dcfce7; color: #16a34a; }
.h1c-code-error { background: #fee2e2; color: #dc2626; }

/* Issues block */
.h1c-issues-wrap {
    background: #fffbeb;
    border: 1px solid #fde68a;
    border-radius: 12px;
    padding: 16px 20px;
    margin-bottom: 16px;
}
.h1c-section-label-warn { color: #d97706; }
.h1c-issues-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.h1c-issue-item {
    font-size: .85rem;
    color: #92400e;
    padding: 8px 12px;
    background: rgba(255,255,255,.6);
    border-radius: 6px;
    border-left: 3px solid #f59e0b;
    padding-left: 10px;
}
.h1c-issue-item::before { content: "⚠ "; }

/* Info box */
.h1c-info-box {
    display: flex;
    gap: 14px;
    padding: 16px 20px;
    background: rgba(117,79,254,.05);
    border: 1px solid rgba(117,79,254,.15);
    border-radius: 12px;
    font-size: .85rem;
    color: var(--clr-muted, #6b7280);
    line-height: 1.6;
}
.h1c-info-icon { color: #754ffe; font-size: 1.1rem; flex-shrink: 0; margin-top: 2px; }
.h1c-info-box strong { color: var(--clr-heading, #1e1b4b); }
.h1c-info-box code { background: rgba(117,79,254,.1); color: #754ffe; padding: .1rem .3rem; border-radius: 4px; font-size: .8rem; }

/* Dark mode */
[data-theme="dark"] .h1c-status-card     { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .h1c-card-good       { background: rgba(22,163,74,.08); border-color: rgba(22,163,74,.3); }
[data-theme="dark"] .h1c-card-warning    { background: rgba(217,119,6,.08); border-color: rgba(217,119,6,.3); }
[data-theme="dark"] .h1c-card-missing,
[data-theme="dark"] .h1c-card-error      { background: rgba(220,38,38,.08); border-color: rgba(220,38,38,.3); }
[data-theme="dark"] .h1c-content-wrap,
[data-theme="dark"] .h1c-details-card    { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .h1c-content-item    { background: var(--clr-surface, #16152e); border-color: var(--clr-border, #2d2b4e); color: var(--clr-text, #e2e2f0); }
[data-theme="dark"] .h1c-detail-row      { border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .h1c-issues-wrap     { background: rgba(217,119,6,.1); border-color: rgba(217,119,6,.3); }
[data-theme="dark"] .h1c-info-box        { background: rgba(117,79,254,.08); border-color: rgba(117,79,254,.2); }

/* ── HTML Lang Checker — code preview ─────────────────────── */
.hlc-code-preview {
    font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace;
    font-size: .85rem;
    color: #754ffe;
    background: rgba(117,79,254,.07);
    border: 1px solid rgba(117,79,254,.18);
    border-radius: 8px;
    padding: .75rem 1rem;
    word-break: break-all;
}
[data-theme="dark"] .hlc-code-preview {
    background: rgba(117,79,254,.1);
    border-color: rgba(117,79,254,.25);
    color: #a78bfa;
}
/* ── Website Clone ────────────────────────────────────────── */
.wc-options-card {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    padding: 1.1rem 1.25rem 1.25rem;
    margin-bottom: 1.25rem;
}
.wc-options-title {
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--clr-muted, #9ca3af);
}
.wc-chk { display: none; }
.wc-option { cursor: pointer; display: block; margin: 0; user-select: none; }
.wc-option-box {
    display: flex;
    align-items: center;
    gap: .45rem;
    font-size: .82rem;
    font-weight: 500;
    color: var(--clr-muted, #6b7280);
    background: var(--clr-surface, #f9fafb);
    border: 1.5px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    padding: .55rem .75rem;
    transition: border-color .15s, background .15s, color .15s;
}
.wc-option-box i { font-size: .95rem; flex-shrink: 0; }
.wc-option:hover .wc-option-box { border-color: #754ffe; }
.wc-chk:checked + .wc-option-box {
    border-color: #754ffe;
    background: rgba(117,79,254,.07);
    color: #754ffe;
}

/* Progress card */
.wc-progress-card {
    display: flex;
    align-items: center;
    gap: 1.1rem;
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    padding: 1.25rem 1.5rem;
    margin-bottom: 1.25rem;
}
.wc-progress-spinner {
    width: 38px !important;
    height: 38px !important;
    border-width: 3px !important;
    flex-shrink: 0;
}
.wc-progress-title {
    font-size: .95rem;
    font-weight: 600;
    color: var(--clr-heading, #1e1b4b);
    margin-bottom: .15rem;
}
.wc-progress-sub { font-size: .82rem; color: var(--clr-muted, #9ca3af); }
.wc-progress-counters {
    display: flex;
    gap: 1.25rem;
    font-size: .8rem;
    color: var(--clr-muted, #6b7280);
}
.wc-progress-counters strong { color: #754ffe; }

/* Complete banner */
.wc-complete-banner {
    display: flex;
    align-items: center;
    gap: .85rem;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: 12px;
    padding: 1rem 1.25rem;
    margin-bottom: 1.1rem;
}
.wc-complete-banner > i { font-size: 1.5rem; color: #16a34a; flex-shrink: 0; }
.wc-complete-banner strong { display: block; color: #15803d; font-size: .92rem; }
.wc-complete-banner span   { font-size: .82rem; color: #166534; }

/* Stats grid */
.wc-stats-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: .75rem;
    margin-bottom: 1.1rem;
}
@media (max-width: 480px) { .wc-stats-grid { grid-template-columns: repeat(2, 1fr); } }
.wc-stat-card {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    padding: 1rem .75rem;
    text-align: center;
}
.wc-stat-icon { display: block; font-size: 1.25rem; color: #754ffe; margin-bottom: .3rem; }
.wc-stat-num  {
    font-size: 1.7rem;
    font-weight: 700;
    color: var(--clr-heading, #1e1b4b);
    line-height: 1;
    margin-bottom: .25rem;
}
.wc-stat-label { font-size: .72rem; color: var(--clr-muted, #9ca3af); font-weight: 500; text-transform: uppercase; letter-spacing: .03em; }
.wc-stat-card-total {
    border-color: rgba(117,79,254,.25);
    background: rgba(117,79,254,.04);
}
.wc-stat-card-total .wc-stat-num { color: #754ffe; }

/* Result actions */
.wc-result-actions { display: flex; gap: .75rem; margin-bottom: 1rem; flex-wrap: wrap; }
@media (max-width: 480px) {
    .wc-result-actions { flex-direction: column; }
    .wc-result-actions .btn { width: 100%; }
}

/* File tree + skipped URLs */
.wc-tree-wrap {
    background: #f8f7ff;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    padding: .75rem 1rem;
}
.wc-tree-summary {
    cursor: pointer;
    font-weight: 600;
    color: #1a1a2e;
    list-style: none;
    display: flex;
    align-items: center;
}
.wc-tree-summary::-webkit-details-marker { display: none; }
.wc-tree-summary::after {
    content: '\F4FE';
    font-family: 'bootstrap-icons';
    margin-left: auto;
    color: #754ffe;
    transition: transform .2s;
}
details[open] > .wc-tree-summary::after { transform: rotate(45deg); }
.wc-tree {
    margin: .75rem 0 0;
    padding: .85rem 1rem;
    background: #ffffff;
    border: 1px solid #ede9fe;
    border-radius: 8px;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: .82rem;
    line-height: 1.55;
    color: #4b5563;
    max-height: 360px;
    overflow: auto;
    white-space: pre;
    word-break: break-all;
}

/* Max pages select sits in the input group */
.wc-progress-card #wcCancel { flex-shrink: 0; }

[data-theme="dark"] .wc-tree-wrap     { background: var(--clr-card); border-color: var(--clr-border); }
[data-theme="dark"] .wc-tree-summary  { color: #f1f5f9; }
[data-theme="dark"] .wc-tree          { background: #0f0e1a; border-color: var(--clr-border); color: #cbd5e1; }

/* Dark mode */
[data-theme="dark"] .wc-options-card   { background: var(--clr-card); border-color: var(--clr-border); }
[data-theme="dark"] .wc-option-box     { background: var(--clr-surface); border-color: var(--clr-border); color: var(--clr-muted); }
[data-theme="dark"] .wc-chk:checked + .wc-option-box { background: rgba(117,79,254,.12); border-color: #754ffe; color: #a78bfa; }
[data-theme="dark"] .wc-progress-card  { background: var(--clr-card); border-color: var(--clr-border); }
[data-theme="dark"] .wc-progress-title { color: var(--clr-heading); }
[data-theme="dark"] .wc-complete-banner { background: rgba(22,163,74,.08); border-color: rgba(22,163,74,.25); }
[data-theme="dark"] .wc-complete-banner strong { color: #4ade80; }
[data-theme="dark"] .wc-complete-banner span   { color: #86efac; }
[data-theme="dark"] .wc-stat-card      { background: var(--clr-card); border-color: var(--clr-border); }
[data-theme="dark"] .wc-stat-num       { color: var(--clr-heading); }
[data-theme="dark"] .wc-stat-card-total { background: rgba(117,79,254,.1); border-color: rgba(117,79,254,.3); }

/* ── Add Name & Date on Photo ─────────────────────────────── */
/* Editor card — matches #aibEditor */
#indEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}

.ind-section-head {
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .07em;
    text-transform: uppercase;
    color: var(--clr-muted, #9ca3af);
    padding: 12px 18px 10px;
    border-bottom: 1px solid var(--clr-border, #f1f5f9);
    background: var(--clr-surface, #f8f7ff);
    margin: 0;
}
.ind-input { height: 44px !important; min-height: unset !important; }
.ind-switch .form-check-input:checked { background-color: #754ffe; border-color: #754ffe; }
.ind-switch .form-check-label { color: var(--clr-muted, #6b7280); font-size: .85rem; }

/* Integrated color swatch + hex input */
.ind-color-group {
    display: flex;
    height: 44px;
    border: 1.5px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    overflow: hidden;
}
.ind-color-swatch {
    width: 36px;
    min-width: 36px;
    height: 100%;
    border: none;
    border-right: 1.5px solid var(--clr-border, #e5e7eb);
    cursor: pointer;
    padding: 4px 3px;
    background: none;
    -webkit-appearance: none;
    appearance: none;
}
.ind-color-swatch::-webkit-color-swatch-wrapper { padding: 2px; }
.ind-color-swatch::-webkit-color-swatch { border: none; border-radius: 3px; }
.ind-color-text {
    flex: 1;
    height: 40px !important;
    min-height: unset !important;
    border: none !important;
    border-radius: 0 !important;
    padding: .3rem .5rem !important;
    font-size: .8rem;
    font-family: 'SFMono-Regular', Consolas, monospace;
    color: var(--clr-heading, #1e1b4b);
    background: transparent;
    box-shadow: none !important;
    outline: none;
}
.ind-color-text:focus { box-shadow: none !important; outline: none; }

/* Fullscreen — mirrors #aibWrap.aib-fullscreen */
#indWrap.aib-fullscreen {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: var(--clr-card, #fff);
    display: flex;
    flex-direction: column;
    padding: 0;
    margin: 0;
    max-width: none;
}
#indWrap.aib-fullscreen #indEditor {
    flex: 1;
    border: none;
    border-radius: 0;
    overflow: hidden;
    display: flex !important;
    flex-direction: column;
}
#indWrap.aib-fullscreen .aib-editor-wrap { flex: 1; min-height: unset; }
#indWrap.aib-fullscreen .aib-preview-side { position: relative; }
#indWrap.aib-fullscreen .aib-fs-close { display: flex; }

[data-theme="dark"] #indEditor           { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .ind-section-head   { background: var(--clr-surface, #16152e); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .ind-color-group    { border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .ind-color-swatch   { border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .ind-color-text     { color: var(--clr-heading, #e2e2f0); }


input[type=color]{
        width: 34px !important;
    border-radius: 50%;
        height: 34px !important;
        margin-top: 4px;
    margin-left: 4px;
}

/* ============================================================
   Tool: Image DPI Checker (#dpiWrap)
   ============================================================ */

/* Editor card */
#dpiEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}

/* Preview image */
#dpiPreview {
    max-width: 100%;
    max-height: 492px;
    width: auto;
    height: auto;
    display: block;
    object-fit: contain;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
}

/* Loader — shown in place of upload zone while fetching */
#dpiLoader {
    display: none;
    align-items: center;
    justify-content: center;
    min-height: 280px;
    border: 2px dashed var(--clr-border, #cbd5e1);
    border-radius: 16px;
    background: var(--clr-surface, #f8f7ff);
}
.dpi-loader-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
}
.dpi-loader-text {
    font-size: .9rem;
    font-weight: 500;
    color: var(--clr-muted, #6b7280);
    margin: 0;
}

/* Large DPI number */
.dpi-big-num {
    font-size: 2rem;
    font-weight: 800;
    color: var(--clr-heading, #1e1b4b);
    line-height: 1.1;
    margin: 4px 0 2px;
}

/* Rating badge */
.dpi-rating-badge {
    display: inline-block;
    font-size: .63rem;
    font-weight: 800;
    letter-spacing: .07em;
    text-transform: uppercase;
    padding: .2rem .55rem;
    border-radius: 100px;
}
.dpi-badge-good { background: #dcfce7; color: #16a34a; }
.dpi-badge-ok   { background: #dbeafe; color: #1d4ed8; }
.dpi-badge-warn { background: #fef3c7; color: #d97706; }
.dpi-badge-bad  { background: #fee2e2; color: #dc2626; }

/* 2-column stat grid */
.dpi-stat-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin-top: 2px;
}
.dpi-stat-item {
    display: flex;
    flex-direction: column;
    gap: 3px;
    background: var(--clr-surface, #f8f7ff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    padding: 8px 10px;
}
.dpi-stat-label {
    font-size: .62rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--clr-muted, #9ca3af);
}
.dpi-stat-val {
    font-size: .88rem;
    font-weight: 700;
    color: var(--clr-heading, #1e1b4b);
}

/* Recommendation card */
.dpi-rec-card {
    font-size: .82rem;
    line-height: 1.55;
    padding: 10px 12px;
    border-radius: 8px;
    border-left: 3px solid;
}
.dpi-rec-good { background: #f0fdf4; border-color: #22c55e; color: #15803d; }
.dpi-rec-ok   { background: #eff6ff; border-color: #3b82f6; color: #1d4ed8; }
.dpi-rec-warn { background: #fffbeb; border-color: #f59e0b; color: #92400e; }
.dpi-rec-bad  { background: #fef2f2; border-color: #ef4444; color: #b91c1c; }

/* Fullscreen */
#dpiWrap.aib-fullscreen {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: var(--clr-card, #fff);
    display: flex;
    flex-direction: column;
    padding: 0;
    margin: 0;
    max-width: none;
}
#dpiWrap.aib-fullscreen #dpiEditor {
    flex: 1;
    border: none;
    border-radius: 0;
    overflow: hidden;
    display: flex !important;
    flex-direction: column;
}
#dpiWrap.aib-fullscreen .aib-editor-wrap { flex: 1; min-height: unset; }
#dpiWrap.aib-fullscreen .aib-preview-side { position: relative; }
#dpiWrap.aib-fullscreen .aib-fs-close { display: flex; }

/* Dark mode */
[data-theme="dark"] #dpiEditor       { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] #dpiLoader       { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .dpi-big-num     { color: var(--clr-text, #e2e2f0); }
[data-theme="dark"] .dpi-stat-item   { background: var(--clr-surface, #16152e); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .dpi-stat-val    { color: var(--clr-text, #e2e2f0); }
[data-theme="dark"] .dpi-rec-good    { background: rgba(22,163,74,.1);  border-color: rgba(34,197,94,.4);  color: #4ade80; }
[data-theme="dark"] .dpi-rec-ok      { background: rgba(59,130,246,.1); border-color: rgba(59,130,246,.4); color: #93c5fd; }
[data-theme="dark"] .dpi-rec-warn    { background: rgba(245,158,11,.1); border-color: rgba(245,158,11,.4); color: #fcd34d; }
[data-theme="dark"] .dpi-rec-bad     { background: rgba(239,68,68,.1);  border-color: rgba(239,68,68,.4);  color: #fca5a5; }

/* ============================================================
   Tool: Increase Image Size in KB (#iisWrap)
   ============================================================ */

/* Editor card */
#iisEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}

/* Preview image */
#iisPreview {
    max-width: 100%;
    max-height: 492px;
    width: auto;
    height: auto;
    display: block;
    object-fit: contain;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
}

/* Filename display */
.iis-file-name {
    font-size: .82rem;
    font-weight: 500;
    color: var(--clr-heading, #1e1b4b);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    padding: 5px 0 2px;
}

/* Number input + KB suffix */
.iis-input-group {
    display: flex;
    align-items: stretch;
    border: 1.5px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    overflow: hidden;
    transition: border-color .2s, box-shadow .2s;
}
.iis-input-group:focus-within {
    border-color: #754ffe;
    box-shadow: 0 0 0 3px rgba(117,79,254,.15);
}
.iis-num-input {
    flex: 1;
    border: none !important;
    border-radius: 0 !important;
    height: 44px !important;
    min-height: unset !important;
    padding: 0 12px;
    font-size: .95rem;
    box-shadow: none !important;
    outline: none;
    background: transparent;
}
.iis-num-input:focus { box-shadow: none !important; outline: none; }
.iis-input-suffix {
    display: flex;
    align-items: center;
    padding: 0 14px;
    background: var(--clr-surface, #f8f7ff);
    border-left: 1.5px solid var(--clr-border, #e5e7eb);
    font-size: .85rem;
    font-weight: 600;
    color: var(--clr-muted, #6b7280);
    white-space: nowrap;
}

/* Success result badge */
.iis-result-badge {
    display: flex;
    align-items: center;
    padding: 10px 14px;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: 8px;
    font-size: .88rem;
    color: #15803d;
}
.iis-result-badge .bi { color: #16a34a; font-size: 1.05rem; }

/* Fullscreen */
#iisWrap.aib-fullscreen {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: var(--clr-card, #fff);
    display: flex;
    flex-direction: column;
    padding: 0;
    margin: 0;
    max-width: none;
}
#iisWrap.aib-fullscreen #iisEditor {
    flex: 1;
    border: none;
    border-radius: 0;
    overflow: hidden;
    display: flex !important;
    flex-direction: column;
}
#iisWrap.aib-fullscreen .aib-editor-wrap { flex: 1; min-height: unset; }
#iisWrap.aib-fullscreen .aib-preview-side { position: relative; }
#iisWrap.aib-fullscreen .aib-fs-close { display: flex; }

/* Dark mode */
[data-theme="dark"] #iisEditor        { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .iis-file-name    { color: var(--clr-text, #e2e2f0); }
[data-theme="dark"] .iis-input-group  { border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .iis-input-suffix { background: var(--clr-surface, #16152e); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .iis-num-input    { color: var(--clr-text, #e2e2f0); }
[data-theme="dark"] .iis-result-badge { background: rgba(22,163,74,.08); border-color: rgba(22,163,74,.25); color: #4ade80; }

/* ============================================================
   Tool: DPI Converter (#dcWrap)
   ============================================================ */

/* Editor card */
#dcEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}

/* Preview image — same pattern as #dpiPreview */
#dcPreview {
    max-width: 100%;
    max-height: 492px;
    width: auto;
    height: auto;
    display: block;
    object-fit: contain;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
}

/* Stat item that spans full width */
.dc-stat-full { grid-column: 1 / -1; }

/* Quick preset buttons */
.dc-preset-row {
    display: flex;
    gap: 5px;
    flex-wrap: wrap;
    margin-top: 2px;
}
.dc-preset {
    flex: 1;
    min-width: 0;
    padding: .28rem .3rem;
    font-size: .75rem;
    font-weight: 700;
    background: var(--clr-surface, #f8f7ff);
    border: 1.5px solid var(--clr-border, #e5e7eb);
    border-radius: 6px;
    color: var(--clr-muted, #6b7280);
    cursor: pointer;
    transition: border-color .15s, background .15s, color .15s, transform .1s;
    text-align: center;
}
.dc-preset:hover {
    border-color: #754ffe;
    color: #754ffe;
    transform: translateY(-1px);
}
.dc-preset.active {
    border-color: #754ffe;
    background: rgba(117,79,254,.1);
    color: #754ffe;
}

/* Fullscreen */
#dcWrap.aib-fullscreen {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: var(--clr-card, #fff);
    display: flex;
    flex-direction: column;
    padding: 0;
    margin: 0;
    max-width: none;
}
#dcWrap.aib-fullscreen #dcEditor {
    flex: 1;
    border: none;
    border-radius: 0;
    overflow: hidden;
    display: flex !important;
    flex-direction: column;
}
#dcWrap.aib-fullscreen .aib-editor-wrap { flex: 1; min-height: unset; }
#dcWrap.aib-fullscreen .aib-preview-side { position: relative; }
#dcWrap.aib-fullscreen .aib-fs-close { display: flex; }

/* Dark mode */
[data-theme="dark"] #dcEditor      { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .dc-preset     { background: var(--clr-surface, #16152e); border-color: var(--clr-border, #2d2b4e); color: var(--clr-muted, #6b7280); }
[data-theme="dark"] .dc-preset.active { background: rgba(117,79,254,.15); border-color: #754ffe; color: #a78bfa; }

/* ============================================================
   Tool: Image to Pixel Art (#ipWrap)
   ============================================================ */

/* Editor card — matches #aibEditor */
#ipEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}

/* Canvas — disable smoothing so pixels stay crisp */
#ipCanvas {
    max-width: 100%;
    max-height: 492px;
    width: auto;
    height: auto;
    display: block;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
    image-rendering: pixelated;
    image-rendering: crisp-edges;
}

/* Hint text below slider */
.ip-hint {
    font-size: .72rem;
    color: var(--clr-muted, #9ca3af);
    margin: 6px 0 0;
    line-height: 1.5;
}

/* Fullscreen — mirrors #aibWrap.aib-fullscreen */
#ipWrap.aib-fullscreen {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: var(--clr-card, #fff);
    display: flex;
    flex-direction: column;
    padding: 0;
    margin: 0;
    max-width: none;
}
#ipWrap.aib-fullscreen #ipEditor {
    flex: 1;
    border: none;
    border-radius: 0;
    overflow: hidden;
    display: flex !important;
    flex-direction: column;
}
#ipWrap.aib-fullscreen .aib-editor-wrap { flex: 1; min-height: unset; }
#ipWrap.aib-fullscreen .aib-preview-side { position: relative; }
#ipWrap.aib-fullscreen .aib-fs-close { display: flex; }

/* Dark mode */
[data-theme="dark"] #ipEditor         { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }

/* ============================================================
   Tool: Resize Signature Image (#rsWrap)
   ============================================================ */

/* Editor card — matches #aibEditor */
#rsEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}

/* Canvas preview */
#rsCanvas {
    max-width: 100%;
    max-height: 492px;
    width: auto;
    height: auto;
    display: block;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
}

/* Unit toggle row */
.rs-unit-row {
    display: flex;
    gap: 8px;
}
.rs-unit-btn {
    flex: 1;
    padding: 7px 10px;
    font-size: .8rem;
    font-weight: 600;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    background: var(--clr-surface, #f9fafb);
    color: var(--clr-muted, #9ca3af);
    cursor: pointer;
    transition: background .15s, color .15s, border-color .15s;
}
.rs-unit-btn.active {
    background: rgba(117,79,254,.12);
    border-color: #754ffe;
    color: #754ffe;
}
.rs-unit-btn:hover:not(.active) {
    border-color: #754ffe;
    color: #754ffe;
}

/* Two-column dimension inputs */
.rs-dim-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}
.rs-dim-field {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

/* Fullscreen — mirrors #aibWrap.aib-fullscreen */
#rsWrap.aib-fullscreen {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: var(--clr-card, #fff);
    display: flex;
    flex-direction: column;
    padding: 0;
    margin: 0;
    max-width: none;
}
#rsWrap.aib-fullscreen #rsEditor {
    flex: 1;
    border: none;
    border-radius: 0;
    overflow: hidden;
    display: flex !important;
    flex-direction: column;
}
#rsWrap.aib-fullscreen .aib-editor-wrap { flex: 1; min-height: unset; }
#rsWrap.aib-fullscreen .aib-preview-side { position: relative; }
#rsWrap.aib-fullscreen .aib-fs-close { display: flex; }

/* Dark mode */
[data-theme="dark"] #rsEditor   { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .rs-unit-btn { background: var(--clr-surface, #16152e); border-color: var(--clr-border, #2d2b4e); color: var(--clr-muted, #6b7280); }
[data-theme="dark"] .rs-unit-btn.active { background: rgba(117,79,254,.15); border-color: #754ffe; color: #a78bfa; }

/* ============================================================
   Tool: Link Finder (#lfWrap)
   ============================================================ */

/* Form card */
.lf-form-card {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    padding: 24px;
}

/* URL inputs */
.lf-input {
    border-radius: 8px !important;
    border: 1px solid var(--clr-border, #cbd5e1);
    padding: 10px 14px;
    font-size: .95rem;
    transition: border-color .2s, box-shadow .2s;
}
.lf-input:focus {
    border-color: #754ffe;
    box-shadow: 0 0 0 3px rgba(117,79,254,.15);
    outline: none;
}

/* Progress match count highlight */
.lf-match-count { color: #16a34a; font-weight: 700; }

/* Truncated cell text */
.lf-truncate {
    max-width: 260px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    display: inline-block;
}

/* Toolbar (export + search) */
.lf-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
    flex-wrap: wrap;
}
.lf-export-row { display: flex; gap: 8px; flex-shrink: 0; }
.lf-search-wrap {
    flex: 1;
    min-width: 180px;
    max-width: 320px;
}
.lf-search-input {
    padding-left: 12px;
    border-radius: 8px;
    border: 1px solid var(--clr-border, #cbd5e1);
    font-size: .88rem;
    height: 36px;
}
.lf-search-input:focus {
    border-color: #754ffe;
    box-shadow: 0 0 0 3px rgba(117,79,254,.12);
}

/* Table */
.lf-table-wrap {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    overflow: hidden;
    overflow-x: auto;
}
.lf-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .88rem;
}
.lf-table thead tr {
    background: var(--clr-surface, #f8f7ff);
}
.lf-table th {
    padding: 10px 14px;
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--clr-muted, #6b7280);
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
    white-space: nowrap;
}
.lf-table td {
    padding: 10px 14px;
    border-bottom: 1px solid var(--clr-border, #f1f5f9);
    vertical-align: top;
    color: var(--clr-heading, #1e1b4b);
}
.lf-table tbody tr:last-child td { border-bottom: none; }
.lf-table tbody tr:hover td { background: var(--clr-surface, #f8f7ff); }
.lf-th-num, .lf-td-num { width: 42px; text-align: center; }
.lf-url-link {
    color: #754ffe;
    text-decoration: none;
    font-weight: 500;
    word-break: break-all;
}
.lf-url-link:hover { text-decoration: underline; }
.lf-context { color: var(--clr-muted, #6b7280); font-size: .82rem; }

/* Link type badges */
.lf-type-badge {
    display: inline-block;
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    padding: .2rem .55rem;
    border-radius: 100px;
    white-space: nowrap;
}
.lf-badge-int { background: rgba(117,79,254,.12); color: #754ffe; }
.lf-badge-ext { background: rgba(107,114,128,.12); color: #374151; }

/* Table footer */
.lf-table-footer {
    padding: 10px 14px;
    font-size: .8rem;
    color: var(--clr-muted, #6b7280);
    background: var(--clr-surface, #f8f7ff);
    border-top: 1px solid var(--clr-border, #e5e7eb);
}

/* Dark mode */
[data-theme="dark"] .lf-form-card       { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .lf-input           { background: var(--clr-surface, #16152e); border-color: var(--clr-border, #2d2b4e); color: var(--clr-text, #e2e2f0); }
[data-theme="dark"] .lf-table thead tr  { background: var(--clr-surface, #16152e); }
[data-theme="dark"] .lf-table th        { border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .lf-table td        { border-color: var(--clr-border, #2d2b4e); color: var(--clr-text, #e2e2f0); }
[data-theme="dark"] .lf-table tbody tr:hover td { background: var(--clr-surface, #16152e); }
[data-theme="dark"] .lf-table-wrap      { border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .lf-table-footer    { background: var(--clr-surface, #16152e); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .lf-search-input    { background: var(--clr-surface, #16152e); border-color: var(--clr-border, #2d2b4e); color: var(--clr-text, #e2e2f0); }
[data-theme="dark"] .lf-badge-ext       { background: rgba(107,114,128,.2); color: #9ca3af; }

/* ============================================================
   Tool: Reduce Image Size in KB (#risWrap)
   ============================================================ */

/* Editor card — mirrors #iisEditor */
#risEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}

/* Preview image */
#risPreview {
    max-width: 100%;
    max-height: 492px;
    width: auto;
    height: auto;
    display: block;
    object-fit: contain;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
}

/* Checkerboard background on preview panel to show transparency */
.ris-checker {
    background-image:
        linear-gradient(45deg, #e9ecef 25%, transparent 25%, transparent 75%, #e9ecef 75%),
        linear-gradient(45deg, #e9ecef 25%, transparent 25%, transparent 75%, #e9ecef 75%);
    background-size: 20px 20px;
    background-position: 0 0, 10px 10px;
}

/* Fullscreen — mirrors #iisWrap.aib-fullscreen */
#risWrap.aib-fullscreen {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: var(--clr-card, #fff);
    display: flex;
    flex-direction: column;
    padding: 0;
    margin: 0;
    max-width: none;
}
#risWrap.aib-fullscreen #risEditor {
    flex: 1;
    border: none;
    border-radius: 0;
    overflow: hidden;
    display: flex !important;
    flex-direction: column;
}
#risWrap.aib-fullscreen .aib-editor-wrap { flex: 1; min-height: unset; }
#risWrap.aib-fullscreen .aib-preview-side { position: relative; }
#risWrap.aib-fullscreen .aib-fs-close { display: flex; }

/* Dark mode */
[data-theme="dark"] #risEditor   { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .ris-checker { background-image: linear-gradient(45deg, #2d2b4e 25%, transparent 25%, transparent 75%, #2d2b4e 75%), linear-gradient(45deg, #2d2b4e 25%, transparent 25%, transparent 75%, #2d2b4e 75%); }

/* ============================================================
   Tool: Merge Photo & Signature (#mpsWrap)
   ============================================================ */

/* Editor card */
#mpsEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}

/* Canvas */
#mpsCanvas {
    max-width: 100%;
    max-height: 500px;
    width: auto;
    height: auto;
    display: block;
    cursor: crosshair;
    box-shadow: 0 4px 20px rgba(0,0,0,.15);
    border-radius: 2px;
}

/* Drag hint tooltip */
.mps-drag-hint {
    position: absolute;
    top: 14px;
    left: 50%;
    transform: translateX(-50%);
    background: rgba(0,0,0,.72);
    color: #fff;
    padding: 5px 14px;
    border-radius: 20px;
    font-size: .75rem;
    font-weight: 500;
    pointer-events: none;
    white-space: nowrap;
    z-index: 10;
}

/* Advanced settings accordion (details/summary) */
.mps-advanced {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    overflow: hidden;
}
.mps-advanced-toggle {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 10px 14px;
    font-size: .82rem;
    font-weight: 600;
    color: var(--clr-muted, #6b7280);
    cursor: pointer;
    list-style: none;
    user-select: none;
    background: var(--clr-surface, #f8f7ff);
}
.mps-advanced-toggle::-webkit-details-marker { display: none; }
.mps-chevron { transition: transform .2s; font-size: .75rem; }
details[open] .mps-chevron { transform: rotate(180deg); }
.mps-advanced-body {
    padding: 14px;
    border-top: 1px solid var(--clr-border, #e5e7eb);
    background: var(--clr-card, #fff);
}

/* Unit select */
.mps-unit-select {
    border-color: var(--clr-border, #cbd5e1);
    font-size: .88rem;
    border-radius: 8px;
}
.mps-unit-select:focus {
    border-color: #754ffe;
    box-shadow: 0 0 0 3px rgba(117,79,254,.12);
}

/* Fullscreen */
#mpsWrap.aib-fullscreen {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: var(--clr-card, #fff);
    display: flex;
    flex-direction: column;
    padding: 0;
    margin: 0;
    max-width: none;
}
#mpsWrap.aib-fullscreen #mpsEditor {
    flex: 1;
    border: none;
    border-radius: 0;
    overflow: hidden;
    display: flex !important;
    flex-direction: column;
}
#mpsWrap.aib-fullscreen .aib-editor-wrap { flex: 1; min-height: unset; }
#mpsWrap.aib-fullscreen .aib-preview-side { position: relative; }
#mpsWrap.aib-fullscreen .aib-fs-close { display: flex; }

/* Dark mode */
[data-theme="dark"] #mpsEditor           { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .mps-advanced        { border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .mps-advanced-toggle { background: var(--clr-surface, #16152e); }
[data-theme="dark"] .mps-advanced-body   { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .mps-unit-select     { background: var(--clr-surface, #16152e); border-color: var(--clr-border, #2d2b4e); color: var(--clr-text, #e2e2f0); }
/* ============================================================
   Image Extractor  (#wieWrap)
   ============================================================ */

/* Gallery header */
.wie-gallery-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 18px;
    padding: 10px 16px;
    background: var(--clr-surface, #f8f7ff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
}
.wie-count-label {
    font-size: .92rem;
    color: var(--clr-muted, #6b7280);
}
.wie-count-label strong {
    color: var(--clr-heading, #1e1b4b);
    font-size: 1.05rem;
}

/* Image grid */
.wie-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 14px;
}

/* Card */
.wie-img-card {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    overflow: hidden;
    background: var(--clr-card, #fff);
    transition: box-shadow .18s, transform .18s;
}
.wie-img-card:hover {
    box-shadow: 0 6px 24px rgba(117,79,254,.13);
    transform: translateY(-2px);
}

/* Image wrapper — checkerboard for transparency */
.wie-img-wrap {
    aspect-ratio: 1;
    overflow: hidden;
    background-color: #f0f0f0;
    background-image:
        linear-gradient(45deg, #ccc 25%, transparent 25%),
        linear-gradient(-45deg, #ccc 25%, transparent 25%),
        linear-gradient(45deg, transparent 75%, #ccc 75%),
        linear-gradient(-45deg, transparent 75%, #ccc 75%);
    background-size: 16px 16px;
    background-position: 0 0, 0 8px, 8px -8px, -8px 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.wie-img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    transition: transform .22s;
}
.wie-img-card:hover .wie-img-wrap img { transform: scale(1.04); }

/* Card details */
.wie-card-details {
    padding: 10px;
}
.wie-meta-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 6px;
    margin-bottom: 8px;
}
.wie-badge {
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .04em;
    padding: 2px 8px;
    border-radius: 20px;
    background: var(--clr-surface, #f0eeff);
    color: #754ffe;
    text-transform: uppercase;
}
.wie-dims {
    font-size: .72rem;
    color: var(--clr-muted, #9ca3af);
    white-space: nowrap;
}

/* Dark mode */
[data-theme="dark"] .wie-gallery-head { background: var(--clr-surface, #16152e); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .wie-count-label strong { color: var(--clr-heading, #e2e2f0); }
[data-theme="dark"] .wie-img-card { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .wie-img-wrap { background-color: #2a2845; background-image: linear-gradient(45deg,#1a1832 25%,transparent 25%),linear-gradient(-45deg,#1a1832 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#1a1832 75%),linear-gradient(-45deg,transparent 75%,#1a1832 75%); }
[data-theme="dark"] .wie-badge { background: rgba(117,79,254,.18); }

/* ============================================================
   Image Upscale  (#iusWrap)
   ============================================================ */

/* Editor card */
#iusEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}

/* Preview image */
#iusPreview {
    max-width: 100%;
    max-height: 492px;
    width: auto;
    height: auto;
    display: block;
    object-fit: contain;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
}

/* Dimension box */
.ius-dim-box {
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--clr-surface, #f8f7ff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    padding: 12px 14px;
}
.ius-dim-item {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.ius-dim-label {
    font-size: .72rem;
    color: var(--clr-muted, #9ca3af);
    text-transform: uppercase;
    letter-spacing: .05em;
    font-weight: 600;
}
.ius-dim-val {
    font-size: .9rem;
    color: var(--clr-heading, #1e1b4b);
    font-weight: 700;
    white-space: nowrap;
}
.ius-dim-new { color: #754ffe; }
.ius-dim-arrow {
    font-size: 1rem;
    color: var(--clr-muted, #9ca3af);
    flex-shrink: 0;
}

/* Fullscreen */
#iusWrap.aib-fullscreen {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: var(--clr-card, #fff);
    display: flex;
    flex-direction: column;
    padding: 0;
    margin: 0;
    max-width: none;
}
#iusWrap.aib-fullscreen #iusEditor {
    flex: 1;
    border: none;
    border-radius: 0;
    overflow: hidden;
    display: flex !important;
    flex-direction: column;
}
#iusWrap.aib-fullscreen .aib-editor-wrap { flex: 1; min-height: unset; }
#iusWrap.aib-fullscreen .aib-preview-side { position: relative; }
#iusWrap.aib-fullscreen .aib-fs-close { display: flex; }

/* Dark mode */
[data-theme="dark"] #iusEditor    { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .ius-dim-box  { background: var(--clr-surface, #16152e); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .ius-dim-val  { color: var(--clr-heading, #e2e2f0); }
[data-theme="dark"] .ius-dim-new  { color: #a78bfa; }

/* ============================================================
   Create ZIP File  (#czfWrap)
   ============================================================ */

/* Files card */
.czf-card {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}

/* Card header */
.czf-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 14px 18px;
    background: var(--clr-surface, #f8f7ff);
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
}
.czf-card-title {
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--clr-muted, #6b7280);
}
.czf-count {
    font-size: .72rem;
    font-weight: 700;
    padding: 3px 10px;
    border-radius: 20px;
    background: rgba(117,79,254,.12);
    color: #754ffe;
}

/* Table */
.czf-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .88rem;
}
.czf-table thead tr {
    background: var(--clr-surface, #f8f7ff);
}
.czf-table th {
    padding: 10px 14px;
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--clr-muted, #6b7280);
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
    white-space: nowrap;
}
.czf-table td {
    padding: 10px 14px;
    border-bottom: 1px solid var(--clr-border, #f1f5f9);
    vertical-align: middle;
    color: var(--clr-heading, #1e1b4b);
}
.czf-table tbody tr:last-child td { border-bottom: none; }
.czf-table tbody tr:hover td { background: var(--clr-surface, #f8f7ff); }
.czf-td-name { word-break: break-all; }
.czf-th-size, .czf-td-size {
    width: 90px;
    text-align: right;
    white-space: nowrap;
    color: var(--clr-muted, #6b7280);
}
.czf-th-act, .czf-td-act {
    width: 44px;
    text-align: center;
}
.czf-file-icon {
    color: #754ffe;
    font-size: .95rem;
    vertical-align: middle;
}

/* Remove button */
.czf-remove-btn {
    background: none;
    border: none;
    padding: 4px 6px;
    border-radius: 6px;
    color: var(--clr-muted, #9ca3af);
    font-size: .8rem;
    cursor: pointer;
    line-height: 1;
    transition: color .15s, background .15s;
}
.czf-remove-btn:hover { color: #ef4444; background: rgba(239,68,68,.08); }

/* Card footer */
.czf-card-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    padding: 12px 18px;
    background: var(--clr-surface, #f8f7ff);
    border-top: 1px solid var(--clr-border, #e5e7eb);
}
.czf-size-info {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: .85rem;
}
.czf-size-label {
    color: var(--clr-muted, #6b7280);
}
.czf-size-info strong {
    color: var(--clr-heading, #1e1b4b);
}
.czf-foot-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

/* Dark mode */
[data-theme="dark"] .czf-card      { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .czf-card-head { background: var(--clr-surface, #16152e); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .czf-card-foot { background: var(--clr-surface, #16152e); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .czf-size-info strong { color: var(--clr-heading, #e2e2f0); }
[data-theme="dark"] .czf-table thead tr          { background: var(--clr-surface, #16152e); }
[data-theme="dark"] .czf-table th                { border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .czf-table td                { border-color: var(--clr-border, #2d2b4e); color: var(--clr-text, #e2e2f0); }
[data-theme="dark"] .czf-table tbody tr:hover td { background: var(--clr-surface, #16152e); }

/* ============================================================
   RAR to ZIP  (#rtzWrap)
   ============================================================ */

/* State cards (processing & success) */
.rtz-state-card {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
.rtz-state-body {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 52px 32px;
    gap: 18px;
}

/* Big spinner (overrides .pxt-spinner defaults) */
.rtz-big-spinner {
    width: 48px !important;
    height: 48px !important;
    border-width: 4px !important;
    margin-right: 0 !important;
}

/* Titles */
.rtz-state-title {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--clr-heading, #1e1b4b);
    margin: 0;
}
.rtz-success-title { color: #16a34a; }

/* Progress bar */
.rtz-progress-wrap {
    width: 100%;
    max-width: 440px;
    height: 22px;
    border-radius: 100px;
    background: var(--clr-surface, #f1f5f9);
    overflow: hidden;
}
.rtz-progress-bar {
    height: 100%;
    min-width: 2rem;
    border-radius: 100px;
    background: linear-gradient(90deg, #754ffe, #a78bfa);
    font-size: .72rem;
    font-weight: 700;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: width .3s ease;
}

/* Detail text */
.rtz-detail-text {
    font-size: .85rem;
    color: var(--clr-muted, #6b7280);
    max-width: 420px;
    margin: 0;
    word-break: break-all;
}

/* Success icon */
.rtz-success-icon {
    font-size: 3.5rem;
    color: #16a34a;
    line-height: 1;
}

/* Success actions */
.rtz-success-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: center;
}

/* Dark mode */
[data-theme="dark"] .rtz-state-card    { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .rtz-state-title   { color: var(--clr-heading, #e2e2f0); }
[data-theme="dark"] .rtz-progress-wrap { background: rgba(255,255,255,.1); }
[data-theme="dark"] .rtz-success-title { color: #4ade80; }
[data-theme="dark"] .rtz-success-icon  { color: #4ade80; }

/* ═══════════════════════════════════════════════════════════════════════════
   IMAGE COMPRESSOR
   ══════════════════════════════════════════════════════════════════════════ */

/* totals strip */
.sic-totals              { display:flex; border-bottom:1px solid var(--clr-border,#e5e7eb); background:var(--clr-surface,#f8f7ff); }
.sic-tot-cell            { flex:1; text-align:center; padding:10px 8px; border-right:1px solid var(--clr-border,#e5e7eb); }
.sic-tot-cell:last-child { border-right:none; }
.sic-tot-lbl             { font-size:.62rem; font-weight:700; color:var(--clr-muted,#9ca3af); text-transform:uppercase; letter-spacing:.06em; margin-bottom:2px; }
.sic-tot-val             { font-size:.9rem; font-weight:800; color:var(--clr-heading,#111); }
.sic-tot-green           { color:#16a34a; }

/* file rows */
.sic-row             { display:flex; align-items:center; gap:12px; padding:12px 18px; border-bottom:1px solid var(--clr-border,#e5e7eb); }
.sic-row:last-child  { border-bottom:none; }
.sic-thumb           { width:46px; height:46px; border-radius:8px; object-fit:cover; background:var(--clr-surface,#f3f4f6); flex-shrink:0; }
.sic-info            { flex:1; min-width:0; }
.sic-name            { font-size:.82rem; font-weight:600; color:var(--clr-heading,#111); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; margin-bottom:4px; }
.sic-sizes           { display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.sic-lbl             { font-size:.68rem; color:var(--clr-muted,#9ca3af); font-weight:500; text-transform:uppercase; letter-spacing:.04em; }
.sic-val             { font-size:.8rem; font-weight:700; }
.sic-before          { color:var(--clr-muted,#6b7280); }
.sic-after           { color:#16a34a; }
.sic-same            { color:var(--clr-muted,#6b7280); }
.sic-err             { color:#dc2626; }
.sic-sep             { font-size:.75rem; color:var(--clr-border,#d1d5db); }

/* savings pill */
.sic-pct           { font-size:.82rem; font-weight:800; padding:3px 10px; border-radius:20px; white-space:nowrap; flex-shrink:0; }
.sic-pct-green     { background:#dcfce7; color:#15803d; }
.sic-pct-gray      { background:var(--clr-surface,#f3f4f6); color:var(--clr-muted,#9ca3af); }
.sic-pct-red       { background:#fee2e2; color:#dc2626; }

/* dark mode */
[data-theme="dark"] .sic-totals     { background:var(--clr-surface,#1a1830); }
[data-theme="dark"] .sic-tot-green  { color:#4ade80; }
[data-theme="dark"] .sic-pct-green  { background:rgba(22,163,74,.18); color:#4ade80; }
[data-theme="dark"] .sic-pct-gray   { background:var(--clr-surface,#2a2840); color:var(--clr-muted,#6b7280); }
[data-theme="dark"] .sic-pct-red    { background:rgba(220,38,38,.18); color:#f87171; }

/* ═══════════════════════════════════════════════════════════════════════════
   COMPRESS PDF
   ══════════════════════════════════════════════════════════════════════════ */

/* file header */
.cpdf-file-head           { gap:10px; flex-wrap:nowrap; }
.cpdf-file-icon-wrap      { font-size:2rem; color:#dc2626; flex-shrink:0; line-height:1; }
.cpdf-file-meta           { min-width:0; }
.cpdf-file-name           { font-size:.88rem; font-weight:700; color:var(--clr-heading,#111); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:260px; }
.cpdf-file-size           { font-size:.76rem; color:var(--clr-muted,#9ca3af); margin-top:1px; }

/* settings body */
.cpdf-body                { padding:22px 22px; }

/* compression option grid */
.cpdf-opt-grid            { display:grid; grid-template-columns:repeat(2,1fr); gap:10px; }
.cpdf-opt-card            { display:flex; flex-direction:column; align-items:center; gap:6px; border:2px solid var(--clr-border,#e5e7eb); border-radius:12px; padding:16px 10px; text-align:center; cursor:pointer; transition:border-color .18s,background .18s; }
.cpdf-opt-card:hover      { border-color:#a78bfa; background:var(--clr-surface,#f8f7ff); }
.cpdf-opt-card.active     { border-color:#754ffe; background:rgba(117,79,254,.07); }
.cpdf-opt-icon            { font-size:1.5rem; color:var(--clr-muted,#9ca3af); transition:color .18s; }
.cpdf-opt-card.active .cpdf-opt-icon { color:#754ffe; }
.cpdf-opt-label           { font-size:.85rem; font-weight:700; color:var(--clr-heading,#111); line-height:1.2; }
.cpdf-opt-sub             { font-size:.7rem; color:var(--clr-muted,#9ca3af); line-height:1.3; }

/* custom settings panel */
.cpdf-custom-wrap         { background:var(--clr-surface,#f8f7ff); border:1px solid var(--clr-border,#e5e7eb); border-radius:12px; padding:18px; margin-bottom:16px; }
.cpdf-radio-row           { display:flex; gap:20px; margin-bottom:16px; flex-wrap:wrap; }
.cpdf-radio-opt           { display:flex; align-items:center; gap:7px; font-size:.86rem; font-weight:600; color:var(--clr-text,#374151); cursor:pointer; }
.cpdf-radio-opt input     { accent-color:#754ffe; width:15px; height:15px; }

/* notice */
.cpdf-notice              { display:flex; align-items:flex-start; gap:8px; background:rgba(251,191,36,.1); border:1px solid rgba(251,191,36,.38); border-radius:10px; padding:11px 14px; font-size:.8rem; line-height:1.5; color:var(--clr-text,#374151); margin-bottom:18px; }
.cpdf-notice i            { color:#d97706; flex-shrink:0; font-size:.9rem; margin-top:2px; }

/* result size comparison */
.cpdf-size-compare        { display:flex; align-items:center; justify-content:center; gap:16px; background:var(--clr-surface,#f8f7ff); border:1px solid var(--clr-border,#e5e7eb); border-radius:12px; padding:18px 24px; flex-wrap:wrap; }
.cpdf-size-box            { text-align:center; }
.cpdf-size-lbl            { font-size:.68rem; text-transform:uppercase; font-weight:700; letter-spacing:.06em; color:var(--clr-muted,#9ca3af); margin-bottom:4px; }
.cpdf-size-val            { font-size:1.05rem; font-weight:800; color:var(--clr-heading,#111); }
.cpdf-size-green          { color:#16a34a; }
.cpdf-size-arrow          { font-size:1.1rem; color:var(--clr-muted,#9ca3af); }
.cpdf-reduction-badge     { background:#dcfce7; color:#15803d; font-size:.85rem; font-weight:800; padding:4px 12px; border-radius:20px; white-space:nowrap; }
.cpdf-badge-gray          { background:var(--clr-surface,#f3f4f6); color:var(--clr-muted,#6b7280); }
.cpdf-info-icon           { color:#754ffe !important; }

/* dark mode */
[data-theme="dark"] .cpdf-opt-card          { border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .cpdf-opt-card:hover    { background:var(--clr-surface,#1a1830); }
[data-theme="dark"] .cpdf-opt-card.active   { background:rgba(117,79,254,.15); }
[data-theme="dark"] .cpdf-custom-wrap       { background:var(--clr-surface,#1a1830); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .cpdf-size-compare      { background:var(--clr-surface,#1a1830); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .cpdf-reduction-badge   { background:rgba(22,163,74,.18); color:#4ade80; }
[data-theme="dark"] .cpdf-badge-gray        { background:var(--clr-surface,#2a2840); color:var(--clr-muted,#6b7280); }

/* ═══════════════════════════════════════════════════════════════════════════
   LOVE CALCULATOR
   ══════════════════════════════════════════════════════════════════════════ */

@keyframes lc-pulse { 0%,100% { transform:scale(1); } 50% { transform:scale(1.18); } }

/* card top banner */
.lc-card-top                { background:linear-gradient(135deg,#ff6b81,#ff4757); padding:28px 24px; text-align:center; color:#fff; position:relative; overflow:hidden; }
.lc-card-top::before,
.lc-card-top::after         { content:''; position:absolute; width:190px; height:190px; background:rgba(255,255,255,.1); border-radius:50%; pointer-events:none; }
.lc-card-top::before        { top:-65px; left:-65px; }
.lc-card-top::after         { bottom:-65px; right:-65px; }
.lc-card-top h4             { position:relative; font-size:1.35rem; font-weight:800; margin-bottom:4px; color:#fff; }
.lc-card-top p              { position:relative; font-size:.85rem; opacity:.88; margin:0; color:#fff; }

/* pulsing heart in header */
.lc-heart-icon              { font-size:2.2rem; color:#fff; animation:lc-pulse 1.5s ease-in-out infinite; position:relative; display:inline-block; margin-bottom:8px; }

/* body */
.lc-body                    { padding:24px; }

/* heart divider */
.lc-divider                 { text-align:center; padding:2px 0 14px; }
.lc-divider-icon            { font-size:1.2rem; color:#ff4757; animation:lc-pulse 1.5s ease-in-out infinite; }

/* validation */
.lc-invalid                 { font-size:.78rem; color:#dc2626; margin-top:5px; display:none; padding-left:2px; }

/* result: names line */
.lc-names-line              { position:relative; font-size:1rem; font-weight:700; color:#fff; margin:8px 0 0; }
.lc-heart-inline            { color:rgba(255,255,255,.9); font-size:.9rem; }

/* circular SVG meter */
.lc-meter-wrap              { position:relative; width:150px; height:150px; margin:0 auto 20px; }
.lc-svg                     { transform:rotate(-90deg); width:100%; height:100%; }
.lc-circle-bg               { fill:none; stroke:var(--clr-border,#f1f2f6); stroke-width:10; }
.lc-circle-prog             { fill:none; stroke:#ff4757; stroke-width:10; stroke-linecap:round; stroke-dasharray:440; stroke-dashoffset:440; }
.lc-pct                     { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); font-size:2.1rem; font-weight:800; color:var(--clr-heading,#111); line-height:1; }

/* result message */
.lc-msg-title               { font-size:1.25rem; font-weight:800; color:#ff4757; margin-bottom:8px; }
.lc-msg-desc                { font-size:.88rem; color:var(--clr-muted,#6b7280); line-height:1.55; margin-bottom:0; }

/* dark mode */
[data-theme="dark"] .lc-circle-bg  { stroke:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .lc-pct        { color:var(--clr-heading,#e2e2f0); }

/* ═══════════════════════════════════════════════════════════════════════════
   EXCEL TO PDF
   ══════════════════════════════════════════════════════════════════════════ */

/* Editor card — same pattern as #ppnEditor */
#e2pEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}

/* Preview panel: PDF-reader grey, iframe fills it */
#e2pWrap .aib-preview-panel {
    background-color: #525659;
    background-image: none;
    padding: 0;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    position: relative;
    overflow: hidden;
}

/* Iframe fills the preview panel */
.e2p-iframe {
    flex: 1;
    width: 100%;
    min-height: 0;
    border: none;
    display: block;
}

/* Loading overlay inside preview */
.e2p-load-overlay {
    position: absolute;
    inset: 0;
    display: none;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background: rgba(40,40,40,.65);
    z-index: 10;
}
.e2p-load-spinner { width:32px; height:32px; border-width:4px; margin-right:0; }
.e2p-load-text    { color:#fff; font-size:.85rem; font-weight:600; }

/* File info strip */
.e2p-file-info  { display:flex; align-items:center; gap:10px; padding:10px 14px; background:var(--clr-surface,#f8f7ff); border:1px solid var(--clr-border,#e5e7eb); border-radius:10px; }
.e2p-file-icon  { font-size:1.6rem; color:#217346; flex-shrink:0; }
.e2p-file-meta  { display:flex; flex-direction:column; gap:2px; min-width:0; }
.e2p-file-name  { font-size:.82rem; font-weight:700; color:var(--clr-heading,#111); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:180px; }
.e2p-row-badge  { display:inline-block; background:rgba(117,79,254,.12); color:#754ffe; font-size:.7rem; font-weight:700; padding:1px 8px; border-radius:20px; width:fit-content; }

/* Orientation active state (matches .aib-pos-btn.active) */
.e2p-orient-btn.active {
    background: var(--clr-primary, #754ffe) !important;
    border-color: var(--clr-primary, #754ffe) !important;
    color: #fff !important;
}

/* Toggle list */
.e2p-toggle-list           { display:flex; flex-direction:column; border:1px solid var(--clr-border,#e5e7eb); border-radius:10px; overflow:hidden; }
.e2p-toggle-row            { display:flex; align-items:center; justify-content:space-between; padding:10px 14px; border-bottom:1px solid var(--clr-border,#e5e7eb); cursor:pointer; background:var(--clr-card,#fff); transition:background .15s; }
.e2p-toggle-row:last-child { border-bottom:none; }
.e2p-toggle-row:hover      { background:var(--clr-surface,#f8f7ff); }
.e2p-toggle-lbl            { font-size:.83rem; font-weight:500; color:var(--clr-text,#374151); pointer-events:none; }
.e2p-toggle-row .form-check-input         { cursor:pointer; }
.e2p-toggle-row .form-check-input:checked { background-color:#754ffe; border-color:#754ffe; }

/* Fullscreen — mirrors #ppnWrap.aib-fullscreen */
#e2pWrap.aib-fullscreen {
    position: fixed; inset: 0; z-index: 99999;
    background: var(--clr-card, #fff);
    display: flex; flex-direction: column;
    padding: 0; margin: 0; max-width: none;
}
#e2pWrap.aib-fullscreen #e2pEditor {
    flex: 1; min-height: 0;
    border: none; border-radius: 0; overflow: hidden;
    display: flex !important; flex-direction: column;
}
#e2pWrap.aib-fullscreen .aib-editor-wrap  { flex: 1; min-height: 0; }
#e2pWrap.aib-fullscreen .aib-preview-side { position: relative; min-height: 0; overflow: hidden; }
#e2pWrap.aib-fullscreen .aib-fs-close     { display: flex; }
#e2pWrap.aib-fullscreen #e2pWrap .aib-preview-panel { flex: 1; min-height: 0; }

/* Dark mode */
[data-theme="dark"] #e2pEditor               { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] #e2pWrap .aib-preview-panel { background-color:#1e1e1e; }
[data-theme="dark"] .e2p-file-info           { background:var(--clr-surface,#1a1830); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .e2p-file-name           { color:var(--clr-heading,#e2e2f0); }
[data-theme="dark"] .e2p-toggle-list         { border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .e2p-toggle-row          { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .e2p-toggle-row:hover    { background:var(--clr-surface,#1a1830); }
[data-theme="dark"] .e2p-toggle-lbl          { color:var(--clr-text,#e2e2f0); }

/* ═══════════════════════════════════════════════════════════════════════════
   IMAGE SITEMAP GENERATOR — reuses pvsg-* and pxs-* classes entirely
   ══════════════════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════════════════
   ADD TEXT TO IMAGE
   ══════════════════════════════════════════════════════════════════════════ */

/* Editor card */
#attiEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px; overflow: hidden; background: var(--clr-card, #fff);
}

/* Canvas panel background */
#attiWrap .aib-preview-panel {
    background: #525659; padding: 16px;
    display: flex; align-items: center; justify-content: center;
    position: relative; overflow: hidden;
}

/* Canvas element */
#attiCanvas {
    max-width: 100%; max-height: 100%; width: auto; height: auto;
    display: block; flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.3); border-radius: 2px;
}

/* Canvas empty-state overlay (shown when no text boxes exist) */
.atti-canvas-hint {
    position: absolute; inset: 0; z-index: 2;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 12px; background: rgba(0,0,0,.38); pointer-events: none;
}
.atti-canvas-hint-icon { font-size: 2.4rem; color: #fff; opacity: .9; }
.atti-canvas-hint-text {
    font-size: .9rem; color: #fff; margin: 0;
    text-align: center; padding: 0 28px; line-height: 1.5;
    text-shadow: 0 1px 5px rgba(0,0,0,.5);
}

/* Labeled section divider  ─── Title ─── */
.atti-section-divider {
    display: flex; align-items: center; gap: 8px;
    font-size: .68rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: .06em; color: var(--clr-muted, #9ca3af);
    margin: 2px 0 10px;
}
.atti-section-divider::before,
.atti-section-divider::after {
    content: ''; flex: 1; height: 1px;
    background: var(--clr-border, #e5e7eb);
}

/* Textarea for text content */
.atti-textarea {
    resize: vertical; min-height: 72px;
    font-size: .88rem; line-height: 1.5;
}

/* Button group — bold/italic/alignment */
.atti-btn-group {
    display: flex; gap: 6px;
}
.atti-btn-group .btn {
    flex: 1; font-size: .85rem; padding: 6px 8px;
}
.atti-style-btn.active,
.atti-align-btn.active {
    background: var(--clr-primary, #754ffe) !important;
    border-color: var(--clr-primary, #754ffe) !important;
    color: #fff !important;
}

/* Sidebar empty-state hint (shown when texts exist but none selected) */
.atti-hint {
    display: flex; flex-direction: column; align-items: center;
    gap: 8px; padding: 20px 18px; text-align: center;
}
.atti-hint-icon  { font-size: 1.6rem; color: var(--clr-muted, #9ca3af); }
.atti-hint-text  { font-size: .8rem; color: var(--clr-muted, #9ca3af); margin: 0; line-height: 1.5; }

/* Fullscreen — mirrors #aibWrap.aib-fullscreen */
#attiWrap.aib-fullscreen {
    position: fixed; inset: 0; z-index: 99999;
    background: var(--clr-card, #fff);
    display: flex; flex-direction: column;
    padding: 0; margin: 0; max-width: none;
}
#attiWrap.aib-fullscreen #attiEditor {
    flex: 1; min-height: 0;
    border: none; border-radius: 0; overflow: hidden;
    display: flex !important; flex-direction: column;
}
#attiWrap.aib-fullscreen .aib-editor-wrap  { flex: 1; min-height: 0; }
#attiWrap.aib-fullscreen .aib-preview-side { position: relative; min-height: 0; overflow: hidden; }
#attiWrap.aib-fullscreen .aib-fs-close     { display: flex; }
#attiWrap.aib-fullscreen .aib-preview-panel { flex: 1; min-height: 0; }

/* Dark mode */
[data-theme="dark"] #attiEditor                 { background: var(--clr-card,#1d1c35); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] #attiWrap .aib-preview-panel { background: #1e1e1e; }
[data-theme="dark"] .atti-hint-icon,
[data-theme="dark"] .atti-hint-text             { color: var(--clr-muted,#6b6b8d); }

/* ═══════════════════════════════════════════════════════════════════════════
   ADSENSE CALCULATOR
   ══════════════════════════════════════════════════════════════════════════ */

/* Body padding */
.asc-body { padding: 24px; }

/* Two-column layout */
.asc-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
}
@media (min-width: 768px) {
    .asc-grid { grid-template-columns: 320px 1fr; align-items: start; }
}

/* Number input below range slider */
.asc-num-input {
    margin-top: 10px;
    font-size: .88rem;
}

/* Live value badge in label row */
.asc-badge {
    font-size: .72rem; font-weight: 700;
    padding: 2px 10px; border-radius: 20px;
    white-space: nowrap;
}
.asc-badge-blue   { background: rgba(59,130,246,.12);  color: #3b82f6; }
.asc-badge-purple { background: rgba(117,79,254,.12);  color: #754ffe; }
.asc-badge-green  { background: rgba(16,185,129,.12);  color: #10b981; }

/* Results column */
.asc-results {
    display: flex; flex-direction: column; gap: 14px;
}

/* Monthly hero */
.asc-hero {
    background: linear-gradient(135deg, #5b3fcb 0%, #754ffe 60%, #9b72ff 100%);
    border-radius: 14px;
    padding: 26px 20px;
    text-align: center;
    color: #fff;
    position: relative; overflow: hidden;
}
.asc-hero::before {
    content: '';
    position: absolute;
    width: 180px; height: 180px;
    background: rgba(255,255,255,.08);
    border-radius: 50%;
    top: -60px; right: -50px;
    pointer-events: none;
}
.asc-hero-label {
    font-size: .75rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .07em;
    opacity: .82; margin-bottom: 10px; position: relative;
}
.asc-hero-val {
    font-size: 3rem; font-weight: 800;
    line-height: 1; position: relative;
    display: flex; align-items: baseline;
    justify-content: center; gap: 3px;
}
.asc-hero-val sup { font-size: .42em; opacity: .75; vertical-align: super; }
.asc-hero-sub {
    font-size: .75rem; opacity: .7;
    margin-top: 8px; position: relative;
}

/* 3-metric row */
.asc-metrics {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
}
.asc-metric {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    padding: 16px 10px;
    text-align: center;
}
.asc-metric-icon {
    width: 36px; height: 36px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: .88rem;
    margin: 0 auto 10px;
}
.asc-metric-blue  .asc-metric-icon { background: rgba(59,130,246,.12);  color: #3b82f6; }
.asc-metric-green .asc-metric-icon { background: rgba(16,185,129,.12);  color: #10b981; }
.asc-metric-amber .asc-metric-icon { background: rgba(245,158,11,.12);  color: #f59e0b; }
.asc-metric-val {
    font-size: 1.05rem; font-weight: 700;
    color: var(--clr-heading, #111);
    margin-bottom: 4px;
    word-break: break-all;
}
.asc-metric-lbl {
    font-size: .68rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .06em;
    color: var(--clr-muted, #9ca3af);
}

/* Formula breakdown */
.asc-formula {
    background: var(--clr-surface, #f8f7ff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    padding: 14px 16px;
}
.asc-formula-title {
    font-size: .68rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .06em;
    color: var(--clr-muted, #9ca3af);
    margin-bottom: 6px;
}
.asc-formula-eq {
    font-size: .82rem;
    color: var(--clr-text, #374151);
    line-height: 1.7;
    font-family: 'Courier New', monospace;
}
.asc-formula-eq strong { color: var(--clr-primary, #754ffe); }

/* Disclaimer */
.asc-disclaimer {
    font-size: .76rem;
    color: var(--clr-muted, #9ca3af);
    text-align: center;
    margin: 0; line-height: 1.5;
}

/* Dark mode */
[data-theme="dark"] .asc-metric                { background: var(--clr-card,#1d1c35); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .asc-formula               { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .asc-formula-eq            { color: var(--clr-text,#c4c4d4); }

/* ============================================================
   TXT to PDF  (#t2pWrap)
   ============================================================ */
#t2pCard {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    background: var(--clr-card, #fff);
    overflow: hidden;
    display: flex;
}

/* Preview panel — hidden by default, shown in fullscreen */
.t2p-preview-panel {
    display: none;
    position: relative;
    background: #1e1e2e;
    flex: 1;
    min-width: 0;
    align-items: center;
    justify-content: center;
}
.t2p-preview-ph {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    position: absolute;
    inset: 0;
    pointer-events: none;
}
.t2p-ph-icon  { font-size: 3.5rem; color: rgba(255,255,255,.2); line-height: 1; }
.t2p-ph-text  { font-size: .85rem; color: rgba(255,255,255,.3); margin: 0; text-align: center; }
.t2p-iframe   { display: none; position: absolute; inset: 0; width: 100%; height: 100%; border: none; }

/* Controls column */
.t2p-controls {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-width: 0;
}

/* Fullscreen */
#t2pWrap.t2p-fullscreen {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: var(--clr-card, #fff);
}
#t2pWrap.t2p-fullscreen #t2pCard {
    border-radius: 0;
    border: none;
    height: 100%;
    flex-direction: row;
}
#t2pWrap.t2p-fullscreen .t2p-preview-panel {
    display: flex;
    flex: 1;
}
#t2pWrap.t2p-fullscreen .t2p-controls {
    width: 360px;
    flex: none;
    overflow-y: auto;
    border-left: 1px solid var(--clr-border, #e5e7eb);
}
#t2pWrap.t2p-fullscreen .t2p-textarea { min-height: 160px; resize: none; }

/* Override settings grid for narrow sidebar in fullscreen */
#t2pWrap.t2p-fullscreen .t2p-settings {
    grid-template-columns: 1fr 1fr;
}
#t2pWrap.t2p-fullscreen .t2p-setting {
    border-right: none;
    margin-right: 0;
    padding-right: 0;
}
#t2pWrap.t2p-fullscreen .t2p-setting:nth-child(odd) {
    border-right: 1px solid var(--clr-border, #e5e7eb);
    margin-right: 16px;
    padding-right: 16px;
}
#t2pWrap.t2p-fullscreen .t2p-setting--slider {
    grid-column: span 2;
    border-right: none;
    margin-right: 0;
    padding-right: 0;
}

/* Fullscreen button */
.t2p-fs-btn {
    font-size: .9rem;
    padding: 8px 10px;
    border-radius: 8px;
    border: 1px solid var(--clr-border, #e5e7eb);
    background: transparent;
    color: var(--clr-text, #374151);
    cursor: pointer;
    transition: background .15s, border-color .15s;
    line-height: 1;
}
.t2p-fs-btn:hover { background: var(--clr-surface, #f8f7ff); border-color: #9ca3af; }

/* Textarea */
.t2p-textarea-wrap { padding: 20px 20px 0; }
.t2p-textarea {
    display: block;
    width: 100%;
    min-height: 200px;
    resize: vertical;
    padding: 14px 16px;
    font-family: 'Courier New', monospace;
    font-size: .875rem;
    line-height: 1.65;
    color: var(--clr-text, #374151);
    background: var(--clr-surface, #f8f7ff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    outline: none;
    transition: border-color .15s;
}
.t2p-textarea:focus { border-color: var(--clr-primary, #754ffe); }
.t2p-textarea::placeholder { color: var(--clr-muted, #9ca3af); }

/* Settings grid */
.t2p-settings {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    padding: 4px 20px 0;
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
}
@media (min-width: 700px) {
    .t2p-settings { grid-template-columns: auto auto 1fr 1fr; }
}

.t2p-setting {
    padding: 16px 16px 16px 0;
    border-right: 1px solid var(--clr-border, #e5e7eb);
    margin-right: 16px;
}
.t2p-setting:last-child {
    border-right: none;
    margin-right: 0;
}
@media (max-width: 699px) {
    .t2p-setting:nth-child(odd)  { border-right: 1px solid var(--clr-border,#e5e7eb); }
    .t2p-setting:nth-child(even) { border-right: none; margin-right: 0; padding-left: 16px; padding-right: 0; }
    .t2p-setting--slider         { grid-column: span 2; border-right: none; margin-right: 0; }
}

.t2p-label {
    display: block;
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--clr-muted, #9ca3af);
    margin-bottom: 8px;
    white-space: nowrap;
}
.t2p-label-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 8px;
}
.t2p-label-row .t2p-label { margin-bottom: 0; }
.t2p-val {
    font-size: .72rem;
    font-weight: 700;
    color: var(--clr-primary, #754ffe);
    background: rgba(117,79,254,.1);
    padding: 1px 8px;
    border-radius: 20px;
}

/* Select */
.t2p-select {
    font-size: .82rem;
    padding: 6px 10px;
    border-radius: 8px;
    border: 1px solid var(--clr-border, #e5e7eb);
    background: var(--clr-surface, #f8f7ff);
    color: var(--clr-text, #374151);
    min-width: 120px;
    outline: none;
    cursor: pointer;
    transition: border-color .15s;
}
.t2p-select:focus { border-color: var(--clr-primary, #754ffe); }

/* Range slider */
.t2p-range { width: 100%; min-width: 120px; }
.t2p-ticks {
    display: flex;
    justify-content: space-between;
    font-size: .65rem;
    color: var(--clr-muted, #9ca3af);
    margin-top: 2px;
}

/* Footer */
.t2p-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 16px 20px;
    flex-wrap: wrap;
}
.t2p-footer-right { display: flex; gap: 8px; align-items: center; }

.t2p-upload-btn,
.t2p-clear-btn {
    font-size: .82rem;
    font-weight: 600;
    padding: 8px 16px;
    border-radius: 8px;
    border: 1px solid var(--clr-border, #e5e7eb);
    background: transparent;
    color: var(--clr-text, #374151);
    cursor: pointer;
    transition: background .15s, border-color .15s;
}
.t2p-upload-btn:hover,
.t2p-clear-btn:hover { background: var(--clr-surface, #f8f7ff); border-color: #9ca3af;    color: black; }

.t2p-download-btn {
    font-size: .9rem;
    font-weight: 700;
    padding: 9px 24px;
    border-radius: 10px;
    border: none;
    background: var(--clr-primary, #754ffe);
    color: #fff;
    cursor: pointer;
    transition: opacity .15s, transform .1s;
}
.t2p-download-btn:hover:not(:disabled)   { opacity: .88; }
.t2p-download-btn:active:not(:disabled)  { transform: scale(.97); }
.t2p-download-btn:disabled               { opacity: .45; cursor: not-allowed; }

/* Dark mode */
[data-theme="dark"] #t2pCard              { background: var(--clr-card,#1d1c35); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .t2p-preview-panel    { background: #0f0f1e; }
[data-theme="dark"] #t2pWrap.t2p-fullscreen .t2p-controls { border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .t2p-fs-btn           { border-color: var(--clr-border,#2d2b4e); color: var(--clr-text,#c4c4d4); }
[data-theme="dark"] .t2p-textarea         { background: var(--clr-surface,#16152e); color: var(--clr-text,#c4c4d4); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .t2p-setting          { border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .t2p-settings         { border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .t2p-select           { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); color: var(--clr-text,#c4c4d4); }
[data-theme="dark"] .t2p-upload-btn,
[data-theme="dark"] .t2p-clear-btn        { border-color: var(--clr-border,#2d2b4e); color: var(--clr-text,#c4c4d4); }
[data-theme="dark"] .t2p-upload-btn:hover,
[data-theme="dark"] .t2p-clear-btn:hover  { background: var(--clr-surface,#16152e); border-color: #6b7280; }

/* ============================================================
   Viewport Checker  (#pxVcWrap)
   ============================================================ */

/* Status hero */
.pxvc-hero {
    display: flex;
    align-items: center;
    gap: 18px;
    padding: 20px 22px;
    border-radius: 12px;
    margin-bottom: 16px;
    border: 1px solid transparent;
}
.pxvc-hero--good    { background: #f0fdf4; border-color: #bbf7d0; }
.pxvc-hero--bad     { background: #fffbeb; border-color: #fde68a; }
.pxvc-hero--missing { background: #fef2f2; border-color: #fecaca; }
.pxvc-hero--error   { background: #fef2f2; border-color: #fecaca; }

.pxvc-hero-icon             { font-size: 2.4rem; line-height: 1; flex-shrink: 0; }
.pxvc-hero--good    .pxvc-hero-icon { color: #16a34a; }
.pxvc-hero--bad     .pxvc-hero-icon { color: #d97706; }
.pxvc-hero--missing .pxvc-hero-icon { color: #dc2626; }
.pxvc-hero--error   .pxvc-hero-icon { color: #dc2626; }

.pxvc-hero-title { font-size: 1.05rem; font-weight: 700; color: var(--clr-heading,#111827); margin-bottom: 4px; }
.pxvc-hero-desc  { font-size: .84rem; color: var(--clr-muted,#6b7280); line-height: 1.5; }

/* Detail rows */
.pxvc-details {
    background: var(--clr-surface, #f8f7ff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    padding: 4px 20px;
    margin-bottom: 16px;
}
.pxvc-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 12px 0;
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
    gap: 20px;
}
.pxvc-row:last-child  { border-bottom: none; }
.pxvc-row-label {
    font-size: .78rem;
    font-weight: 600;
    color: var(--clr-muted, #6b7280);
    white-space: nowrap;
    flex-shrink: 0;
}
.pxvc-row-val {
    font-size: .82rem;
    color: var(--clr-text, #374151);
    word-break: break-all;
    text-align: right;
}

/* Issues */
.pxvc-issues-wrap {
    background: #fffbeb;
    border: 1px solid #fde68a;
    border-radius: 12px;
    padding: 14px 18px;
    margin-bottom: 16px;
}
.pxvc-issues-head {
    font-size: .8rem;
    font-weight: 700;
    color: #92400e;
    margin-bottom: 10px;
}
.pxvc-issues-list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.pxvc-issues-list li {
    font-size: .82rem;
    color: #78350f;
    padding: 5px 0 5px 20px;
    border-bottom: 1px solid #fde68a;
    position: relative;
    line-height: 1.5;
}
.pxvc-issues-list li:last-child { border-bottom: none; }
.pxvc-issues-list li::before    { content: '⚠'; position: absolute; left: 0; font-size: .72rem; top: 6px; }

/* Tip */
.pxvc-tip {
    font-size: .82rem;
    color: var(--clr-muted, #6b7280);
    background: var(--clr-surface, #f8f7ff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    padding: 12px 16px;
    line-height: 1.6;
}

/* Dark mode */
[data-theme="dark"] .pxvc-hero--good    { background: rgba(22,163,74,.1);  border-color: rgba(22,163,74,.3); }
[data-theme="dark"] .pxvc-hero--bad     { background: rgba(217,119,6,.1); border-color: rgba(217,119,6,.3); }
[data-theme="dark"] .pxvc-hero--missing { background: rgba(220,38,38,.1);  border-color: rgba(220,38,38,.3); }
[data-theme="dark"] .pxvc-hero--error   { background: rgba(220,38,38,.1);  border-color: rgba(220,38,38,.3); }
[data-theme="dark"] .pxvc-details       { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .pxvc-row           { border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .pxvc-issues-wrap   { background: rgba(217,119,6,.08); border-color: rgba(217,119,6,.3); }
[data-theme="dark"] .pxvc-issues-head   { color: #fcd34d; }
[data-theme="dark"] .pxvc-issues-list li { color: #fde68a; border-color: rgba(217,119,6,.25); }
[data-theme="dark"] .pxvc-tip           { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); }

/* ============================================================
   Meta Tags Analyzer  (#pxMtaWrap)
   ============================================================ */

/* Shared card */
.mta-card-head {
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--clr-muted, #6b7280);
    padding: 12px 18px;
    background: var(--clr-surface, #f8f7ff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px 10px 0 0;
    border-bottom: none;
}

/* Section wrapper */
.mta-section { margin-bottom: 16px; }
.mta-section .pxvc-details {
    border-radius: 0 0 10px 10px;
    margin-bottom: 0;
}

/* Previews grid */
.mta-previews {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
    margin-bottom: 16px;
}
@media (min-width: 680px) {
    .mta-previews { grid-template-columns: 1fr 1fr; }
}

.mta-card {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    overflow: hidden;
}
.mta-card .mta-card-head {
    border-radius: 0;
    border: none;
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
}

/* Google preview */
.mta-google {
    padding: 16px 18px;
    background: var(--clr-card, #fff);
}
.mta-g-url   { font-size: .75rem; color: #3c4043; margin-bottom: 3px; }
.mta-g-title { font-size: 1rem; font-weight: 400; color: #1a0dab; margin-bottom: 4px; line-height: 1.3; max-width: 480px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mta-g-desc  { font-size: .82rem; color: #4d5156; line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

/* OG / Facebook preview */
.mta-og-card { background: var(--clr-card, #fff); }
.mta-og-img  { width: 100%; max-height: 160px; object-fit: cover; display: block; }
.mta-og-body { padding: 12px 14px; background: var(--clr-surface, #f0f2f5); }
.mta-og-site  { font-size: .68rem; text-transform: uppercase; color: var(--clr-muted,#6b7280); margin-bottom: 3px; letter-spacing: .04em; }
.mta-og-title { font-size: .9rem; font-weight: 700; color: var(--clr-heading,#111827); margin-bottom: 3px; line-height: 1.3; }
.mta-og-desc  { font-size: .78rem; color: var(--clr-muted,#6b7280); line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

/* Char-count badge */
.mta-badge {
    display: inline-block;
    font-size: .65rem;
    font-weight: 700;
    padding: 1px 7px;
    border-radius: 20px;
    background: rgba(117,79,254,.1);
    color: var(--clr-primary, #754ffe);
    margin-left: 8px;
    vertical-align: middle;
    white-space: nowrap;
}

/* Dark mode */
[data-theme="dark"] .mta-card           { border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .mta-card-head      { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .mta-google         { background: var(--clr-card,#1d1c35); }
[data-theme="dark"] .mta-g-url          { color: #9ca3af; }
[data-theme="dark"] .mta-g-title        { color: #93c5fd; }
[data-theme="dark"] .mta-g-desc         { color: #9ca3af; }
[data-theme="dark"] .mta-og-card        { background: var(--clr-card,#1d1c35); }
[data-theme="dark"] .mta-og-body        { background: var(--clr-surface,#16152e); }

/* ============================================================
   META TAG GENERATOR  (#mtgWrap)
   ============================================================ */

/* ── Outer card ── */
.mtg-card-wrap {
    border: 1px solid var(--clr-border, #e5e7eb) !important;
    border-radius: 16px !important;
    overflow: hidden;
    min-height: 520px;
}
.mtg-card-wrap > .row { min-height: 520px; }

/* ── Form column ── */
.mtg-form-col {
    display: flex;
    flex-direction: column;
    border-right: 1px solid var(--clr-border, #e5e7eb);
}
.mtg-panes-wrap {
    flex: 1;
    overflow-y: auto;
}
.mtg-pane { min-height: 0; }

/* ── Nav pills (form tabs) ── */
#mtgWrap .nav-pills .mtg-nav-btn {
    font-size: .78rem;
    font-weight: 600;
    color: var(--clr-muted, #9ca3af);
    border-radius: 8px;
    padding: .45rem .5rem;
    border: none;
    background: transparent;
    transition: background .15s, color .15s;
}
#mtgWrap .nav-pills .mtg-nav-btn:hover:not(.active) {
    background: rgba(117,79,254,.08);
    color: var(--clr-primary, #754ffe);
}
#mtgWrap .nav-pills .mtg-nav-btn.active {
    background: var(--clr-primary, #754ffe);
    color: #fff;
}

/* ── Char counter ── */
.mtg-ctr       { font-size: .7rem; font-weight: 600; color: var(--clr-muted, #9ca3af); white-space: nowrap; }
.mtg-ctr.good  { color: #16a34a; }
.mtg-ctr.warn  { color: #d97706; }
.mtg-ctr.bad   { color: #dc2626; }

/* ── btn-check active = purple ── */
#mtgWrap .btn-check:checked + .btn-outline-secondary {
    background-color: var(--clr-primary, #754ffe);
    border-color:     var(--clr-primary, #754ffe);
    color: #fff;
}
#mtgWrap .btn-outline-secondary:hover {
    background-color: rgba(117,79,254,.08);
    border-color:     var(--clr-primary, #754ffe);
    color:            var(--clr-primary, #754ffe);
}

/* ── Output column ── */
.mtg-out-col {
    background: #13111f;
    display: flex;
    flex-direction: column;
}
.mtg-out-head {
    border-bottom: 1px solid rgba(255,255,255,.08) !important;
    background: rgba(255,255,255,.03);
    flex-shrink: 0;
}
.mtg-out-body {
    flex: 1;
    overflow-y: auto;
    padding: 18px 20px;
}

/* Output tabs */
.mtg-out-tab {
    font-size: .74rem;
    font-weight: 600;
    padding: 5px 12px;
    border-radius: 7px;
    border: 1px solid rgba(255,255,255,.15);
    background: transparent;
    color: rgba(255,255,255,.5);
    cursor: pointer;
    transition: all .15s;
}
.mtg-out-tab:hover  { color: #fff; border-color: rgba(255,255,255,.3); background: rgba(255,255,255,.06); }
.mtg-out-tab.active { background: var(--clr-primary, #754ffe); border-color: var(--clr-primary, #754ffe); color: #fff; }

/* Copy button */
.mtg-copy-btn {
    font-size: .75rem;
    font-weight: 700;
    padding: 5px 14px;
    border-radius: 7px;
    border: 1px solid rgba(255,255,255,.2);
    background: rgba(255,255,255,.06);
    color: rgba(255,255,255,.8);
    cursor: pointer;
    transition: all .15s;
}
.mtg-copy-btn:hover { background: rgba(255,255,255,.12); color: #fff; border-color: rgba(255,255,255,.35); }

/* ── Code output ── */
.mtg-pre {
    margin: 0;
    font-family: 'JetBrains Mono','Fira Code','Cascadia Code',monospace;
    font-size: .8rem;
    line-height: 1.75;
    color: #cdd6f4;
    white-space: pre-wrap;
    word-break: break-all;
    background: transparent;
    border: none;
    padding: 0;
}
.mtg-tag     { color: #89b4fa; }
.mtg-attr    { color: #a6e3a1; }
.mtg-str     { color: #f9e2af; }
.mtg-comment { color: #6c7086; font-style: italic; }
.mtg-empty   { color: #6c7086; font-style: italic; }

/* ── Google preview ── */
.mtg-google-card {
    background: #fff;
    border: 1px solid #e5e7eb;
}
.mtg-g-url   { font-size: .78rem; color: #666; margin-bottom: 3px; }
.mtg-g-title { font-size: 1.05rem; font-weight: 500; color: #1a0dab; margin-bottom: 4px;
               white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mtg-g-desc  { font-size: .84rem; color: #555; line-height: 1.5;
               display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

/* ── Social / OG preview ── */
.mtg-og-card { background: #fff; border: 1px solid #e5e7eb; }
.mtg-og-img  { aspect-ratio: 1.91 / 1; background: #e5e7eb; overflow: hidden; }
.mtg-og-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mtg-og-ph   { display: flex; align-items: center; justify-content: center;
               width: 100%; height: 100%; color: #9ca3af; font-size: 2.5rem; }
.mtg-og-site  { font-size: .68rem; font-weight: 700; letter-spacing: .05em; color: #888;
                text-transform: uppercase; margin-bottom: 3px; }
.mtg-og-title { font-size: .95rem; font-weight: 700; color: #111; margin-bottom: 3px; line-height: 1.3; }
.mtg-og-desc  { font-size: .8rem; color: #555; line-height: 1.5;
                display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

.mtg-out-note { font-size: .72rem; color: rgba(255,255,255,.4); margin: 0; }

/* ── Mobile ── */
@media (max-width: 991px) {
    .mtg-form-col { border-right: none; border-bottom: 1px solid var(--clr-border, #e5e7eb); }
    .mtg-out-col  { min-height: 380px; }
    .mtg-card-wrap > .row { min-height: 0; }
}

/* ── Dark mode (form side only — output is always dark) ── */
[data-theme="dark"] .mtg-card-wrap  { border-color: var(--clr-border, #2d2b4e) !important; }
[data-theme="dark"] .mtg-form-col   { border-color: var(--clr-border, #2d2b4e); background: var(--clr-card, #1d1c35); }
[data-theme="dark"] #mtgWrap .nav-pills { background: var(--clr-surface, #16152e) !important; }
[data-theme="dark"] #mtgWrap .form-label,
[data-theme="dark"] #mtgWrap .fw-semibold { color: var(--clr-heading, #e0deff); }
[data-theme="dark"] #mtgWrap .form-text   { color: var(--clr-muted, #9ca3af); }
[data-theme="dark"] .mtg-google-card { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .mtg-g-title     { color: #93c5fd; }
[data-theme="dark"] .mtg-g-url,
[data-theme="dark"] .mtg-g-desc      { color: #9ca3af; }
[data-theme="dark"] .mtg-og-card     { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .mtg-og-img      { background: #2d2b4e; }
[data-theme="dark"] .mtg-og-body     { background: var(--clr-card, #1d1c35); }
[data-theme="dark"] .mtg-og-title    { color: #e0deff; }
[data-theme="dark"] .mtg-og-site,
[data-theme="dark"] .mtg-og-desc     { color: #9ca3af; }

/* ============================================================
   REDIRECT CHAIN CHECKER  (#rccWrap)
   ============================================================ */

/* Summary bar */
.rcc-summary {
    display: flex;
    align-items: center;
    padding: 12px 16px;
    border-radius: 10px;
    font-size: .92rem;
    font-weight: 600;
    margin-bottom: 14px;
    border: 1px solid transparent;
}
.rcc-summary--ok    { background: #f0fdf4; border-color: #bbf7d0; color: #15803d; }
.rcc-summary--info  { background: #eff6ff; border-color: #bfdbfe; color: #1d4ed8; }
.rcc-summary--error { background: #fef2f2; border-color: #fecaca; color: #b91c1c; }

/* Warning alert (reuses .pxt-alert base) */
.rcc-alert-warn {
    background: #fffbeb;
    border: 1px solid #fde68a;
    color: #92400e;
}

/* Chain container */
.rcc-chain { padding-top: 4px; }

/* Hop row */
.rcc-hop {
    display: flex;
    gap: 14px;
    align-items: stretch;
}

/* Left column — number + connector */
.rcc-left {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex-shrink: 0;
    width: 32px;
}

.rcc-num {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    font-size: .78rem;
    font-weight: 700;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.rcc-num--redir  { background: var(--clr-primary, #754ffe); }
.rcc-num--ok     { background: #16a34a; }
.rcc-num--final  { background: #16a34a; }

.rcc-connector {
    flex: 1;
    width: 2px;
    background: var(--clr-border, #e5e7eb);
    margin: 4px 0;
    min-height: 20px;
}

/* Hop card */
.rcc-card {
    flex: 1;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    background: var(--clr-card, #fff);
    padding: 12px 14px;
    margin-bottom: 8px;
    min-width: 0;
}
.rcc-card--final {
    border-color: #bbf7d0;
    background: #f0fdf4;
}

.rcc-url {
    font-size: .84rem;
    word-break: break-all;
    color: var(--clr-text, #374151);
    margin-bottom: 8px;
    font-weight: 500;
}

.rcc-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
}

/* Status badges */
.rcc-badge {
    font-size: .7rem;
    font-weight: 700;
    padding: 2px 9px;
    border-radius: 20px;
    white-space: nowrap;
}
.rcc-badge--ok     { background: #dcfce7; color: #15803d; }
.rcc-badge--redir  { background: #fef9c3; color: #854d0e; }
.rcc-badge--err    { background: #fee2e2; color: #b91c1c; }
.rcc-badge--server { background: #f1f5f9; color: #475569; }
.rcc-badge--final  { background: #dcfce7; color: #15803d; }

/* Open link */
.rcc-open-btn {
    font-size: .75rem;
    font-weight: 600;
    color: var(--clr-muted, #6b7280);
    text-decoration: none;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 6px;
    padding: 2px 8px;
    transition: color .15s, border-color .15s;
}
.rcc-open-btn:hover { color: var(--clr-primary, #754ffe); border-color: var(--clr-primary, #754ffe); }

/* Dark mode */
[data-theme="dark"] .rcc-summary--ok    { background: rgba(22,163,74,.12);  border-color: rgba(134,239,172,.3); color: #86efac; }
[data-theme="dark"] .rcc-summary--info  { background: rgba(29,78,216,.12);  border-color: rgba(147,197,253,.3); color: #93c5fd; }
[data-theme="dark"] .rcc-summary--error { background: rgba(239,68,68,.12);  border-color: rgba(252,165,165,.3); color: #fca5a5; }
[data-theme="dark"] .rcc-alert-warn     { background: rgba(251,191,36,.08); border-color: rgba(253,230,138,.3); color: #fde68a; }
[data-theme="dark"] .rcc-connector      { background: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .rcc-card           { border-color: var(--clr-border, #2d2b4e); background: var(--clr-card, #1d1c35); }
[data-theme="dark"] .rcc-card--final    { border-color: rgba(134,239,172,.3); background: rgba(22,163,74,.08); }
[data-theme="dark"] .rcc-url            { color: var(--clr-text, #e2e2f0); }
[data-theme="dark"] .rcc-badge--ok      { background: rgba(22,163,74,.15);  color: #86efac; }
[data-theme="dark"] .rcc-badge--redir   { background: rgba(251,191,36,.15); color: #fde68a; }
[data-theme="dark"] .rcc-badge--err     { background: rgba(239,68,68,.15);  color: #fca5a5; }
[data-theme="dark"] .rcc-badge--server  { background: rgba(71,85,105,.25);  color: #94a3b8; }
[data-theme="dark"] .rcc-badge--final   { background: rgba(22,163,74,.15);  color: #86efac; }
[data-theme="dark"] .rcc-open-btn       { border-color: var(--clr-border, #2d2b4e); color: var(--clr-muted, #9ca3af); }

/* ═══════════════════════════════════════════════════
   Google Review Calculator  (#grcWrap)
═══════════════════════════════════════════════════ */

/* Live star preview (below inputs) */
.grc-live-stars { font-size: 1.1rem; line-height: 1; min-height: 20px; }

/* Star tokens */
.grc-star            { font-size: inherit; }
.grc-star--full      { color: #f59e0b; }
.grc-star--empty     { color: var(--clr-border, #d1d5db); }

/* Already-at-target card */
.grc-already-card {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: 12px;
    padding: 20px 22px;
}
.grc-already-icon { font-size: 1.8rem; color: #16a34a; flex-shrink: 0; margin-top: 2px; }
.grc-already-msg  { font-size: 1rem; font-weight: 600; color: #15803d; margin: 0; }

/* Hero number card */
.grc-hero {
    background: var(--clr-surface, #f8f9fa);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 14px;
    padding: 28px 20px;
    text-align: center;
}
.grc-hero-num {
    font-size: 3.8rem;
    font-weight: 800;
    line-height: 1;
    color: var(--clr-primary, #754ffe);
}
.grc-hero-sub {
    font-size: .85rem;
    color: var(--clr-muted, #6b7280);
    margin-top: 6px;
}
.grc-hero-stars  { font-size: 1.5rem; margin-top: 10px; line-height: 1; }
.grc-hero-rating { font-size: .9rem; font-weight: 700; color: var(--clr-heading, #1a1a2e); margin-top: 4px; }

/* Before / After comparison cards */
.grc-cmp-card {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    padding: 16px 14px;
    text-align: center;
    height: 100%;
}
.grc-cmp-card--after { border-color: rgba(117,79,254,.35); background: rgba(117,79,254,.04); }
.grc-cmp-label    { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--clr-muted, #6b7280); margin-bottom: 6px; }
.grc-cmp-score    { font-size: 1.4rem; font-weight: 800; color: var(--clr-heading, #1a1a2e); line-height: 1; }
.grc-cmp-card--after .grc-cmp-score { color: var(--clr-primary, #754ffe); }
.grc-cmp-stars    { font-size: 1rem; margin: 6px 0 4px; line-height: 1; }
.grc-cmp-count    { font-size: .78rem; color: var(--clr-muted, #6b7280); }

/* Dark mode */
[data-theme="dark"] .grc-already-card        { background: rgba(22,163,74,.08); border-color: rgba(134,239,172,.25); }
[data-theme="dark"] .grc-already-icon        { color: #86efac; }
[data-theme="dark"] .grc-already-msg         { color: #86efac; }
[data-theme="dark"] .grc-hero                { background: var(--clr-surface, #1e1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .grc-hero-rating         { color: var(--clr-heading, #e0deff); }
[data-theme="dark"] .grc-cmp-card            { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .grc-cmp-card--after     { background: rgba(117,79,254,.08); border-color: rgba(117,79,254,.35); }
[data-theme="dark"] .grc-cmp-score           { color: var(--clr-heading, #e0deff); }
[data-theme="dark"] .grc-star--empty         { color: var(--clr-border, #3d3b5e); }

/* ═══════════════════════════════════════════════════
   Unlock PDF  (#ulpdfWrap)
   Reuses: aib-upload-zone/icon-wrap/title/sub/privacy,
           aib-editor-wrap, aib-preview-side, aib-sidebar,
           aib-sidebar-head/title/actions, aib-form-group/label
═══════════════════════════════════════════════════ */

#ulpdfEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}

/* File info panel (replaces aib-preview-panel) */
.ulpdf-file-panel {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 32px 24px;
    background: var(--clr-surface, #f8f9fa);
    text-align: center;
    min-height: 320px;
}

.ulpdf-file-icon {
    font-size: 5rem;
    color: #dc3545;
    margin-bottom: 14px;
    transition: color .4s;
    line-height: 1;
}

.ulpdf-file-name {
    font-size: 1rem;
    font-weight: 600;
    color: var(--clr-heading, #1e1b4b);
    word-break: break-all;
    max-width: 90%;
    margin-bottom: 4px;
}

.ulpdf-file-size {
    font-size: .82rem;
    color: var(--clr-muted, #6b7280);
    margin-bottom: 14px;
}

.ulpdf-status {
    display: inline-flex;
    align-items: center;
    background: #fef9c3;
    color: #854d0e;
    padding: 5px 16px;
    border-radius: 20px;
    font-size: .82rem;
    font-weight: 600;
    transition: background .35s, color .35s;
}

.ulpdf-status--unlocked {
    background: #dcfce7;
    color: #15803d;
}

/* Sidebar scroll body */
.ulpdf-sidebar-body {
    flex: 1;
    overflow-y: auto;
}

/* Loader overlay */
#ulpdfLoader {
    background: rgba(255, 255, 255, .92);
    backdrop-filter: blur(4px);
}

/* Responsive — stack below md */
@media (max-width: 767px) {
    #ulpdfWrap .aib-editor-wrap  { flex-direction: column; min-height: 0; }
    #ulpdfWrap .aib-preview-side { border-right: none; border-bottom: 1px solid var(--clr-border, #e5e7eb); }
    #ulpdfWrap .aib-sidebar      { width: 100%; }
}

/* Dark mode */
[data-theme="dark"] #ulpdfEditor          { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .ulpdf-file-panel     { background: var(--clr-surface, #16152e); }
[data-theme="dark"] .ulpdf-file-name      { color: var(--clr-heading, #e0deff); }
[data-theme="dark"] .ulpdf-status         { background: rgba(251,191,36,.12); color: #fde68a; }
[data-theme="dark"] .ulpdf-status--unlocked { background: rgba(22,163,74,.12); color: #86efac; }
[data-theme="dark"] #ulpdfLoader          { background: rgba(14,13,30,.92); }

/* ═══════════════════════════════════════════════════
   Protect PDF  (#ppdfWrap)
   Reuses ALL aib-* and ulpdf-* classes.
   Only status badge colour modifiers are new.
═══════════════════════════════════════════════════ */

/* Editor wrapper — same pattern as #ulpdfEditor */
#ppdfEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}

/* Loader overlay */
#ppdfLoader {
    background: rgba(255, 255, 255, .92);
    backdrop-filter: blur(4px);
}

/* Status badge colour variants */
.ppdf-status--open   { background: #dcfce7; color: #15803d; }
.ppdf-status--locked { background: rgba(117,79,254,.1); color: var(--clr-primary, #754ffe); }

/* Responsive stack (mirrors unlock-pdf breakpoint) */
@media (max-width: 767px) {
    #ppdfWrap .aib-editor-wrap  { flex-direction: column; min-height: 0; }
    #ppdfWrap .aib-preview-side { border-right: none; border-bottom: 1px solid var(--clr-border, #e5e7eb); }
    #ppdfWrap .aib-sidebar      { width: 100%; }
}

/* Dark mode */
[data-theme="dark"] #ppdfEditor          { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] #ppdfLoader          { background: rgba(14,13,30,.92); }
[data-theme="dark"] .ppdf-status--open   { background: rgba(22,163,74,.12);  color: #86efac; }
[data-theme="dark"] .ppdf-status--locked { background: rgba(117,79,254,.15); color: #c4b5fd; }

/* ═══════════════════════════════════════════════════
   Website Page Size Checker  (#wpscWrap)
   Reuses: pxt-input-area, pxt-alert, pxvc-details/row,
           pxs-actions, pxt-spinner
═══════════════════════════════════════════════════ */

.wpsc-status-card {
    border-radius: 14px;
    padding: 28px 20px;
    text-align: center;
    border: 1px solid;
}
.wpsc-status--good { background: #f0fdf4; border-color: #bbf7d0; }
.wpsc-status--warn { background: #fefce8; border-color: #fde68a; }
.wpsc-status--bad  { background: #fef2f2; border-color: #fecaca; }

.wpsc-status-icon { font-size: 2.8rem; display: block; margin-bottom: 10px; }
.wpsc-status--good .wpsc-status-icon { color: #16a34a; }
.wpsc-status--warn .wpsc-status-icon { color: #d97706; }
.wpsc-status--bad  .wpsc-status-icon { color: #dc2626; }

.wpsc-status-title { font-size: 1.2rem; font-weight: 700; margin-bottom: 6px; }
.wpsc-status--good .wpsc-status-title { color: #15803d; }
.wpsc-status--warn .wpsc-status-title { color: #92400e; }
.wpsc-status--bad  .wpsc-status-title { color: #b91c1c; }

.wpsc-status-desc { font-size: .875rem; opacity: .85; }
.wpsc-status--good .wpsc-status-desc { color: #166534; }
.wpsc-status--warn .wpsc-status-desc { color: #78350f; }
.wpsc-status--bad  .wpsc-status-desc { color: #991b1b; }

/* Dark mode */
[data-theme="dark"] .wpsc-status--good { background: rgba(22,163,74,.08);  border-color: rgba(134,239,172,.25); }
[data-theme="dark"] .wpsc-status--warn { background: rgba(217,119,6,.08);   border-color: rgba(253,230,138,.25); }
[data-theme="dark"] .wpsc-status--bad  { background: rgba(220,38,38,.08);   border-color: rgba(252,165,165,.25); }
[data-theme="dark"] .wpsc-status--good .wpsc-status-title { color: #86efac; }
[data-theme="dark"] .wpsc-status--warn .wpsc-status-title { color: #fde68a; }
[data-theme="dark"] .wpsc-status--bad  .wpsc-status-title { color: #fca5a5; }
[data-theme="dark"] .wpsc-status--good .wpsc-status-desc  { color: #86efac; opacity: .8; }
[data-theme="dark"] .wpsc-status--warn .wpsc-status-desc  { color: #fde68a; opacity: .8; }
[data-theme="dark"] .wpsc-status--bad  .wpsc-status-desc  { color: #fca5a5; opacity: .8; }
[data-theme="dark"] .wpsc-status--good .wpsc-status-icon  { color: #86efac; }
[data-theme="dark"] .wpsc-status--warn .wpsc-status-icon  { color: #fde68a; }
[data-theme="dark"] .wpsc-status--bad  .wpsc-status-icon  { color: #fca5a5; }

/* ═══════════════════════════════════════════════════
   Case Converter  (#ccWrap)
   Reuses: pxt-input-area, lf-form-card, form-control,
           pxs-action btn classes (Bootstrap)
═══════════════════════════════════════════════════ */

/* Stats bar */
.cc-stats {
    display: flex;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    overflow: hidden;
}
.cc-stat {
    flex: 1;
    text-align: center;
    padding: 10px 6px;
    border-right: 1px solid var(--clr-border, #e5e7eb);
}
.cc-stat:last-child { border-right: none; }
.cc-stat-val {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--clr-primary, #754ffe);
    line-height: 1.2;
}
.cc-stat-lbl {
    font-size: .6rem;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--clr-muted, #6b7280);
    margin-top: 2px;
}

/* Case conversion buttons */
.cc-case-btn {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 7px 13px;
    border-radius: 8px;
    border: 1.5px solid var(--clr-border, #e5e7eb);
    background: var(--clr-card, #fff);
    font-weight: 600;
    font-size: .78rem;
    cursor: pointer;
    color: var(--clr-text, #495057);
    transition: border-color .15s, color .15s, background .15s;
    white-space: nowrap;
}
.cc-case-btn:hover  { border-color: var(--clr-primary, #754ffe); color: var(--clr-primary, #754ffe); background: var(--clr-card, #fff); }
.cc-case-btn.active { background: var(--clr-primary, #754ffe); color: #fff; border-color: var(--clr-primary, #754ffe); }

/* Active format badge */
.cc-badge {
    font-size: .72rem;
    font-weight: 700;
    background: var(--clr-primary, #754ffe);
    color: #fff;
    padding: 3px 12px;
    border-radius: 20px;
    white-space: nowrap;
}
.cc-badge--muted { background: var(--clr-surface, #f1f0ff); color: var(--clr-muted, #6b7280); }

/* Actions bar */
.cc-actions-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    border-top: 1px solid var(--clr-border, #e5e7eb);
}

/* Toast */
.cc-toast {
    position: fixed;
    bottom: 22px;
    right: 22px;
    background: var(--clr-heading, #1e1b4b);
    color: #fff;
    padding: 9px 18px;
    border-radius: 8px;
    font-size: .82rem;
    font-weight: 600;
    box-shadow: 0 8px 24px rgba(0,0,0,.2);
    opacity: 0;
    transform: translateY(8px);
    transition: opacity .22s, transform .22s;
    z-index: 9999;
    pointer-events: none;
}
.cc-toast.show { opacity: 1; transform: translateY(0); }

@media (max-width: 576px) {
    .cc-stats   { flex-wrap: wrap; }
    .cc-stat    { min-width: 33%; }
}

/* Dark mode */
[data-theme="dark"] .cc-stats      { border-color: var(--clr-border, #2d2b4e); background: var(--clr-card, #1d1c35); }
[data-theme="dark"] .cc-stat       { border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .cc-case-btn   { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); color: var(--clr-text, #e2e2f0); }
[data-theme="dark"] .cc-case-btn:hover  { border-color: var(--clr-primary, #754ffe); color: var(--clr-primary, #754ffe); background: var(--clr-card, #1d1c35); }
[data-theme="dark"] .cc-badge--muted    { background: var(--clr-surface, #1e1c35); color: var(--clr-muted, #9ca3af); }
[data-theme="dark"] .cc-actions-bar     { border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .cc-toast           { background: #e0deff; color: #1e1b4b; }

/* ═══════════════════════════════════════════════════
   Merge PDF  (#mpdfWrap)
   Reuses: aib-upload-zone, aib-editor-wrap,
           aib-preview-side, aib-sidebar, aib-sidebar-head,
           aib-sidebar-title, aib-change-btn,
           aib-sidebar-actions, pxt-spinner, pxt-alert
═══════════════════════════════════════════════════ */

/* Editor card — matches #aibEditor */
#mpdfEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}

/* Editor layout overrides */
#mpdfWrap .mpdf-editor-wrap {
    height: 78vh;
    min-height: 520px;
    align-items: stretch;
    overflow: hidden;
}
#mpdfWrap .mpdf-preview-side {
    flex: 1 1 0;
    min-width: 0;
    padding: 0;
    background: transparent;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
#mpdfWrap .aib-sidebar {
    width: 300px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

/* Dark preview panel */
.mpdf-preview-panel {
    flex: 1;
    background: #525659;
    overflow-y: auto;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 0;
    border-radius: 12px 0 0 12px;
    min-height: 0;
}

/* Page canvases */
.mpdf-page-canvas {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 4px;
    margin-bottom: 8px;
    box-shadow: 0 2px 8px rgba(0,0,0,.4);
    background: #fff;
}

.mpdf-placeholder {
    width: 100%;
    aspect-ratio: 210 / 297;
    background: #fff;
    border-radius: 4px;
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #6b7280;
    font-size: .85rem;
}

/* File anchor (invisible scroll target) */
.mpdf-anchor { height: 0; pointer-events: none; }

/* Dashed divider between PDFs */
.mpdf-divider {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 8px 0 12px;
    color: rgba(255,255,255,.55);
    font-size: .7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .07em;
    white-space: nowrap;
}
.mpdf-divider::before,
.mpdf-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    border-top: 1px dashed rgba(255,255,255,.3);
}

/* Summary line */
.mpdf-summary {
    padding: 8px 16px;
    font-size: .78rem;
    color: var(--clr-muted, #6b7280);
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
}

/* Scrollable file list */
.mpdf-file-body {
    flex: 1;
    overflow-y: auto;
    padding: 8px 0;
    min-height: 0;
}
.mpdf-file-list {
    list-style: none;
    margin: 0;
    padding: 0 12px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

/* File list item */
.mpdf-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    border-radius: 8px;
    border: 1px solid var(--clr-border, #e5e7eb);
    background: var(--clr-card, #fff);
    cursor: pointer;
    transition: border-color .15s, background .15s;
    min-width: 0;
}
.mpdf-item:hover { border-color: var(--clr-primary, #754ffe); }

.mpdf-drag-icon {
    color: var(--clr-muted, #9ca3af);
    cursor: grab;
    flex-shrink: 0;
    font-size: 1rem;
}
.mpdf-drag-icon:active { cursor: grabbing; }

.mpdf-item-icon {
    color: var(--clr-primary, #754ffe);
    font-size: 1.3rem;
    flex-shrink: 0;
}

.mpdf-item-info {
    flex: 1;
    min-width: 0;
}
.mpdf-filename {
    font-size: .8rem;
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: var(--clr-heading, #1e1b4b);
}
.mpdf-filesize {
    font-size: .7rem;
    color: var(--clr-muted, #6b7280);
    margin-top: 1px;
}

.mpdf-pages-badge {
    font-size: .68rem;
    font-weight: 700;
    background: var(--clr-surface, #f1f0ff);
    color: var(--clr-primary, #754ffe);
    padding: 2px 7px;
    border-radius: 20px;
    flex-shrink: 0;
    white-space: nowrap;
}

.mpdf-remove-btn {
    background: none;
    border: none;
    padding: 4px 5px;
    border-radius: 6px;
    color: var(--clr-muted, #9ca3af);
    cursor: pointer;
    flex-shrink: 0;
    line-height: 1;
    transition: color .15s, background .15s;
}
.mpdf-remove-btn:hover { color: #dc2626; background: #fef2f2; }

/* Fullscreen */
#mpdfWrap.aib-fullscreen {
    position: fixed;
    inset: 0;
    z-index: 99998;
    background: var(--clr-card, #fff);
    display: flex;
    flex-direction: column;
    padding: 0;
    margin: 0;
    max-width: none;
}
#mpdfWrap.aib-fullscreen #mpdfEditor {
    flex: 1;
    border: none;
    border-radius: 0;
    overflow: hidden;
    display: flex !important;
    flex-direction: column;
}
#mpdfWrap.aib-fullscreen .mpdf-editor-wrap {
    flex: 1;
    height: auto;
    min-height: unset;
}
#mpdfWrap.aib-fullscreen .mpdf-preview-side {
    position: relative;
}
#mpdfWrap.aib-fullscreen .mpdf-preview-panel {
    border-radius: 0;
}
#mpdfWrap.aib-fullscreen .aib-fs-close {
    display: flex;
}

/* Responsive: stack at 767px */
@media (max-width: 767px) {
    #mpdfWrap .mpdf-editor-wrap   { flex-direction: column; height: auto; }
    #mpdfWrap .mpdf-preview-side  { min-height: 340px; }
    .mpdf-preview-panel           { border-radius: 12px 12px 0 0; }
    #mpdfWrap .aib-sidebar        { max-height: 50vh; overflow-y: auto; }
}

/* Dark mode */
[data-theme="dark"] #mpdfEditor         { border-color: var(--clr-border,#2d2b4e); background: var(--clr-card,#1d1c35); }
[data-theme="dark"] .mpdf-item          { background: var(--clr-card,#1d1c35); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .mpdf-filename      { color: var(--clr-heading,#e2e2f0); }
[data-theme="dark"] .mpdf-pages-badge   { background: var(--clr-surface,#1e1c35); color: var(--clr-primary,#754ffe); }
[data-theme="dark"] .mpdf-summary       { border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .mpdf-remove-btn:hover { background: rgba(220,38,38,.15); }

/* ═══════════════════════════════════════════════════
   Signature Generator  (#sgWrap)
   Reuses: pxt-input-area, aib-editor-wrap, aib-preview-side,
           aib-sidebar, aib-sidebar-head/title/actions,
           aib-form-group/label/row/val, aib-range/ticks,
           aib-color-row/picker/hex, aib-swatches/swatch
═══════════════════════════════════════════════════ */

/* ── Tab navigation ─────────────────────────────── */
.sg-tab-nav {
    display: flex;
    gap: 8px;
    justify-content: center;
    margin-bottom: 24px;
}
.sg-tab-btn {
    padding: 9px 28px;
    border-radius: 50px;
    border: 1.5px solid var(--clr-border, #e5e7eb);
    background: var(--clr-card, #fff);
    color: var(--clr-muted, #6b7280);
    font-weight: 600;
    font-size: .875rem;
    cursor: pointer;
    transition: background .15s, border-color .15s, color .15s;
}
.sg-tab-btn:hover  { border-color: var(--clr-primary, #754ffe); color: var(--clr-primary, #754ffe); }
.sg-tab-btn.active { background: var(--clr-primary, #754ffe); border-color: var(--clr-primary, #754ffe); color: #fff; }

/* ── Inline colour input in text bar ────────────── */
.sg-color-inline {
    width: 32px;
    height: 32px;
    padding: 0;
    border: none;
    background: none;
    cursor: pointer;
    border-radius: 50%;
    outline: none;
}
.sg-color-inline::-webkit-color-swatch-wrapper { padding: 0; }
.sg-color-inline::-webkit-color-swatch { border: none; border-radius: 50%; }

/* ── Signature cards (Type mode) ────────────────── */
.sg-card {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    overflow: hidden;
    background: var(--clr-card, #fff);
    transition: box-shadow .18s, border-color .18s;
}
.sg-card:hover { box-shadow: 0 4px 18px rgba(117,79,254,.12); border-color: var(--clr-primary, #754ffe); }

.sg-card-preview {
    height: 140px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px 16px;
    background-color: #fff;
    background-image:
        linear-gradient(45deg, #f5f5f5 25%, transparent 25%),
        linear-gradient(-45deg, #f5f5f5 25%, transparent 25%),
        linear-gradient(45deg, transparent 75%, #f5f5f5 75%),
        linear-gradient(-45deg, transparent 75%, #f5f5f5 75%);
    background-size: 16px 16px;
    background-position: 0 0, 0 8px, 8px -8px, -8px 0;
    overflow: hidden;
}

.sg-card-text {
    font-size: 42px;
    line-height: 1.15;
    text-align: center;
    white-space: nowrap;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sg-card-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 14px;
    border-top: 1px solid var(--clr-border, #e5e7eb);
    background: var(--clr-surface, #f8f7ff);
}

.sg-font-name {
    font-size: .75rem;
    font-weight: 600;
    color: var(--clr-muted, #6b7280);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ── Draw editor card ───────────────────────────── */
#sgDrawEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}

/* ── Canvas panel ───────────────────────────────── */
.sg-canvas-panel {
    flex: 1;
    display: flex;
    flex-direction: column;
    position: relative;
    cursor: crosshair;
    touch-action: none;
    min-height: 400px;
    background-color: #ffffff;
    background-image:
        linear-gradient(45deg, #f0f4f8 25%, transparent 25%),
        linear-gradient(-45deg, #f0f4f8 25%, transparent 25%),
        linear-gradient(45deg, transparent 75%, #f0f4f8 75%),
        linear-gradient(-45deg, transparent 75%, #f0f4f8 75%);
    background-size: 20px 20px;
    background-position: 0 0, 0 10px, 10px -10px, -10px 0;
}

#sgCanvasDraw {
    flex: 1;
    display: block;
    width: 100%;
    min-height: 0;
}

.sg-canvas-hint {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: var(--clr-muted, #94a3b8);
    font-size: 1.35rem;
    font-weight: 500;
    pointer-events: none;
    white-space: nowrap;
    opacity: .55;
}

/* ── Responsive ─────────────────────────────────── */
@media (max-width: 767px) {
    #sgWrap .aib-editor-wrap { flex-direction: column; }
    .sg-canvas-panel         { min-height: 280px; }
}

/* ── Dark mode ──────────────────────────────────── */
[data-theme="dark"] .sg-tab-btn            { background: var(--clr-card,#1d1c35); border-color: var(--clr-border,#2d2b4e); color: var(--clr-text,#e2e2f0); }
[data-theme="dark"] .sg-tab-btn:hover      { border-color: var(--clr-primary,#754ffe); color: var(--clr-primary,#754ffe); }
[data-theme="dark"] .sg-card              { background: var(--clr-card,#1d1c35); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .sg-card-preview      { background-color: #1a1a2e; background-image: linear-gradient(45deg,#1e1c35 25%,transparent 25%),linear-gradient(-45deg,#1e1c35 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#1e1c35 75%),linear-gradient(-45deg,transparent 75%,#1e1c35 75%); }
[data-theme="dark"] .sg-card-footer       { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] #sgDrawEditor         { border-color: var(--clr-border,#2d2b4e); background: var(--clr-card,#1d1c35); }
[data-theme="dark"] .sg-canvas-panel      { background-color: #1a1a2e; background-image: linear-gradient(45deg,#1e1c35 25%,transparent 25%),linear-gradient(-45deg,#1e1c35 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#1e1c35 75%),linear-gradient(-45deg,transparent 75%,#1e1c35 75%); }

/* ═══════════════════════════════════════════════════
   Sitemap Finder  (#smfWrap)
   Reuses: lf-form-card, pxt-input-area, pxt-alert-danger,
           cc-stats/cc-stat/cc-stat-val/cc-stat-lbl,
           pxs-actions, pxt-spinner
═══════════════════════════════════════════════════ */

.smf-table-wrap {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    overflow: hidden;
    overflow-x: auto;
}

.smf-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .875rem;
}
.smf-table thead tr {
    background: var(--clr-surface, #f8f7ff);
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
}
.smf-table thead th {
    padding: 11px 14px;
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--clr-muted, #6b7280);
    white-space: nowrap;
}
.smf-table tbody tr {
    border-bottom: 1px solid var(--clr-border, #f1f5f9);
}
.smf-table tbody tr:last-child { border-bottom: none; }
.smf-table tbody tr:hover { background: var(--clr-surface, #f8f7ff); }
.smf-table tbody td {
    padding: 10px 14px;
    vertical-align: middle;
    color: var(--clr-text, #374151);
}

/* URL cell */
.smf-url-cell { max-width: 320px; }
.smf-url-cell a {
    color: var(--clr-primary, #754ffe);
    text-decoration: none;
    word-break: break-all;
    font-size: .8rem;
}
.smf-url-cell a:hover { text-decoration: underline; }

/* Status */
.smf-status-ok  { color: #16a34a; font-weight: 700; }
.smf-status-err { color: #dc2626; font-weight: 700; }

/* Type badge */
.smf-type-badge {
    display: inline-block;
    padding: 2px 10px;
    border-radius: 20px;
    font-size: .68rem;
    font-weight: 700;
    white-space: nowrap;
}
.smf-type-index  { background: rgba(117,79,254,.1);  color: var(--clr-primary,#754ffe); }
.smf-type-urlset { background: rgba(22,163,74,.1);   color: #16a34a; }
.smf-type-text   { background: rgba(217,119,6,.1);   color: #d97706; }
.smf-type-error  { background: rgba(220,38,38,.1);   color: #dc2626; }
.smf-type-other  { background: var(--clr-surface,#f1f0ff); color: var(--clr-muted,#6b7280); }

.smf-entries  { font-weight: 600; color: var(--clr-heading, #1e1b4b); }
.smf-modified { color: var(--clr-muted, #6b7280); font-size: .8rem; white-space: nowrap; }

/* Dark mode */
[data-theme="dark"] .smf-table-wrap  { border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .smf-table thead tr { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .smf-table tbody tr { border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .smf-table tbody tr:hover { background: var(--clr-surface,#16152e); }
[data-theme="dark"] .smf-table tbody td { color: var(--clr-text,#e2e2f0); }

/* ═══════════════════════════════════════════════════════════════════════════
   HEADING TAGS CHECKER  (#htcWrap)
═══════════════════════════════════════════════════════════════════════════ */

/* H1–H6 stat accent colors */
.htc-stat-h1 .cc-stat-val { color: #754ffe; }
.htc-stat-h2 .cc-stat-val { color: #3b82f6; }
.htc-stat-h3 .cc-stat-val { color: #10b981; }
.htc-stat-h4 .cc-stat-val { color: #f59e0b; }
.htc-stat-h5 .cc-stat-val { color: #ef4444; }
.htc-stat-h6 .cc-stat-val { color: #6b7280; }

/* Issues box */
.htc-issue-box {
    border: 1px solid #fde68a;
    border-radius: 12px;
    overflow: hidden;
    background: #fffbeb;
}
.htc-issue-head {
    padding: 10px 16px;
    background: #fef3c7;
    color: #92400e;
    font-size: .9rem;
}
.htc-issue-list {
    list-style: none;
    padding: 12px 16px 12px 36px;
    margin: 0;
}
.htc-issue-list li {
    position: relative;
    padding: 4px 0;
    color: #78350f;
    font-size: .85rem;
    line-height: 1.5;
}
.htc-issue-list li::before {
    content: '';
    position: absolute;
    left: -18px;
    top: 10px;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #f59e0b;
}

/* Tree container */
.htc-tree-wrap {
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 12px;
    overflow: hidden;
}
.htc-tree-head {
    padding: 12px 16px;
    background: var(--clr-surface, #f8f7ff);
    border-bottom: 1px solid var(--clr-border, #e5e3ff);
    font-size: .9rem;
    display: flex;
    align-items: center;
    gap: 8px;
}
.htc-total-badge {
    margin-left: auto;
    background: var(--clr-primary, #754ffe);
    color: #fff;
    font-size: .7rem;
    font-weight: 700;
    padding: 2px 10px;
    border-radius: 20px;
}

/* Tree rows */
.htc-tree { padding: 8px 0; }

.htc-item {
    display: flex;
    align-items: baseline;
    gap: 10px;
    padding: 7px 16px;
    border-left: 3px solid transparent;
    transition: background .15s;
    flex-wrap: wrap;
}
.htc-item:hover { background: var(--clr-surface, #f8f7ff); }

/* Level-specific left border colors */
.htc-item-h1 { border-left-color: #754ffe; }
.htc-item-h2 { border-left-color: #3b82f6; }
.htc-item-h3 { border-left-color: #10b981; }
.htc-item-h4 { border-left-color: #f59e0b; }
.htc-item-h5 { border-left-color: #ef4444; }
.htc-item-h6 { border-left-color: #6b7280; }

.htc-has-issue { background: #fffbeb !important; }

/* Tag badge */
.htc-tag {
    flex-shrink: 0;
    display: inline-block;
    width: 28px;
    text-align: center;
    font-size: .7rem;
    font-weight: 800;
    padding: 1px 0;
    border-radius: 4px;
    line-height: 1.6;
}
.htc-tag-h1 { background: rgba(117,79,254,.12); color: #754ffe; }
.htc-tag-h2 { background: rgba(59,130,246,.12);  color: #3b82f6; }
.htc-tag-h3 { background: rgba(16,185,129,.12);  color: #10b981; }
.htc-tag-h4 { background: rgba(245,158,11,.12);  color: #f59e0b; }
.htc-tag-h5 { background: rgba(239,68,68,.12);   color: #ef4444; }
.htc-tag-h6 { background: rgba(107,114,128,.12); color: #6b7280; }

/* Heading text */
.htc-text {
    flex: 1;
    font-size: .875rem;
    color: var(--clr-text, #3d3a6b);
    word-break: break-word;
    min-width: 0;
}
.htc-empty-text { color: var(--clr-muted, #6b7280); font-style: italic; }

/* Issue chips */
.htc-chips { display: flex; flex-wrap: wrap; gap: 4px; }
.htc-issue-chip {
    display: inline-flex;
    align-items: center;
    font-size: .68rem;
    font-weight: 600;
    padding: 1px 8px;
    border-radius: 20px;
    white-space: nowrap;
}
.htc-issue-empty  { background: rgba(239,68,68,.1);   color: #dc2626; }
.htc-issue-skip   { background: rgba(245,158,11,.1);  color: #d97706; }
.htc-issue-dup    { background: rgba(107,114,128,.1); color: #6b7280; }

.htc-empty { padding: 20px 16px; color: var(--clr-muted, #6b7280); font-size: .9rem; }

/* Dark mode */
[data-theme="dark"] .htc-issue-box  { background: #1c1500; border-color: #78350f; }
[data-theme="dark"] .htc-issue-head { background: #291d00; color: #fde68a; }
[data-theme="dark"] .htc-issue-list li { color: #fef3c7; }
[data-theme="dark"] .htc-tree-wrap  { border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .htc-tree-head  { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); color: var(--clr-text,#e2e2f0); }
[data-theme="dark"] .htc-item:hover { background: var(--clr-surface,#16152e); }
[data-theme="dark"] .htc-has-issue  { background: #1c1500 !important; }
[data-theme="dark"] .htc-text       { color: var(--clr-text,#e2e2f0); }
[data-theme="dark"] .smf-entries { color: var(--clr-heading,#e2e2f0); }

/* ═══════════════════════════════════════════════════════════════════════════
   TITLE & META DESCRIPTION CHECKER  (#tdcWrap)
═══════════════════════════════════════════════════════════════════════════ */

#tdcEditor {
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
#tdcWrap .aib-editor-wrap { height: auto; min-height: 500px; }
#tdcWrap .aib-preview-side.tdc-preview-side {
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    overflow-y: auto;
    padding: 28px 24px;
    gap: 20px;
    background: var(--clr-surface, #f8f7ff);
}
#tdcWrap .aib-sidebar { width: 300px; overflow-y: auto; }

/* Score ring */
.tdc-score-area { width: 100%; display: flex; justify-content: center; }
.tdc-score-ring-wrap {
    position: relative;
    width: 120px;
    height: 120px;
    flex-shrink: 0;
}
.tdc-score-svg {
    transform: rotate(-90deg);
    transform-origin: 50% 50%;
    display: block;
}
.tdc-score-circle-bg {
    fill: none;
    stroke: var(--clr-border, #e5e3ff);
    stroke-width: 8;
}
.tdc-score-circle {
    fill: none;
    stroke: #10b981;
    stroke-width: 8;
    stroke-dasharray: 339.292;
    stroke-dashoffset: 339.292;
    transition: stroke-dashoffset .8s ease-out, stroke .4s;
    stroke-linecap: round;
}
.tdc-score-val {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -58%);
    font-size: 30px;
    font-weight: 800;
    color: var(--clr-heading, #1e1b4b);
    line-height: 1;
}
.tdc-score-lbl {
    position: absolute;
    bottom: 16px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--clr-muted, #6b7280);
    white-space: nowrap;
}

/* SERP panel */
.tdc-serp-panel { width: 100%; max-width: 640px; }
.tdc-serp-label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: .85rem;
    font-weight: 700;
    color: var(--clr-heading, #1e1b4b);
    margin-bottom: 10px;
}
.tdc-tabs  { display: flex; gap: 4px; }
.tdc-tab-btn {
    padding: 3px 14px;
    border-radius: 20px;
    border: 1px solid var(--clr-border, #e5e3ff);
    background: transparent;
    font-size: .75rem;
    font-weight: 600;
    color: var(--clr-muted, #6b7280);
    cursor: pointer;
    transition: all .15s;
    line-height: 1.8;
}
.tdc-tab-btn.active {
    background: var(--clr-primary, #754ffe);
    border-color: var(--clr-primary, #754ffe);
    color: #fff;
}
.tdc-serp-box {
    background: #fff;
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 12px;
    padding: 16px 18px;
}

/* Google Desktop */
.tdc-gd { font-family: Arial, sans-serif; }
.tdc-gd-header { display: flex; align-items: center; gap: 10px; margin-bottom: 3px; }
.tdc-gd-favicon {
    width: 16px; height: 16px;
    border-radius: 50%;
    flex-shrink: 0;
    object-fit: cover;
    background: #f1f3f4;
}
.tdc-gd-site { line-height: 1.35; }
.tdc-gd-site-name { display: block; font-size: 13px; color: #202124; }
.tdc-gd-url       { display: block; font-size: 12px; color: #4d5156; }
.tdc-gd-title {
    display: block;
    font-size: 19px;
    line-height: 26px;
    color: #1a0dab;
    text-decoration: none;
    margin: 2px 0 3px;
    font-family: Arial, sans-serif;
    font-weight: 400;
}
.tdc-gd-title:hover { text-decoration: underline; }
.tdc-gd-desc { font-size: 14px; line-height: 22px; color: #4d5156; }

/* Google Mobile */
.tdc-gm {
    font-family: Arial, sans-serif;
    background: #fff;
    border-radius: 8px;
    padding: 10px 12px;
    box-shadow: 0 1px 3px rgba(0,0,0,.12);
}
.tdc-gm-header { display: flex; align-items: center; gap: 10px; margin-bottom: 7px; }
.tdc-gm-favicon {
    width: 18px; height: 18px;
    border-radius: 50%;
    flex-shrink: 0;
    object-fit: cover;
    background: #f1f3f4;
}
.tdc-gm-site-info  { line-height: 1.35; }
.tdc-gm-site-name  { display: block; font-size: 12px; color: #202124; }
.tdc-gm-url        { display: block; font-size: 12px; color: #4d5156; }
.tdc-gm-title      { font-size: 17px; line-height: 22px; color: #1967d2; margin-bottom: 4px; }
.tdc-gm-desc       { font-size: 14px; line-height: 20px; color: #4d5156; }

/* Progress bar */
.tdc-bar {
    height: 5px;
    border-radius: 3px;
    background: var(--clr-border, #e5e3ff);
    overflow: hidden;
}
.tdc-bar-fill {
    height: 100%;
    border-radius: 3px;
    width: 0;
    transition: width .3s, background .3s;
    background: #10b981;
}
.tdc-bar-fill.tdc-warn { background: #f59e0b; }
.tdc-bar-fill.tdc-bad  { background: #ef4444; }

.tdc-hint         { font-size: .73rem; color: var(--clr-muted, #6b7280); display: block; margin-top: 4px; }
.tdc-count-ok   { color: #10b981 !important; }
.tdc-count-warn { color: #f59e0b !important; }
.tdc-count-bad  { color: #ef4444 !important; }

/* Dark mode */
[data-theme="dark"] #tdcEditor     { border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] #tdcWrap .aib-preview-side.tdc-preview-side { background: var(--clr-surface,#16152e); }
[data-theme="dark"] .tdc-serp-box  { background: #0d0d1a; border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .tdc-gm        { background: #0d0d1a; box-shadow: 0 1px 3px rgba(0,0,0,.5); }
[data-theme="dark"] .tdc-gd-title  { color: #8ab4f8; }
[data-theme="dark"] .tdc-gm-title  { color: #8ab4f8; }
[data-theme="dark"] .tdc-gd-site-name,
[data-theme="dark"] .tdc-gd-url,
[data-theme="dark"] .tdc-gd-desc   { color: #bdc1c6; }
[data-theme="dark"] .tdc-gm-site-name,
[data-theme="dark"] .tdc-gm-url,
[data-theme="dark"] .tdc-gm-desc   { color: #bdc1c6; }
[data-theme="dark"] .tdc-score-val { color: var(--clr-heading,#e2e2f0); }
[data-theme="dark"] .tdc-score-circle-bg { stroke: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .tdc-tab-btn   { border-color: var(--clr-border,#2d2b4e); color: var(--clr-muted,#a0aec0); }

/* ═══════════════════════════════════════════════════════════════════════════
   ROBOTS.TXT CHECKER  (#rtcWrap)
═══════════════════════════════════════════════════════════════════════════ */

/* Stat accent colors */
.rtc-stat-disallow { color: #ef4444; }
.rtc-stat-allow    { color: #10b981; }
.rtc-stat-sitemap  { color: #3b82f6; }

/* Tab nav */
.rtc-tab-nav { display: flex; gap: 6px; }
.rtc-tab-btn {
    display: inline-flex;
    align-items: center;
    padding: 6px 18px;
    border-radius: 20px;
    border: 1px solid var(--clr-border, #e5e3ff);
    background: transparent;
    font-size: .82rem;
    font-weight: 600;
    color: var(--clr-muted, #6b7280);
    cursor: pointer;
    transition: all .15s;
    line-height: 1.5;
}
.rtc-tab-btn.active {
    background: var(--clr-primary, #754ffe);
    border-color: var(--clr-primary, #754ffe);
    color: #fff !important;
}
.rtc-tab-btn:hover:not(.active) {
    border-color: var(--clr-primary, #754ffe);
    color: var(--clr-primary, #754ffe);
    color: #fff !important;
}

/* User-agent groups */
.rtc-group {
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 12px;
    overflow: hidden;
    margin-bottom: 12px;
}
.rtc-group-head {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 10px 14px;
    background: var(--clr-surface, #f8f7ff);
    border-bottom: 1px solid var(--clr-border, #e5e3ff);
}
.rtc-agent-badge {
    display: inline-block;
    padding: 2px 12px;
    border-radius: 20px;
    background: var(--clr-primary, #754ffe);
    color: #fff;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .02em;
}
.rtc-rules { padding: 4px 0; }

/* Rule rows */
.rtc-rule {
    display: flex;
    align-items: baseline;
    gap: 10px;
    padding: 6px 14px;
    border-bottom: 1px solid var(--clr-border, #e5e3ff);
    transition: background .12s;
}
.rtc-rule:last-child  { border-bottom: none; }
.rtc-rule:hover { background: var(--clr-surface, #f8f7ff); }

.rtc-rule-type {
    flex-shrink: 0;
    width: 82px;
    text-align: center;
    font-size: .68rem;
    font-weight: 800;
    padding: 2px 0;
    border-radius: 4px;
    line-height: 1.6;
}
.rtc-type-allow    { background: rgba(16,185,129,.12);  color: #10b981; }
.rtc-type-disallow { background: rgba(239,68,68,.12);   color: #ef4444; }
.rtc-type-other    { background: rgba(107,114,128,.12); color: #6b7280; }

.rtc-rule-path {
    font-size: .83rem;
    color: var(--clr-text, #3d3a6b);
    background: transparent;
    font-family: ui-monospace, 'SFMono-Regular', Consolas, monospace;
    word-break: break-all;
}

/* Raw content */
.rtc-raw-wrap {
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 12px;
    overflow: hidden;
}
.rtc-raw-head {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 14px;
    background: var(--clr-surface, #f8f7ff);
    border-bottom: 1px solid var(--clr-border, #e5e3ff);
}
.rtc-raw-url {
    flex: 1;
    font-size: .75rem;
    color: var(--clr-muted, #6b7280);
    word-break: break-all;
}
.rtc-copy-btn {
    flex-shrink: 0;
    background: transparent;
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 6px;
    padding: 3px 8px;
    font-size: .8rem;
    color: var(--clr-muted, #6b7280);
    cursor: pointer;
    transition: all .15s;
}
.rtc-copy-btn:hover { border-color: var(--clr-primary, #754ffe); color: var(--clr-primary, #754ffe); }

pre.rtc-raw {
    margin: 0;
    padding: 14px 16px;
    font-size: .8rem;
    line-height: 1.7;
    max-height: 420px;
    overflow-y: auto;
    background: var(--clr-card, #fff);
    color: var(--clr-text, #3d3a6b);
    font-family: ui-monospace, 'SFMono-Regular', Consolas, monospace;
    white-space: pre-wrap;
    word-break: break-all;
}
/* Syntax colors */
.rtc-raw-comment  { color: var(--clr-muted, #9ca3af); font-style: italic; }
.rtc-raw-agent    { color: var(--clr-primary, #754ffe); font-weight: 700; }
.rtc-raw-disallow { color: #ef4444; }
.rtc-raw-allow    { color: #10b981; }
.rtc-raw-sitemap  { color: #3b82f6; }
.rtc-raw-delay    { color: #f59e0b; }

/* Sitemaps list */
.rtc-section-head {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: .9rem;
    margin-bottom: 10px;
}
.rtc-sitemap-list {
    list-style: none;
    padding: 0;
    margin: 0;
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 10px;
    overflow: hidden;
}
.rtc-sitemap-list li {
    padding: 8px 14px;
    border-bottom: 1px solid var(--clr-border, #e5e3ff);
    font-size: .83rem;
}
.rtc-sitemap-list li:last-child { border-bottom: none; }
.rtc-sitemap-list li:hover { background: var(--clr-surface, #f8f7ff); }
.rtc-sitemap-list a { color: var(--clr-primary, #754ffe); text-decoration: none; word-break: break-all; }
.rtc-sitemap-list a:hover { text-decoration: underline; }

/* Dark mode */
[data-theme="dark"] .rtc-tab-btn      { border-color: var(--clr-border,#2d2b4e); color: var(--clr-muted,#a0aec0); }
[data-theme="dark"] .rtc-group        { border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .rtc-group-head   { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .rtc-rule         { border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .rtc-rule:hover   { background: var(--clr-surface,#16152e); }
[data-theme="dark"] .rtc-rule-path    { color: var(--clr-text,#e2e2f0); }
[data-theme="dark"] .rtc-raw-wrap     { border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .rtc-raw-head     { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] pre.rtc-raw       { background: var(--clr-card,#0d0d1a); color: var(--clr-text,#e2e2f0); }
[data-theme="dark"] .rtc-copy-btn     { border-color: var(--clr-border,#2d2b4e); color: var(--clr-muted,#a0aec0); }
[data-theme="dark"] .rtc-sitemap-list { border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .rtc-sitemap-list li { border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .rtc-sitemap-list li:hover { background: var(--clr-surface,#16152e); }

/* ═══════════════════════════════════════════════════════════════════════════
   QR CODE GENERATOR  (#qrcWrap)
═══════════════════════════════════════════════════════════════════════════ */

#qrcEditor {
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
#qrcWrap .aib-editor-wrap { height: auto; min-height: 600px; }
#qrcWrap .aib-preview-side.qrc-preview-side {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 20px;
    padding: 28px 24px;
    background: var(--clr-surface, #f8f7ff);
    overflow-y: auto;
}
#qrcWrap .aib-sidebar { width: 320px; overflow-y: auto; }

/* QR canvas */
.qrc-canvas-wrap { display: flex; justify-content: center; }
.qrc-canvas-box {
    width: 260px;
    height: 260px;
    background: #fff;
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    flex-shrink: 0;
}
.qrc-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    color: var(--clr-muted, #9ca3af);
    font-size: .85rem;
    text-align: center;
}
.qrc-placeholder i { font-size: 3rem; color: var(--clr-border, #c7c5e8); }

/* Download buttons */
.qrc-dl-btns { width: 260px; }

/* Type tabs */
.qrc-type-tabs {
    display: flex;
    gap: 5px;
    overflow-x: auto;
    padding-bottom: 4px;
    margin-bottom: 12px;
    scrollbar-width: none;
}
.qrc-type-tabs::-webkit-scrollbar { display: none; }
.qrc-type-btn {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 12px;
    border-radius: 8px;
    border: 1px solid var(--clr-border, #e5e3ff);
    background: var(--clr-surface, #f8f7ff);
    font-size: .75rem;
    font-weight: 600;
    color: var(--clr-muted, #6b7280);
    cursor: pointer;
    white-space: nowrap;
    transition: all .15s;
    line-height: 1.5;
}
.qrc-type-btn.active {
    background: var(--clr-primary, #754ffe);
    border-color: var(--clr-primary, #754ffe);
    color: #fff;
    box-shadow: 0 2px 8px rgba(117,79,254,.25);
}
.qrc-type-btn:hover:not(.active) {
    border-color: var(--clr-primary, #754ffe);
    color: var(--clr-primary, #754ffe);
}

/* Accordion sections */
.qrc-section { border-bottom: 1px solid var(--clr-border, #e5e3ff); }
.qrc-section:last-child { border-bottom: none; }
.qrc-section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 11px 16px;
    cursor: pointer;
    font-size: .82rem;
    font-weight: 700;
    color: var(--clr-heading, #1e1b4b);
    user-select: none;
    transition: background .12s;
}
.qrc-section-head:hover { background: var(--clr-surface, #f8f7ff); }
.qrc-chevron {
    font-size: .65rem;
    color: var(--clr-muted, #9ca3af);
    transition: transform .2s;
}
.qrc-section.qrc-open .qrc-chevron { transform: rotate(180deg); }
.qrc-section-body { padding: 4px 16px 14px; }

/* Logo upload zone overrides */
.qrc-logo-zone { padding: 14px 10px !important; }
.qrc-logo-zone .aib-upload-icon  { font-size: 1.4rem !important; }
.qrc-logo-zone .aib-upload-title { font-size: .8rem !important; }

/* Dark mode */
[data-theme="dark"] #qrcEditor { border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] #qrcWrap .aib-preview-side.qrc-preview-side { background: var(--clr-surface,#16152e); }
[data-theme="dark"] .qrc-canvas-box  { background: var(--clr-card,#0d0d1a); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .qrc-type-btn    { border-color: var(--clr-border,#2d2b4e); background: var(--clr-surface,#16152e); color: var(--clr-muted,#a0aec0); }
[data-theme="dark"] .qrc-section     { border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .qrc-section-head { color: var(--clr-heading,#e2e2f0); }
[data-theme="dark"] .qrc-section-head:hover { background: var(--clr-surface,#16152e); }

/* ── QR Code: flat sidebar ──────────────────────────────────────────────── */
.qrc-sep-head {
    padding: 8px 16px 6px;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--clr-muted, #6b7280);
    background: var(--clr-surface, #f8f7ff);
    border-top: 1px solid var(--clr-border, #e5e3ff);
    border-bottom: 1px solid var(--clr-border, #e5e3ff);
}
.qrc-sep-head:first-child { border-top: none; }

.qrc-pad { padding: 14px 16px; }
.qrc-pad + .qrc-pad { padding-top: 0; }

.qrc-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 12px;
    padding: 14px 16px 0;
}

/* Logo drop zone */
.qrc-logo-drop {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    padding: 14px 12px;
    border: 2px dashed var(--clr-border, #c7c5e8);
    border-radius: 8px;
    cursor: pointer;
    text-align: center;
    transition: border-color .18s, background .18s;
}
.qrc-logo-drop:hover { border-color: var(--clr-primary, #754ffe); background: #f3f0ff; }
.qrc-logo-drop i { font-size: 1.5rem; color: var(--clr-primary, #754ffe); }
.qrc-logo-drop span { font-size: .82rem; color: var(--clr-text, #333); }
.qrc-logo-hint { font-size: .72rem !important; color: var(--clr-muted, #6b7280) !important; }
.qrc-logo-drop.aib-upload-zone--over { border-color: var(--clr-primary, #754ffe); background: #ede9ff; }

/* Logo inline preview */
.qrc-logo-row {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    background: var(--clr-surface, #f8f7ff);
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 8px;
}
.qrc-logo-row img {
    width: 40px;
    height: 40px;
    object-fit: contain;
    border-radius: 4px;
    background: #fff;
    border: 1px solid var(--clr-border, #e5e3ff);
    flex-shrink: 0;
}

/* Dark mode */
[data-theme="dark"] .qrc-sep-head { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); color: var(--clr-muted,#a0aec0); }
[data-theme="dark"] .qrc-logo-drop { border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .qrc-logo-drop:hover { background: #1e1c38; }
[data-theme="dark"] .qrc-logo-row { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .qrc-logo-row img { background: #0d0d1a; border-color: var(--clr-border,#2d2b4e); }

/* ── QR Code: accordion + fullscreen + sidebar scroll ──────────────────── */

/* Sidebar scrollable */
#qrcWrap .aib-sidebar.qrc-sidebar {
    overflow-y: auto;
    overflow-x: hidden;
}

/* Fullscreen button in header */
.qrc-fs-btn { padding: 3px 7px; line-height: 1; }

/* Accordion section */
.qrc-acc-section {
    border-bottom: 1px solid var(--clr-border, #e5e3ff);
}
.qrc-acc-section:last-child { border-bottom: none; }

/* Accordion header */
.qrc-acc-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 11px 16px;
    cursor: pointer;
    font-size: .8rem;
    font-weight: 600;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: var(--clr-heading, #1a1040);
    user-select: none;
    transition: background .15s;
}
.qrc-acc-head:hover { background: var(--clr-surface, #f8f7ff); }

/* Chevron */
.qrc-acc-chevron {
    font-size: .75rem;
    color: var(--clr-muted, #6b7280);
    transition: transform .2s;
}
.qrc-acc-section.qrc-acc-open .qrc-acc-chevron {
    transform: rotate(180deg);
}

/* Accordion body padding */
.qrc-acc-body {
    padding: 4px 16px 14px;
}

/* Fullscreen mode */
#qrcEditor.qrc-fullscreen {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: var(--clr-card, #fff);
    border-radius: 0 !important;
    border: none !important;
    display: flex;
    flex-direction: column;
}
#qrcEditor.qrc-fullscreen .aib-editor-wrap {
    flex: 1;
    min-height: 0;
    height: 100%;
}
#qrcEditor.qrc-fullscreen .aib-sidebar.qrc-sidebar {
    height: 100%;
}
#qrcEditor.qrc-fullscreen .aib-preview-side.qrc-preview-side {
    flex: 1;
    height: 100%;
}

/* Dark mode */
[data-theme="dark"] .qrc-acc-section  { border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .qrc-acc-head     { color: var(--clr-heading,#e2e2f0); }
[data-theme="dark"] .qrc-acc-head:hover { background: var(--clr-surface,#16152e); }
[data-theme="dark"] #qrcEditor.qrc-fullscreen { background: var(--clr-card,#0d0d1a); }

/* ── GIF to WebP ──────────────────────────────────────────────────────────── */
.agw-split-view {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin-bottom: 8px;
}
@media (max-width: 640px) {
    .agw-split-view { grid-template-columns: 1fr; }
}

.agw-col { display: flex; flex-direction: column; }

.agw-preview-box {
    position: relative;
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 12px;
    background: var(--clr-surface, #f8f7ff);
    padding: 36px 16px 16px;
    display: flex;
    flex-direction: column;
    align-items: center;
    min-height: 260px;
    flex: 1;
}
.agw-preview-webp { background: var(--clr-card, #fff); }

.agw-box-label {
    position: absolute;
    top: -1px; left: 50%;
    transform: translateX(-50%);
    background: var(--clr-surface, #f8f7ff);
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 0 0 8px 8px;
    padding: 3px 14px;
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .05em;
    text-transform: uppercase;
    color: var(--clr-muted, #6b7280);
    white-space: nowrap;
}
.agw-label-webp {
    background: #10b981;
    border-color: #059669;
    color: #fff;
}

.agw-img-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1;
    width: 100%;
}
.agw-img {
    max-width: 100%;
    max-height: 280px;
    border-radius: 6px;
    display: block;
}

/* Progress inside WebP box */
.agw-progress-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex: 1;
    width: 100%;
    gap: 8px;
    padding: 12px 0;
}
.agw-progress-bar-outer {
    width: 100%;
    max-width: 260px;
    height: 8px;
    background: var(--clr-border, #e5e3ff);
    border-radius: 4px;
    overflow: hidden;
}
.agw-progress-bar-inner {
    height: 100%;
    width: 0%;
    background: var(--clr-primary, #754ffe);
    border-radius: 4px;
    transition: width .2s;
}
.agw-progress-text {
    font-size: .82rem;
    color: var(--clr-muted, #6b7280);
    font-weight: 500;
}

/* Dark mode */
[data-theme="dark"] .agw-preview-box  { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .agw-preview-webp { background: var(--clr-card,#0d0d1a); }
[data-theme="dark"] .agw-box-label    { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .agw-label-webp   { background: #059669; border-color: #047857; }
[data-theme="dark"] .agw-progress-bar-outer { background: var(--clr-border,#2d2b4e); }

/* ── Password Generator ───────────────────────────────────────────────────── */
#pgwWrap {
    margin: 0 auto;
    position: relative;
}

.pgw-card {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 16px;
    padding: 28px 28px 24px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

/* Password display */
.pgw-display-wrap {
    position: relative;
}
.pgw-display {
    width: 100%;
    padding: 14px 56px 14px 18px;
    font-family: SFMono-Regular, Menlo, Monaco, Consolas, 'Courier New', monospace;
    font-size: 1.35rem;
    font-weight: 700;
    letter-spacing: 2px;
    text-align: center;
    border: 2px solid var(--clr-border, #e5e3ff);
    border-radius: 10px;
    background: var(--clr-surface, #f8f7ff);
    color: var(--clr-heading, #1a1040);
    outline: none;
    transition: border-color .2s;
}
.pgw-display:focus { border-color: var(--clr-primary, #754ffe); }

.pgw-copy-btn {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    width: 38px;
    height: 38px;
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 8px;
    background: var(--clr-card, #fff);
    color: var(--clr-muted, #6b7280);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    cursor: pointer;
    transition: background .15s, border-color .15s, color .15s;
}
.pgw-copy-btn:hover   { border-color: var(--clr-primary, #754ffe); color: var(--clr-primary, #754ffe); }
.pgw-copy-btn.pgw-copy-ok { border-color: #10b981; color: #10b981; }

/* Strength meter */
.pgw-strength-wrap {
    display: flex;
    flex-direction: column;
    gap: 7px;
    background: var(--clr-surface, #f8f7ff);
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 10px;
    padding: 12px 16px;
}
.pgw-strength-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.pgw-strength-label {
    font-size: .75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--clr-muted, #6b7280);
}
.pgw-strength-text {
    font-size: .88rem;
    font-weight: 700;
}
.pgw-bar-outer {
    height: 8px;
    background: var(--clr-border, #e5e3ff);
    border-radius: 4px;
    overflow: hidden;
}
.pgw-bar-inner {
    height: 100%;
    width: 0%;
    border-radius: 4px;
    transition: width .3s, background-color .3s;
}
.pgw-bar-weak   { background: #ef4444; }
.pgw-bar-good   { background: #f59e0b; }
.pgw-bar-strong { background: #10b981; }

/* Options grid */
.pgw-opt-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}
.pgw-opt-card {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    border: 1.5px solid var(--clr-border, #e5e3ff);
    border-radius: 10px;
    background: var(--clr-surface, #f8f7ff);
    cursor: pointer;
    transition: border-color .15s, background .15s;
    user-select: none;
}
.pgw-opt-card:hover { border-color: var(--clr-primary, #754ffe); }

.pgw-opt-icon {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background: var(--clr-primary, #754ffe);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: .95rem;
    flex-shrink: 0;
}
.pgw-opt-icon--lower { background: #06b6d4; }
.pgw-opt-icon--num   { background: #10b981; }
.pgw-opt-icon--sym   { background: #f59e0b; }

.pgw-opt-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
}
.pgw-opt-name    { font-size: .83rem; font-weight: 700; color: var(--clr-heading, #1a1040); line-height: 1.2; }
.pgw-opt-example { font-size: .7rem;  color: var(--clr-muted, #6b7280); }

/* Generate button */
.pgw-gen-btn { border-radius: 10px; padding: 13px; font-size: .98rem; gap: 8px; }
.pgw-spin-icon { transition: transform .45s ease; font-size: 1.1rem; }

/* Toast */
.pgw-toast {
    position: fixed;
    bottom: 28px;
    left: 50%;
    transform: translateX(-50%) translateY(20px);
    background: var(--clr-heading, #1a1040);
    color: #fff;
    padding: 10px 22px;
    border-radius: 100px;
    font-size: .88rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    box-shadow: 0 8px 24px rgba(0,0,0,.18);
    opacity: 0;
    visibility: hidden;
    transition: opacity .25s, visibility .25s, transform .3s cubic-bezier(.68,-.55,.265,1.55);
    z-index: 99999;
    pointer-events: none;
}
.pgw-toast-show {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
}

@media (max-width: 480px) {
    .pgw-card { padding: 20px 16px; }
    .pgw-display { font-size: 1.1rem; letter-spacing: 1px; }
    .pgw-opt-grid { grid-template-columns: 1fr; }
}

/* Dark mode */
[data-theme="dark"] .pgw-card     { background: var(--clr-card,#0d0d1a); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .pgw-display  { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); color: var(--clr-heading,#e2e2f0); }
[data-theme="dark"] .pgw-copy-btn { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .pgw-strength-wrap { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .pgw-bar-outer { background: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .pgw-opt-card { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .pgw-opt-name { color: var(--clr-heading,#e2e2f0); }
[data-theme="dark"] .pgw-toast    { background: var(--clr-card,#1a1830); }

/* ── Speech to Text ──────────────────────────────────────────────────────── */
#sttWrap { max-width: 680px; margin: 0 auto; }

.stt-card {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 16px;
    padding: 28px;
    display: flex;
    flex-direction: column;
    gap: 22px;
}

/* Language selector */
.stt-lang-wrap { display: flex; flex-direction: column; align-items: center; }
.stt-lang-select { max-width: 240px; text-align: center; border-radius: 8px; }

/* Mic area */
.stt-mic-area {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
}

.stt-mic-btn {
    width: 76px;
    height: 76px;
    border-radius: 50%;
    background: var(--clr-card, #fff);
    border: 2px solid var(--clr-border, #e5e3ff);
    color: var(--clr-muted, #6b7280);
    font-size: 1.6rem;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background .2s, border-color .2s, color .2s, transform .2s;
    box-shadow: 0 4px 14px rgba(117,79,254,.08);
}
.stt-mic-btn:hover {
    transform: scale(1.06);
    border-color: var(--clr-primary, #754ffe);
    color: var(--clr-primary, #754ffe);
}
.stt-mic-btn.stt-listening {
    background: #ef4444;
    border-color: #ef4444;
    color: #fff;
    animation: sttPulse 1.5s infinite;
}
@keyframes sttPulse {
    0%   { box-shadow: 0 0 0 0   rgba(239,68,68,.45); }
    70%  { box-shadow: 0 0 0 18px rgba(239,68,68,0);  }
    100% { box-shadow: 0 0 0 0   rgba(239,68,68,0);   }
}

/* Status */
.stt-status {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: .87rem;
    font-weight: 500;
    color: var(--clr-muted, #6b7280);
}
.stt-status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--clr-border, #c7c5e8);
    flex-shrink: 0;
    transition: background .2s;
}
.stt-status-dot.stt-dot-active {
    background: #ef4444;
    animation: sttDotBlink .9s infinite;
}
@keyframes sttDotBlink {
    0%, 100% { opacity: 1; }
    50%       { opacity: .3; }
}

/* Textarea */
.stt-textarea-wrap { display: flex; flex-direction: column; gap: 6px; }
.stt-textarea {
    width: 100%;
    min-height: 200px;
    padding: 16px;
    border: 2px solid var(--clr-border, #e5e3ff);
    border-radius: 10px;
    font-size: 1rem;
    line-height: 1.7;
    resize: vertical;
    background: var(--clr-surface, #f8f7ff);
    color: var(--clr-text, #374151);
    transition: border-color .2s;
    outline: none;
}
.stt-textarea:focus { border-color: var(--clr-primary, #754ffe); background: var(--clr-card, #fff); }

.stt-counts {
    display: flex;
    justify-content: flex-end;
    gap: 14px;
    font-size: .75rem;
    color: var(--clr-muted, #6b7280);
}

/* Dark mode */
[data-theme="dark"] .stt-card     { background: var(--clr-card,#0d0d1a); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .stt-mic-btn  { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); color: var(--clr-muted,#a0aec0); }
[data-theme="dark"] .stt-textarea { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); color: var(--clr-text,#e2e2f0); }
[data-theme="dark"] .stt-textarea:focus { background: var(--clr-card,#0d0d1a); }

/* ── Noindex Checker ─────────────────────────────────────────────────────── */

/* Status banner */
.nic-status-banner {
    display: flex;
    align-items: center;
    gap: 18px;
    padding: 20px 22px;
    border-radius: 12px;
    border: 1px solid var(--clr-border, #e5e3ff);
    background: var(--clr-surface, #f8f7ff);
    margin-top: 24px;
}
.nic-banner-ok  { border-color: #10b981; background: #f0fdf4; }
.nic-banner-bad { border-color: #ef4444; background: #fef2f2; }

.nic-status-icon-wrap {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    flex-shrink: 0;
    background: var(--clr-border, #e5e3ff);
    color: var(--clr-muted, #6b7280);
}
.nic-icon-ok  { background: #dcfce7; color: #10b981; }
.nic-icon-bad { background: #fee2e2; color: #ef4444; }

.nic-status-title { font-size: 1.15rem; font-weight: 700; color: var(--clr-heading, #1a1040); }
.nic-status-desc  { font-size: .88rem; color: var(--clr-muted, #6b7280); margin-top: 2px; }

/* Detail card */
.nic-detail-card {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 12px;
    overflow: hidden;
}
.nic-detail-head {
    padding: 12px 18px;
    background: var(--clr-surface, #f8f7ff);
    border-bottom: 1px solid var(--clr-border, #e5e3ff);
    font-size: .9rem;
}
.nic-detail-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    padding: 12px 18px;
    border-bottom: 1px solid var(--clr-border, #e5e3ff);
}
.nic-detail-label {
    font-size: .85rem;
    font-weight: 600;
    color: var(--clr-muted, #6b7280);
    white-space: nowrap;
    flex-shrink: 0;
}
.nic-detail-val {
    font-family: SFMono-Regular, Menlo, Monaco, Consolas, 'Courier New', monospace;
    font-size: .82rem;
    color: var(--clr-heading, #1a1040);
    text-align: right;
    word-break: break-all;
}
.nic-detail-val a { color: var(--clr-primary, #754ffe); }

/* Dark mode */
[data-theme="dark"] .nic-status-banner { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .nic-banner-ok     { background: #052e16; border-color: #10b981; }
[data-theme="dark"] .nic-banner-bad    { background: #2d0a0a; border-color: #ef4444; }
[data-theme="dark"] .nic-detail-card   { background: var(--clr-card,#0d0d1a); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .nic-detail-head   { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .nic-detail-row    { border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .nic-detail-val    { color: var(--clr-heading,#e2e2f0); }

/* ── PDF Image Extractor ─────────────────────────────────────────────────── */

/* Processing card */
.pie-processing-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 36px 24px;
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 14px;
    text-align: center;
    gap: 4px;
}
.pie-proc-status {
    font-size: 1rem;
    font-weight: 600;
    color: var(--clr-heading, #1a1040);
}

/* Gallery grid */
.pie-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
    gap: 16px;
    margin-bottom: 4px;
}

/* Image card */
.pie-image-card {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 10px;
    overflow: hidden;
    transition: box-shadow .2s, transform .18s;
}
.pie-image-card:hover {
    box-shadow: 0 4px 16px rgba(117,79,254,.12);
    transform: translateY(-2px);
}

/* Checkered transparency background */
.pie-img-wrap {
    height: 160px;
    background-color: #f8f9fa;
    background-image:
        linear-gradient(45deg, #e9ecef 25%, transparent 25%, transparent 75%, #e9ecef 75%),
        linear-gradient(45deg, #e9ecef 25%, transparent 25%, transparent 75%, #e9ecef 75%);
    background-size: 16px 16px;
    background-position: 0 0, 8px 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 8px;
}
.pie-img-wrap img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    border-radius: 4px;
}

.pie-card-foot {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 10px;
    border-top: 1px solid var(--clr-border, #e5e3ff);
}
.pie-card-dim {
    font-size: .72rem;
    color: var(--clr-muted, #6b7280);
    font-variant-numeric: tabular-nums;
}
.pie-dl-btn {
    width: 28px;
    height: 28px;
    border-radius: 6px;
    background: var(--clr-surface, #f8f7ff);
    border: 1px solid var(--clr-border, #e5e3ff);
    color: var(--clr-muted, #6b7280);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .8rem;
    cursor: pointer;
    transition: background .15s, color .15s;
}
.pie-dl-btn:hover { background: var(--clr-primary,#754ffe); border-color: var(--clr-primary,#754ffe); color: #fff; }

/* Empty state */
.pie-empty {
    grid-column: 1 / -1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding: 40px;
    color: var(--clr-muted, #6b7280);
    font-size: .9rem;
}
.pie-empty i { font-size: 2.5rem; opacity: .5; }

/* Dark mode */
[data-theme="dark"] .pie-processing-card { background: var(--clr-card,#0d0d1a); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .pie-image-card      { background: var(--clr-card,#0d0d1a); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .pie-img-wrap        { background-color: #16152e; background-image: linear-gradient(45deg,#2d2b4e 25%,transparent 25%,transparent 75%,#2d2b4e 75%), linear-gradient(45deg,#2d2b4e 25%,transparent 25%,transparent 75%,#2d2b4e 75%); }
[data-theme="dark"] .pie-card-foot       { border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .pie-dl-btn          { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); }

/* ── PDF Reader ──────────────────────────────────────────────────────────── */
.pdv-viewer-card {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 14px;
    overflow: hidden;
    position: relative;
}

/* Progress bar */
.pdv-load-bar-wrap {
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: transparent;
    z-index: 30;
}
.pdv-load-bar {
    height: 100%;
    background: var(--clr-primary, #754ffe);
    width: 0%;
    transition: width .25s;
}

/* Toolbar */
.pdv-toolbar {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
    padding: 9px 14px;
    background: var(--clr-surface, #f8f7ff);
    border-bottom: 1px solid var(--clr-border, #e5e3ff);
    position: sticky;
    top: 0;
    z-index: 20;
}
.pdv-tb-group { display: flex; align-items: center; gap: 4px; }
.pdv-tb-sep   { width: 1px; height: 20px; background: var(--clr-border, #e5e3ff); margin: 0 3px; }

/* Toolbar button */
.pdv-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 5px 10px;
    font-size: .8rem;
    font-weight: 600;
    color: var(--clr-heading, #1a1040);
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 6px;
    cursor: pointer;
    white-space: nowrap;
    transition: background .15s, color .15s, border-color .15s;
    line-height: 1.3;
}
.pdv-btn:hover:not(:disabled) {
    background: var(--clr-primary, #754ffe);
    border-color: var(--clr-primary, #754ffe);
    color: #fff;
}
.pdv-btn:disabled { opacity: .35; cursor: not-allowed; }

/* Page input */
.pdv-page-input {
    width: 48px;
    text-align: center;
    padding: 4px 6px;
    font-size: .8rem;
    font-weight: 600;
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 6px;
    background: var(--clr-card, #fff);
    color: var(--clr-heading, #1a1040);
    outline: none;
}
.pdv-page-input:focus { border-color: var(--clr-primary, #754ffe); }
.pdv-page-input::-webkit-inner-spin-button,
.pdv-page-input::-webkit-outer-spin-button { -webkit-appearance: none; }

.pdv-page-total {
    font-size: .8rem;
    font-weight: 600;
    color: var(--clr-muted, #6b7280);
    white-space: nowrap;
}

/* Zoom select */
.pdv-zoom-sel {
    padding: 4px 7px;
    font-size: .8rem;
    font-weight: 600;
    border: 1px solid var(--clr-border, #e5e3ff);
    border-radius: 6px;
    background: var(--clr-card, #fff);
    color: var(--clr-heading, #1a1040);
    outline: none;
    cursor: pointer;
}
.pdv-zoom-sel:focus { border-color: var(--clr-primary, #754ffe); }

/* Filename */
.pdv-filename {
    margin-left: auto;
    font-size: .78rem;
    font-weight: 600;
    color: var(--clr-heading, #1a1040);
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Scroll area */
.pdv-scroll {
    background: #525659;
    height: 76vh;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 20px 16px;
    gap: 16px;
    scroll-behavior: smooth;
}

/* Page block */
.pdv-page-block { flex-shrink: 0; }
.pdv-page-block canvas {
    display: block;
    box-shadow: 0 4px 20px rgba(0,0,0,.45);
    background: #fff;
    max-width: 100%;
}
.pdv-page-lbl {
    text-align: center;
    font-size: .7rem;
    color: rgba(255,255,255,.5);
    margin-top: 5px;
    font-weight: 600;
    letter-spacing: .04em;
}

/* Fullscreen */
.pdv-viewer-card.pdv-fullscreen {
    position: fixed;
    inset: 0;
    z-index: 99999;
    border-radius: 0;
    border: none;
    display: flex;
    flex-direction: column;
}
.pdv-viewer-card.pdv-fullscreen .pdv-scroll {
    flex: 1;
    height: 100%;
}

#pdvBackdrop {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.7);
    z-index: 99998;
}
#pdvBackdrop.pdv-backdrop-show { display: block; }

/* Hide btn label on narrow viewports */
@media (max-width: 600px) {
    .pdv-btn-label { display: none; }
    .pdv-filename  { display: none; }
}

/* Dark mode */
[data-theme="dark"] .pdv-viewer-card { background: var(--clr-card,#0d0d1a); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .pdv-toolbar     { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); }
[data-theme="dark"] .pdv-btn         { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); color: var(--clr-heading,#e2e2f0); }
[data-theme="dark"] .pdv-page-input  { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); color: var(--clr-heading,#e2e2f0); }
[data-theme="dark"] .pdv-zoom-sel    { background: var(--clr-surface,#16152e); border-color: var(--clr-border,#2d2b4e); color: var(--clr-heading,#e2e2f0); }
[data-theme="dark"] .pdv-filename    { color: var(--clr-heading,#e2e2f0); }

/* ═══════════════════════════════════════════════════════════
   Open Graph Checker — ogc-*
   ═══════════════════════════════════════════════════════════ */

/* Status banner warn state (amber) */
.nic-banner-warn { background: linear-gradient(135deg,#fffbeb,#fef3c7); border-left:4px solid #f59e0b; }
[data-theme="dark"] .nic-banner-warn { background: linear-gradient(135deg,rgba(245,158,11,.12),rgba(245,158,11,.06)); }
.nic-icon-warn { background: linear-gradient(135deg,#f59e0b,#d97706); }

/* Two-column layout */
.ogc-two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.25rem;
    align-items: start;
}
@media (max-width: 768px) { .ogc-two-col { grid-template-columns: 1fr; } }

/* OG tag values */
.ogc-tag-val {
    word-break: break-all;
    font-size: .82rem;
    max-width: 55%;
    text-align: right;
}
.ogc-tag-missing {
    color: var(--clr-muted, #94a3b8);
    font-style: italic;
    font-size: .8rem;
}
.ogc-tag-missing .bi { font-size: .75rem; }

/* Facebook-style preview card */
.ogc-preview-card {
    border: 1px solid var(--clr-border,#e2e8f0);
    border-radius: 10px;
    overflow: hidden;
    background: var(--clr-surface,#f8fafc);
}
[data-theme="dark"] .ogc-preview-card { background: var(--clr-surface,#1e293b); border-color: var(--clr-border,#334155); }

.ogc-preview-img-wrap {
    width: 100%;
    aspect-ratio: 1.91 / 1;
    overflow: hidden;
    background: var(--clr-border,#e2e8f0);
    display: flex;
    align-items: center;
    justify-content: center;
}
.ogc-preview-img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.ogc-preview-img-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .5rem;
    color: var(--clr-muted,#94a3b8);
    font-size: .85rem;
}
.ogc-preview-img-placeholder .bi { font-size: 2rem; }

.ogc-preview-meta {
    padding: .75rem 1rem;
    border-top: 1px solid var(--clr-border,#e2e8f0);
}
[data-theme="dark"] .ogc-preview-meta { border-color: var(--clr-border,#334155); }

.ogc-preview-domain {
    font-size: .7rem;
    font-weight: 600;
    letter-spacing: .04em;
    color: var(--clr-muted,#94a3b8);
    text-transform: uppercase;
    margin-bottom: .25rem;
}
.ogc-preview-title {
    font-size: .9rem;
    font-weight: 700;
    color: var(--clr-heading,#1e293b);
    line-height: 1.3;
    margin-bottom: .25rem;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
[data-theme="dark"] .ogc-preview-title { color: var(--clr-heading,#f1f5f9); }
.ogc-preview-desc {
    font-size: .78rem;
    color: var(--clr-muted,#64748b);
    line-height: 1.45;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* ═══════════════════════════════════════════════════════════
   Image Resizer — irs-*
   ═══════════════════════════════════════════════════════════ */

/* Editor card — matches #aibEditor */
#irsEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
[data-theme="dark"] #irsEditor { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }

/* Preview image */
.irs-preview-img {
    max-width: 100%;
    max-height: 492px;
    width: auto;
    height: auto;
    display: block;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
}

/* Mode tabs */
.irs-tabs {
    display: flex;
    background: var(--clr-surface, #f1f3f5);
    padding: 4px;
    border-radius: 10px;
    margin-bottom: 0;
    gap: 3px;
}
.irs-tab-btn {
    flex: 1;
    padding: 7px 6px;
    font-size: .78rem;
    font-weight: 600;
    border: none;
    background: transparent;
    color: var(--clr-muted, #6c757d);
    border-radius: 7px;
    cursor: pointer;
    transition: all .18s;
    white-space: nowrap;
}
.irs-tab-btn:hover { color: var(--clr-text, #1e293b); }
.irs-tab-active {
    background: var(--clr-card, #fff);
    color: var(--clr-primary, #754ffe) !important;
    box-shadow: 0 2px 8px rgba(0,0,0,.08);
}
[data-theme="dark"] .irs-tabs       { background: var(--clr-surface, #16152e); }
[data-theme="dark"] .irs-tab-active { background: var(--clr-card, #1d1c35); box-shadow: 0 2px 8px rgba(0,0,0,.3); }

/* Aspect lock + form-check label */
#irsWrap .form-check-label {
    font-size: .82rem;
    font-weight: 600;
    color: var(--clr-text, #374151);
    cursor: pointer;
}
.irs-lock-icon { color: var(--clr-primary, #754ffe); }
.irs-lock-open { color: var(--clr-muted, #94a3b8); }

/* Size stats inside sidebar */
.irs-size-stats {
    padding: 10px;
    background: var(--clr-surface, #f8f7ff);
    border-radius: 10px;
    border: 1px solid var(--clr-border, #ede9fe);
    margin-top: 4px;
}
.irs-size-stats .cc-stat-val {
    font-size: .95rem;
    letter-spacing: -.01em;
}
.irs-size-stats .cc-stat-lbl { font-size: .68rem; }
[data-theme="dark"] .irs-size-stats { background: var(--clr-surface, #16152e); border-color: var(--clr-border, #2d2b4e); }

/* Fullscreen */
#irsWrap.aib-fullscreen {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: var(--clr-card, #fff);
    display: flex;
    flex-direction: column;
    padding: 0;
    margin: 0;
    max-width: none;
}
#irsWrap.aib-fullscreen #irsEditor {
    flex: 1;
    border: none;
    border-radius: 0;
    overflow: hidden;
    display: flex !important;
    flex-direction: column;
}
#irsWrap.aib-fullscreen .aib-editor-wrap { flex: 1; min-height: unset; }
#irsWrap.aib-fullscreen .aib-preview-side { position: relative; }
#irsWrap.aib-fullscreen .aib-fs-close { display: flex; }

/* ═══════════════════════════════════════════════════════════
   Rotate PDF — rpt-*
   ═══════════════════════════════════════════════════════════ */

/* Toolbar */
.rpt-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: .75rem;
    padding: 12px 16px;
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    margin-bottom: 20px;
}
.rpt-tb-left   { display: flex; align-items: center; gap: .6rem; min-width: 0; }
.rpt-tb-center { display: flex; align-items: center; gap: .4rem; flex-wrap: wrap; }
.rpt-tb-right  { display: flex; align-items: center; gap: .5rem; }

.rpt-filename {
    font-weight: 700;
    font-size: .85rem;
    color: var(--clr-heading, #1e293b);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 200px;
}
.rpt-page-count {
    font-size: .75rem;
    color: var(--clr-muted, #94a3b8);
    white-space: nowrap;
}
.rpt-tb-label {
    font-size: .78rem;
    font-weight: 600;
    color: var(--clr-muted, #6b7280);
    white-space: nowrap;
}

/* Page grid */
.rpt-page-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 16px;
}

/* Page card */
.rpt-page-card {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    overflow: hidden;
    transition: box-shadow .2s, transform .2s;
    position: relative !important;
}
.rpt-page-card:hover {
    box-shadow: 0 4px 16px rgba(0,0,0,.1);
    transform: translateY(-2px);
}

/* Thumbnail container */
.rpt-thumb {
    height: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background-color: #e2e8f0;
    background-image:
        linear-gradient(45deg, #cbd5e1 25%, transparent 25%, transparent 75%, #cbd5e1 75%),
        linear-gradient(45deg, #cbd5e1 25%, transparent 25%, transparent 75%, #cbd5e1 75%);
    background-size: 16px 16px;
    background-position: 0 0, 8px 8px;
}
.rpt-thumb canvas {
    max-width: 90%;
    max-height: 90%;
    display: block;
    box-shadow: 0 2px 8px rgba(0,0,0,.18);
    transition: transform .3s ease;
}

/* Card footer */
.rpt-page-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 7px 10px;
    border-top: 1px solid var(--clr-border, #f1f5f9);
    gap: .25rem;
}
.rpt-page-num {
    font-size: .75rem;
    font-weight: 600;
    color: var(--clr-muted, #6b7280);
    flex: 1;
    text-align: center;
}

/* Rotate buttons */
.rpt-rot-btn {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 1px solid var(--clr-border, #e2e8f0);
    background: var(--clr-surface, #f8fafc);
    color: var(--clr-text, #374151);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .8rem;
    cursor: pointer;
    flex-shrink: 0;
    transition: background .15s, color .15s, border-color .15s;
        padding: 0 !important;
}
.rpt-rot-btn:hover {
    background: var(--clr-primary, #754ffe);
    color: #fff;
    border-color: var(--clr-primary, #754ffe);
}

/* Rotation badge */
.rpt-badge {
    font-size: .65rem;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 100px;
    background: var(--clr-surface, #f1f5f9);
    color: var(--clr-muted, #94a3b8);
    white-space: nowrap;
    transition: background .2s, color .2s;
}
.rpt-badge-active {
    background: rgba(117,79,254,.12);
    color: var(--clr-primary, #754ffe);
}

/* Dark mode */
[data-theme="dark"] .rpt-toolbar   { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .rpt-page-card { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .rpt-page-foot { border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .rpt-rot-btn   { background: var(--clr-surface, #16152e); border-color: var(--clr-border, #2d2b4e); color: var(--clr-text, #e2e2f0); }
[data-theme="dark"] .rpt-badge     { background: var(--clr-surface, #16152e); }
[data-theme="dark"] .rpt-thumb     { background-color: #1a1a2e; background-image: linear-gradient(45deg,#252540 25%,transparent 25%,transparent 75%,#252540 75%), linear-gradient(45deg,#252540 25%,transparent 25%,transparent 75%,#252540 75%); }

@media (max-width: 640px) {
    .rpt-toolbar  { flex-direction: column; align-items: flex-start; }
    .rpt-tb-right { width: 100%; }
    .rpt-tb-right .btn { flex: 1; }
    .rpt-page-grid { grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 12px; }
    .rpt-thumb { height: 160px; }
}

/* ═══════════════════════════════════════════════════════════
   Delete Pages from PDF — dpp-*
   (grid/toolbar/card base: reuses rpt-* classes)
   ═══════════════════════════════════════════════════════════ */

/* Hover overlay on page thumbnail */
.dpp-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.38);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity .2s;
}
.rpt-page-card:hover .dpp-overlay,
.dpp-deleted .dpp-overlay { opacity: 1; }

/* Deleted card — red tint */
.dpp-deleted {
    border-color: var(--clr-danger, #ef4444) !important;
}
.dpp-deleted .rpt-thumb {
    background-color: rgba(239,68,68,.08);
}
.dpp-deleted .dpp-overlay {
    background: rgba(239,68,68,.18);
}
.dpp-deleted .rpt-page-num {
    color: var(--clr-danger, #ef4444);
    text-decoration: line-through;
}

/* Action buttons (trash / restore) */
.dpp-action-btn {
    width: 46px;
    height: 46px;
    border-radius: 50%;
    border: none;
    font-size: 1.1rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 8px rgba(0,0,0,.25);
    transition: transform .15s, box-shadow .15s;
        padding: 0 !important;
}
.dpp-action-btn:hover { transform: scale(1.1); box-shadow: 0 4px 12px rgba(0,0,0,.3); }

.dpp-trash-btn   { background: #fff; color: var(--clr-danger, #ef4444); }
.dpp-trash-btn:hover { background: var(--clr-danger, #ef4444); color: #fff; }

.dpp-restore-btn { background: var(--clr-success, #10b981); color: #fff; }

/* Hint text in toolbar center */
.dpp-hint {
    font-size: .78rem;
    color: var(--clr-muted, #94a3b8);
}

/* Deleted count banner */
.dpp-banner {
    display: flex;
    align-items: center;
    padding: 10px 16px;
    background: rgba(239,68,68,.08);
    border: 1px solid rgba(239,68,68,.25);
    border-radius: 10px;
    color: var(--clr-danger, #dc2626);
    font-size: .83rem;
    font-weight: 600;
    margin-bottom: 16px;
}
[data-theme="dark"] .dpp-banner { background: rgba(239,68,68,.12); border-color: rgba(239,68,68,.3); }

/* ============================================================
   Images to PDF  (#i2pWrap)
   ============================================================ */

/* Actions bar */
.i2p-actions-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 10px;
    padding: 14px 20px;
    border-bottom: 1px solid var(--clr-border, #f1f5f9);
    background: var(--clr-surface, #f8fafc);
    border-radius: 16px 16px 0 0;
}
.i2p-count-label { font-size: .88rem; color: var(--clr-muted, #64748b); }

/* Sortable image grid */
.i2p-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 12px;
    padding: 20px;
    min-height: 180px;
}

/* Single image card */
.i2p-item {
    position: relative;
    border-radius: 10px;
    overflow: hidden;
    border: 2px solid var(--clr-border, #e5e7eb);
    background: var(--clr-surface, #f8fafc);
    aspect-ratio: 210 / 297; /* A4 portrait */
    cursor: grab;
    transition: box-shadow .2s, border-color .2s;
    display: flex;
    align-items: center;
    justify-content: center;
}
.i2p-item:hover { box-shadow: 0 4px 18px rgba(117,79,254,.18); border-color: var(--clr-primary, #754ffe); }
.i2p-item:active { cursor: grabbing; }

/* Landscape variant (297/210 ratio) */
.i2p-item.i2p-landscape { aspect-ratio: 297 / 210; }

/* Margin preview via padding */
.i2p-item.i2p-margin-small  img { padding: 6%; }
.i2p-item.i2p-margin-normal img { padding: 12%; }

/* Grayscale */
.i2p-item.i2p-grayscale img { filter: grayscale(100%); }

/* Image fill */
.i2p-item img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    transition: filter .2s, padding .2s;
}

/* Page number overlay badge (top-left) */
.i2p-number {
    position: absolute;
    top: 6px;
    left: 6px;
    background: var(--clr-primary, #754ffe);
    color: #fff;
    font-size: .65rem;
    font-weight: 700;
    line-height: 1;
    border-radius: 6px;
    padding: 3px 6px;
    pointer-events: none;
    z-index: 2;
}

/* Page num preview text (bottom overlay) */
.i2p-page-num-preview {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    text-align: center;
    font-size: .6rem;
    font-weight: 600;
    color: #555;
    background: rgba(255,255,255,.75);
    padding: 3px 0;
    opacity: 0;
    transition: opacity .2s;
    pointer-events: none;
    z-index: 2;
}
.i2p-item.i2p-show-pagenum .i2p-page-num-preview { opacity: 1; }

/* Remove button (top-right, hover reveal) */
.i2p-remove-btn {
    position: absolute;
    top: 5px;
    right: 5px;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    border: none;
    background: rgba(239,68,68,.9);
    color: #fff;
    font-size: .65rem;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    opacity: 0;
    transition: opacity .15s, transform .15s;
    z-index: 3;
    padding: 0;
    line-height: 1;
}
.i2p-item:hover .i2p-remove-btn { opacity: 1; }
.i2p-remove-btn:hover { transform: scale(1.15); background: #ef4444; }

/* Drag ghost */
.i2p-ghost { opacity: .4; border: 2px dashed var(--clr-primary, #754ffe); }

/* Controls panel */
.i2p-controls-panel {
    padding: 20px;
    border-top: 1px solid var(--clr-border, #f1f5f9);
    background: var(--clr-surface, #f8fafc);
    border-radius: 0 0 16px 16px;
}

/* Toggle row vertical alignment */
.i2p-toggle-row {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 0;
}
.i2p-toggle-row .form-check-input { margin-top: 0; cursor: pointer; }
.i2p-toggle-row .form-check-label { cursor: pointer; font-size: .88rem; }

/* Editor card wrapper */
#i2pEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}

/* Dark mode */
[data-theme="dark"] #i2pEditor { background: var(--clr-card, #1e293b); border-color: var(--clr-border, #334155); }
[data-theme="dark"] .i2p-actions-bar,
[data-theme="dark"] .i2p-controls-panel { background: var(--clr-surface, #0f172a); }
[data-theme="dark"] .i2p-item { background: var(--clr-surface, #1e293b); border-color: var(--clr-border, #334155); }
[data-theme="dark"] .i2p-page-num-preview { background: rgba(0,0,0,.6); color: #cbd5e1; }

/* Mobile */
@media (max-width: 480px) {
    .i2p-grid { grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: 8px; padding: 14px; }
    .i2p-actions-bar, .i2p-controls-panel { padding: 12px 14px; }
}

/* i2p toggle-row: override Bootstrap form-switch positioning for flex layout */
.i2p-toggle-row {
    padding-left: 0;
}
.i2p-toggle-row .form-check-input {
    float: none;
    margin-left: 0;
    flex-shrink: 0;
}

/* ============================================================
   Image to Text OCR  (#oitWrap)
   ============================================================ */

#oitEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}

/* Preview image fills the panel */
.oit-preview-img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    display: block;
    margin: auto;
    border-radius: 8px;
}

/* Result group stretches to fill sidebar space */
.oit-result-group {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
    border-bottom: none !important;
}

.oit-result-textarea {
    flex: 1;
    min-height: 220px;
    resize: vertical;
    font-size: .85rem;
    line-height: 1.7;
    border-color: var(--clr-border, #e5e7eb);
    border-radius: 10px;
    color: var(--clr-text, #334155);
}
.oit-result-textarea:focus {
    border-color: var(--clr-primary, #754ffe);
    box-shadow: 0 0 0 .2rem rgba(117,79,254,.15);
    outline: none;
}

/* Dark mode */
[data-theme="dark"] #oitEditor { background: var(--clr-card, #1e293b); border-color: var(--clr-border, #334155); }
[data-theme="dark"] .oit-result-textarea {
    background: var(--clr-surface, #0f172a);
    color: var(--clr-text, #e2e8f0);
    border-color: var(--clr-border, #334155);
}

/* Fullscreen — mirrors #aibWrap.aib-fullscreen */
#oitWrap.aib-fullscreen {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: var(--clr-card, #fff);
    display: flex;
    flex-direction: column;
    padding: 0;
    margin: 0;
    max-width: none;
}
#oitWrap.aib-fullscreen #oitEditor {
    flex: 1;
    border: none;
    border-radius: 0;
    overflow: hidden;
    display: flex !important;
    flex-direction: column;
}
#oitWrap.aib-fullscreen .aib-editor-wrap { flex: 1; min-height: unset; }
#oitWrap.aib-fullscreen .aib-preview-side { position: relative; }
#oitWrap.aib-fullscreen .aib-fs-close { display: flex; }
[data-theme="dark"] #oitWrap.aib-fullscreen { background: var(--clr-card, #1e293b); }

/* Light placeholder text — all inputs & textareas */
input::placeholder,
textarea::placeholder,
.form-control::placeholder {
    color: #c2ccd8 !important;
    opacity: 1;
}
[data-theme="dark"] input::placeholder,
[data-theme="dark"] textarea::placeholder,
[data-theme="dark"] .form-control::placeholder {
    color: #475569 !important;
    opacity: 1;
}

/* ═══════════════════════════════════════════════
   Image Converter  (ic-*)
   ═══════════════════════════════════════════════ */
#icEditor,
#pcEditor,
#wcEditor,
#jcEditor,
#rcEditor {
  border: 1px solid var(--clr-border);
  border-radius: 12px;
  overflow: hidden;
  background: var(--clr-card);
}

.ic-list-head,
.ic-list-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .5rem;
  padding: .75rem 1rem;
  background: var(--clr-surface);
  border-color: var(--clr-border);
}
.ic-list-head { border-bottom: 1px solid var(--clr-border); }
.ic-list-foot { border-top: 1px solid var(--clr-border); }

.ic-count-label { font-size: .875rem; }
.ic-foot-label  { font-size: .875rem; color: var(--clr-muted); white-space: nowrap; }

/* File rows */
.ic-file-item {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .6rem 1rem;
  border-bottom: 1px solid var(--clr-border);
  background: var(--clr-card);
  transition: background .15s;
}
.ic-file-item:last-child { border-bottom: none; }
.ic-file-item:hover { background: var(--clr-surface); }

/* Thumbnail */
.ic-file-thumb {
  width: 48px;
  height: 48px;
  flex-shrink: 0;
  border-radius: 6px;
  overflow: hidden;
  background: var(--clr-surface);
  border: 1px solid var(--clr-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  color: var(--clr-muted);
}
.ic-file-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* File info */
.ic-file-info {
  flex: 1;
  min-width: 0;
}
.ic-file-name {
  font-weight: 500;
  font-size: .875rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--clr-heading);
}
.ic-file-meta {
  font-size: .75rem;
  color: var(--clr-muted);
  margin-top: 2px;
}

/* Format selector cell */
.ic-file-fmt {
  flex-shrink: 0;
}
.ic-file-fmt .form-select {
  width: 90px;
  font-size: .8125rem;
}

/* Status badge cell */
.ic-file-status {
  flex-shrink: 0;
  min-width: 90px;
  text-align: center;
}

/* Action buttons */
.ic-file-actions {
  display: flex;
  align-items: center;
  gap: .25rem;
  flex-shrink: 0;
}
.ic-action-btn {
  width: 32px;
  height: 32px;
  border: 1px solid transparent;
  border-radius: 6px;
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: .9rem;
  cursor: pointer;
  transition: background .15s, border-color .15s, color .15s;
  color: var(--clr-muted);
  padding: 0;
}
.ic-action-btn:hover { background: var(--clr-surface); border-color: var(--clr-border); }
.ic-dl:hover { color: #22c55e; border-color: #22c55e; }
.ic-rm:hover { color: var(--clr-danger); border-color: var(--clr-danger); }

/* Dark mode */
[data-theme="dark"] #icEditor,
[data-theme="dark"] #pcEditor,
[data-theme="dark"] #wcEditor,
[data-theme="dark"] #jcEditor,
[data-theme="dark"] #rcEditor,
.dark-mode #icEditor,
.dark-mode #pcEditor,
.dark-mode #wcEditor,
.dark-mode #jcEditor,
.dark-mode #rcEditor,
body.dark #icEditor,
body.dark #pcEditor,
body.dark #wcEditor,
body.dark #jcEditor,
body.dark #rcEditor {
  border-color: var(--clr-border);
  background: var(--clr-card);
}

/* Mobile */
@media (max-width: 600px) {
  .ic-file-item { flex-wrap: wrap; gap: .5rem; }
  .ic-file-fmt  { width: 100%; }
  .ic-file-status { min-width: auto; }
  .ic-list-foot { flex-direction: column; align-items: stretch; }
  .ic-list-foot > div { justify-content: stretch; }
  .ic-list-foot .btn { flex: 1; }
}

/* ═══════════════════════════════════════════════
   Instagram Profile Picture Downloader  (ig-*)
   ═══════════════════════════════════════════════ */

.ig-result-card {
  text-align: center;
  padding: 2.5rem 1.5rem;
  border: 1px solid var(--clr-border);
  border-radius: 16px;
  background: var(--clr-card);
  margin-top: 1.5rem;
}
.ig-result-img {
  width: 180px;
  height: 180px;
  border-radius: 50%;
  object-fit: cover;
  border: 4px solid var(--clr-border);
  background: var(--clr-surface);
  display: block;
  margin: 0 auto 1.25rem;
}
.ig-result-username {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--clr-heading);
  margin-bottom: 1.25rem;
}

/* ═══════════════════════════════════════════════
   Dummy Images Generator  (dig-*)
   ═══════════════════════════════════════════════ */

#digEditor {
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 16px;
  overflow: hidden;
  background: var(--clr-card, #fff);
}

#digCanvas {
  max-width: 100%;
  max-height: 492px;
  width: auto;
  height: auto;
  display: block;
  flex-shrink: 0;
  box-shadow: 0 8px 28px rgba(0,0,0,.22);
  border-radius: 2px;
}

.dig-size-label {
  text-align: center;
  font-size: .8rem;
  color: var(--clr-muted, #6b7280);
  margin: .6rem 0 0;
}

.dig-random-btn {
  padding: .2rem .65rem;
  font-size: .8rem;
}

.dig-color-input {
  height: 40px !important;
  padding: .25rem !important;
  cursor: pointer;
}

/* Fullscreen — mirrors #aibWrap.aib-fullscreen */
#digWrap.aib-fullscreen {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: var(--clr-card, #fff);
  display: flex;
  flex-direction: column;
  padding: 0;
  margin: 0;
  max-width: none;
}
#digWrap.aib-fullscreen #digEditor {
  flex: 1;
  border: none;
  border-radius: 0;
  overflow: hidden;
  display: flex !important;
  flex-direction: column;
}
#digWrap.aib-fullscreen .aib-editor-wrap { flex: 1; min-height: unset; }
#digWrap.aib-fullscreen .aib-preview-side { position: relative; }
#digWrap.aib-fullscreen .aib-fs-close { display: flex; }

/* Dark mode */
[data-theme="dark"] #digEditor { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }

/* ═══════════════════════════════════════════════
   Blur Face  (bf-*)
   ═══════════════════════════════════════════════ */

#bfEditor {
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 16px;
  overflow: hidden;
  background: var(--clr-card, #fff);
}

.bf-toggle-btn.active,
.bf-shape-btn.active {
  background: var(--clr-primary, #754ffe) !important;
  border-color: var(--clr-primary, #754ffe) !important;
  color: #fff !important;
}

/* Fullscreen — mirrors #aibWrap.aib-fullscreen */
#bfWrap.aib-fullscreen {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: var(--clr-card, #fff);
  display: flex;
  flex-direction: column;
  padding: 0;
  margin: 0;
  max-width: none;
}
#bfWrap.aib-fullscreen #bfEditor {
  flex: 1;
  border: none;
  border-radius: 0;
  overflow: hidden;
  display: flex !important;
  flex-direction: column;
}
#bfWrap.aib-fullscreen .aib-editor-wrap { flex: 1; min-height: unset; }
#bfWrap.aib-fullscreen .aib-preview-side { position: relative; }
#bfWrap.aib-fullscreen .aib-fs-close { display: flex; }

/* Dark mode */
[data-theme="dark"] #bfEditor { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }

/* ═══════════════════════════════════════════════
   Pixelate Face  (pf-*)
   ═══════════════════════════════════════════════ */

#pfEditor {
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 16px;
  overflow: hidden;
  background: var(--clr-card, #fff);
}

.pf-toggle-btn.active,
.pf-shape-btn.active {
  background: var(--clr-primary, #754ffe) !important;
  border-color: var(--clr-primary, #754ffe) !important;
  color: #fff !important;
}

/* Fullscreen — mirrors #aibWrap.aib-fullscreen */
#pfWrap.aib-fullscreen {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: var(--clr-card, #fff);
  display: flex;
  flex-direction: column;
  padding: 0;
  margin: 0;
  max-width: none;
}
#pfWrap.aib-fullscreen #pfEditor {
  flex: 1;
  border: none;
  border-radius: 0;
  overflow: hidden;
  display: flex !important;
  flex-direction: column;
}
#pfWrap.aib-fullscreen .aib-editor-wrap { flex: 1; min-height: unset; }
#pfWrap.aib-fullscreen .aib-preview-side { position: relative; }
#pfWrap.aib-fullscreen .aib-fs-close { display: flex; }

/* Dark mode */
[data-theme="dark"] #pfEditor { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }

/* ── Photo Effects ─────────────────────────────────────────────────────────── */
#peEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
.pe-canvas-wrap {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1;
    width: 100%;
}
#peCanvas {
    max-width: 100%;
    max-height: 492px;
    width: auto;
    height: auto;
    display: block;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
}
.pe-loader {
    display: none;
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.48);
    border-radius: 2px;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: #fff;
    gap: .5rem;
    font-size: .875rem;
    z-index: 10;
}
.pe-loader-spinner {
    width: 32px;
    height: 32px;
    border: 3px solid rgba(255,255,255,.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: peSpin .7s linear infinite;
}
@keyframes peSpin { to { transform: rotate(360deg); } }
.pe-filter-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .35rem;
}
.pe-filter-btn {
    padding: .35rem .5rem;
    font-size: .8rem;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 6px;
    background: var(--clr-surface, #f9fafb);
    color: var(--clr-text, #374151);
    cursor: pointer;
    transition: border-color .15s, color .15s, background .15s;
    text-align: center;
    line-height: 1.4;
}
.pe-filter-btn:hover:not(:disabled) {
    border-color: var(--clr-primary, #754ffe);
    color: #FFF !important;
}
.pe-filter-btn.active {
    background: var(--clr-primary, #754ffe);
    border-color: var(--clr-primary, #754ffe);
    color: #fff;
}
.pe-filter-btn:disabled {
    opacity: .5;
    cursor: not-allowed;
}
#peWrap.aib-fullscreen { position:fixed; inset:0; z-index:99999; background:var(--clr-card,#fff); display:flex; flex-direction:column; padding:0; margin:0; max-width:none; }
#peWrap.aib-fullscreen #peEditor { flex:1; border:none; border-radius:0; overflow:hidden; display:flex!important; flex-direction:column; }
#peWrap.aib-fullscreen .aib-editor-wrap { flex:1; min-height:unset; }
#peWrap.aib-fullscreen .aib-preview-side { position:relative; }
#peWrap.aib-fullscreen .aib-fs-close { display:flex; }
[data-theme="dark"] #peEditor { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .pe-filter-btn { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); color:var(--clr-text,#d1d5db); }
[data-theme="dark"] .pe-filter-btn:hover:not(:disabled) { border-color:var(--clr-primary,#754ffe); color:var(--clr-primary,#754ffe); }

/* ── Crop Image ────────────────────────────────────────────────────────────── */
#ciEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
.ci-crop-area {
    position: relative;
    flex: 1;
    min-height: 500px;
    background: #1a1a2e;
    overflow: hidden;
}
.ci-crop-area .aib-fs-close {
    z-index: 200;
}
.ci-ratio-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: .35rem;
}
.ci-ratio-btn {
    padding: .35rem .5rem;
    font-size: .8rem;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 6px;
    background: var(--clr-surface, #f9fafb);
    color: var(--clr-text, #374151);
    cursor: pointer;
    transition: border-color .15s, color .15s, background .15s;
    text-align: center;
    line-height: 1.4;
}
.ci-ratio-btn:hover {
    border-color: var(--clr-primary, #754ffe);
    color: var(--clr-primary, #754ffe);
}
.ci-ratio-btn.active {
    background: var(--clr-primary, #754ffe);
    border-color: var(--clr-primary, #754ffe);
    color: #fff;
}
.ci-tools-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: .35rem;
}
.ci-tool-btn {
    padding: .5rem;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 6px;
    background: var(--clr-surface, #f9fafb);
    color: var(--clr-text, #374151);
    cursor: pointer;
    transition: border-color .15s, color .15s;
    text-align: center;
    font-size: 1rem;
    line-height: 1;
}
.ci-tool-btn:hover {
    border-color: var(--clr-primary, #754ffe);
    color: var(--clr-primary, #754ffe);
}
#ciWrap.aib-fullscreen { position:fixed; inset:0; z-index:99999; background:var(--clr-card,#fff); display:flex; flex-direction:column; padding:0; margin:0; max-width:none; }
#ciWrap.aib-fullscreen #ciEditor { flex:1; border:none; border-radius:0; overflow:hidden; display:flex!important; flex-direction:column; }
#ciWrap.aib-fullscreen .aib-editor-wrap { flex:1; min-height:unset; }
#ciWrap.aib-fullscreen .aib-preview-side { position:relative; }
#ciWrap.aib-fullscreen .aib-fs-close { display:flex; }
#ciWrap.aib-fullscreen .ci-crop-area { min-height: unset; }
[data-theme="dark"] #ciEditor { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .ci-ratio-btn,
[data-theme="dark"] .ci-tool-btn { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); color:var(--clr-text,#d1d5db); }
[data-theme="dark"] .ci-ratio-btn:hover,
[data-theme="dark"] .ci-tool-btn:hover { border-color:var(--clr-primary,#754ffe); color:var(--clr-primary,#754ffe); }

/* ── Image Rotator ─────────────────────────────────────────────────────────── */
#irEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
#irCanvas {
    max-width: 100%;
    max-height: 492px;
    width: auto;
    height: auto;
    display: block;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
}
.ir-actions-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .5rem;
}
.ir-action-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: .3rem;
    padding: .7rem .5rem;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    background: var(--clr-surface, #f9fafb);
    color: var(--clr-text, #374151);
    cursor: pointer;
    transition: border-color .15s, color .15s, transform .15s;
    font-size: .8rem;
    line-height: 1.2;
}
.ir-action-btn i {
    font-size: 1.2rem;
    color: var(--clr-primary, #754ffe);
    transition: color .15s;
}
.ir-action-btn:hover {
    border-color: var(--clr-primary, #754ffe);
    color: #FFFFFF !important;
    transform: translateY(-2px);
}
.ir-action-btn:active { transform: translateY(0); }
#irWrap.aib-fullscreen { position:fixed; inset:0; z-index:99999; background:var(--clr-card,#fff); display:flex; flex-direction:column; padding:0; margin:0; max-width:none; }
#irWrap.aib-fullscreen #irEditor { flex:1; border:none; border-radius:0; overflow:hidden; display:flex!important; flex-direction:column; }
#irWrap.aib-fullscreen .aib-editor-wrap { flex:1; min-height:unset; }
#irWrap.aib-fullscreen .aib-preview-side { position:relative; }
#irWrap.aib-fullscreen .aib-fs-close { display:flex; }
[data-theme="dark"] #irEditor { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .ir-action-btn { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); color:var(--clr-text,#d1d5db); }
[data-theme="dark"] .ir-action-btn:hover { border-color:var(--clr-primary,#754ffe); color:var(--clr-primary,#754ffe); }

/* ── Flip Image ────────────────────────────────────────────────────────────── */
#fiEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
#fiCanvas {
    max-width: 100%;
    max-height: 492px;
    width: auto;
    height: auto;
    display: block;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
}
.fi-flip-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .75rem;
}
.fi-flip-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    padding: 1.4rem .75rem;
    border: 2px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    background: var(--clr-surface, #f9fafb);
    color: var(--clr-text, #374151);
    cursor: pointer;
    transition: border-color .2s, color .2s, background .2s, transform .2s;
    font-size: .875rem;
    font-weight: 600;
    line-height: 1.3;
}
.fi-flip-btn i {
    font-size: 1.6rem;
    color: var(--clr-primary, #754ffe);
    transition: color .15s;
}
.fi-flip-btn:hover {
    border-color: var(--clr-primary, #754ffe);
    color: #FFF !important;
    transform: translateY(-2px);
}
.fi-flip-btn.active {
    background: var(--clr-primary, #754ffe);
    border-color: var(--clr-primary, #754ffe);
    color: #fff;
}
.fi-flip-btn.active i { color: #fff; }
.fi-flip-btn:active { transform: translateY(0); }
.fi-hint {
    margin: .6rem 0 0;
    font-size: .78rem;
    color: var(--clr-muted, #6b7280);
    text-align: center;
}
#fiWrap.aib-fullscreen { position:fixed; inset:0; z-index:99999; background:var(--clr-card,#fff); display:flex; flex-direction:column; padding:0; margin:0; max-width:none; }
#fiWrap.aib-fullscreen #fiEditor { flex:1; border:none; border-radius:0; overflow:hidden; display:flex!important; flex-direction:column; }
#fiWrap.aib-fullscreen .aib-editor-wrap { flex:1; min-height:unset; }
#fiWrap.aib-fullscreen .aib-preview-side { position:relative; }
#fiWrap.aib-fullscreen .aib-fs-close { display:flex; }
[data-theme="dark"] #fiEditor { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .fi-flip-btn { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); color:var(--clr-text,#d1d5db); }
[data-theme="dark"] .fi-flip-btn:hover { border-color:var(--clr-primary,#754ffe); color:var(--clr-primary,#754ffe); }

/* ── Passport Resize 3.5×4.5cm ────────────────────────────────────────────── */
#prEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
.pr-canvas-wrap {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}
#prCanvas {
    max-width: 100%;
    max-height: 492px;
    width: auto;
    height: auto;
    display: block;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
    background: #fff;
}
.pr-size-overlay {
    position: absolute;
    bottom: 8px;
    right: 8px;
    background: rgba(0,0,0,.65);
    color: #fff;
    padding: 3px 9px;
    border-radius: 4px;
    font-size: .7rem;
    font-weight: 600;
    pointer-events: none;
    letter-spacing: .3px;
}
.pr-compress-options {
    margin-top: .5rem;
    padding: .75rem;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    background: var(--clr-surface, #f9fafb);
}
.pr-stats { gap: .5rem; }
.pr-loader-overlay {
    position: fixed;
    inset: 0;
    background: rgba(255,255,255,.92);
    z-index: 100000;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1rem;
}
.pr-loader-spinner {
    width: 48px;
    height: 48px;
    border: 4px solid rgba(117,79,254,.2);
    border-top-color: var(--clr-primary, #754ffe);
    border-radius: 50%;
    animation: prSpin .7s linear infinite;
}
.pr-loader-text {
    font-weight: 600;
    color: var(--clr-heading, #1f2937);
}
@keyframes prSpin { to { transform: rotate(360deg); } }
#prWrap.aib-fullscreen { position:fixed; inset:0; z-index:99999; background:var(--clr-card,#fff); display:flex; flex-direction:column; padding:0; margin:0; max-width:none; }
#prWrap.aib-fullscreen #prEditor { flex:1; border:none; border-radius:0; overflow:hidden; display:flex!important; flex-direction:column; }
#prWrap.aib-fullscreen .aib-editor-wrap { flex:1; min-height:unset; }
#prWrap.aib-fullscreen .aib-preview-side { position:relative; }
#prWrap.aib-fullscreen .aib-fs-close { display:flex; }
[data-theme="dark"] #prEditor { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .pr-compress-options { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .pr-loader-overlay { background:rgba(20,18,46,.92); }
[data-theme="dark"] .pr-loader-text { color:var(--clr-heading,#f9fafb); }

/* ── Resize Image in MM ───────────────────────────────────────────────────── */
#rmmEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
.rmm-canvas-wrap {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}
#rmmCanvas {
    max-width: 100%;
    max-height: 492px;
    width: auto;
    height: auto;
    display: block;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
    background: #fff;
}
.rmm-size-overlay {
    position: absolute;
    bottom: 8px;
    right: 8px;
    background: rgba(0,0,0,.65);
    color: #fff;
    padding: 3px 9px;
    border-radius: 4px;
    font-size: .7rem;
    font-weight: 600;
    letter-spacing: .3px;
    pointer-events: none;
}
.rmm-optimize-options {
    margin-top: .5rem;
    padding: .75rem;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    background: var(--clr-surface, #f9fafb);
}
.rmm-stats { gap: .5rem; }
.rmm-loader-overlay {
    position: fixed;
    inset: 0;
    background: rgba(255,255,255,.92);
    z-index: 100000;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1rem;
}
.rmm-loader-spinner {
    width: 48px;
    height: 48px;
    border: 4px solid rgba(117,79,254,.2);
    border-top-color: var(--clr-primary, #754ffe);
    border-radius: 50%;
    animation: rmmSpin .7s linear infinite;
}
.rmm-loader-text {
    font-weight: 600;
    color: var(--clr-heading, #1f2937);
}
@keyframes rmmSpin { to { transform: rotate(360deg); } }
#rmmWrap.aib-fullscreen { position:fixed; inset:0; z-index:99999; background:var(--clr-card,#fff); display:flex; flex-direction:column; padding:0; margin:0; max-width:none; }
#rmmWrap.aib-fullscreen #rmmEditor { flex:1; border:none; border-radius:0; overflow:hidden; display:flex!important; flex-direction:column; }
#rmmWrap.aib-fullscreen .aib-editor-wrap { flex:1; min-height:unset; }
#rmmWrap.aib-fullscreen .aib-preview-side { position:relative; }
#rmmWrap.aib-fullscreen .aib-fs-close { display:flex; }
[data-theme="dark"] #rmmEditor { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .rmm-optimize-options { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .rmm-loader-overlay { background:rgba(20,18,46,.92); }
[data-theme="dark"] .rmm-loader-text { color:var(--clr-heading,#f9fafb); }

/* ── Resize Image in CM ───────────────────────────────────────────────────── */
#rcmEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
.rcm-canvas-wrap {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}
#rcmCanvas {
    max-width: 100%;
    max-height: 492px;
    width: auto;
    height: auto;
    display: block;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
    background: #fff;
}
.rcm-size-overlay {
    position: absolute;
    bottom: 8px;
    right: 8px;
    background: rgba(0,0,0,.65);
    color: #fff;
    padding: 3px 9px;
    border-radius: 4px;
    font-size: .7rem;
    font-weight: 600;
    letter-spacing: .3px;
    pointer-events: none;
}
.rcm-optimize-options {
    margin-top: .5rem;
    padding: .75rem;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    background: var(--clr-surface, #f9fafb);
}
.rcm-stats { gap: .5rem; }
.rcm-loader-overlay {
    position: fixed;
    inset: 0;
    background: rgba(255,255,255,.92);
    z-index: 100000;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1rem;
}
.rcm-loader-spinner {
    width: 48px;
    height: 48px;
    border: 4px solid rgba(117,79,254,.2);
    border-top-color: var(--clr-primary, #754ffe);
    border-radius: 50%;
    animation: rcmSpin .7s linear infinite;
}
.rcm-loader-text {
    font-weight: 600;
    color: var(--clr-heading, #1f2937);
}
@keyframes rcmSpin { to { transform: rotate(360deg); } }
#rcmWrap.aib-fullscreen { position:fixed; inset:0; z-index:99999; background:var(--clr-card,#fff); display:flex; flex-direction:column; padding:0; margin:0; max-width:none; }
#rcmWrap.aib-fullscreen #rcmEditor { flex:1; border:none; border-radius:0; overflow:hidden; display:flex!important; flex-direction:column; }
#rcmWrap.aib-fullscreen .aib-editor-wrap { flex:1; min-height:unset; }
#rcmWrap.aib-fullscreen .aib-preview-side { position:relative; }
#rcmWrap.aib-fullscreen .aib-fs-close { display:flex; }
[data-theme="dark"] #rcmEditor { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .rcm-optimize-options { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .rcm-loader-overlay { background:rgba(20,18,46,.92); }
[data-theme="dark"] .rcm-loader-text { color:var(--clr-heading,#f9fafb); }

/* ── Resize Image in Inch ─────────────────────────────────────────────────── */
#rinEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
.rin-canvas-wrap {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}
#rinCanvas {
    max-width: 100%;
    max-height: 492px;
    width: auto;
    height: auto;
    display: block;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
    background: #fff;
}
.rin-size-overlay {
    position: absolute;
    bottom: 8px;
    right: 8px;
    background: rgba(0,0,0,.65);
    color: #fff;
    padding: 3px 9px;
    border-radius: 4px;
    font-size: .7rem;
    font-weight: 600;
    letter-spacing: .3px;
    pointer-events: none;
}
.rin-optimize-options {
    margin-top: .5rem;
    padding: .75rem;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    background: var(--clr-surface, #f9fafb);
}
.rin-stats { gap: .5rem; }
.rin-loader-overlay {
    position: fixed;
    inset: 0;
    background: rgba(255,255,255,.92);
    z-index: 100000;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1rem;
}
.rin-loader-spinner {
    width: 48px;
    height: 48px;
    border: 4px solid rgba(117,79,254,.2);
    border-top-color: var(--clr-primary, #754ffe);
    border-radius: 50%;
    animation: rinSpin .7s linear infinite;
}
.rin-loader-text {
    font-weight: 600;
    color: var(--clr-heading, #1f2937);
}
@keyframes rinSpin { to { transform: rotate(360deg); } }
#rinWrap.aib-fullscreen { position:fixed; inset:0; z-index:99999; background:var(--clr-card,#fff); display:flex; flex-direction:column; padding:0; margin:0; max-width:none; }
#rinWrap.aib-fullscreen #rinEditor { flex:1; border:none; border-radius:0; overflow:hidden; display:flex!important; flex-direction:column; }
#rinWrap.aib-fullscreen .aib-editor-wrap { flex:1; min-height:unset; }
#rinWrap.aib-fullscreen .aib-preview-side { position:relative; }
#rinWrap.aib-fullscreen .aib-fs-close { display:flex; }
[data-theme="dark"] #rinEditor { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .rin-optimize-options { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .rin-loader-overlay { background:rgba(20,18,46,.92); }
[data-theme="dark"] .rin-loader-text { color:var(--clr-heading,#f9fafb); }

/* ── Increase Image Quality ───────────────────────────────────────────────── */
#iiqResult {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
    padding: 1.25rem;
}
.iiq-result-head {
    display: flex;
    justify-content: center;
    margin-bottom: 1rem;
}
.iiq-hint-pill {
    display: inline-flex;
    align-items: center;
    padding: .35rem .9rem;
    border-radius: 999px;
    background: var(--clr-surface, #f3f4f6);
    border: 1px solid var(--clr-border, #e5e7eb);
    color: var(--clr-muted, #6b7280);
    font-size: .8rem;
    font-weight: 500;
}
.iiq-compare-panel {
    max-height: 400px;
    overflow: scroll;
    margin-bottom: 1rem;
    display: flex;
    justify-content: center;
}
.iiq-compare-container {
    position: relative;
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
    overflow: hidden;
    background: #1a1a2e;
    user-select: none;
    cursor: ew-resize;
    border-radius: 8px;
    line-height: 0;
}
.iiq-compare-container > canvas {
    display: block;
    width: 100%;
    height: auto;
    pointer-events: none;
}
.iiq-after-wrapper {
    position: absolute;
    top: 0;
    left: 0;
    width: 50%;
    height: 100%;
    overflow: hidden;
    border-right: 3px solid #fff;
    box-shadow: 4px 0 14px rgba(0,0,0,.25);
}
.iiq-after-wrapper > canvas {
    display: block;
    height: auto;
    pointer-events: none;
    /* Width is set via JS to match container width so it aligns with the before canvas */
}
.iiq-handle-circle {
    position: absolute;
    top: 50%;
    right: -22px;
    width: 44px;
    height: 44px;
    background: #fff;
    border-radius: 50%;
    box-shadow: 0 4px 14px rgba(0,0,0,.35);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--clr-primary, #754ffe);
    font-size: 1.05rem;
    z-index: 10;
    transform: translateY(-50%);
    pointer-events: none;
}
.iiq-badge {
    position: absolute;
    top: 12px;
    padding: 5px 11px;
    border-radius: 5px;
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .8px;
    color: #fff;
    background: rgba(0,0,0,.6);
    pointer-events: none;
    z-index: 5;
}
.iiq-badge-before { right: 12px; }
.iiq-badge-after  { left:  12px; background: var(--clr-primary, #754ffe); }
.iiq-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: .6rem;
}
.iiq-loader-overlay {
    position: fixed;
    inset: 0;
    background: rgba(255,255,255,.92);
    z-index: 100000;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1rem;
}
.iiq-loader-spinner {
    width: 56px;
    height: 56px;
    border: 4px solid rgba(117,79,254,.2);
    border-top-color: var(--clr-primary, #754ffe);
    border-radius: 50%;
    animation: iiqSpin .7s linear infinite;
}
.iiq-loader-text {
    font-weight: 600;
    color: var(--clr-primary, #754ffe);
    font-size: 1.05rem;
}
@keyframes iiqSpin { to { transform: rotate(360deg); } }
[data-theme="dark"] #iiqResult { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .iiq-hint-pill { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); color:var(--clr-muted,#9ca3af); }
[data-theme="dark"] .iiq-loader-overlay { background:rgba(20,18,46,.94); }

/* ── Black & White ─────────────────────────────────────────────────────────── */
#bwEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
#bwCanvas {
    max-width: 100%;
    max-height: 492px;
    width: auto;
    height: auto;
    display: block;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
}
#bwWrap.aib-fullscreen { position:fixed; inset:0; z-index:99999; background:var(--clr-card,#fff); display:flex; flex-direction:column; padding:0; margin:0; max-width:none; }
#bwWrap.aib-fullscreen #bwEditor { flex:1; border:none; border-radius:0; overflow:hidden; display:flex!important; flex-direction:column; }
#bwWrap.aib-fullscreen .aib-editor-wrap { flex:1; min-height:unset; }
#bwWrap.aib-fullscreen .aib-preview-side { position:relative; }
#bwWrap.aib-fullscreen .aib-fs-close { display:flex; }
[data-theme="dark"] #bwEditor { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }

/* ── Join Images Online ───────────────────────────────────────────────────── */
#jiEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
#jiCanvas {
    max-width: 100%;
    max-height: 492px;
    width: auto;
    height: auto;
    display: block;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
}
.ji-list {
    list-style: none;
    margin: 0;
    padding: 0;
    max-height: 220px;
    overflow-y: auto;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    background: var(--clr-surface, #f9fafb);
}
.ji-list-item {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .35rem .5rem;
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
    background: var(--clr-card, #fff);
    cursor: default;
}
.ji-list-item:last-child { border-bottom: none; }
.ji-list-item-ghost { opacity: .5; background: var(--clr-surface, #f3f4f6); }
.ji-drag-handle {
    color: var(--clr-muted, #9ca3af);
    cursor: grab;
    font-size: .95rem;
}
.ji-thumb {
    width: 32px;
    height: 32px;
    object-fit: cover;
    border-radius: 4px;
    background: #fff;
    flex-shrink: 0;
}
.ji-name {
    font-size: .8rem;
    color: var(--clr-text, #374151);
    flex: 1 1 auto;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
}
.ji-remove {
    border: none;
    background: transparent;
    color: var(--clr-muted, #9ca3af);
    padding: .2rem .35rem;
    border-radius: 4px;
    cursor: pointer;
    font-size: .8rem;
    transition: color .15s, background .15s;
}
.ji-remove:hover {
    color: #ef4444;
    background: rgba(239,68,68,.08);
}
.ji-dir-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .5rem;
}
.ji-dir-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: .3rem;
    padding: .65rem .5rem;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    background: var(--clr-surface, #f9fafb);
    color: var(--clr-text, #374151);
    cursor: pointer;
    font-size: .8rem;
    font-weight: 600;
    transition: border-color .15s, color .15s, background .15s;
}
.ji-dir-btn i { font-size: 1.1rem; color: var(--clr-primary, #754ffe); transition: color .15s; }
.ji-dir-btn:hover { border-color: var(--clr-primary, #754ffe); color: var(--clr-primary, #754ffe); }
.ji-dir-btn.active {
    background: var(--clr-primary, #754ffe);
    border-color: var(--clr-primary, #754ffe);
    color: #fff;
}
.ji-dir-btn.active i { color: #fff; }
.ji-color-row {
    display: flex;
    gap: .5rem;
    align-items: center;
}
.ji-color-input {
    height: 38px !important;
    padding: .15rem !important;
    width: 50px !important;
    cursor: pointer;
    flex-shrink: 0;
}
.ji-loader-overlay {
    position: fixed;
    inset: 0;
    background: rgba(255,255,255,.92);
    z-index: 100000;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1rem;
}
.ji-loader-spinner {
    width: 48px;
    height: 48px;
    border: 4px solid rgba(117,79,254,.2);
    border-top-color: var(--clr-primary, #754ffe);
    border-radius: 50%;
    animation: jiSpin .7s linear infinite;
}
.ji-loader-text {
    font-weight: 600;
    color: var(--clr-heading, #1f2937);
}
@keyframes jiSpin { to { transform: rotate(360deg); } }
#jiWrap.aib-fullscreen { position:fixed; inset:0; z-index:99999; background:var(--clr-card,#fff); display:flex; flex-direction:column; padding:0; margin:0; max-width:none; }
#jiWrap.aib-fullscreen #jiEditor { flex:1; border:none; border-radius:0; overflow:hidden; display:flex!important; flex-direction:column; }
#jiWrap.aib-fullscreen .aib-editor-wrap { flex:1; min-height:unset; }
#jiWrap.aib-fullscreen .aib-preview-side { position:relative; }
#jiWrap.aib-fullscreen .aib-fs-close { display:flex; }
[data-theme="dark"] #jiEditor { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .ji-list { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .ji-list-item { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .ji-name { color:var(--clr-text,#d1d5db); }
[data-theme="dark"] .ji-dir-btn { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); color:var(--clr-text,#d1d5db); }
[data-theme="dark"] .ji-loader-overlay { background:rgba(20,18,46,.92); }
[data-theme="dark"] .ji-loader-text { color:var(--clr-heading,#f9fafb); }

/* ── Circle Crop ──────────────────────────────────────────────────────────── */
#cciEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
.cci-crop-area {
    position: relative;
    flex: 1;
    min-height: 480px;
    background: #1a1a2e;
    overflow: hidden;
}
.cci-crop-area .aib-fs-close { z-index: 200; }
/* Make Cropper.js show a circle preview */
#cciWrap .cropper-view-box,
#cciWrap .cropper-face {
    border-radius: 50%;
}
#cciWrap .cropper-view-box {
    outline: 2px dashed rgba(255,255,255,.85);
    outline-color: rgba(255,255,255,.85);
}
.cci-filename {
    padding: .45rem .65rem;
    background: var(--clr-surface, #f9fafb);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 6px;
    font-size: .8rem;
    color: var(--clr-text, #374151);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.cci-tools-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: .35rem;
}
.cci-tool-btn {
    padding: .5rem;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 6px;
    background: var(--clr-surface, #f9fafb);
    color: var(--clr-text, #374151);
    cursor: pointer;
    transition: border-color .15s, color .15s;
    text-align: center;
    font-size: 1rem;
    line-height: 1;
}
.cci-tool-btn:hover {
    border-color: var(--clr-primary, #754ffe);
    color: var(--clr-primary, #754ffe);
}
.cci-color-row {
    display: flex;
    gap: .5rem;
    align-items: center;
}
.cci-color-input {
    height: 38px !important;
    padding: .15rem !important;
    width: 50px !important;
    cursor: pointer;
    flex-shrink: 0;
}
.cci-hint {
    margin: 0 0 .75rem;
    padding: .5rem .65rem;
    border-radius: 6px;
    background: rgba(117,79,254,.08);
    color: var(--clr-primary, #754ffe);
    font-size: .78rem;
    font-weight: 500;
}
#cciWrap.aib-fullscreen { position:fixed; inset:0; z-index:99999; background:var(--clr-card,#fff); display:flex; flex-direction:column; padding:0; margin:0; max-width:none; }
#cciWrap.aib-fullscreen #cciEditor { flex:1; border:none; border-radius:0; overflow:hidden; display:flex!important; flex-direction:column; }
#cciWrap.aib-fullscreen .aib-editor-wrap { flex:1; min-height:unset; }
#cciWrap.aib-fullscreen .aib-preview-side { position:relative; }
#cciWrap.aib-fullscreen .aib-fs-close { display:flex; }
#cciWrap.aib-fullscreen .cci-crop-area { min-height: unset; }
[data-theme="dark"] #cciEditor { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .cci-filename,
[data-theme="dark"] .cci-tool-btn { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); color:var(--clr-text,#d1d5db); }
[data-theme="dark"] .cci-tool-btn:hover { border-color:var(--clr-primary,#754ffe); color:var(--clr-primary,#754ffe); }
[data-theme="dark"] .cci-hint { background:rgba(117,79,254,.15); }

/* ── Invert Image ─────────────────────────────────────────────────────────── */
#ivEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
#ivCanvas {
    max-width: 100%;
    max-height: 492px;
    width: auto;
    height: auto;
    display: block;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
}
.iv-channel-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: .35rem;
}
.iv-ch-btn {
    padding: .35rem .4rem;
    font-size: .78rem;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 6px;
    background: var(--clr-surface, #f9fafb);
    color: var(--clr-text, #374151);
    cursor: pointer;
    transition: border-color .15s, color .15s, background .15s;
    text-align: center;
    line-height: 1.4;
    font-weight: 500;
}
.iv-ch-btn:hover {
    border-color: var(--clr-primary, #754ffe);
    color: #FFF !important;
}
.iv-ch-btn.active {
    background: var(--clr-primary, #754ffe);
    border-color: var(--clr-primary, #754ffe);
    color: #fff;
}
.iv-hint {
    margin: .35rem 0 0;
    font-size: .75rem;
    color: var(--clr-muted, #6b7280);
}
#ivWrap.aib-fullscreen { position:fixed; inset:0; z-index:99999; background:var(--clr-card,#fff); display:flex; flex-direction:column; padding:0; margin:0; max-width:none; }
#ivWrap.aib-fullscreen #ivEditor { flex:1; border:none; border-radius:0; overflow:hidden; display:flex!important; flex-direction:column; }
#ivWrap.aib-fullscreen .aib-editor-wrap { flex:1; min-height:unset; }
#ivWrap.aib-fullscreen .aib-preview-side { position:relative; }
#ivWrap.aib-fullscreen .aib-fs-close { display:flex; }
[data-theme="dark"] #ivEditor { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .iv-ch-btn { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); color:var(--clr-text,#d1d5db); }
[data-theme="dark"] .iv-ch-btn:hover { border-color:var(--clr-primary,#754ffe); color:var(--clr-primary,#754ffe); }

/* ── Add Watermark to PDF ─────────────────────────────────────────────────── */
#wpdfEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
.wpdf-preview-panel {
    flex: 1;
    overflow-y: auto;
    background: #1f1e3c;
    padding: 1rem !important;
    align-items: flex-start !important;
    min-height: 600px;
    max-height: 800px;
}
.wpdf-page-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    width: 100%;
    align-items: center;
}
.wpdf-page-wrap {
    position: relative;
    background: #fff;
    line-height: 0;
    box-shadow: 0 4px 14px rgba(0,0,0,.35);
    border-radius: 2px;
    overflow: hidden;
    max-width: 100%;
}
.wpdf-page-wrap canvas {
    max-width: 100%;
    height: auto;
    display: block;
}
.wpdf-watermark-overlay {
    position: absolute;
    white-space: nowrap;
    pointer-events: none;
    z-index: 10;
    transform-origin: center center;
    font-family: Helvetica, Arial, sans-serif;
    font-weight: 700;
    line-height: 1;
}
.wpdf-loader {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: .8rem;
    color: #fff;
    background: rgba(31,30,60,.95);
    z-index: 20;
}
.wpdf-loader-spinner {
    width: 36px;
    height: 36px;
    border: 3px solid rgba(255,255,255,.25);
    border-top-color: #fff;
    border-radius: 50%;
    animation: wpdfSpin .7s linear infinite;
}
@keyframes wpdfSpin { to { transform: rotate(360deg); } }
.wpdf-loader-text {
    font-size: .9rem;
    font-weight: 500;
}
.wpdf-filename {
    padding: .45rem .65rem;
    background: var(--clr-surface, #f9fafb);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 6px;
    font-size: .8rem;
    color: var(--clr-text, #374151);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.wpdf-color-row {
    display: flex;
    gap: .5rem;
    align-items: center;
}
.wpdf-color-input {
    height: 38px !important;
    padding: .15rem !important;
    width: 50px !important;
    cursor: pointer;
    flex-shrink: 0;
}
.wpdf-pos-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: .35rem;
    width: 144px;
    margin: 0 auto;
}
.wpdf-pos-btn {
    width: 44px;
    height: 44px;
    border: 2px solid var(--clr-border, #e5e7eb);
    background: var(--clr-surface, #f9fafb);
    border-radius: 8px;
    cursor: pointer;
    transition: border-color .15s, background .15s, box-shadow .15s;
    padding: 0;
}
.wpdf-pos-btn:hover {
    border-color: var(--clr-primary, #754ffe);
    background: var(--clr-card, #fff);
}
.wpdf-pos-btn.active {
    background: var(--clr-primary, #754ffe);
    border-color: var(--clr-primary, #754ffe);
    box-shadow: 0 0 0 3px rgba(117,79,254,.18);
}
#wpdfWrap.aib-fullscreen { position:fixed; inset:0; z-index:99999; background:var(--clr-card,#fff); display:flex; flex-direction:column; padding:0; margin:0; max-width:none; }
#wpdfWrap.aib-fullscreen #wpdfEditor { flex:1; border:none; border-radius:0; overflow:hidden; display:flex!important; flex-direction:column; min-height:0; }
#wpdfWrap.aib-fullscreen .aib-editor-wrap { flex:1; min-height:0; overflow:hidden; }
#wpdfWrap.aib-fullscreen .aib-preview-side { position:relative; min-height:0; height:100%; overflow:hidden; display:flex; flex-direction:column; }
#wpdfWrap.aib-fullscreen .wpdf-preview-panel {
    max-height: none;
    min-height: 0;
    flex: 1 1 auto;
    height: 100%;
    overflow-y: auto !important;
}
#wpdfWrap.aib-fullscreen .aib-fs-close { display:flex; }
[data-theme="dark"] #wpdfEditor { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .wpdf-filename,
[data-theme="dark"] .wpdf-pos-btn { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); color:var(--clr-text,#d1d5db); }
[data-theme="dark"] .wpdf-pos-btn:hover { background:var(--clr-card,#1d1c35); }

/* ── Watermark Image ──────────────────────────────────────────────────────── */
#wimEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
#wimCanvas {
    max-width: 100%;
    max-height: 492px;
    width: auto;
    height: auto;
    display: block;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
}
.wim-tabs {
    display: flex;
    background: var(--clr-surface, #f1f3f5);
    padding: 4px;
    border-radius: 10px;
    gap: 2px;
}
.wim-tab-btn {
    flex: 1;
    padding: .5rem;
    border: none;
    background: transparent;
    border-radius: 8px;
    font-weight: 600;
    color: var(--clr-muted, #6b7280);
    cursor: pointer;
    transition: background .2s, color .2s, box-shadow .2s;
    font-size: .85rem;
}
.wim-tab-btn.active {
    background: var(--clr-card, #fff);
    color: var(--clr-primary, #754ffe);
    box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.wim-color-row {
    display: flex;
    gap: .5rem;
    align-items: center;
}
.wim-color-input {
    height: 38px !important;
    padding: .15rem !important;
    width: 50px !important;
    cursor: pointer;
    flex-shrink: 0;
}
.wim-pos-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: .35rem;
    width: 144px;
    margin: 0 auto;
}
.wim-pos-btn {
    width: 44px;
    height: 44px;
    border: 2px solid var(--clr-border, #e5e7eb);
    background: var(--clr-surface, #f9fafb);
    border-radius: 8px;
    cursor: pointer;
    transition: border-color .15s, background .15s, box-shadow .15s;
    padding: 0;
}
.wim-pos-btn:hover {
    border-color: var(--clr-primary, #754ffe);
    background: var(--clr-card, #fff);
}
.wim-pos-btn.active {
    background: var(--clr-primary, #754ffe);
    border-color: var(--clr-primary, #754ffe);
    box-shadow: 0 0 0 3px rgba(117,79,254,.18);
}
.wim-hint {
    margin: .35rem 0 0;
    font-size: .75rem;
    color: var(--clr-muted, #6b7280);
}
#wimWrap.aib-fullscreen { position:fixed; inset:0; z-index:99999; background:var(--clr-card,#fff); display:flex; flex-direction:column; padding:0; margin:0; max-width:none; }
#wimWrap.aib-fullscreen #wimEditor { flex:1; border:none; border-radius:0; overflow:hidden; display:flex!important; flex-direction:column; }
#wimWrap.aib-fullscreen .aib-editor-wrap { flex:1; min-height:unset; }
#wimWrap.aib-fullscreen .aib-preview-side { position:relative; }
#wimWrap.aib-fullscreen .aib-fs-close { display:flex; }
[data-theme="dark"] #wimEditor { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .wim-tabs { background:var(--clr-surface,#28274a); }
[data-theme="dark"] .wim-tab-btn.active { background:var(--clr-card,#1d1c35); }
[data-theme="dark"] .wim-pos-btn { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .wim-pos-btn:hover { background:var(--clr-card,#1d1c35); }

/* ── Image to GIF ─────────────────────────────────────────────────────────── */
#i2gEditor {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.i2g-card {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 14px;
    background: var(--clr-card, #fff);
    padding: 1.1rem 1.25rem;
}
.i2g-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: .85rem;
    flex-wrap: wrap;
    gap: .5rem;
}
.i2g-card-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--clr-heading, #1f2937);
    display: inline-flex;
    align-items: center;
}
.i2g-count-pill {
    display: inline-block;
    margin-left: .5rem;
    background: var(--clr-primary, #754ffe);
    color: #fff;
    font-size: .7rem;
    font-weight: 700;
    padding: 2px 9px;
    border-radius: 999px;
    min-width: 24px;
    text-align: center;
}
.i2g-head-actions {
    display: flex;
    gap: .4rem;
    flex-wrap: wrap;
}
.i2g-frames-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: .65rem;
}
.i2g-frame {
    position: relative;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    background: var(--clr-surface, #f9fafb);
    overflow: hidden;
    aspect-ratio: 1 / 1;
    cursor: grab;
    transition: border-color .15s, transform .15s, opacity .15s;
}
.i2g-frame:hover { border-color: var(--clr-primary, #754ffe); }
.i2g-frame:active { cursor: grabbing; }
.i2g-frame-dragging { opacity: .4; transform: scale(.96); }
.i2g-frame-over {
    border-color: var(--clr-primary, #754ffe);
    box-shadow: 0 0 0 3px rgba(117,79,254,.18);
}
.i2g-frame img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    pointer-events: none;
}
.i2g-frame-num {
    position: absolute;
    top: 6px;
    left: 6px;
    background: var(--clr-primary, #754ffe);
    color: #fff;
    font-size: .7rem;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 999px;
    z-index: 2;
}
.i2g-frame-remove {
    position: absolute;
    top: 6px;
    right: 6px;
    width: 24px;
    height: 24px;
    border: none;
    border-radius: 50%;
    background: rgba(0,0,0,.6);
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .7rem;
    z-index: 2;
    transition: background .15s;
        padding: 0 !important;
}
.i2g-frame-remove:hover { background: #ef4444; }
.i2g-frame-meta {
    position: absolute;
    bottom: 6px;
    right: 6px;
    background: rgba(0,0,0,.65);
    color: #fff;
    font-size: .65rem;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 4px;
    z-index: 2;
}
.i2g-help {
    margin: .85rem 0 0;
    font-size: .8rem;
    color: var(--clr-muted, #6b7280);
    text-align: center;
}
.i2g-warn {
    border-color: #f59e0b;
    background: rgba(245,158,11,.06);
}
.i2g-warn-head {
    font-weight: 700;
    color: #92400e;
    margin-bottom: .5rem;
    font-size: .95rem;
}
.i2g-warn-sub {
    margin: 0 0 .75rem;
    font-size: .85rem;
    color: var(--clr-text, #374151);
}
.i2g-mode-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: .5rem;
}
.i2g-mode-card {
    display: flex;
    flex-direction: column;
    gap: .25rem;
    padding: .75rem;
    border: 2px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    background: var(--clr-card, #fff);
    cursor: pointer;
    transition: border-color .15s, background .15s;
    margin: 0;
}
.i2g-mode-card input { display: none; }
.i2g-mode-card:hover { border-color: var(--clr-primary, #754ffe); }
.i2g-mode-card:has(input:checked) {
    border-color: var(--clr-primary, #754ffe);
    background: rgba(117,79,254,.06);
}
.i2g-mode-title {
    font-weight: 600;
    font-size: .85rem;
    color: var(--clr-heading, #1f2937);
}
.i2g-mode-desc {
    font-size: .75rem;
    color: var(--clr-muted, #6b7280);
    line-height: 1.3;
}
.i2g-actions {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
}
.i2g-result-area {
    background: #1f1e3c;
    border-radius: 10px;
    padding: 1.25rem;
    min-height: 220px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.i2g-loader {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .6rem;
    color: #fff;
}
.i2g-loader-spinner {
    width: 42px;
    height: 42px;
    border: 4px solid rgba(255,255,255,.2);
    border-top-color: #fff;
    border-radius: 50%;
    animation: i2gSpin .7s linear infinite;
}
@keyframes i2gSpin { to { transform: rotate(360deg); } }
.i2g-loader-text { font-weight: 600; font-size: .9rem; }
.i2g-output img {
    max-width: 100%;
    max-height: 460px;
    border-radius: 4px;
    background: #fff;
    box-shadow: 0 6px 22px rgba(0,0,0,.3);
}
.i2g-download-row {
    margin-top: 1rem;
    display: flex;
    align-items: center;
    gap: .75rem;
    flex-wrap: wrap;
}
.i2g-meta {
    color: var(--clr-muted, #6b7280);
    font-size: .8rem;
    font-weight: 500;
}
[data-theme="dark"] .i2g-card { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .i2g-frame { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .i2g-warn { background:rgba(245,158,11,.1); }
[data-theme="dark"] .i2g-warn-head { color:#fbbf24; }
[data-theme="dark"] .i2g-mode-card { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .i2g-mode-card:has(input:checked) { background:rgba(117,79,254,.18); }

/* ── PDF to ZIP ───────────────────────────────────────────────────────────── */
#p2zEditor { display: flex; flex-direction: column; }
.p2z-card {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 14px;
    background: var(--clr-card, #fff);
    padding: 1.1rem 1.25rem;
}
.p2z-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: .85rem;
    flex-wrap: wrap;
    gap: .5rem;
}
.p2z-card-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--clr-heading, #1f2937);
    display: inline-flex;
    align-items: center;
}
.p2z-count-pill {
    display: inline-block;
    margin-left: .5rem;
    background: var(--clr-primary, #754ffe);
    color: #fff;
    font-size: .7rem;
    font-weight: 700;
    padding: 2px 9px;
    border-radius: 999px;
    min-width: 24px;
    text-align: center;
}
.p2z-head-actions {
    display: flex;
    gap: .4rem;
    flex-wrap: wrap;
}
.p2z-file-list {
    list-style: none;
    margin: 0;
    padding: 0;
    max-height: 380px;
    overflow-y: auto;
}
.p2z-file-item {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .65rem .85rem;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    background: var(--clr-surface, #f9fafb);
    margin-bottom: .4rem;
    transition: border-color .15s, background .15s;
}
.p2z-file-item:hover {
    border-color: var(--clr-primary, #754ffe);
    background: var(--clr-card, #fff);
}
.p2z-file-item:last-child { margin-bottom: 0; }
.p2z-file-left {
    display: flex;
    align-items: center;
    gap: .65rem;
    flex: 1 1 auto;
    min-width: 0;
}
.p2z-pdf-icon {
    color: #ef4444;
    font-size: 1.25rem;
    flex-shrink: 0;
}
.p2z-file-name {
    font-size: .88rem;
    font-weight: 500;
    color: var(--clr-text, #374151);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    flex: 1 1 auto;
    min-width: 0;
}
.p2z-file-size {
    font-size: .75rem;
    color: var(--clr-muted, #6b7280);
    flex-shrink: 0;
}
.p2z-remove {
    border: none;
    background: transparent;
    color: var(--clr-muted, #9ca3af);
    padding: .25rem .4rem;
    border-radius: 4px;
    cursor: pointer;
    font-size: .8rem;
    transition: color .15s, background .15s;
    flex-shrink: 0;
}
.p2z-remove:hover { color: #ef4444; background: rgba(239,68,68,.08); }
.p2z-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 2.5rem 1rem;
    color: var(--clr-muted, #9ca3af);
    text-align: center;
    gap: .25rem;
}
.p2z-empty i {
    font-size: 2.5rem;
    color: var(--clr-border, #e5e7eb);
    margin-bottom: .5rem;
}
.p2z-empty p {
    margin: 0;
    font-weight: 600;
    color: var(--clr-muted, #6b7280);
}
.p2z-stats {
    display: flex;
    gap: 1rem;
    margin-bottom: 1rem;
    background: var(--clr-surface, #f9fafb);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    padding: .75rem;
}
.p2z-stat { flex: 1; text-align: center; }
.p2z-stat-val {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--clr-primary, #754ffe);
    line-height: 1.1;
}
.p2z-stat-lbl {
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--clr-muted, #6b7280);
    margin-top: .15rem;
}
.p2z-actions {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
}
.p2z-info {
    margin: .85rem 0 0;
    font-size: .78rem;
    color: var(--clr-muted, #6b7280);
}
.p2z-loader-overlay {
    position: fixed;
    inset: 0;
    background: rgba(255,255,255,.92);
    z-index: 100000;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1rem;
}
.p2z-loader-spinner {
    width: 48px;
    height: 48px;
    border: 4px solid rgba(117,79,254,.2);
    border-top-color: var(--clr-primary, #754ffe);
    border-radius: 50%;
    animation: p2zSpin .7s linear infinite;
}
@keyframes p2zSpin { to { transform: rotate(360deg); } }
.p2z-loader-text { font-weight: 600; color: var(--clr-heading, #1f2937); }
[data-theme="dark"] .p2z-card { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .p2z-file-item { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .p2z-file-item:hover { background:var(--clr-card,#1d1c35); }
[data-theme="dark"] .p2z-file-name { color:var(--clr-text,#d1d5db); }
[data-theme="dark"] .p2z-stats { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .p2z-loader-overlay { background:rgba(20,18,46,.92); }
[data-theme="dark"] .p2z-loader-text { color:var(--clr-heading,#f9fafb); }

/* ── Shopify Theme Detector ───────────────────────────────────────────────── */
#pxStd { display: block; }
.pxstd-stat {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    padding: 1rem;
    text-align: center;
    height: 100%;
}
.pxstd-stat-icon {
    font-size: 1.5rem;
    margin-bottom: .35rem;
    display: block;
}
.pxstd-stat-val {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--clr-heading, #1f2937);
    line-height: 1.2;
}
.pxstd-stat-lbl {
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--clr-muted, #6b7280);
    margin-top: .2rem;
}
.pxstd-result-card {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 14px;
    background: var(--clr-card, #fff);
    overflow: hidden;
    margin-bottom: 1rem;
}
.pxstd-banner {
    position: relative;
    height: 90px;
    background: linear-gradient(135deg, #95bf47 0%, #5e8e3e 100%);
    overflow: hidden;
}
.pxstd-banner-bg {
    position: absolute; inset: 0;
    background-image:
        radial-gradient(circle at 20% 30%, rgba(255,255,255,.18) 0%, transparent 35%),
        radial-gradient(circle at 80% 70%, rgba(255,255,255,.12) 0%, transparent 30%);
}
.pxstd-banner-overlay {
    position: absolute;
    bottom: 12px;
    left: 16px;
    z-index: 2;
}
.pxstd-shopify-badge {
    background: rgba(255,255,255,.96);
    color: #5e8e3e;
    padding: 5px 12px;
    border-radius: 999px;
    font-size: .75rem;
    font-weight: 700;
    box-shadow: 0 2px 6px rgba(0,0,0,.15);
}
.pxstd-info { padding: 1.1rem 1.25rem; }
.pxstd-info-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: .75rem;
}
.pxstd-theme-name {
    margin: 0 0 .25rem;
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--clr-heading, #1f2937);
}
.pxstd-theme-id {
    margin: 0;
    font-size: .85rem;
    color: var(--clr-muted, #6b7280);
}
.pxstd-id-pill {
    display: inline-block;
    background: var(--clr-surface, #f3f4f6);
    border: 1px solid var(--clr-border, #e5e7eb);
    padding: 1px 8px;
    border-radius: 5px;
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Consolas, monospace;
    font-size: .8rem;
    color: var(--clr-text, #374151);
    margin-left: .25rem;
}
.pxstd-info-badges {
    display: flex;
    flex-direction: column;
    gap: .35rem;
    align-items: flex-end;
}
.pxstd-badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: .73rem;
    font-weight: 600;
}
.pxstd-badge-success {
    background: rgba(16,185,129,.12);
    color: #047857;
}
.pxstd-badge-muted {
    background: var(--clr-surface, #f3f4f6);
    color: var(--clr-muted, #6b7280);
    border: 1px solid var(--clr-border, #e5e7eb);
}
.pxstd-section-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: .25rem 0 .85rem;
    font-size: 1rem;
    font-weight: 700;
    color: var(--clr-heading, #1f2937);
}
.pxstd-count-pill {
    background: var(--clr-primary, #754ffe);
    color: #fff;
    font-size: .7rem;
    font-weight: 700;
    padding: 2px 9px;
    border-radius: 999px;
    min-width: 24px;
    text-align: center;
}
.pxstd-app-card {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .65rem .85rem;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    background: var(--clr-card, #fff);
    transition: border-color .15s, transform .15s, box-shadow .15s;
    height: 100%;
}
.pxstd-app-card:hover {
    border-color: var(--clr-primary, #754ffe);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0,0,0,.06);
}
.pxstd-app-icon {
    width: 40px;
    height: 40px;
    border-radius: 8px;
    box-shadow: 0 2px 4px rgba(0,0,0,.1);
    flex-shrink: 0;
}
.pxstd-app-name {
    font-size: .9rem;
    font-weight: 600;
    color: var(--clr-heading, #1f2937);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
}
.pxstd-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 2rem 1rem;
    border: 1px dashed var(--clr-border, #e5e7eb);
    border-radius: 12px;
    background: var(--clr-surface, #f9fafb);
    color: var(--clr-muted, #6b7280);
    text-align: center;
}
.pxstd-empty i {
    font-size: 2rem;
    color: var(--clr-border, #d1d5db);
    margin-bottom: .5rem;
}
.pxstd-empty p {
    margin: 0 0 .15rem;
    font-weight: 600;
    color: var(--clr-text, #374151);
}
[data-theme="dark"] .pxstd-stat,
[data-theme="dark"] .pxstd-result-card,
[data-theme="dark"] .pxstd-app-card {
    background:var(--clr-card,#1d1c35);
    border-color:var(--clr-border,#2d2b4e);
}
[data-theme="dark"] .pxstd-id-pill,
[data-theme="dark"] .pxstd-empty,
[data-theme="dark"] .pxstd-badge-muted {
    background:var(--clr-surface,#28274a);
    border-color:var(--clr-border,#2d2b4e);
    color:var(--clr-text,#d1d5db);
}
[data-theme="dark"] .pxstd-badge-success { background:rgba(16,185,129,.18); color:#34d399; }

/* ── Create RAR File ──────────────────────────────────────────────────────── */
.crf-note {
    margin-top: 1rem;
    padding: .75rem 1rem;
    background: var(--clr-surface, #f9fafb);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    font-size: .8rem;
    color: var(--clr-muted, #6b7280);
    line-height: 1.5;
}
.crf-note code {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 4px;
    padding: 0 5px;
    font-size: .78rem;
    color: var(--clr-text, #374151);
}
[data-theme="dark"] .crf-note { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .crf-note code { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); color:var(--clr-text,#d1d5db); }

/* ── Website Email Finder ─────────────────────────────────────────────────── */
.pemf-sub {
    margin: 0;
    font-size: .8rem;
    color: var(--clr-muted, #6b7280);
}
.pemf-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: .75rem;
    margin: 1rem 0;
}
.pemf-stat {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    padding: 1rem;
    text-align: center;
}
.pemf-stat-val {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--clr-primary, #754ffe);
    line-height: 1.1;
    word-break: break-word;
}
.pemf-stat-lbl {
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--clr-muted, #6b7280);
    margin-top: .2rem;
}
.pemf-actions {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
    margin-bottom: 1rem;
    align-items: center;
}
.pemf-section-head {
    font-size: 1rem;
    font-weight: 700;
    color: var(--clr-heading, #1f2937);
    margin-bottom: .65rem;
    display: flex;
    align-items: center;
}
.pemf-list {
    list-style: none;
    margin: 0;
    padding: 0;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    overflow: hidden;
}
.pemf-item {
    display: flex;
    align-items: center;
    padding: .55rem .85rem;
    background: var(--clr-card, #fff);
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
    transition: background .15s;
}
.pemf-item:last-child { border-bottom: none; }
.pemf-item:hover { background: var(--clr-surface, #f9fafb); }
.pemf-item-link {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    flex: 1 1 auto;
    min-width: 0;
    text-decoration: none;
    color: var(--clr-text, #374151);
}
.pemf-item-link:hover { color: var(--clr-primary, #754ffe); }
.pemf-item-icon {
    color: var(--clr-primary, #754ffe);
    font-size: 1rem;
    flex-shrink: 0;
}
.pemf-item-addr {
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Consolas, monospace;
    font-size: .88rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1 1 auto;
    min-width: 0;
}
.pemf-item-copy {
    border: none;
    background: transparent;
    color: var(--clr-muted, #9ca3af);
    padding: .25rem .5rem;
    border-radius: 6px;
    cursor: pointer;
    transition: color .15s, background .15s;
    flex-shrink: 0;
}
.pemf-item-copy:hover { color: var(--clr-primary, #754ffe); background: rgba(117,79,254,.08); }
.pemf-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 2rem 1rem;
    border: 1px dashed var(--clr-border, #e5e7eb);
    border-radius: 12px;
    background: var(--clr-surface, #f9fafb);
    color: var(--clr-muted, #6b7280);
    text-align: center;
}
.pemf-empty i {
    font-size: 2rem;
    color: var(--clr-border, #d1d5db);
    margin-bottom: .5rem;
}
.pemf-empty p {
    margin: 0 0 .15rem;
    font-weight: 600;
    color: var(--clr-text, #374151);
}
.pemf-pages {
    list-style: none;
    margin: 0;
    padding: 0;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    background: var(--clr-card, #fff);
    overflow: hidden;
}
.pemf-page-item {
    display: flex;
    align-items: center;
    padding: .5rem .85rem;
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
    font-size: .82rem;
    color: var(--clr-text, #374151);
}
.pemf-page-item:last-child { border-bottom: none; }
.pemf-page-url {
    flex: 1 1 auto;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Consolas, monospace;
    font-size: .78rem;
    min-width: 0;
}
.pemf-page-status {
    margin-left: .75rem;
    flex-shrink: 0;
    font-size: .72rem;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 999px;
}
.pemf-status-found { background: rgba(16,185,129,.12); color: #047857; }
.pemf-status-none  { background: var(--clr-surface, #f3f4f6); color: var(--clr-muted, #6b7280); }
[data-theme="dark"] .pemf-stat,
[data-theme="dark"] .pemf-list,
[data-theme="dark"] .pemf-pages { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .pemf-item { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .pemf-item:hover { background:var(--clr-surface,#28274a); }
[data-theme="dark"] .pemf-empty { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .pemf-page-item { border-color:var(--clr-border,#2d2b4e); color:var(--clr-text,#d1d5db); }
[data-theme="dark"] .pemf-status-found { background:rgba(16,185,129,.18); color:#34d399; }
[data-theme="dark"] .pemf-status-none  { background:var(--clr-surface,#28274a); }

/* Email finder – tag pills + skip status */
.pemf-tag {
    display: inline-block;
    margin-left: .5rem;
    font-size: .65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .4px;
    padding: 2px 7px;
    border-radius: 999px;
    flex-shrink: 0;
}
.pemf-tag-same   { background: rgba(16,185,129,.15);  color: #047857; }
.pemf-tag-public { background: rgba(117,79,254,.12); color: var(--clr-primary,#754ffe); }
.pemf-status-skip {
    background: rgba(239,68,68,.1);
    color: #b91c1c;
    margin-left: .75rem;
    flex-shrink: 0;
    font-size: .7rem;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 999px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 50%;
}
[data-theme="dark"] .pemf-tag-same   { background:rgba(16,185,129,.22);  color:#34d399; }
[data-theme="dark"] .pemf-tag-public { background:rgba(117,79,254,.22); color:#a99bff; }
[data-theme="dark"] .pemf-status-skip{ background:rgba(239,68,68,.18); color:#f87171; }

/* ── Unzip Files Online ───────────────────────────────────────────────────── */
.uzf-zip-name {
    margin-left: .65rem;
    font-size: .82rem;
    font-weight: 500;
    color: var(--clr-muted, #6b7280);
    font-style: italic;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    display: inline-block;
    vertical-align: middle;
    max-width: 240px;
}
.uzf-table th.czf-th-size,
.uzf-table td.czf-td-size {
    text-align: right;
    width: auto;
    min-width: 90px;
    color: var(--clr-muted, #6b7280);
    font-size: .85rem;
    white-space: nowrap;
}
.uzf-extract-btn {
    border: none;
    background: transparent;
    color: var(--clr-primary, #754ffe);
    padding: .25rem .5rem;
    border-radius: 6px;
    cursor: pointer;
    font-size: .95rem;
    transition: background .15s, color .15s;
}
.uzf-extract-btn:hover:not(:disabled) {
    background: rgba(117,79,254,.1);
    color: var(--clr-primary, #754ffe);
}
.uzf-extract-btn:disabled { opacity: .65; cursor: wait; }
.uzf-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: .8rem;
    padding: 2.5rem 1rem;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 14px;
    background: var(--clr-card, #fff);
    margin-top: 1rem;
}
.uzf-loader-spinner {
    width: 42px;
    height: 42px;
    border: 4px solid rgba(117,79,254,.2);
    border-top-color: var(--clr-primary, #754ffe);
    border-radius: 50%;
    animation: uzfSpin .7s linear infinite;
}
@keyframes uzfSpin { to { transform: rotate(360deg); } }
.uzf-loader-text {
    font-weight: 600;
    color: var(--clr-heading, #1f2937);
    font-size: .95rem;
}
[data-theme="dark"] .uzf-loading { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .uzf-loader-text { color:var(--clr-heading,#f9fafb); }

/* ── Image Color Picker ───────────────────────────────────────────────────── */
.icp-editor {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
}
.icp-topbar {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
    background: var(--clr-surface, #fafafa);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 1rem;
}
.icp-color-display {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex: 1 1 auto;
    min-width: 0;
}
.icp-swatch {
    width: 60px;
    height: 60px;
    border-radius: 12px;
    border: 2px solid var(--clr-border, #dee2e6);
    box-shadow: 0 4px 12px rgba(0,0,0,.06);
    flex-shrink: 0;
    background: transparent;
    transition: transform .15s, background .1s;
}
.icp-values {
    display: flex;
    flex-direction: column;
    min-width: 0;
}
.icp-hex {
    font-size: 1.45rem;
    font-weight: 800;
    color: var(--clr-heading, #111827);
    letter-spacing: .04em;
    line-height: 1.1;
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Consolas, monospace;
}
.icp-rgb {
    font-size: .85rem;
    color: var(--clr-muted, #6b7280);
    font-weight: 500;
    margin-top: 2px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.icp-actions {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
}
.icp-canvas-container {
    padding: 1.25rem;
    background-color: #f1f0fa;
    background-image:
        linear-gradient(45deg, rgba(0,0,0,.05) 25%, transparent 25%, transparent 75%, rgba(0,0,0,.05) 75%, rgba(0,0,0,.05)),
        linear-gradient(45deg, rgba(0,0,0,.05) 25%, transparent 25%, transparent 75%, rgba(0,0,0,.05) 75%, rgba(0,0,0,.05));
    background-size: 20px 20px;
    background-position: 0 0, 10px 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 320px;
}
#icpCanvas {
    max-width: 100%;
    max-height: 540px;
    border-radius: 6px;
    cursor: crosshair;
    box-shadow: 0 6px 24px rgba(0,0,0,.18);
}
.icp-helper {
    padding: .65rem 1.25rem;
    background: var(--clr-surface, #f9fafb);
    border-top: 1px solid var(--clr-border, #e5e7eb);
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
    color: var(--clr-muted, #6b7280);
    font-size: .82rem;
    text-align: center;
}
.icp-bottom {
    padding: 1.25rem;
    background: var(--clr-card, #fff);
    display: flex;
    flex-direction: column;
    gap: 1.4rem;
}
#icpVarsBox { display: flex; flex-direction: column; gap: 1.4rem; }
.icp-var-group {
    display: flex;
    flex-direction: column;
}
.icp-var-label {
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--clr-heading, #1f2937);
    margin-bottom: .65rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: .75rem;
    flex-wrap: wrap;
}
.icp-hint-small {
    font-size: .7rem;
    text-transform: none;
    letter-spacing: 0;
    color: var(--clr-muted, #9ca3af);
    font-weight: 500;
}
.icp-loading-pill {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    font-size: .7rem;
    color: var(--clr-muted, #6b7280);
    font-weight: 500;
    text-transform: none;
    letter-spacing: 0;
}
.icp-spinner {
    width: 12px;
    height: 12px;
    border: 2px solid rgba(117,79,254,.25);
    border-top-color: var(--clr-primary, #754ffe);
    border-radius: 50%;
    animation: icpSpin .8s linear infinite;
    display: inline-block;
}
@keyframes icpSpin { to { transform: rotate(360deg); } }
.icp-swatch-row {
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
}
.icp-swatch-pill {
    flex: 1 1 36px;
    min-width: 36px;
    height: 38px;
    border-radius: 6px;
    border: 1px solid rgba(0,0,0,.12);
    cursor: pointer;
    position: relative;
    padding: 0;
    transition: transform .15s, box-shadow .15s, z-index 0s;
}
.icp-swatch-pill:hover {
    transform: scaleY(1.18);
    z-index: 5;
    box-shadow: 0 6px 14px rgba(0,0,0,.18);
}
.icp-swatch-pill.icp-swatch-base {
    border: 2px solid var(--clr-primary, #754ffe);
    box-shadow: 0 0 0 2px rgba(117,79,254,.12);
}
.icp-tooltip {
    position: absolute;
    bottom: calc(100% + 6px);
    left: 50%;
    transform: translateX(-50%);
    background: #111827;
    color: #fff;
    font-size: 11px;
    padding: 3px 7px;
    border-radius: 4px;
    white-space: nowrap;
    pointer-events: none;
    opacity: 0;
    transition: opacity .15s;
    font-weight: 600;
    letter-spacing: .04em;
}
.icp-swatch-pill:hover .icp-tooltip { opacity: 1; }
.icp-empty {
    color: var(--clr-muted, #9ca3af);
    font-size: .85rem;
    padding: .5rem 0;
}
.icp-lens {
    position: fixed;
    display: none;
    pointer-events: none;
    z-index: 99999;
    width: 88px;
    height: 88px;
    border-radius: 50%;
    border: 3px solid #fff;
    box-shadow: 0 6px 18px rgba(0,0,0,.35);
    overflow: hidden;
    transform: translate(-50%, -50%);
    background: #000;
}
#icpLensCanvas {
    width: 100%;
    height: 100%;
    image-rendering: pixelated;
}
.icp-lens-dot {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 4px;
    height: 4px;
    background: #ef4444;
    border-radius: 50%;
    transform: translate(-50%, -50%);
    box-shadow: 0 0 0 1px rgba(255,255,255,.7);
}
.icp-toast {
    position: fixed;
    bottom: 24px;
    right: 24px;
    background: #111827;
    color: #fff;
    padding: 10px 18px;
    border-radius: 8px;
    font-size: .9rem;
    font-weight: 600;
    box-shadow: 0 8px 22px rgba(0,0,0,.22);
    opacity: 0;
    transform: translateY(10px);
    transition: opacity .25s, transform .25s;
    z-index: 100000;
    pointer-events: none;
    display: inline-flex;
    align-items: center;
}
.icp-toast.show { opacity: 1; transform: translateY(0); }
.icp-toast.icp-toast-error { background: #b91c1c; }
[data-theme="dark"] .icp-editor { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .icp-topbar { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .icp-canvas-container { background-color:#16142b; }
[data-theme="dark"] .icp-helper { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .icp-bottom { background:var(--clr-card,#1d1c35); }
[data-theme="dark"] .icp-hex   { color:var(--clr-heading,#f9fafb); }

/* ── Broken Image Checker ─────────────────────────────────────────────────── */
.bic-scope {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    align-items: center;
}
.bic-actions {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
    align-items: center;
}
.bic-table-wrap {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
.bic-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .85rem;
}
.bic-table th,
.bic-table td {
    padding: .65rem .85rem;
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
    vertical-align: top;
    text-align: left;
}
.bic-table thead th {
    background: var(--clr-surface, #f9fafb);
    font-weight: 700;
    color: var(--clr-heading, #1f2937);
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .04em;
    border-bottom: 2px solid var(--clr-border, #e5e7eb);
}
.bic-table tbody tr:last-child td { border-bottom: none; }
.bic-th-num    { width: 40px; }
.bic-th-status { width: 80px; }
.bic-img-link {
    word-break: break-all;
    color: var(--clr-primary, #754ffe);
    text-decoration: none;
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Consolas, monospace;
    font-size: .8rem;
}
.bic-img-link:hover { text-decoration: underline; }
.bic-status-badge {
    display: inline-block;
    background: rgba(220,38,38,.12);
    color: #b91c1c;
    font-weight: 700;
    font-size: .75rem;
    padding: 3px 9px;
    border-radius: 999px;
    letter-spacing: .03em;
}
.bic-table td a {
    color: var(--clr-primary, #754ffe);
    text-decoration: none;
    word-break: break-all;
    font-size: .78rem;
}
.bic-table td a:hover { text-decoration: underline; }
.bic-no-broken {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 2.5rem 1rem;
    border: 1px dashed var(--clr-border, #e5e7eb);
    border-radius: 12px;
    background: var(--clr-surface, #f9fafb);
    color: var(--clr-muted, #6b7280);
    text-align: center;
}
.bic-no-broken i {
    font-size: 2.5rem;
    color: #10b981;
    margin-bottom: .5rem;
}
.bic-no-broken p {
    margin: 0 0 .15rem;
    font-weight: 600;
    color: var(--clr-heading, #047857);
    font-size: 1rem;
}
[data-theme="dark"] .bic-table-wrap { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .bic-table thead th { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); color:var(--clr-text,#d1d5db); }
[data-theme="dark"] .bic-table th,
[data-theme="dark"] .bic-table td { border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .bic-no-broken { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .bic-status-badge { background:rgba(220,38,38,.22); color:#fca5a5; }

/* ── Broken Link Checker (extends BIC styles) ─────────────────────────────── */
.blc-type {
    display: inline-block;
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    padding: 3px 8px;
    border-radius: 999px;
}
.blc-type-internal {
    background: rgba(117,79,254,.12);
    color: var(--clr-primary, #754ffe);
}
.blc-type-external {
    background: rgba(59,130,246,.12);
    color: #1d4ed8;
}
[data-theme="dark"] .blc-type-internal { background:rgba(117,79,254,.22); color:#a99bff; }
[data-theme="dark"] .blc-type-external { background:rgba(59,130,246,.22); color:#93c5fd; }

/* ── Image Alt Checker (extends BIC styles) ───────────────────────────────── */
.iac-filter-bar {
    display: flex;
    gap: .4rem;
    flex-wrap: wrap;
    align-items: center;
}
.iac-filter-btn {
    padding: .35rem .8rem;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 999px;
    background: var(--clr-card, #fff);
    color: var(--clr-text, #374151);
    cursor: pointer;
    font-size: .8rem;
    font-weight: 600;
    transition: border-color .15s, background .15s, color .15s;
}
.iac-filter-btn:hover {
    border-color: var(--clr-primary, #754ffe);
    color: var(--clr-primary, #754ffe);
}
.iac-filter-btn.active {
    background: var(--clr-primary, #754ffe);
    border-color: var(--clr-primary, #754ffe);
    color: #fff;
}
.iac-th-thumb { width: 70px; }
.iac-thumb {
    width: 56px;
    height: 56px;
    object-fit: cover;
    background: var(--clr-surface, #f3f4f6);
    border-radius: 6px;
    border: 1px solid var(--clr-border, #e5e7eb);
    display: block;
}
.iac-badge {
    display: inline-block;
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    padding: 3px 9px;
    border-radius: 999px;
}
.iac-badge-missing { background: rgba(220,38,38,.12);  color: #b91c1c; }
.iac-badge-empty   { background: rgba(217,119,6,.12);  color: #92400e; }
.iac-badge-present { background: rgba(16,185,129,.12); color: #047857; }
.iac-alt-none {
    color: #b91c1c;
    font-style: italic;
    font-size: .82rem;
}
.iac-alt-empty {
    color: #92400e;
    font-style: italic;
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Consolas, monospace;
    font-size: .82rem;
}
[data-theme="dark"] .iac-filter-btn { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); color:var(--clr-text,#d1d5db); }
[data-theme="dark"] .iac-thumb     { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .iac-badge-missing { background:rgba(220,38,38,.22);  color:#fca5a5; }
[data-theme="dark"] .iac-badge-empty   { background:rgba(217,119,6,.22);  color:#fcd34d; }
[data-theme="dark"] .iac-badge-present { background:rgba(16,185,129,.22); color:#34d399; }
[data-theme="dark"] .iac-alt-none  { color:#fca5a5; }
[data-theme="dark"] .iac-alt-empty { color:#fcd34d; }

/* ── Blur Image Background ────────────────────────────────────────────────── */
#bibEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
#bibCanvas {
    max-width: 100%;
    max-height: 540px;
    width: auto;
    height: auto;
    display: block;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
}
.bib-loader {
    position: absolute;
    inset: 0;
    background: rgba(255,255,255,.92);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: .8rem;
    z-index: 5;
}
.bib-loader-spinner {
    width: 42px;
    height: 42px;
    border: 4px solid rgba(117,79,254,.2);
    border-top-color: var(--clr-primary, #754ffe);
    border-radius: 50%;
    animation: bibSpin .7s linear infinite;
}
@keyframes bibSpin { to { transform: rotate(360deg); } }
.bib-loader-text { font-weight: 600; color: var(--clr-heading, #1f2937); }
.bib-tabs {
    display: flex;
    background: var(--clr-surface, #f1f3f5);
    padding: 4px;
    border-radius: 10px;
    gap: 2px;
}
.bib-tab-btn {
    flex: 1;
    padding: .45rem .25rem;
    border: none;
    background: transparent;
    border-radius: 8px;
    font-weight: 600;
    color: var(--clr-muted, #6b7280);
    cursor: pointer;
    transition: background .2s, color .2s, box-shadow .2s;
    font-size: .8rem;
}
.bib-tab-btn.active {
    background: var(--clr-card, #fff);
    color: var(--clr-primary, #754ffe);
    box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.bib-color-row {
    display: flex;
    gap: .5rem;
    align-items: center;
}
.bib-color-input {
    height: 38px !important;
    padding: .15rem !important;
    width: 50px !important;
    cursor: pointer;
    flex-shrink: 0;
}
.bib-hint {
    margin: 0;
    padding: .55rem .7rem;
    background: rgba(117,79,254,.08);
    border-radius: 8px;
    color: var(--clr-primary, #754ffe);
    font-size: .78rem;
}
#bibWrap.aib-fullscreen { position:fixed; inset:0; z-index:99999; background:var(--clr-card,#fff); display:flex; flex-direction:column; padding:0; margin:0; max-width:none; }
#bibWrap.aib-fullscreen #bibEditor { flex:1; border:none; border-radius:0; overflow:hidden; display:flex!important; flex-direction:column; }
#bibWrap.aib-fullscreen .aib-editor-wrap { flex:1; min-height:unset; }
#bibWrap.aib-fullscreen .aib-preview-side { position:relative; }
#bibWrap.aib-fullscreen .aib-fs-close { display:flex; }
[data-theme="dark"] #bibEditor { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .bib-loader { background:rgba(20,18,46,.92); }
[data-theme="dark"] .bib-loader-text { color:var(--clr-heading,#f9fafb); }
[data-theme="dark"] .bib-tabs { background:var(--clr-surface,#28274a); }
[data-theme="dark"] .bib-tab-btn.active { background:var(--clr-card,#1d1c35); }
[data-theme="dark"] .bib-hint { background:rgba(117,79,254,.18); }

/* ── Image Splitter ───────────────────────────────────────────────────────── */
#ispEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
#ispCanvas {
    max-width: 100%;
    max-height: 540px;
    width: auto;
    height: auto;
    display: block;
    flex-shrink: 0;
    box-shadow: 0 8px 28px rgba(0,0,0,.22);
    border-radius: 2px;
}
.isp-stats { gap: .5rem; }
.isp-hint {
    margin: .35rem 0 0;
    font-size: .75rem;
    color: var(--clr-muted, #6b7280);
}
.isp-loader-overlay {
    position: fixed;
    inset: 0;
    background: rgba(255,255,255,.92);
    z-index: 100000;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1rem;
}
.isp-loader-spinner {
    width: 48px;
    height: 48px;
    border: 4px solid rgba(117,79,254,.2);
    border-top-color: var(--clr-primary, #754ffe);
    border-radius: 50%;
    animation: ispSpin .7s linear infinite;
}
@keyframes ispSpin { to { transform: rotate(360deg); } }
.isp-loader-text { font-weight: 600; color: var(--clr-heading, #1f2937); }
#ispWrap.aib-fullscreen { position:fixed; inset:0; z-index:99999; background:var(--clr-card,#fff); display:flex; flex-direction:column; padding:0; margin:0; max-width:none; }
#ispWrap.aib-fullscreen #ispEditor { flex:1; border:none; border-radius:0; overflow:hidden; display:flex!important; flex-direction:column; }
#ispWrap.aib-fullscreen .aib-editor-wrap { flex:1; min-height:unset; }
#ispWrap.aib-fullscreen .aib-preview-side { position:relative; }
#ispWrap.aib-fullscreen .aib-fs-close { display:flex; }
[data-theme="dark"] #ispEditor { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .isp-loader-overlay { background:rgba(20,18,46,.92); }
[data-theme="dark"] .isp-loader-text { color:var(--clr-heading,#f9fafb); }

/* ── Bulk Image Resizer ───────────────────────────────────────────────────── */
.bir-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: .75rem;
}
.bir-card {
    background: var(--clr-surface, #f9fafb);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    overflow: hidden;
    transition: border-color .15s, transform .15s, box-shadow .15s;
}
.bir-card:hover {
    border-color: var(--clr-primary, #754ffe);
    transform: translateY(-2px);
    box-shadow: 0 6px 14px rgba(0,0,0,.08);
}
.bir-thumb-wrap {
    position: relative;
    background: var(--clr-card, #fff);
}
.bir-thumb {
    width: 100%;
    height: 130px;
    object-fit: cover;
    display: block;
}
.bir-remove {
    position: absolute;
    top: 6px;
    right: 6px;
    width: 24px;
    height: 24px;
    border: none;
    border-radius: 50%;
    background: rgba(0,0,0,.6);
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .7rem;
    z-index: 2;
    padding: 0;
    transition: background .15s;
}
.bir-remove:hover { background: #ef4444; }
.bir-info { padding: .65rem .75rem; }
.bir-name {
    font-weight: 600;
    font-size: .8rem;
    color: var(--clr-heading, #1f2937);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.bir-meta {
    display: flex;
    justify-content: space-between;
    margin-top: .15rem;
    font-size: .72rem;
    color: var(--clr-muted, #6b7280);
    gap: .35rem;
}
.bir-meta-orig { font-weight: 600; color: var(--clr-text, #374151); }
.bir-status { margin-top: .45rem; }
.bir-badge {
    display: inline-block;
    font-size: .65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    padding: 3px 8px;
    border-radius: 999px;
}
.bir-badge-ready    { background: rgba(59,130,246,.12); color: #1d4ed8; }
.bir-badge-progress { background: rgba(217,119,6,.12); color: #92400e; }
.bir-badge-error    { background: rgba(220,38,38,.14); color: #b91c1c; }
.bir-result { margin-top: .45rem; }
.bir-result-dims {
    font-size: .72rem;
    color: #047857;
    font-weight: 700;
}
.bir-tabs {
    display: flex;
    background: var(--clr-surface, #f1f3f5);
    padding: 4px;
    border-radius: 10px;
    gap: 2px;
    width: fit-content;
}
.bir-tab-btn {
    padding: .45rem .9rem;
    border: none;
    background: transparent;
    border-radius: 8px;
    font-weight: 600;
    color: var(--clr-muted, #6b7280);
    cursor: pointer;
    transition: background .2s, color .2s, box-shadow .2s;
    font-size: .82rem;
}
.bir-tab-btn.active {
    background: var(--clr-card, #fff);
    color: var(--clr-primary, #754ffe);
    box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.bir-tip {
    margin: 0;
    padding: .55rem .75rem;
    background: rgba(117,79,254,.06);
    border: 1px solid rgba(117,79,254,.18);
    border-radius: 8px;
    font-size: .78rem;
    color: var(--clr-text, #374151);
}
.bir-quality { flex: 1 1 auto; padding: 0 .75rem; }
.bir-global-progress {
    display: flex;
    flex-direction: column;
    gap: .35rem;
}
.bir-global-bar {
    height: 8px;
    background: var(--clr-border, #e5e7eb);
    border-radius: 4px;
    overflow: hidden;
}
.bir-global-fill {
    height: 100%;
    width: 0;
    background: linear-gradient(90deg, var(--clr-primary, #754ffe), #5b3fd9);
    transition: width .25s;
}
.bir-global-text {
    font-size: .82rem;
    color: var(--clr-muted, #6b7280);
    text-align: center;
}
[data-theme="dark"] .bir-card { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .bir-card:hover { background:var(--clr-card,#1d1c35); }
[data-theme="dark"] .bir-thumb-wrap { background:var(--clr-card,#1d1c35); }
[data-theme="dark"] .bir-name { color:var(--clr-heading,#f9fafb); }
[data-theme="dark"] .bir-tabs { background:var(--clr-surface,#28274a); }
[data-theme="dark"] .bir-tab-btn.active { background:var(--clr-card,#1d1c35); }
[data-theme="dark"] .bir-tip { background:rgba(117,79,254,.18); border-color:rgba(117,79,254,.3); color:var(--clr-text,#d1d5db); }
[data-theme="dark"] .bir-global-bar { background:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .bir-badge-ready    { background:rgba(59,130,246,.22); color:#93c5fd; }
[data-theme="dark"] .bir-badge-progress { background:rgba(217,119,6,.22); color:#fcd34d; }
[data-theme="dark"] .bir-badge-error    { background:rgba(220,38,38,.22); color:#fca5a5; }
[data-theme="dark"] .bir-result-dims    { color:#34d399; }

/* ── SEO Checker ──────────────────────────────────────────────────────────── */
#pxSeo .hidden { display: none !important; }
.sc-hero {
    display: flex;
    align-items: center;
    gap: 2rem;
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    padding: 1.75rem;
    margin-bottom: 1rem;
}
.sc-donut-wrap { position: relative; width: 160px; height: 160px; flex-shrink: 0; }
.sc-donut-wrap svg { transform: rotate(-90deg); display: block; }
.sc-donut-center {
    position: absolute; inset: 0;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    pointer-events: none;
}
.sc-donut-num { font-size: 2.6rem; font-weight: 800; line-height: 1; }
.sc-donut-lbl {
    font-size: .65rem;
    color: var(--clr-muted, #6b7280);
    text-transform: uppercase;
    letter-spacing: .6px;
    margin-top: 4px;
}
.sc-cat-bars { flex: 1; min-width: 0; }
.sc-cat-row {
    display: flex; align-items: center; gap: .65rem;
    margin-bottom: .65rem;
}
.sc-cat-row:last-child { margin-bottom: 0; }
.sc-cat-icon { font-size: 1rem; width: 22px; text-align: center; flex-shrink: 0; }
.sc-cat-name {
    font-size: .8rem; font-weight: 600;
    width: 175px; flex-shrink: 0;
    color: var(--clr-text, #374151);
}
.sc-cat-track {
    flex: 1; height: 8px;
    background: var(--clr-border, #e5e7eb);
    border-radius: 4px; overflow: hidden;
    min-width: 40px;
}
.sc-cat-fill {
    height: 100%; border-radius: 4px;
    transition: width 1s cubic-bezier(.4,0,.2,1);
    width: 0;
}
.sc-cat-pct { font-size: .8rem; font-weight: 700; width: 38px; text-align: right; flex-shrink: 0; }
.sc-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: .75rem; margin-bottom: 1rem;
}
.sc-stat {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    padding: .85rem 1rem;
}
.sc-stat-lbl {
    font-size: .68rem; text-transform: uppercase;
    letter-spacing: .6px;
    color: var(--clr-muted, #9ca3af);
    margin-bottom: .25rem; font-weight: 600;
}
.sc-stat-val {
    font-size: 1.1rem; font-weight: 700;
    color: var(--clr-heading, #1f2937); line-height: 1.2;
}
.sc-stat-url {
    font-size: .72rem; font-family: ui-monospace, Menlo, monospace;
    font-weight: 500; color: var(--clr-primary, #754ffe);
    word-break: break-all;
}
.sc-stat-unit, .sc-stat-sub { font-size: .72rem; font-weight: 500; color: var(--clr-muted, #6b7280); margin-left: 2px; }
.sc-stat-warn { color: #f59e0b; font-size: .72rem; font-weight: 500; }
.sc-stat-mini { font-size: .9rem; }
.sc-priority {
    background: rgba(239,68,68,.05);
    border: 1px solid #fecaca;
    border-left: 4px solid #ef4444;
    border-radius: 12px;
    padding: 1.1rem 1.25rem;
    margin-bottom: 1rem;
}
.sc-priority-ttl {
    font-size: .88rem; font-weight: 700;
    color: #991b1b;
    margin-bottom: .75rem;
    display: flex; align-items: center; gap: .35rem;
}
.sc-pri-item {
    display: flex; align-items: flex-start; gap: .5rem;
    margin-bottom: .45rem; font-size: .82rem;
    color: var(--clr-text, #374151);
}
.sc-pri-item:last-child { margin-bottom: 0; }
.sc-pri-dot {
    width: 6px; height: 6px;
    background: #ef4444; border-radius: 50%;
    margin-top: 6px; flex-shrink: 0;
}
.sc-card {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 14px;
    overflow: hidden;
    margin-bottom: .75rem;
}
.sc-card-hdr {
    display: flex; align-items: center; gap: .65rem;
    padding: .9rem 1.2rem;
    cursor: pointer; user-select: none;
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
    transition: background .15s;
}
.sc-card-hdr:hover { background: var(--clr-surface, #fafafa); }
.sc-card-icon { font-size: 1.2rem; }
.sc-card-title { font-size: .95rem; font-weight: 700; flex: 1; color: var(--clr-heading, #1f2937); }
.sc-score-badge {
    font-size: .75rem; font-weight: 700;
    padding: 4px 12px; border-radius: 20px;
    flex-shrink: 0;
}
.sc-sbh { background: rgba(34,197,94,.15);  color: #047857; }
.sc-sbm { background: rgba(245,158,11,.15); color: #92400e; }
.sc-sbl { background: rgba(239,68,68,.15);  color: #991b1b; }
.sc-chevron { font-size: .75rem; color: var(--clr-muted, #9ca3af); transition: transform .25s; flex-shrink: 0; }
.sc-chevron.open { transform: rotate(180deg); }
.sc-prog-wrap { height: 3px; background: var(--clr-border, #e5e7eb); }
.sc-prog-fill { height: 100%; transition: width 1s cubic-bezier(.4,0,.2,1); width: 0; }
.sc-card-body { padding: 0 1.2rem .25rem; }
.sc-check {
    display: flex; align-items: flex-start; gap: .75rem;
    padding: .9rem 0;
    border-bottom: 1px solid var(--clr-border, #f5f5f5);
}
.sc-check:last-child { border-bottom: none; }
.sc-ci {
    width: 26px; height: 26px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: .8rem; font-weight: 700;
    flex-shrink: 0;
    margin-top: 1px;
}
.sc-ci-pass { background: rgba(34,197,94,.15);  color: #059669; }
.sc-ci-warn { background: rgba(245,158,11,.15); color: #d97706; }
.sc-ci-fail { background: rgba(239,68,68,.15);  color: #dc2626; }
.sc-cb { flex: 1; min-width: 0; }
.sc-ct { display: flex; align-items: center; gap: .45rem; flex-wrap: wrap; }
.sc-clbl { font-size: .88rem; font-weight: 600; color: var(--clr-heading, #1f2937); }
.sc-cbadge {
    font-size: .65rem; font-weight: 700;
    padding: 2px 7px; border-radius: 4px;
    text-transform: uppercase; letter-spacing: .03em;
}
.sc-cb-pass { background: rgba(34,197,94,.15);  color: #047857; }
.sc-cb-warn { background: rgba(245,158,11,.15); color: #92400e; }
.sc-cb-fail { background: rgba(239,68,68,.15);  color: #991b1b; }
.sc-cpts { font-size: .72rem; color: var(--clr-muted, #9ca3af); margin-left: auto; flex-shrink: 0; white-space: nowrap; }
.sc-cnote {
    font-size: .82rem;
    color: var(--clr-muted, #6b7280);
    margin-top: .3rem; line-height: 1.55;
}
.sc-cval {
    font-size: .78rem;
    color: var(--clr-text, #374151);
    background: var(--clr-surface, #f9fafb);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 6px;
    padding: .35rem .65rem;
    margin-top: .5rem;
    word-break: break-all;
    font-family: ui-monospace, Menlo, monospace;
}
.sc-cval-img {
    display: flex; align-items: center; gap: .5rem;
    font-family: inherit;
}
.sc-cval-img img {
    height: 44px; width: auto; max-width: 80px;
    border-radius: 4px; object-fit: cover; flex-shrink: 0;
}
.sc-tags { margin-top: .5rem; display: flex; flex-wrap: wrap; gap: .25rem; }
.sc-schema-badge {
    display: inline-block;
    background: rgba(117,79,254,.1);
    border: 1px solid rgba(117,79,254,.25);
    border-radius: 5px;
    padding: 2px 9px;
    font-size: .72rem;
    color: var(--clr-primary, #754ffe);
    font-weight: 600;
}
.sc-section {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 14px;
    padding: 1.25rem;
    margin-bottom: .75rem;
}
.sc-section-ttl {
    font-size: .95rem; font-weight: 700;
    margin: 0 0 1rem;
    display: flex; align-items: center; gap: .5rem;
    color: var(--clr-heading, #1f2937);
}
.sc-table {
    width: 100%; border-collapse: collapse;
    font-size: .85rem;
}
.sc-table th, .sc-table td {
    padding: .55rem .75rem;
    border-bottom: 1px solid var(--clr-border, #f3f4f6);
    text-align: left;
}
.sc-table thead th {
    background: var(--clr-surface, #f9fafb);
    font-weight: 700;
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--clr-muted, #6b7280);
}
.sc-table tbody tr:last-child td { border-bottom: none; }
.sc-kbar-bg { height: 6px; background: var(--clr-border, #e5e7eb); border-radius: 3px; min-width: 60px; }
.sc-kbar-fg { height: 100%; background: var(--clr-primary, #754ffe); border-radius: 3px; }
.sc-reset-row { text-align: center; margin-top: 1.5rem; }
@media (max-width: 700px) {
    .sc-hero { flex-direction: column; gap: 1.25rem; }
    .sc-donut-wrap { margin: 0 auto; }
    .sc-stats { grid-template-columns: repeat(2, 1fr); }
    .sc-cat-name { width: 130px; }
}
[data-theme="dark"] .sc-hero,
[data-theme="dark"] .sc-stat,
[data-theme="dark"] .sc-card,
[data-theme="dark"] .sc-section { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .sc-cat-track,
[data-theme="dark"] .sc-prog-wrap,
[data-theme="dark"] .sc-kbar-bg { background:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .sc-card-hdr:hover { background:var(--clr-surface,#28274a); }
[data-theme="dark"] .sc-cval,
[data-theme="dark"] .sc-table thead th { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); color:var(--clr-text,#d1d5db); }
[data-theme="dark"] .sc-priority { background:rgba(239,68,68,.12); border-color:rgba(239,68,68,.25); }
[data-theme="dark"] .sc-priority-ttl { color:#fca5a5; }
[data-theme="dark"] .sc-sbh, [data-theme="dark"] .sc-cb-pass { background:rgba(34,197,94,.22);  color:#34d399; }
[data-theme="dark"] .sc-sbm, [data-theme="dark"] .sc-cb-warn { background:rgba(245,158,11,.22); color:#fcd34d; }
[data-theme="dark"] .sc-sbl, [data-theme="dark"] .sc-cb-fail { background:rgba(239,68,68,.22);  color:#fca5a5; }

/* ── SEO Compare ──────────────────────────────────────────────────────────── */
#pxSeoCmp .cmp-hidden { display: none !important; }
.cmp-url-label {
    display: block; font-size: .78rem; font-weight: 700;
    letter-spacing: .3px; text-transform: uppercase; margin-bottom: .35rem;
}
.cmp-url-label.cmp-s1, .cmp-c1 { color: #4361ee; }
.cmp-url-label.cmp-s2, .cmp-c2 { color: #7c3aed; }

.cmp-hero {
    display: grid; grid-template-columns: 1fr auto 1fr;
    gap: 1rem; align-items: stretch; margin-top: 1rem; margin-bottom: 1rem;
}
.cmp-hero-card {
    background: var(--clr-card, #fff);
    border: 2px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    padding: 1.5rem 1.25rem;
    text-align: center; position: relative;
}
.cmp-hero-card.cmp-winner {
    border-color: #4361ee;
    box-shadow: 0 0 0 4px rgba(67,97,238,.08);
}
.cmp-winner-tag {
    position: absolute; top: 10px; right: 12px;
    font-size: .68rem; font-weight: 700;
    padding: 3px 10px; border-radius: 20px;
    background: #eef2ff; color: #4361ee;
}
.cmp-fav { width: 16px; height: 16px; border-radius: 3px; vertical-align: middle; margin-right: 5px; }
.cmp-hero-domain {
    font-size: .9rem; font-weight: 700;
    color: var(--clr-heading, #111827); margin-bottom: .15rem;
}
.cmp-hero-url {
    display: block; font-size: .72rem; color: var(--clr-muted, #9ca3af);
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap; margin-bottom: 1rem;
}
.cmp-donut-wrap { position: relative; width: 120px; height: 120px; margin: 0 auto .5rem; }
.cmp-donut-wrap svg { transform: rotate(-90deg); display: block; }
.cmp-donut-center {
    position: absolute; inset: 0;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center; pointer-events: none;
}
.cmp-donut-num { font-size: 2rem; font-weight: 800; line-height: 1; }
.cmp-donut-lbl { font-size: .62rem; color: var(--clr-muted, #6b7280); text-transform: uppercase; letter-spacing: .5px; margin-top: 2px; }
.cmp-hero-badges { display: flex; justify-content: center; gap: 6px; flex-wrap: wrap; margin-top: .8rem; }
.cmp-bd { padding: 3px 10px; border-radius: 20px; font-size: .72rem; font-weight: 600; }
.cmp-bd-pass { background: rgba(16,185,129,.15); color: #047857; }
.cmp-bd-warn { background: rgba(245,158,11,.15); color: #92400e; }
.cmp-bd-fail { background: rgba(239,68,68,.15);  color: #991b1b; }
.cmp-vs { display: flex; align-items: center; justify-content: center; }
.cmp-vs-badge {
    background: var(--clr-surface, #f3f4f6);
    border: 2px solid var(--clr-border, #e5e7eb);
    border-radius: 50%;
    width: 46px; height: 46px;
    display: flex; align-items: center; justify-content: center;
    font-size: .85rem; font-weight: 800;
    color: var(--clr-muted, #6b7280);
}
.cmp-verdict { background: var(--clr-card, #fff); border-left: 4px solid #4361ee; }
.cmp-verdict-row { display: grid; grid-template-columns: 1fr auto 1fr; gap: 1rem; align-items: center; text-align: center; }
.cmp-vw-num { font-size: 2rem; font-weight: 800; }
.cmp-vw-lbl { font-size: .8rem; color: var(--clr-muted, #6b7280); font-weight: 600; }
.cmp-verdict-text { font-size: .85rem; color: var(--clr-muted, #6b7280); font-weight: 600; padding: 0 .75rem; }

.cmp-stats-table {
    width: 100%; border-collapse: collapse; font-size: .85rem;
}
.cmp-stats-table thead tr { background: var(--clr-surface, #f9fafb); }
.cmp-stats-table th {
    padding: .65rem 1rem;
    font-size: .72rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .04em;
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
    text-align: left;
}
.cmp-th-metric { color: var(--clr-muted, #6b7280); }
.cmp-th-s1 { color: #4361ee; text-align: center !important; width: 30%; }
.cmp-th-s2 { color: #7c3aed; text-align: center !important; width: 30%; }
.cmp-stats-table td {
    padding: .55rem 1rem;
    border-bottom: 1px solid var(--clr-border, #f3f4f6);
}
.cmp-stats-table tr:last-child td { border-bottom: none; }
.cmp-stats-table .cmp-th-metric, .cmp-stats-table td:first-child { font-weight: 500; color: var(--clr-text, #374151); }
.cmp-td { text-align: center; color: var(--clr-text, #374151); }
.cmp-td.cmp-win-1 { color: #4361ee; font-weight: 700; }
.cmp-td.cmp-win-2 { color: #7c3aed; font-weight: 700; }
.cmp-stats-table tr:hover td { background: var(--clr-surface, #fafafa); }
.cmp-lbl-pass { display: inline-block; background: rgba(34,197,94,.12); color: #16a34a; font-size: .72rem; font-weight: 700; padding: 2px 8px; border-radius: 4px; }
.cmp-lbl-fail { display: inline-block; background: rgba(239,68,68,.12); color: #dc2626; font-size: .72rem; font-weight: 700; padding: 2px 8px; border-radius: 4px; }

.sc-cmp-card { background: var(--clr-card, #fff); border: 1px solid var(--clr-border, #e5e7eb); border-radius: 14px; overflow: hidden; margin-bottom: .75rem; }
.cmp-card-hdr { display: flex; align-items: center; gap: .65rem; padding: .9rem 1.2rem; cursor: pointer; user-select: none; border-bottom: 1px solid var(--clr-border, #f0f0f0); }
.cmp-card-hdr:hover { background: var(--clr-surface, #fafafa); }
.cmp-acc-pills { display: flex; gap: 6px; }
.cmp-acc-pill { padding: 3px 10px; border-radius: 20px; font-size: .7rem; font-weight: 700; }
.cmp-acc-pill.cmp-c1 { background: #eef2ff; color: #4361ee; }
.cmp-acc-pill.cmp-c2 { background: #f5f3ff; color: #7c3aed; }

.cmp-cat-body { padding: .65rem 1.25rem 1rem; }
.cmp-cat-row { display: grid; grid-template-columns: 1fr 170px 1fr; align-items: center; padding: .75rem 0; border-bottom: 1px solid var(--clr-border, #f3f4f6); }
.cmp-cat-row:last-child { border-bottom: none; }
.cmp-cat-left { display: flex; align-items: center; gap: .65rem; }
.cmp-cat-right { display: flex; align-items: center; gap: .65rem; justify-content: flex-end; }
.cmp-cat-score { font-size: 1rem; font-weight: 800; min-width: 34px; flex-shrink: 0; }
.cmp-bar-track { flex: 1; height: 8px; background: var(--clr-border, #e5e7eb); border-radius: 4px; overflow: hidden; min-width: 50px; }
.cmp-cat-bar { height: 100%; border-radius: 4px; width: 0; transition: width 1s cubic-bezier(.4,0,.2,1); }
.cmp-cat-mid { text-align: center; padding: 0 .65rem; }
.cmp-cat-emoji { display: block; font-size: 1.1rem; line-height: 1; }
.cmp-cat-lbl { display: block; font-size: .72rem; font-weight: 600; color: var(--clr-muted, #6b7280); margin-top: 2px; }

.cmp-col-hdr-row { display: grid; grid-template-columns: 1fr 180px 1fr; background: var(--clr-surface, #f8f9fa); border-bottom: 1px solid var(--clr-border, #e9ecef); }
.cmp-col-hdr { padding: .55rem 1rem; font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; }
.cmp-col-hdr.cmp-c2 { text-align: right; }
.cmp-col-hdr.cmp-mid { text-align: center; color: var(--clr-muted, #9ca3af); border-left: 1px solid var(--clr-border, #f0f0f0); border-right: 1px solid var(--clr-border, #f0f0f0); }
.cmp-chk-row { display: grid; grid-template-columns: 1fr 180px 1fr; border-bottom: 1px solid var(--clr-border, #f9fafb); min-height: 48px; }
.cmp-chk-row:last-child { border-bottom: none; }
.cmp-chk-side { padding: .65rem 1rem; display: flex; align-items: flex-start; gap: .5rem; }
.cmp-chk-side.cmp-chk-right { justify-content: end; flex-direction: row-reverse; }
.cmp-chk-name { padding: .65rem .5rem; font-size: .8rem; font-weight: 600; color: var(--clr-text, #374151); text-align: center; display: flex; align-items: center; justify-content: center; border-left: 1px solid var(--clr-border, #f0f0f0); border-right: 1px solid var(--clr-border, #f0f0f0); background: var(--clr-surface, #fafafa); }
.cmp-ci { width: 22px; height: 22px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: .65rem; font-weight: 700; flex-shrink: 0; margin-top: 1px; }
.cmp-ci-pass { background: rgba(16,185,129,.15); color: #059669; }
.cmp-ci-warn { background: rgba(245,158,11,.15); color: #d97706; }
.cmp-ci-fail { background: rgba(239,68,68,.15);  color: #dc2626; }
.cmp-chk-note { font-size: .77rem; color: var(--clr-muted, #6b7280); line-height: 1.45; }

.cmp-fix-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
.cmp-fix-hdr { font-size: .8rem; font-weight: 700; margin-bottom: .65rem; padding-bottom: .35rem; border-bottom: 2px solid currentColor; opacity: .9; }
.cmp-fix-hdr.cmp-c1 { border-color: #eef2ff; }
.cmp-fix-hdr.cmp-c2 { border-color: #f5f3ff; }
.cmp-fix-item { display: flex; align-items: flex-start; gap: .5rem; margin-bottom: .65rem; }
.cmp-fix-dot { width: 6px; height: 6px; background: #ef4444; border-radius: 50%; margin-top: 6px; flex-shrink: 0; }
.cmp-fix-label { font-size: .82rem; font-weight: 600; color: var(--clr-heading, #111827); }
.cmp-fix-note { font-size: .77rem; color: var(--clr-muted, #6b7280); line-height: 1.45; margin-top: 2px; }
.cmp-no-fails { color: var(--clr-muted, #9ca3af); font-size: .85rem; padding: .5rem 0; }

.cmp-kw-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.cmp-kw-card { background: var(--clr-card, #fff); border: 1px solid var(--clr-border, #e5e7eb); border-radius: 14px; overflow: hidden; }
.cmp-kw-hdr { padding: .65rem 1rem; font-size: .8rem; font-weight: 700; border-bottom: 1px solid var(--clr-border, #f0f0f0); }
.cmp-kw-hdr.cmp-c1 { color: #4361ee; background: #fafbff; }
.cmp-kw-hdr.cmp-c2 { color: #7c3aed; background: #faf8ff; }
.cmp-kw-tbl { width: 100%; border-collapse: collapse; font-size: .82rem; }
.cmp-kw-tbl th, .cmp-kw-tbl td { padding: .45rem .85rem; border-bottom: 1px solid var(--clr-border, #f3f4f6); text-align: left; }
.cmp-kw-tbl thead th { font-size: .68rem; text-transform: uppercase; letter-spacing: .04em; color: var(--clr-muted, #6b7280); font-weight: 700; background: var(--clr-surface, #f9fafb); }
.cmp-kbar-bg { height: 5px; background: var(--clr-border, #e5e7eb); border-radius: 3px; min-width: 50px; }
.cmp-kbar-fg-s1 { height: 100%; background: #4361ee; border-radius: 3px; }
.cmp-kbar-fg-s2 { height: 100%; background: #7c3aed; border-radius: 3px; }
.cmp-empty { padding: .65rem 1rem; color: var(--clr-muted, #9ca3af); font-size: .85rem; }
.cmp-recompare-row { text-align: center; margin: 1.5rem 0; }
@media (max-width: 700px) {
    .cmp-hero { grid-template-columns: 1fr; }
    .cmp-vs { padding: 0; }
    .cmp-cat-row { grid-template-columns: 1fr; gap: .35rem; }
    .cmp-cat-mid { display: flex; align-items: center; gap: .5rem; border-top: 1px solid var(--clr-border, #f0f0f0); padding-top: .5rem; }
    .cmp-col-hdr-row { display: none; }
    .cmp-chk-row { grid-template-columns: 1fr; }
    .cmp-chk-name { border: none; border-top: 1px solid var(--clr-border, #f0f0f0); justify-content: flex-start; text-align: left; }
    .cmp-chk-side.cmp-chk-right { flex-direction: row; justify-content: flex-start; }
    .cmp-kw-grid, .cmp-fix-grid, .cmp-verdict-row { grid-template-columns: 1fr; }
}
[data-theme="dark"] .cmp-hero-card,
[data-theme="dark"] .sc-cmp-card,
[data-theme="dark"] .cmp-kw-card { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .cmp-vs-badge,
[data-theme="dark"] .cmp-bar-track,
[data-theme="dark"] .cmp-kbar-bg { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .cmp-card-hdr:hover,
[data-theme="dark"] .cmp-stats-table thead tr,
[data-theme="dark"] .cmp-chk-name,
[data-theme="dark"] .col-hdr-row { background:var(--clr-surface,#28274a); }
[data-theme="dark"] .cmp-acc-pill.cmp-c1 { background:rgba(67,97,238,.22); color:#a5b4fc; }
[data-theme="dark"] .cmp-acc-pill.cmp-c2 { background:rgba(124,58,237,.22); color:#c4b5fd; }
[data-theme="dark"] .cmp-kw-hdr.cmp-c1 { background:rgba(67,97,238,.12); }
[data-theme="dark"] .cmp-kw-hdr.cmp-c2 { background:rgba(124,58,237,.12); }

/* ── Color Converter ──────────────────────────────────────────────────────── */
#ccoWrap { display: flex; flex-direction: column; }
.cco-card {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    padding: 1.5rem;
}
.cco-section-head {
    font-size: .95rem;
    font-weight: 700;
    color: var(--clr-heading, #1f2937);
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
}
.cco-preview {
    height: 100%;
    min-height: 220px;
    border-radius: 14px;
    border: 1px solid rgba(0,0,0,.08);
    box-shadow: inset 0 0 40px rgba(0,0,0,.05);
    position: relative;
    transition: background-color .15s;
}
.cco-picker-shell {
    position: absolute;
    bottom: 14px; right: 14px;
    width: 50px; height: 50px;
    background: #fff;
    border-radius: 50%;
    box-shadow: 0 4px 14px rgba(0,0,0,.18);
    display: flex; align-items: center; justify-content: center;
    overflow: hidden;
}
.cco-picker-icon {
    position: absolute;
    z-index: 1;
    color: #1f2937;
    font-size: 1.05rem;
    pointer-events: none;
}
.cco-picker {
    -webkit-appearance: none;
    appearance: none;
    border: none;
    width: 100%;
    height: 100%;
    padding: 0;
    background: transparent;
    cursor: pointer;
    opacity: 0;
    z-index: 2;
}
.cco-picker::-webkit-color-swatch-wrapper { padding: 0; }
.cco-picker::-webkit-color-swatch { border: none; border-radius: 50%; }
.cco-label {
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--clr-primary, #754ffe);
    letter-spacing: .8px;
    margin-bottom: .35rem;
    display: block;
}
.cco-universal-in {
    height: 56px;
    font-size: 1.1rem;
    border-radius: 10px;
    background: var(--clr-surface, #f8fafc);
    border: 2px solid transparent;
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Consolas, monospace;
    font-weight: 600;
    color: var(--clr-heading, #1f2937);
    transition: border-color .15s, background .15s;
}
.cco-universal-in:focus {
    background: var(--clr-card, #fff);
    border-color: var(--clr-primary, #754ffe);
    box-shadow: 0 0 0 4px rgba(117,79,254,.12);
    outline: none;
}
.cco-universal-in.is-invalid {
    border-color: #ef4444;
    background: rgba(239,68,68,.05);
}
.cco-result-pill {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .65rem .85rem;
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    transition: border-color .15s;
    height: 100%;
}
.cco-result-pill:hover { border-color: var(--clr-primary, #754ffe); }
.cco-result-label {
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .8px;
    color: var(--clr-muted, #6b7280);
    flex-shrink: 0;
    width: 60px;
}
.cco-fmt-box .cco-result-label { width: auto; display: block; margin-bottom: .35rem; }
.cco-result-val {
    flex: 1 1 auto;
    border: none;
    background: transparent;
    padding: 0;
    color: var(--clr-heading, #1f2937);
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Consolas, monospace;
    font-size: .92rem;
    font-weight: 600;
    cursor: pointer;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
}
.cco-result-val:focus { outline: none; color: var(--clr-primary, #754ffe); }
.cco-copy-btn {
    border: none;
    background: var(--clr-surface, #f3f4f6);
    color: var(--clr-muted, #6b7280);
    padding: .35rem .55rem;
    border-radius: 6px;
    cursor: pointer;
    transition: background .15s, color .15s;
    flex-shrink: 0;
    line-height: 1;
}
.cco-copy-btn:hover { background: var(--clr-primary, #754ffe); color: #fff; }
.cco-copy-mini {
    background: transparent;
    padding: .25rem .35rem;
    font-size: .85rem;
}
.cco-fmt-box {
    background: var(--clr-surface, #f9fafb);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    padding: .75rem .85rem;
    height: 100%;
}
.cco-fmt-row {
    display: flex;
    align-items: center;
    gap: .35rem;
}
.cco-toast {
    position: fixed;
    bottom: 24px;
    left: 50%;
    transform: translate(-50%, 10px);
    background: #111827;
    color: #fff;
    padding: 10px 22px;
    border-radius: 999px;
    font-size: .9rem;
    font-weight: 600;
    box-shadow: 0 8px 22px rgba(0,0,0,.22);
    opacity: 0;
    transition: opacity .25s, transform .25s;
    z-index: 100000;
    pointer-events: none;
    display: inline-flex;
    align-items: center;
}
.cco-toast.show { opacity: 1; transform: translate(-50%, 0); }
.cco-toast.cco-toast-error { background: #b91c1c; }
[data-theme="dark"] .cco-card,
[data-theme="dark"] .cco-result-pill { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .cco-universal-in { background:var(--clr-surface,#28274a); color:var(--clr-text,#f9fafb); }
[data-theme="dark"] .cco-universal-in:focus { background:var(--clr-card,#1d1c35); }
[data-theme="dark"] .cco-result-val { color:var(--clr-text,#f9fafb); }
[data-theme="dark"] .cco-fmt-box { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .cco-copy-btn { background:var(--clr-surface,#28274a); color:var(--clr-text,#d1d5db); }

/* ── CSS Grid Generator ───────────────────────────────────────────────────── */
#cggWrap {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    padding: 1.5rem;
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
}
.cgg-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: .65rem;
    align-items: center;
    justify-content: center;
}
.cgg-control {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .35rem .85rem;
    background: var(--clr-surface, #f3f4f6);
    border: 1px solid var(--clr-border, #d1d5db);
    border-radius: 8px;
}
.cgg-control-lbl {
    font-size: .85rem;
    color: var(--clr-text, #374151);
    font-weight: 600;
}
.cgg-control-unit {
    font-size: .75rem;
    color: var(--clr-muted, #6b7280);
    font-weight: 500;
}
.cgg-num {
    width: 56px;
    padding: .25rem .35rem;
    border: none;
    border-radius: 4px;
    background: var(--clr-heading, #1f2937);
    color: #fff;
    text-align: center;
    font-size: .9rem;
    font-weight: 600;
    -moz-appearance: textfield;
    appearance: textfield;
}
.cgg-num::-webkit-outer-spin-button,
.cgg-num::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
.cgg-reset { margin-left: .25rem; }
.cgg-stage {
    background: var(--clr-surface, #f9fafb);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    padding: 1.5rem;
}
.cgg-grid {
    display: grid;
    user-select: none;
    position: relative;
    width: 100%;
}
.cgg-cell-empty {
    background: #b5b2ad;
    border-radius: 5px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 1.2rem;
    font-weight: 300;
    min-height: 80px;
    cursor: pointer;
    transition: background .15s, transform .1s;
}
.cgg-cell-empty:hover,
.cgg-cell-empty.cgg-drag-over {
    background: var(--clr-primary, #754ffe);
    transform: scale(1.02);
}
.cgg-item {
    background: #fdfdf9;
    border: 1px solid #111;
    border-radius: 6px;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #111;
    z-index: 10;
    cursor: move;
    box-shadow: inset 0 0 0 1px rgba(0,0,0,.1);
    overflow: hidden;
}
.cgg-item-num {
    font-size: 1.05rem;
    font-weight: 600;
}
.cgg-item-del {
    position: absolute;
    top: 0; right: 0;
    background: #dc3545;
    color: #fff;
    width: 22px; height: 22px;
    font-size: .85rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    border-radius: 0 5px 0 4px;
    cursor: pointer;
    padding: 0;
    line-height: 1;
}
.cgg-item-del:hover { background: #b91c1c; }
.cgg-item-resize {
    position: absolute;
    bottom: 0; right: 0;
    width: 18px; height: 18px;
    cursor: se-resize;
}
.cgg-item-resize::after {
    content: '';
    position: absolute;
    bottom: 3px; right: 3px;
    width: 8px; height: 8px;
    border-right: 4px solid #111;
    border-bottom: 4px solid #111;
    border-radius: 0 0 3px 0;
}
.cgg-hint {
    margin: 1rem 0 0;
    text-align: center;
    font-size: .82rem;
    color: var(--clr-muted, #6b7280);
}
.cgg-hint strong { color: var(--clr-primary, #754ffe); font-weight: 700; }
.cgg-code-card {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 12px;
    overflow: hidden;
    height: 100%;
    display: flex;
    flex-direction: column;
}
.cgg-code-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .75rem 1rem;
    background: var(--clr-surface, #f9fafb);
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
}
.cgg-code-title {
    font-size: .85rem;
    font-weight: 700;
    color: var(--clr-heading, #1f2937);
    text-transform: uppercase;
    letter-spacing: .04em;
}
.cgg-code {
    margin: 0;
    padding: 1rem 1.25rem;
    background: #0e172a;
    color: #f9fafb;
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Consolas, monospace;
    font-size: .82rem;
    line-height: 1.55;
    min-height: 220px;
    max-height: 280px;
    overflow-y: auto;
    white-space: pre-wrap;
    flex: 1;
}
.cgg-toast {
    position: fixed;
    bottom: 24px;
    right: 24px;
    background: #111827;
    color: #fff;
    padding: 10px 18px;
    border-radius: 8px;
    font-size: .9rem;
    font-weight: 600;
    box-shadow: 0 8px 22px rgba(0,0,0,.22);
    opacity: 0;
    transform: translateY(10px);
    transition: opacity .25s, transform .25s;
    z-index: 100000;
    pointer-events: none;
    display: inline-flex;
    align-items: center;
}
.cgg-toast.show { opacity: 1; transform: translateY(0); }
.cgg-toast.cgg-toast-error { background: #b91c1c; }
[data-theme="dark"] #cggWrap { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .cgg-stage { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .cgg-control { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .cgg-control-lbl { color:var(--clr-text,#d1d5db); }
[data-theme="dark"] .cgg-code-card { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .cgg-code-head { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .cgg-code-title { color:var(--clr-heading,#f9fafb); }

/* ── SharePad ─────────────────────────────────────────────────────────────── */
#spdWrap {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 14px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.spd-header {
    padding: .9rem 1.25rem;
    background: var(--clr-surface, #f8fafc);
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: .65rem;
}
.spd-title {
    margin: 0;
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--clr-heading, #0f172a);
    display: flex;
    align-items: center;
}
.spd-controls {
    display: flex;
    gap: .35rem;
    flex-wrap: wrap;
}
.spd-btn-danger { color: #ef4444 !important; border-color: #fecaca !important; }
.spd-btn-danger:hover {
    background: #fef2f2 !important;
    color: #dc2626 !important;
    border-color: #f87171 !important;
}
#spdEditor {
    height: 460px;
    font-family: inherit;
}
#spdWrap .ql-toolbar.ql-snow {
    border: none !important;
    border-bottom: 1px solid var(--clr-border, #e5e7eb) !important;
    padding: .65rem 1.25rem !important;
    background: var(--clr-card, #fff);
    font-family: inherit;
}
#spdWrap .ql-container.ql-snow { border: none !important; }
#spdWrap .ql-editor {
    padding: 1.5rem !important;
    font-size: 1rem;
    line-height: 1.65;
    color: var(--clr-text, #334155);
    min-height: 360px;
}
.spd-footer {
    padding: .65rem 1.25rem;
    border-top: 1px solid var(--clr-border, #e5e7eb);
    background: var(--clr-surface, #f8fafc);
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: .82rem;
    color: var(--clr-muted, #64748b);
    font-weight: 500;
    flex-wrap: wrap;
    gap: .35rem;
}
.spd-savestate { display: flex; align-items: center; }
.spd-savestate.spd-saving { color: #d97706; }
.spd-toast {
    position: fixed;
    bottom: 24px; right: 24px;
    background: #10b981;
    color: #fff;
    padding: 12px 22px;
    border-radius: 8px;
    font-size: .9rem;
    font-weight: 600;
    box-shadow: 0 8px 22px rgba(0,0,0,.18);
    transform: translateY(20px);
    opacity: 0;
    transition: transform .25s, opacity .25s;
    z-index: 100000;
    pointer-events: none;
    display: inline-flex;
    align-items: center;
}
.spd-toast.show { transform: translateY(0); opacity: 1; }
.spd-toast.spd-toast-error { background: #ef4444; }
@media (max-width: 700px) {
    .spd-header { flex-direction: column; align-items: stretch; }
    .spd-controls { width: 100%; }
    .spd-controls .btn { flex: 1 1 calc(50% - .35rem); justify-content: center; }
    #spdEditor { height: 380px; }
}
[data-theme="dark"] #spdWrap { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .spd-header,
[data-theme="dark"] .spd-footer { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .spd-title { color:var(--clr-heading,#f9fafb); }
[data-theme="dark"] #spdWrap .ql-toolbar.ql-snow { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e) !important; }
[data-theme="dark"] #spdWrap .ql-toolbar.ql-snow svg .ql-stroke { stroke:var(--clr-text,#d1d5db); }
[data-theme="dark"] #spdWrap .ql-toolbar.ql-snow svg .ql-fill { fill:var(--clr-text,#d1d5db); }
[data-theme="dark"] #spdWrap .ql-editor { color:var(--clr-text,#d1d5db); }

/* ── GIF to JPG ───────────────────────────────────────────────────────────── */
.g2j-progress {
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 14px;
    padding: 2rem 1.5rem;
    margin-top: 1rem;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .8rem;
}
.g2j-spinner {
    width: 42px;
    height: 42px;
    border: 4px solid rgba(117,79,254,.18);
    border-top-color: var(--clr-primary, #754ffe);
    border-radius: 50%;
    animation: g2jSpin .7s linear infinite;
}
@keyframes g2jSpin { to { transform: rotate(360deg); } }
.g2j-status {
    font-weight: 600;
    color: var(--clr-text, #475569);
    font-size: .9rem;
}
.g2j-bar {
    width: 100%;
    max-width: 320px;
    height: 8px;
    background: var(--clr-border, #e5e7eb);
    border-radius: 4px;
    overflow: hidden;
}
.g2j-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--clr-primary, #754ffe), #5b3fd9);
    width: 0;
    transition: width .25s ease;
}
.g2j-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: .75rem;
}
.g2j-card {
    background: var(--clr-surface, #f9fafb);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    overflow: hidden;
    transition: border-color .15s, transform .15s, box-shadow .15s;
}
.g2j-card:hover {
    border-color: var(--clr-primary, #754ffe);
    transform: translateY(-2px);
    box-shadow: 0 4px 14px rgba(0,0,0,.08);
}
.g2j-thumb-wrap {
    background: #fff;
    background-image:
        linear-gradient(45deg, #f0f0f0 25%, transparent 25%, transparent 75%, #f0f0f0 75%, #f0f0f0),
        linear-gradient(45deg, #f0f0f0 25%, transparent 25%, transparent 75%, #f0f0f0 75%, #f0f0f0);
    background-size: 16px 16px;
    background-position: 0 0, 8px 8px;
    aspect-ratio: 1 / 1;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.g2j-thumb {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    display: block;
}
.g2j-info {
    padding: .55rem .75rem .65rem;
}
.g2j-name {
    font-size: .82rem;
    font-weight: 600;
    color: var(--clr-text, #374151);
    text-align: center;
}
[data-theme="dark"] .g2j-progress { background:var(--clr-card,#1d1c35); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .g2j-card { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); }
[data-theme="dark"] .g2j-card:hover { background:var(--clr-card,#1d1c35); }
[data-theme="dark"] .g2j-name { color:var(--clr-text,#d1d5db); }
[data-theme="dark"] .g2j-bar { background:var(--clr-border,#2d2b4e); }

/* ── SSL Checker ──────────────────────────────────────────────────────────── */
.ssl-banner-warn {
    background: rgba(245,158,11,.08);
    border: 1px solid rgba(245,158,11,.3);
}
.ssl-icon-warn {
    background: rgba(245,158,11,.15);
    color: #b45309;
}
.ssl-banner-urgent {
    background: rgba(239,68,68,.08);
    border: 1px solid rgba(239,68,68,.3);
}
.ssl-icon-urgent {
    background: rgba(239,68,68,.15);
    color: #b91c1c;
}
.ssl-san-list {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
    padding: .85rem 1rem;
}
.ssl-san-pill {
    display: inline-block;
    background: var(--clr-surface, #f3f4f6);
    border: 1px solid var(--clr-border, #e5e7eb);
    color: var(--clr-text, #374151);
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Consolas, monospace;
    font-size: .78rem;
    padding: 3px 9px;
    border-radius: 4px;
    word-break: break-all;
}
#sslWrap .nic-detail-val.mono {
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Consolas, monospace;
    font-size: .8rem;
    word-break: break-all;
}
[data-theme="dark"] .ssl-banner-warn   { background:rgba(245,158,11,.14); border-color:rgba(245,158,11,.32); }
[data-theme="dark"] .ssl-icon-warn     { background:rgba(245,158,11,.22); color:#fcd34d; }
[data-theme="dark"] .ssl-banner-urgent { background:rgba(239,68,68,.14); border-color:rgba(239,68,68,.32); }
[data-theme="dark"] .ssl-icon-urgent   { background:rgba(239,68,68,.22); color:#fca5a5; }
[data-theme="dark"] .ssl-san-pill      { background:var(--clr-surface,#28274a); border-color:var(--clr-border,#2d2b4e); color:var(--clr-text,#d1d5db); }

/* ── PDF to Image: page picker ─────────────────────────── */
.p2i-prev-card { position:relative; cursor:pointer; transition:transform .15s ease, border-color .15s ease, box-shadow .15s ease; }
.p2i-prev-card.is-selected { border-color:var(--clr-primary,#754ffe); box-shadow:0 0 0 2px rgba(117,79,254,.18); }
.p2i-prev-card.is-skipped  { opacity:.45; }
.p2i-prev-card.is-skipped .g2j-thumb { filter:grayscale(1); }
.p2i-prev-card:hover { transform:translateY(-2px); }
.p2i-prev-check {
    position:absolute; top:8px; right:8px; z-index:2;
    width:20px; height:20px; cursor:pointer; accent-color:var(--clr-primary,#754ffe);
}
.p2i-prev-thumb-wrap { min-height:140px; display:flex; align-items:center; justify-content:center; }
.p2i-thumb-spinner { display:flex; align-items:center; justify-content:center; padding:1.5rem 0; }
[data-theme="dark"] .p2i-prev-card.is-selected { box-shadow:0 0 0 2px rgba(117,79,254,.32); }

/* ── Color Palette Generator ───────────────────────────── */
.cpg-color-input {
    width: 36px; height: 36px; padding: 0; border: 0; cursor: pointer; background: none; border-radius: 6px;
}
.cpg-color-input::-webkit-color-swatch-wrapper { padding: 0; }
.cpg-color-input::-webkit-color-swatch { border: 1px solid var(--clr-border, #d1d5db); border-radius: 6px; }
.cpg-mode-select { min-width: 170px; }
.cpg-kbd {
    display: inline-block; padding: 1px 6px; font-size: .7rem; font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    background: rgba(255,255,255,.22); border: 1px solid rgba(255,255,255,.35); border-radius: 4px; line-height: 1;
}
.cpg-palette {
    display: grid; grid-template-columns: repeat(5, 1fr);
    height: 360px; border-radius: 16px; overflow: hidden;
    box-shadow: 0 10px 25px -10px rgba(0,0,0,.18); margin: 1.25rem 0 1rem;
}
.cpg-swatch {
    position: relative; padding: 18px 12px; cursor: copy;
    display: flex; flex-direction: column; justify-content: flex-end;
    transition: flex .25s ease;
}
.cpg-swatch:hover { flex: 1.25; }
.cpg-swatch-foot { text-align: center; }
.cpg-hex {
    display: inline-block; padding: 7px 14px; min-width: 96px;
    background: rgba(255,255,255,.92); color: #1f2937;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-weight: 700; letter-spacing: .5px;
    border-radius: 8px; box-shadow: 0 4px 10px rgba(0,0,0,.12);
    transition: transform .15s ease;
}
.cpg-swatch:hover .cpg-hex { transform: translateY(-2px); }
.cpg-copy-cue {
    margin-top: 6px; font-size: .72rem; opacity: 0; transition: opacity .2s ease;
    text-shadow: 0 1px 2px rgba(0,0,0,.2);
}
.cpg-swatch:hover .cpg-copy-cue { opacity: .9; }
.cpg-lock-btn {
    position: absolute; top: 12px; right: 12px;
    width: 34px; height: 34px; border-radius: 50%;
    background: rgba(255,255,255,.18); border: 1.5px solid currentColor;
    display: inline-flex; align-items: center; justify-content: center;
    opacity: 0; transform: translateY(-6px); transition: all .2s ease; cursor: pointer;
    padding: 0 !important;
}
.cpg-swatch:hover .cpg-lock-btn { opacity: 1; transform: translateY(0); }
.cpg-lock-btn.is-locked { opacity: 1; transform: translateY(0); background: rgba(255,255,255,.95); color: #b91c1c !important; border-color: rgba(255,255,255,.95); }
.cpg-hint {
    color: var(--clr-muted, #6b7280); font-size: .85rem; text-align: center; margin: .5rem 0 0;
}
@media (max-width: 768px) {
    .cpg-palette { grid-template-columns: 1fr; height: auto; }
    .cpg-swatch { flex: 1 1 auto !important; height: 110px; }
    .cpg-swatch:hover { flex: 1 1 auto !important; }
    .cpg-lock-btn { opacity: 1; transform: translateY(0); }
    .cpg-mode-select { min-width: 0; flex: 1; }
}
[data-theme="dark"] .cpg-hex { background: rgba(255,255,255,.88); }
[data-theme="dark"] .cpg-color-input::-webkit-color-swatch { border-color: var(--clr-border, #2d2b4e); }

/* Variable column count — 5 normal, 8 in fullscreen */
.cpg-palette { grid-template-columns: repeat(var(--cpg-cols, 5), 1fr); }

/* Fullscreen mode — locks scroll, fills viewport, palette grows to fill */
body.cpg-fs-lock { overflow: hidden; }
#cpgWrap.cpg-fullscreen {
    position: fixed; inset: 0; z-index: 9999;
    background: var(--clr-bg, #ffffff);
    padding: 1rem 1.25rem 1.25rem;
    display: flex; flex-direction: column;
    margin: 0;
}
#cpgWrap.cpg-fullscreen .cgg-toolbar { flex: 0 0 auto; }
#cpgWrap.cpg-fullscreen .cpg-palette {
    flex: 1 1 auto; height: auto; min-height: 0;
    margin: 1rem 0 .5rem; border-radius: 12px;
}
#cpgWrap.cpg-fullscreen .cpg-hint { flex: 0 0 auto; margin: 0; }
#cpgWrap.cpg-fullscreen .cpg-lock-btn { opacity: 1; transform: translateY(0); }
[data-theme="dark"] #cpgWrap.cpg-fullscreen { background: var(--clr-bg, #14132c); }

/* On small screens the 8-col fullscreen layout would be cramped — wrap responsibly */
@media (max-width: 992px) {
    #cpgWrap.cpg-fullscreen .cpg-palette { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 600px) {
    #cpgWrap.cpg-fullscreen .cpg-palette { grid-template-columns: repeat(2, 1fr); }
}

/* ── Mailto Link Generator: Gmail-style compose rows ──────── */
.mlg-compose { padding: 0; }
.mlg-row {
    display: flex; align-items: center; gap: .85rem;
    padding: .85rem 1.15rem;
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
    transition: background .15s ease;
}
.mlg-row:hover { background: rgba(117,79,254,.025); }
.mlg-row:last-child { border-bottom: 0; }
.mlg-row-label {
    flex: 0 0 78px;
    font-weight: 600;
    color: var(--clr-heading, #111827);
    font-size: .92rem;
    margin: 0;
}
.mlg-row-input {
    flex: 1 1 auto;
    border: 0; outline: 0; background: transparent;
    color: var(--clr-text, #111827);
    font-size: .98rem;
    padding: .35rem 0;
    box-shadow: none !important;
    min-width: 0;
}
.mlg-row-input::placeholder { color: var(--clr-muted, #9ca3af); }
.mlg-row-input:focus { outline: 0; box-shadow: none; }
.mlg-row-actions { display: flex; gap: .35rem; flex: 0 0 auto; }

/* Cc / Bcc pills */
.mlg-pill {
    border: 1px solid var(--clr-border, #d1d5db);
    background: transparent;
    color: var(--clr-muted, #6b7280);
    padding: .2rem .8rem;
    border-radius: 999px;
    font-size: .78rem; font-weight: 600; line-height: 1.5;
    cursor: pointer; transition: all .15s ease;
}
.mlg-pill:hover { color: var(--clr-primary, #754ffe); border-color: var(--clr-primary, #754ffe); }
.mlg-pill.is-active {
    background: var(--clr-primary, #754ffe);
    border-color: var(--clr-primary, #754ffe);
    color: #fff;
}

/* Stacked row (Body) */
.mlg-row-stack { flex-direction: column; align-items: stretch; gap: .25rem; }
.mlg-row-stack .mlg-row-label { flex: 0 0 auto; margin-bottom: .15rem; }
.mlg-textarea { resize: vertical; min-height: 140px; line-height: 1.55; padding-top: .25rem; }

/* Soft row (Link Text) — secondary visual weight */
.mlg-row-soft { background: var(--clr-surface, #fafafa); }
.mlg-row-hint { font-size: .78rem; color: var(--clr-muted, #6b7280); flex: 0 0 auto; }

/* To-row validation states (left accent stripe) */
.mlg-row.is-valid   { box-shadow: inset 3px 0 0 0 #10b981; }
.mlg-row.is-invalid { box-shadow: inset 3px 0 0 0 #ef4444; }

/* Validity strip below the To row */
.mlg-validity {
    padding: .5rem 1.15rem;
    font-size: .82rem;
    color: var(--clr-muted, #6b7280);
    background: var(--clr-surface, #fafafa);
    border-bottom: 1px solid var(--clr-border, #e5e7eb);
}
.mlg-validity.is-ok  { color: #047857; background: rgba(16,185,129,.08); }
.mlg-validity.is-bad { color: #b91c1c; background: rgba(239,68,68,.08); }

@media (max-width: 575px) {
    .mlg-row { flex-wrap: wrap; padding: .7rem .9rem; }
    .mlg-row-label { flex: 0 0 100%; margin-bottom: .15rem; }
    .mlg-row-actions { flex: 0 0 100%; }
    .mlg-row-hint { flex: 0 0 100%; }
    .mlg-validity { padding: .5rem .9rem; }
}

[data-theme="dark"] .mlg-row { border-bottom-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .mlg-row:hover { background: rgba(117,79,254,.06); }
[data-theme="dark"] .mlg-row-label { color: var(--clr-heading-dark, #f1f5f9); }
[data-theme="dark"] .mlg-row-input { color: var(--clr-text, #d1d5db); }
[data-theme="dark"] .mlg-pill { border-color: var(--clr-border, #2d2b4e); color: var(--clr-text, #94a3b8); }
[data-theme="dark"] .mlg-row-soft { background: var(--clr-surface, #28274a); }
[data-theme="dark"] .mlg-validity { background: var(--clr-surface, #28274a); border-bottom-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .mlg-validity.is-ok  { background: rgba(16,185,129,.14); color: #86efac; }
[data-theme="dark"] .mlg-validity.is-bad { background: rgba(239,68,68,.14); color: #fca5a5; }

/* ── What Is My IP ─────────────────────────────────────── */
.wimi-hero {
    padding: 2.25rem 1.5rem 2rem;
    background: linear-gradient(135deg, rgba(117,79,254,.08), rgba(117,79,254,0) 60%);
}
.wimi-hero-eyebrow {
    font-size: .72rem; letter-spacing: 1.5px; text-transform: uppercase;
    color: var(--clr-muted, #6b7280); font-weight: 700; margin-bottom: .85rem;
}
.wimi-ip {
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Consolas, monospace;
    font-size: clamp(1.6rem, 4.5vw, 2.6rem);
    font-weight: 800; letter-spacing: -.5px;
    color: var(--clr-primary, #754ffe);
    margin: 0 0 .35rem; word-break: break-all; line-height: 1.15;
    transition: opacity .25s ease;
}
.wimi-ip.is-loading { opacity: .5; }
.wimi-ip-meta {
    font-size: .85rem; color: var(--clr-muted, #6b7280);
    margin-bottom: 1.4rem; min-height: 1.2em;
}
.wimi-hero-actions { display: flex; gap: .65rem; justify-content: center; flex-wrap: wrap; }
.wimi-map-card iframe { display: block; width: 100%; }
[data-theme="dark"] .wimi-hero {
    background: linear-gradient(135deg, rgba(117,79,254,.18), rgba(117,79,254,0) 60%);
}

/* ── Campaign URL Builder ──────────────────────────────── */
.cub-out-box { padding: 1rem 1.15rem 1.15rem; }
.cub-out-text {
    background: var(--clr-surface, #f9fafb);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    padding: .85rem 1rem;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: .9rem;
    line-height: 1.55;
    color: var(--clr-heading, #111827);
    word-break: break-all;
    min-height: 56px;
}
.cub-out-text.cub-empty { color: var(--clr-muted, #9ca3af); font-style: italic; font-family: inherit; }
[data-theme="dark"] .cub-out-text { background: var(--clr-surface, #28274a); border-color: var(--clr-border, #2d2b4e); color: var(--clr-text, #d1d5db); }

/* ── SVG Converter ─────────────────────────────────────── */
.svg-pane-label {
    font-size: .78rem; font-weight: 700; letter-spacing: .5px; text-transform: uppercase;
    color: var(--clr-muted, #6b7280); text-align: center; margin-bottom: .5rem;
}
.svg-pane-meta {
    font-size: .8rem; color: var(--clr-muted, #6b7280);
    text-align: center; margin-top: .5rem;
}
.svg-checkered {
    background-color: #ffffff;
    background-image:
        linear-gradient(45deg,  #e9ecef 25%, transparent 25%),
        linear-gradient(-45deg, #e9ecef 25%, transparent 25%),
        linear-gradient(45deg,  transparent 75%, #e9ecef 75%),
        linear-gradient(-45deg, transparent 75%, #e9ecef 75%);
    background-size: 20px 20px;
    background-position: 0 0, 0 10px, 10px -10px, -10px 0;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    padding: .5rem;
    min-height: 180px;
    display: flex; align-items: center; justify-content: center;
}
.svg-checkered img,
.svg-checkered svg,
.svg-checkered canvas {
    max-width: 100%; height: auto; display: block; margin: 0 auto;
}
[data-theme="dark"] .svg-checkered {
    background-color: #1d1c35; border-color: var(--clr-border, #2d2b4e);
    background-image:
        linear-gradient(45deg,  #28274a 25%, transparent 25%),
        linear-gradient(-45deg, #28274a 25%, transparent 25%),
        linear-gradient(45deg,  transparent 75%, #28274a 75%),
        linear-gradient(-45deg, transparent 75%, #28274a 75%);
}

/* ── Favicon Checker ───────────────────────────────────── */
.fav-row {
    display: flex; align-items: center; gap: 1rem;
    padding: .85rem 1.15rem;
    border-bottom: 1px solid var(--clr-border, #f1f5f9);
}
.fav-row:last-child { border-bottom: 0; }
.fav-thumb {
    width: 48px; height: 48px; flex: 0 0 48px;
    display: flex; align-items: center; justify-content: center;
    background: #fff; border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 8px; overflow: hidden; color: var(--clr-muted, #9ca3af);
}
.fav-thumb img { max-width: 100%; max-height: 100%; }
.fav-thumb.is-bad { background: rgba(239,68,68,.06); border-color: rgba(239,68,68,.25); color: #ef4444; }
.fav-info { flex: 1 1 auto; min-width: 0; }
.fav-info-head {
    display: flex; justify-content: space-between; align-items: center;
    gap: .5rem; flex-wrap: wrap; margin-bottom: 2px;
}
.fav-type {
    font-weight: 700; color: var(--clr-heading, #111827); font-size: .9rem;
    text-transform: capitalize;
}
.fav-status {
    font-size: .72rem; font-weight: 700; letter-spacing: .3px;
    padding: 2px 9px; border-radius: 999px; white-space: nowrap;
}
.fav-status.is-good { background: rgba(16,185,129,.14); color: #047857; }
.fav-status.is-bad  { background: rgba(239,68,68,.14);  color: #b91c1c; }
.fav-src {
    display: block; font-size: .82rem; color: var(--clr-muted, #6b7280);
    text-decoration: none; word-break: break-all; line-height: 1.4;
}
.fav-src:hover { color: var(--clr-primary, #754ffe); text-decoration: underline; }
.fav-meta { margin-top: 4px; display: flex; flex-wrap: wrap; gap: .35rem; }
.fav-meta-pill {
    display: inline-block; font-size: .7rem; font-weight: 600;
    padding: 1px 8px; border-radius: 999px;
    background: var(--clr-surface, #f3f4f6); color: var(--clr-muted, #6b7280);
    border: 1px solid var(--clr-border, #e5e7eb);
}
.fav-empty { padding: 1.5rem; text-align: center; color: var(--clr-muted, #6b7280); }

[data-theme="dark"] .fav-row { border-bottom-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .fav-thumb { background: var(--clr-surface, #28274a); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .fav-type { color: var(--clr-heading-dark, #f1f5f9); }
[data-theme="dark"] .fav-meta-pill { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); color: var(--clr-text, #94a3b8); }
[data-theme="dark"] .fav-status.is-good { background: rgba(16,185,129,.18); color: #6ee7b7; }
[data-theme="dark"] .fav-status.is-bad  { background: rgba(239,68,68,.18); color: #fca5a5; }

/* ── Favicon Generator ─────────────────────────────────── */
.favg-ico-card {
    display: flex; align-items: center; gap: 1rem;
    padding: 1rem 1.15rem;
    margin: 0 1.15rem 1rem;
    background: linear-gradient(135deg, rgba(117,79,254,.10), rgba(117,79,254,0) 70%);
    border: 1px solid rgba(117,79,254,.25);
    border-radius: 12px;
}
.favg-ico-thumb {
    width: 64px; height: 64px; flex: 0 0 64px;
    display: flex; align-items: center; justify-content: center;
    background: #fff; border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px; padding: 6px;
    box-shadow: 0 4px 12px -6px rgba(117,79,254,.35);
}
.favg-ico-thumb img { max-width: 100%; max-height: 100%; }
.favg-ico-info  { flex: 1 1 auto; min-width: 0; }
.favg-ico-title { font-weight: 700; color: var(--clr-heading, #111827); margin-bottom: 2px; font-size: 1rem; }
.favg-ico-desc  { font-size: .85rem; color: var(--clr-muted, #6b7280); line-height: 1.45; }

.favg-section-head {
    display: flex; justify-content: space-between; align-items: center;
    padding: .25rem 1.25rem .65rem;
    color: var(--clr-heading, #111827); font-weight: 600; font-size: .92rem;
}
.favg-section-hint {
    font-size: .75rem; color: var(--clr-muted, #6b7280); font-weight: 500;
}

.favg-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: .85rem;
    padding: 0 1.15rem 1.25rem;
}
.favg-tile {
    display: flex; flex-direction: column; align-items: center;
    padding: 1rem .75rem .85rem;
    background: var(--clr-card, #fff);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    text-decoration: none !important;
    color: inherit;
    transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease;
}
.favg-tile:hover {
    transform: translateY(-2px);
    border-color: var(--clr-primary, #754ffe);
    box-shadow: 0 10px 22px -10px rgba(117,79,254,.35);
    color: inherit;
}
.favg-tile-preview {
    width: 80px; height: 80px;
    display: flex; align-items: center; justify-content: center;
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 8px;
    background-color: #fff;
    background-image:
        linear-gradient(45deg,  #eee 25%, transparent 25%),
        linear-gradient(-45deg, #eee 25%, transparent 25%),
        linear-gradient(45deg,  transparent 75%, #eee 75%),
        linear-gradient(-45deg, transparent 75%, #eee 75%);
    background-size: 12px 12px;
    background-position: 0 0, 0 6px, 6px -6px, -6px 0;
    margin-bottom: .65rem;
}
.favg-tile-preview img { display: block; image-rendering: pixelated; }
.favg-tile-size {
    font-weight: 700; font-size: .92rem;
    color: var(--clr-heading, #111827);
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    letter-spacing: -.3px;
}
.favg-tile-use {
    font-size: .72rem; color: var(--clr-muted, #6b7280);
    margin-bottom: .55rem; text-align: center;
    min-height: 2em; line-height: 1.3;
}
.favg-tile-action {
    display: inline-flex; align-items: center;
    font-size: .7rem; font-weight: 600; letter-spacing: .2px;
    padding: 4px 11px; border-radius: 999px;
    background: var(--clr-surface, #f3f4f6);
    color: var(--clr-muted, #6b7280);
    border: 1px solid var(--clr-border, #e5e7eb);
    transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.favg-tile:hover .favg-tile-action {
    background: var(--clr-primary, #754ffe);
    border-color: var(--clr-primary, #754ffe);
    color: #fff;
}

@media (max-width: 575px) {
    .favg-ico-card { flex-wrap: wrap; }
    .favg-ico-info { flex: 1 1 60%; }
    .favg-grid { grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: .65rem; }
    .favg-tile-preview { width: 68px; height: 68px; }
}

[data-theme="dark"] .favg-ico-card  {
    background: linear-gradient(135deg, rgba(117,79,254,.20), rgba(117,79,254,0) 70%);
    border-color: rgba(117,79,254,.4);
}
[data-theme="dark"] .favg-ico-thumb {
    background-color: var(--clr-surface, #28274a);
    border-color: var(--clr-border, #2d2b4e);
}
[data-theme="dark"] .favg-ico-title { color: var(--clr-heading-dark, #f1f5f9); }
[data-theme="dark"] .favg-section-head { color: var(--clr-heading-dark, #f1f5f9); }
[data-theme="dark"] .favg-tile {
    background: var(--clr-card, #1d1c35);
    border-color: var(--clr-border, #2d2b4e);
}
[data-theme="dark"] .favg-tile-preview {
    background-color: #1d1c35; border-color: var(--clr-border, #2d2b4e);
    background-image:
        linear-gradient(45deg,  #28274a 25%, transparent 25%),
        linear-gradient(-45deg, #28274a 25%, transparent 25%),
        linear-gradient(45deg,  transparent 75%, #28274a 75%),
        linear-gradient(-45deg, transparent 75%, #28274a 75%);
}
[data-theme="dark"] .favg-tile-size  { color: var(--clr-heading-dark, #f1f5f9); }
[data-theme="dark"] .favg-tile-action {
    background: var(--clr-surface, #28274a);
    border-color: var(--clr-border, #2d2b4e);
    color: var(--clr-text, #94a3b8);
}

/* ── Lorem Ipsum Generator ─────────────────────────────── */
/* Outer card — mirrors #aibEditor */
#ligEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
/* Drop the checkered preview background — output is text, not canvas */
#ligEditor .aib-preview-side { background: var(--clr-card, #fff); }

/* Output panel — replaces .aib-preview-panel for text content */
#ligWrap .lig-output-panel {
    flex: 1; min-width: 0;
    display: flex; flex-direction: column; gap: .85rem;
    padding: 1.5rem 1.75rem;
    overflow: hidden;
}
#ligWrap .lig-output-head {
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: .5rem;
}
#ligWrap .lig-output-title { margin: 0; font-weight: 700; color: var(--clr-heading, #111827); }
#ligWrap .lig-output-actions { display: flex; gap: .5rem; }

#ligWrap .lig-stats {
    display: flex; gap: 1rem; flex-wrap: wrap;
    font-size: .8rem; color: var(--clr-muted, #6b7280);
    padding-bottom: .25rem;
    border-bottom: 1px solid var(--clr-border, #f1f5f9);
    padding: 0 0 .65rem;
}
#ligWrap .lig-stats > span { display: inline-flex; align-items: center; }
#ligWrap .lig-stats > span > span {
    font-weight: 700; color: var(--clr-heading, #111827); margin-right: .3rem;
    font-variant-numeric: tabular-nums;
}

#ligWrap .lig-output-box {
    flex: 1 1 auto;
    min-height: 280px;
    max-height: 480px;
    overflow-y: auto;
    background: var(--clr-surface, #f8fafc);
    border: 1px solid var(--clr-border, #edf2f7);
    border-radius: 12px;
    padding: 1.25rem 1.5rem;
    line-height: 1.7;
    color: var(--clr-text, #4a5568);
}
#ligWrap .lig-output-box p { margin: 0 0 1rem; }
#ligWrap .lig-output-box p:last-child { margin-bottom: 0; }
#ligWrap .lig-empty {
    color: var(--clr-muted, #a0aec0);
    font-style: italic;
    text-align: center;
    padding: 2rem 1rem;
}
#ligWrap .lig-code {
    margin: 0;
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Consolas, monospace;
    font-size: .85rem;
    line-height: 1.6;
    color: var(--clr-heading, #1f2937);
    white-space: pre-wrap;
    word-break: break-word;
}

/* Sidebar tweaks — keep the .aib-* sectioned-form-group separator look,
   but ensure tighter form controls fit the 270px width */
#ligEditor .aib-sidebar select.form-select { font-size: .92rem; padding: .45rem .65rem; }
#ligEditor .aib-sidebar .btn-group .btn { font-size: .82rem; padding: .45rem .25rem; }
#ligEditor .aib-sidebar .btn-check:checked + .btn-outline-secondary,
#ligEditor .aib-sidebar .btn-check:active   + .btn-outline-secondary {
    background-color: var(--clr-primary, #754ffe);
    border-color: var(--clr-primary, #754ffe);
    color: #fff;
}

#ligEditor .lig-switch.form-switch { padding-left: 2.5em; margin: 0; }
#ligEditor .lig-switch .form-check-input { width: 2.2em; height: 1.2em; margin-top: .15em; cursor: pointer; }
#ligEditor .lig-switch .form-check-input:checked {
    background-color: var(--clr-primary, #754ffe);
    border-color: var(--clr-primary, #754ffe);
}
#ligEditor .lig-switch .form-check-input:focus {
    box-shadow: 0 0 0 .2rem rgba(117,79,254,.18);
    border-color: rgba(117,79,254,.45);
}
#ligEditor .lig-switch .form-check-label { cursor: pointer; font-weight: 600; color: var(--clr-heading, #111827); font-size: .85rem; }

/* Stack vertically on tablet / mobile — match the aib- responsive pattern */
@media (max-width: 991.98px) {
    #ligEditor .aib-editor-wrap { flex-direction: column; min-height: auto; }
    #ligEditor .aib-preview-side { border-right: 0; border-bottom: 1px solid var(--clr-border, #f1f5f9); }
    #ligEditor .aib-sidebar { width: 100%; }
}

[data-theme="dark"] #ligEditor { border-color: var(--clr-border, #2d2b4e); background: var(--clr-card, #1d1c35); }
[data-theme="dark"] #ligEditor .aib-preview-side { background: var(--clr-card, #1d1c35); }
[data-theme="dark"] #ligWrap .lig-output-box {
    background: var(--clr-surface, #28274a);
    border-color: var(--clr-border, #2d2b4e);
    color: var(--clr-text, #d1d5db);
}
[data-theme="dark"] #ligWrap .lig-output-title,
[data-theme="dark"] #ligWrap .lig-stats > span > span,
[data-theme="dark"] #ligWrap .lig-code { color: var(--clr-heading-dark, #f1f5f9); }
[data-theme="dark"] #ligWrap .lig-empty { color: var(--clr-muted, #6b7280); }
[data-theme="dark"] #ligWrap .lig-stats { border-bottom-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] #ligEditor .lig-switch .form-check-label { color: var(--clr-heading-dark, #f1f5f9); }

/* Fullscreen — mirror #aibWrap.aib-fullscreen for #ligWrap */
#ligWrap.aib-fullscreen {
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: var(--clr-card, #fff);
    display: flex;
    flex-direction: column;
    padding: 0;
    margin: 0;
    max-width: none;
}
#ligWrap.aib-fullscreen #ligEditor {
    flex: 1 1 auto;
    min-height: 0;
    border: none;
    border-radius: 0;
    overflow: hidden;
    display: flex !important;
    flex-direction: column;
}
#ligWrap.aib-fullscreen .aib-editor-wrap {
    flex: 1 1 auto;
    min-height: 0;
}
#ligWrap.aib-fullscreen .aib-preview-side {
    position: relative;
    min-width: 0;
    min-height: 0;
}
/* Fullscreen scroll chain — every flex ancestor needs min-height:0 so
   .lig-output-box can scroll instead of pushing its content past the viewport */
#ligWrap.aib-fullscreen .lig-output-panel {
    height: 100%;
    min-height: 0;
}
#ligWrap.aib-fullscreen .lig-output-box {
    max-height: none;
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
}
@media (max-width: 991.98px) {
    #ligWrap.aib-fullscreen .aib-editor-wrap { flex-direction: row; }
    #ligWrap.aib-fullscreen .aib-preview-side { border-right: 1px solid var(--clr-border, #f1f5f9); border-bottom: 0; }
    #ligWrap.aib-fullscreen .aib-sidebar { width: 270px; }
}

/* ── Keyword Density Checker ───────────────────────────── */
#kdcWrap .kdc-mode {
    display: inline-flex;
    background: var(--clr-surface, #f3f4f6);
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 999px;
    padding: 4px;
    margin-bottom: 1rem;
}
#kdcWrap .kdc-mode-btn {
    background: transparent; border: 0; cursor: pointer;
    padding: .4rem 1rem; border-radius: 999px;
    font-size: .85rem; font-weight: 600;
    color: var(--clr-muted, #6b7280);
    transition: all .15s ease;
}
#kdcWrap .kdc-mode-btn:hover { color: var(--clr-heading, #111827); }
#kdcWrap .kdc-mode-btn.is-active {
    background: #fff;
    color: var(--clr-primary, #754ffe);
    box-shadow: 0 1px 3px rgba(0,0,0,.06);
}

#kdcWrap .kdc-textarea {
    border-radius: 12px;
    padding: 1rem 1.15rem;
    font-size: .95rem;
    line-height: 1.55;
    resize: vertical;
    min-height: 180px;
}

#kdcWrap .kdc-filters {
    display: flex; flex-wrap: wrap; gap: 1rem 1.5rem;
    align-items: center;
    padding: .85rem 1.15rem;
    background: var(--clr-surface, #f8fafc);
    border: 1px solid var(--clr-border, #edf2f7);
    border-radius: 10px;
    margin-bottom: .85rem;
}
#kdcWrap .kdc-filter { display: inline-flex; align-items: center; gap: .55rem; }
#kdcWrap .kdc-filter-label {
    font-size: .72rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
    color: var(--clr-muted, #6b7280); margin: 0;
}
#kdcWrap .kdc-stop.form-switch { padding-left: 2.5em; margin: 0; }
#kdcWrap .kdc-stop .form-check-input { width: 2.2em; height: 1.15em; cursor: pointer; }
#kdcWrap .kdc-stop .form-check-input:checked {
    background-color: var(--clr-primary, #754ffe);
    border-color: var(--clr-primary, #754ffe);
}
#kdcWrap .kdc-stop .form-check-label { font-weight: 600; font-size: .85rem; cursor: pointer; }
#kdcWrap .btn-check:checked + .btn-outline-secondary {
    background-color: var(--clr-primary, #754ffe);
    border-color: var(--clr-primary, #754ffe);
    color: #fff;
}

#kdcWrap .kdc-source-pill {
    margin-left: auto;
    font-size: .72rem; font-weight: 600;
    padding: 3px 10px; border-radius: 999px;
    background: var(--clr-surface, #f3f4f6);
    color: var(--clr-muted, #6b7280);
    border: 1px solid var(--clr-border, #e5e7eb);
    max-width: 60%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

#kdcWrap .kdc-rows { padding: .25rem 0; }
#kdcWrap .kdc-row {
    display: grid;
    grid-template-columns: 32px 1.4fr 2fr auto auto;
    gap: .85rem; align-items: center;
    padding: .65rem 1.15rem;
    border-bottom: 1px solid var(--clr-border, #f1f5f9);
}
#kdcWrap .kdc-row:last-child { border-bottom: 0; }
#kdcWrap .kdc-row:nth-child(odd) { background: rgba(117,79,254,.025); }
#kdcWrap .kdc-rank {
    font-size: .75rem; font-weight: 700;
    color: var(--clr-muted, #9ca3af);
    text-align: center;
    font-variant-numeric: tabular-nums;
}
#kdcWrap .kdc-word {
    font-weight: 600; color: var(--clr-heading, #111827);
    font-size: .92rem;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
#kdcWrap .kdc-bar-wrap {
    height: 8px;
    background: var(--clr-border, #e5e7eb);
    border-radius: 999px;
    overflow: hidden;
}
#kdcWrap .kdc-bar {
    height: 100%;
    background: linear-gradient(90deg, var(--clr-primary, #754ffe), #a78bfa);
    border-radius: 999px;
    transition: width .35s ease;
}
#kdcWrap .kdc-count {
    font-size: .82rem; font-weight: 600;
    color: var(--clr-muted, #6b7280);
    font-variant-numeric: tabular-nums;
    min-width: 38px; text-align: right;
}
#kdcWrap .kdc-density {
    font-size: .85rem; font-weight: 700;
    color: var(--clr-primary, #754ffe);
    font-variant-numeric: tabular-nums;
    min-width: 56px; text-align: right;
}
#kdcWrap .kdc-empty {
    padding: 2rem 1.15rem;
    text-align: center;
    color: var(--clr-muted, #6b7280);
    font-size: .9rem;
}

@media (max-width: 575px) {
    #kdcWrap .kdc-row { grid-template-columns: 28px 1fr auto; gap: .55rem; }
    #kdcWrap .kdc-bar-wrap { display: none; }
    #kdcWrap .kdc-source-pill { max-width: 50%; }
}

[data-theme="dark"] #kdcWrap .kdc-mode { background: var(--clr-surface, #28274a); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] #kdcWrap .kdc-mode-btn.is-active { background: var(--clr-card, #1d1c35); }
[data-theme="dark"] #kdcWrap .kdc-filters { background: var(--clr-surface, #28274a); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] #kdcWrap .kdc-row { border-bottom-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] #kdcWrap .kdc-row:nth-child(odd) { background: rgba(117,79,254,.06); }
[data-theme="dark"] #kdcWrap .kdc-word { color: var(--clr-heading-dark, #f1f5f9); }
[data-theme="dark"] #kdcWrap .kdc-source-pill { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); color: var(--clr-text, #94a3b8); }
[data-theme="dark"] #kdcWrap .kdc-bar-wrap { background: var(--clr-border, #2d2b4e); }

/* ── Word Counter ──────────────────────────────────────── */
#wcEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
#wcEditor .aib-preview-side { background: var(--clr-card, #fff); }

#wcWrap .wc-editor-panel {
    flex: 1; min-width: 0;
    display: flex; flex-direction: column; gap: .85rem;
    padding: 1.5rem 1.75rem;
    overflow: hidden;
}
#wcWrap .wc-editor-head {
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: .5rem;
}
#wcWrap .wc-editor-title { margin: 0; font-weight: 700; color: var(--clr-heading, #111827); }
#wcWrap .wc-editor-actions { display: flex; gap: .5rem; flex-wrap: wrap; }

#wcWrap .wc-textarea {
    flex: 1 1 auto;
    min-height: 320px;
    max-height: 520px;
    width: 100%;
    background: var(--clr-surface, #f8fafc);
    border: 1px solid var(--clr-border, #edf2f7);
    border-radius: 12px;
    padding: 1.15rem 1.35rem;
    color: var(--clr-text, #1f2937);
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
    font-size: 1rem;
    line-height: 1.7;
    resize: vertical;
    outline: 0;
    transition: border-color .15s ease, box-shadow .15s ease;
}
#wcWrap .wc-textarea:focus {
    border-color: var(--clr-primary, #754ffe);
    box-shadow: 0 0 0 3px rgba(117,79,254,.12);
}

#wcWrap .wc-quickbar {
    display: flex; gap: .55rem; align-items: center; flex-wrap: wrap;
    font-size: .82rem; color: var(--clr-muted, #6b7280);
}
#wcWrap .wc-quickbar > span > span { font-weight: 700; color: var(--clr-heading, #111827); margin-right: .15rem; font-variant-numeric: tabular-nums; }
#wcWrap .wc-dot { color: var(--clr-border, #d1d5db); }

/* Sidebar metric grid */
#wcEditor .wc-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
    margin-top: 4px;
}
#wcEditor .wc-cell {
    background: var(--clr-surface, #f8fafc);
    border: 1px solid var(--clr-border, #edf2f7);
    border-radius: 8px;
    padding: .55rem .65rem;
    text-align: left;
}
#wcEditor .wc-cell-val {
    font-size: 1.15rem; font-weight: 700;
    color: var(--clr-heading, #111827);
    line-height: 1.1;
    font-variant-numeric: tabular-nums;
}
#wcEditor .wc-cell-lbl {
    font-size: .68rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: .05em;
    color: var(--clr-muted, #6b7280);
    margin-top: 2px;
}

/* Reading-time block */
#wcEditor .wc-meter { display: flex; flex-direction: column; gap: 6px; margin-top: 4px; }
#wcEditor .wc-meter-row {
    display: flex; align-items: center; gap: .5rem;
    padding: .45rem .65rem;
    background: var(--clr-surface, #f8fafc);
    border: 1px solid var(--clr-border, #edf2f7);
    border-radius: 8px;
    font-size: .82rem;
}
#wcEditor .wc-meter-icon {
    width: 24px; text-align: center; color: var(--clr-primary, #754ffe);
}
#wcEditor .wc-meter-text { flex: 1; color: var(--clr-text, #4a5568); font-weight: 500; }
#wcEditor .wc-meter-val {
    font-weight: 700; color: var(--clr-heading, #111827);
    font-variant-numeric: tabular-nums;
}

/* Top keywords */
#wcEditor .wc-top { display: flex; flex-direction: column; gap: 5px; margin-top: 4px; }
#wcEditor .wc-top-row {
    display: grid;
    grid-template-columns: 1fr 1.2fr auto;
    gap: .5rem;
    align-items: center;
    font-size: .8rem;
}
#wcEditor .wc-top-word {
    font-weight: 600; color: var(--clr-heading, #111827);
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
#wcEditor .wc-top-bar {
    height: 6px; border-radius: 999px;
    background: var(--clr-border, #e5e7eb);
    overflow: hidden;
}
#wcEditor .wc-top-fill {
    height: 100%; border-radius: 999px;
    background: linear-gradient(90deg, var(--clr-primary, #754ffe), #a78bfa);
    transition: width .35s ease;
}
#wcEditor .wc-top-count {
    font-weight: 600; color: var(--clr-muted, #6b7280);
    font-variant-numeric: tabular-nums;
    min-width: 28px; text-align: right;
}
#wcEditor .wc-top-empty {
    font-size: .8rem; color: var(--clr-muted, #6b7280); font-style: italic;
}

@media (max-width: 991.98px) {
    #wcEditor .aib-editor-wrap { flex-direction: column; min-height: auto; }
    #wcEditor .aib-preview-side { border-right: 0; border-bottom: 1px solid var(--clr-border, #f1f5f9); }
    #wcEditor .aib-sidebar { width: 100%; }
}

/* Fullscreen — mirror lorem-ipsum's pattern for #wcWrap */
#wcWrap.aib-fullscreen {
    position: fixed; inset: 0; z-index: 99999;
    background: var(--clr-card, #fff);
    display: flex; flex-direction: column;
    padding: 0; margin: 0; max-width: none;
}
#wcWrap.aib-fullscreen #wcEditor {
    flex: 1 1 auto; min-height: 0;
    border: none; border-radius: 0;
    overflow: hidden;
    display: flex !important; flex-direction: column;
}
#wcWrap.aib-fullscreen .aib-editor-wrap { flex: 1 1 auto; min-height: 0; }
#wcWrap.aib-fullscreen .aib-preview-side {
    position: relative; min-width: 0; min-height: 0;
}
#wcWrap.aib-fullscreen .wc-editor-panel { height: 100%; min-height: 0; }
#wcWrap.aib-fullscreen .wc-textarea {
    max-height: none; flex: 1 1 auto; min-height: 0;
}
@media (max-width: 991.98px) {
    #wcWrap.aib-fullscreen .aib-editor-wrap { flex-direction: row; }
    #wcWrap.aib-fullscreen .aib-preview-side { border-right: 1px solid var(--clr-border, #f1f5f9); border-bottom: 0; }
    #wcWrap.aib-fullscreen .aib-sidebar { width: 270px; }
}

[data-theme="dark"] #wcEditor { border-color: var(--clr-border, #2d2b4e); background: var(--clr-card, #1d1c35); }
[data-theme="dark"] #wcEditor .aib-preview-side { background: var(--clr-card, #1d1c35); }
[data-theme="dark"] #wcWrap .wc-textarea {
    background: var(--clr-surface, #28274a);
    border-color: var(--clr-border, #2d2b4e);
    color: var(--clr-text, #d1d5db);
}
[data-theme="dark"] #wcWrap .wc-editor-title,
[data-theme="dark"] #wcWrap .wc-quickbar > span > span,
[data-theme="dark"] #wcEditor .wc-cell-val,
[data-theme="dark"] #wcEditor .wc-meter-val,
[data-theme="dark"] #wcEditor .wc-top-word { color: var(--clr-heading-dark, #f1f5f9); }
[data-theme="dark"] #wcEditor .wc-cell,
[data-theme="dark"] #wcEditor .wc-meter-row { background: var(--clr-surface, #28274a); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] #wcEditor .wc-top-bar { background: var(--clr-border, #2d2b4e); }

/* ── Photo Editor ──────────────────────────────────────── */
#peEditor {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 16px;
    overflow: hidden;
    background: var(--clr-card, #fff);
}
#peEditor .aib-preview-side {
    background: #1a1a2e;
    background-image:
        linear-gradient(45deg,  #232342 25%, transparent 25%),
        linear-gradient(-45deg, #232342 25%, transparent 25%),
        linear-gradient(45deg,  transparent 75%, #232342 75%),
        linear-gradient(-45deg, transparent 75%, #232342 75%);
    background-size: 24px 24px;
    background-position: 0 0, 0 12px, 12px -12px, -12px 0;
    min-height: 532px;
    /* Center the stage horizontally + vertically inside the dark side panel */
    align-items: center;
    justify-content: center;
    padding: 1rem;
}
/* Stage is 95% of side width and exactly 500px tall — leaves a thin
   dark gutter around the image so it visually breathes */
#peEditor .pe-stage {
    position: relative;
    width: 95%;
    max-width: 95%;
    height: 500px;
    max-height: 500px;
    overflow: hidden;
}
#peEditor .pe-stage img { max-width: 100%; display: block; }
.cropper-bg { background-image: none !important; }

/* Hide cropper UI on every tab except Crop — image still rotates / flips
   / filters live, but the dashed grid + handles + dark overlay disappear,
   and pointer interactions (scroll-zoom + drag) are disabled */
#peEditor:not(.pe-mode-crop) .cropper-crop-box,
#peEditor:not(.pe-mode-crop) .cropper-line,
#peEditor:not(.pe-mode-crop) .cropper-point,
#peEditor:not(.pe-mode-crop) .cropper-dashed,
#peEditor:not(.pe-mode-crop) .cropper-center { display: none !important; }
#peEditor:not(.pe-mode-crop) .cropper-modal     { opacity: 0 !important; }
/* Killing pointer-events on the cropper container disables wheel zoom +
   click-drag on every tab that isn't Crop. Programmatic API calls
   (rotate, scale, slider filters) are unaffected. */
#peEditor:not(.pe-mode-crop) .cropper-container { pointer-events: none; }

/* Sidebar — tabs */
#peEditor .pe-sidebar { width: 290px; }
#peEditor .pe-tabs {
    display: flex;
    border-bottom: 1px solid var(--clr-border, #f1f5f9);
    background: var(--clr-surface, #f8f7ff);
}
#peEditor .pe-tab {
    flex: 1; border: 0; background: transparent; cursor: pointer;
    padding: .75rem .25rem; font-size: .72rem; font-weight: 600;
    color: var(--clr-muted, #6b7280);
    display: flex; flex-direction: column; align-items: center; gap: 4px;
    transition: color .15s ease, background .15s ease;
    border-bottom: 2px solid transparent;
}
#peEditor .pe-tab i { font-size: 1.05rem; }
#peEditor .pe-tab:hover { color: var(--clr-primary, #754ffe); background: rgba(117,79,254,.04); }
#peEditor .pe-tab.is-active {
    color: var(--clr-primary, #754ffe);
    border-bottom-color: var(--clr-primary, #754ffe);
    background: var(--clr-card, #fff);
}

#peEditor .pe-panels { flex: 1 1 auto; min-height: 0; overflow-y: auto; }
#peEditor .pe-panel { display: none; }
#peEditor .pe-panel.is-active { display: block; }

/* Aspect-ratio chips */
#peEditor .pe-aspect-grid {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; margin-top: 4px;
}
#peEditor .pe-aspect {
    border: 1px solid var(--clr-border, #d1d5db);
    background: transparent; color: var(--clr-text, #4a5568);
    font-size: .78rem; font-weight: 600;
    padding: .4rem .25rem; border-radius: 6px; cursor: pointer;
    transition: all .15s ease;
}
#peEditor .pe-aspect:hover { color: var(--clr-primary, #754ffe); border-color: var(--clr-primary, #754ffe); }
#peEditor .pe-aspect.is-active {
    background: var(--clr-primary, #754ffe);
    border-color: var(--clr-primary, #754ffe);
    color: #fff;
}

/* Two-button rows */
#peEditor .pe-btn-row { display: flex; gap: .35rem; margin-top: 4px; }
#peEditor .pe-btn-row .btn { flex: 1; font-size: .8rem; padding: .4rem .25rem; }
#peEditor .pe-zoom-hint {
    font-size: .7rem; color: var(--clr-muted, #9ca3af);
    margin: .5rem 0 0; line-height: 1.3;
}

/* Filter preset grid */
#peEditor .pe-filter-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-top: 4px;
}
#peEditor .pe-filter-tile {
    border: 1px solid var(--clr-border, #e5e7eb);
    background: var(--clr-card, #fff);
    border-radius: 8px; padding: 4px 4px 6px; cursor: pointer;
    transition: all .15s ease;
}
#peEditor .pe-filter-tile:hover { border-color: var(--clr-primary, #754ffe); }
#peEditor .pe-filter-tile.is-active {
    border-color: var(--clr-primary, #754ffe);
    box-shadow: 0 0 0 2px rgba(117,79,254,.18);
}
#peEditor .pe-filter-thumb {
    width: 100%; aspect-ratio: 1; border-radius: 5px; overflow: hidden;
    background: #f3f4f6;
}
#peEditor .pe-filter-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
#peEditor .pe-filter-name {
    font-size: .68rem; font-weight: 600; text-align: center;
    color: var(--clr-text, #4a5568); margin-top: 4px;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
#peEditor .pe-filter-tile.is-active .pe-filter-name { color: var(--clr-primary, #754ffe); }

/* Sidebar export row */
#peEditor .pe-export-row { display: flex; gap: .5rem; align-items: stretch; }
#peEditor .pe-export-row .form-select { width: 80px; flex: 0 0 80px; }

/* Range bubble — small adjustment to default Bootstrap range styling */
#peEditor input[type="range"].form-range { padding: .35rem 0; }

/* Mobile: stack sidebar below editor canvas */
@media (max-width: 991.98px) {
    #peEditor .aib-editor-wrap { flex-direction: column; min-height: auto; }
    #peEditor .aib-preview-side {
        border-right: 0; border-bottom: 1px solid var(--clr-border, #f1f5f9);
        min-height: 380px;
        padding: .65rem;
    }
    #peEditor .pe-stage { height: 350px; max-height: 350px; }
    #peEditor .pe-sidebar { width: 100%; }
    #peEditor .pe-panels { max-height: 360px; }
}

/* Fullscreen — image preview fills the full viewport edge-to-edge.
   The sidebar stays at 290px on the right so users can keep adjusting,
   which means the image preview area gets ~100vw - 290px = nearly full
   viewport width × full viewport height to display the photo. */
#peWrap.aib-fullscreen {
    position: fixed; inset: 0; z-index: 99999;
    background: var(--clr-card, #fff);
    display: flex; flex-direction: column;
    padding: 0; margin: 0; max-width: none;
}
#peWrap.aib-fullscreen #peEditor {
    flex: 1 1 auto; min-height: 0;
    width: 100%; height: 100%;
    max-width: none; max-height: none;
    border: 0; border-radius: 0;
    overflow: hidden;
    display: flex !important; flex-direction: column;
}
#peWrap.aib-fullscreen .aib-editor-wrap { flex: 1 1 auto; min-height: 0; }
#peWrap.aib-fullscreen .aib-preview-side {
    position: relative;
    min-width: 0; min-height: 0;
    align-items: center;       /* centre the stage vertically */
    justify-content: center;   /* centre the stage horizontally */
    padding: 0;
    background: #1a1a2e;
}
/* In fullscreen the image preview sits as a centred 80% × 80% box on the
   dark backdrop — matches the user's design and gives a comfortable
   margin around the photo */
#peWrap.aib-fullscreen .pe-stage {
    width: 80%;  max-width: 80%;
    height: 80%; max-height: 80%;
    min-height: 0;
    flex: 0 0 auto;
}
#peWrap.aib-fullscreen .pe-panels { max-height: none; }

/* Mobile fullscreen — sidebar stacks above image preview */
@media (max-width: 991.98px) {
    #peWrap.aib-fullscreen .aib-editor-wrap { flex-direction: column; }
    #peWrap.aib-fullscreen .aib-preview-side { border-right: 0; border-bottom: 1px solid var(--clr-border, #f1f5f9); }
    #peWrap.aib-fullscreen .pe-sidebar { width: 100%; max-height: 40vh; overflow-y: auto; }
}

/* Dark mode */
[data-theme="dark"] #peEditor { border-color: var(--clr-border, #2d2b4e); background: var(--clr-card, #1d1c35); }
[data-theme="dark"] #peEditor .pe-tabs { background: var(--clr-card, #1d1c35); }
[data-theme="dark"] #peEditor .pe-tab.is-active { background: var(--clr-surface, #28274a); }
[data-theme="dark"] #peEditor .pe-aspect { border-color: var(--clr-border, #2d2b4e); color: var(--clr-text, #d1d5db); }
[data-theme="dark"] #peEditor .pe-filter-tile { background: var(--clr-surface, #28274a); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] #peEditor .pe-filter-thumb { background: var(--clr-card, #1d1c35); }
[data-theme="dark"] #peEditor .pe-filter-name { color: var(--clr-text, #d1d5db); }

/* ── Calendar Link Generator ───────────────────────────── */
#clgWrap .clg-switch.form-switch { padding-left: 2.5em; margin: .25rem 0 0; }
#clgWrap .clg-switch .form-check-input { width: 2.2em; height: 1.2em; cursor: pointer; }
#clgWrap .clg-switch .form-check-input:checked { background-color: var(--clr-primary, #754ffe); border-color: var(--clr-primary, #754ffe); }
#clgWrap .clg-switch .form-check-label { cursor: pointer; }

#clgWrap select#clgTimezone { font-size: .9rem; }
#clgWrap select#clgTimezone option { padding: 4px 8px; }

#clgWrap .clg-link-card {
    border: 1px solid var(--clr-border, #e5e7eb);
    border-radius: 10px;
    overflow: hidden;
    background: var(--clr-card, #fff);
    margin-bottom: .75rem;
}
#clgWrap .clg-link-head {
    display: flex; align-items: center;
    padding: .65rem 1rem;
    background: var(--clr-surface, #f8fafc);
    border-bottom: 1px solid var(--clr-border, #edf2f7);
    color: var(--clr-heading, #111827);
    font-size: .95rem;
}
#clgWrap .clg-link-open {
    font-size: .78rem; font-weight: 600;
    color: var(--clr-primary, #754ffe);
    text-decoration: none;
    padding: 3px 10px; border-radius: 999px;
    border: 1px solid rgba(117, 79, 254, .25);
}
#clgWrap .clg-link-open:hover {
    background: var(--clr-primary, #754ffe);
    color: #fff;
}
#clgWrap .clg-link-body {
    display: flex; gap: .5rem;
    padding: .75rem 1rem;
}
#clgWrap .clg-link-url {
    flex: 1 1 auto;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: .82rem;
}
#clgWrap .clg-copy-btn { flex: 0 0 auto; white-space: nowrap; }

[data-theme="dark"] #clgWrap .clg-link-card { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] #clgWrap .clg-link-head { background: var(--clr-surface, #28274a); border-bottom-color: var(--clr-border, #2d2b4e); color: var(--clr-heading-dark, #f1f5f9); }
[data-theme="dark"] #clgWrap .clg-link-open { color: var(--clr-text, #d1d5db); border-color: var(--clr-border, #2d2b4e); }

/* ============================================================
   AGE CALCULATOR — .ac-*
   ============================================================ */

#acWrap { max-width: 920px; margin: 0 auto; }

.ac-input-card {
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 16px;
    padding: 1.5rem;
    box-shadow: 0 2px 12px rgba(117,79,254,.06);
}
.ac-input-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-bottom: 1rem;
}
.ac-input-group { display: flex; flex-direction: column; }
.ac-label { font-weight: 600; font-size: .92rem; color: #1a1a2e; margin-bottom: .4rem; }
.ac-hint  { display: block; font-size: .8rem; color: #6b7280; margin-top: .35rem; }
.ac-actions { display: flex; gap: .6rem; flex-wrap: wrap; }
.ac-error {
    margin-top: .85rem;
    padding: .75rem 1rem;
    border-radius: 10px;
    background: rgba(220,38,38,.08);
    border: 1px solid rgba(220,38,38,.25);
    color: #b91c1c;
    font-size: .92rem;
}

/* Headline result */
.ac-headline {
    margin-top: 1.5rem;
    padding: 2.25rem 1.5rem;
    border-radius: 22px;
    background: linear-gradient(135deg, #754ffe 0%, #5c3dd8 100%);
    color: #fff;
    text-align: center;
    box-shadow: 0 12px 36px rgba(117,79,254,.28);
}
.ac-headline-label {
    font-size: .82rem;
    text-transform: uppercase;
    letter-spacing: .14em;
    opacity: .85;
    margin-bottom: .5rem;
}
.ac-headline-num {
    font-size: clamp(2.4rem, 7vw, 4rem);
    font-weight: 800;
    letter-spacing: -.02em;
    line-height: 1;
}
.ac-headline-num span:not(.ac-headline-unit) { display: inline-block; min-width: 1.2em; }
.ac-headline-unit {
    font-size: .45em;
    font-weight: 600;
    margin: 0 .55em 0 .12em;
    opacity: .85;
    vertical-align: super;
}
.ac-headline-sub { margin-top: .85rem; opacity: .9; font-size: .98rem; }

/* Stats grid */
.ac-stats-grid {
    margin-top: 1.25rem;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: .85rem;
}
.ac-stat {
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 14px;
    padding: 1.1rem 1rem;
    text-align: center;
    transition: border-color .2s, transform .2s;
}
.ac-stat:hover { border-color: #9b7ffe; transform: translateY(-2px); }
.ac-stat-num   { font-size: 1.45rem; font-weight: 800; color: #754ffe; line-height: 1; }
.ac-stat-label { font-size: .82rem; color: #6b7280; margin-top: .4rem; }
.ac-stat-live .ac-stat-num { color: #16a34a; }
.ac-live-dot {
    display: inline-block; width: 7px; height: 7px;
    background: #16a34a; border-radius: 50%; margin-right: .35rem;
    animation: ac-pulse 1.2s infinite;
    vertical-align: middle;
}
@keyframes ac-pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%      { opacity: .35; transform: scale(.6); }
}

/* Info grid (4 cards) */
.ac-info-grid {
    margin-top: 1rem;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: .85rem;
}
.ac-info-card {
    display: flex;
    gap: 1rem;
    align-items: center;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 14px;
    padding: 1rem 1.1rem;
}
.ac-info-icon {
    width: 48px; height: 48px;
    border-radius: 12px;
    background: rgba(117,79,254,.12);
    color: #754ffe;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.5rem;
    flex-shrink: 0;
}
.ac-info-title { font-size: .98rem; color: #1a1a2e; line-height: 1.35; }
.ac-info-title strong { color: #754ffe; }
.ac-info-sub   { font-size: .85rem; color: #6b7280; margin-top: .2rem; }

/* Breakdown list */
.ac-breakdown {
    margin-top: 1rem;
    background: #f8f7ff;
    border: 1px dashed #c7baff;
    border-radius: 14px;
    padding: 1rem 1.25rem;
}
.ac-breakdown-title {
    font-size: .82rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #754ffe;
    margin-bottom: .6rem;
}
.ac-breakdown-list {
    list-style: disc;
    padding-left: 1.25rem;
    margin: 0;
    color: #1a1a2e;
}
.ac-breakdown-list li { margin-bottom: .25rem; }

.ac-result-actions {
    margin-top: 1.25rem;
    display: flex;
    gap: .6rem;
    flex-wrap: wrap;
    justify-content: center;
}

/* Responsive */
@media (max-width: 767.98px) {
    .ac-input-row,
    .ac-info-grid    { grid-template-columns: 1fr; }
    .ac-stats-grid   { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
    .ac-actions .btn,
    .ac-result-actions .btn { flex: 1 1 100%; }
}

/* Dark mode */
[data-theme="dark"] .ac-input-card,
[data-theme="dark"] .ac-stat,
[data-theme="dark"] .ac-info-card {
    background: var(--clr-card, #1d1c35);
    border-color: var(--clr-border, #2d2b4e);
}
[data-theme="dark"] .ac-label,
[data-theme="dark"] .ac-info-title,
[data-theme="dark"] .ac-breakdown-list { color: #f1f5f9; }
[data-theme="dark"] .ac-hint,
[data-theme="dark"] .ac-info-sub,
[data-theme="dark"] .ac-stat-label { color: #9ca3af; }
[data-theme="dark"] .ac-breakdown { background: rgba(117,79,254,.10); border-color: rgba(117,79,254,.35); }

/* ============================================================
   HASH GENERATOR — .hg-*
   ============================================================ */

#hgWrap { max-width: 920px; margin: 0 auto; }

.hg-tabs {
    display: flex;
    gap: .35rem;
    border-bottom: 2px solid #e5e7eb;
    margin-bottom: 1rem;
    flex-wrap: wrap;
}
.hg-tab {
    background: transparent;
    border: 0;
    padding: .65rem 1.1rem;
    font-weight: 600;
    color: #6b7280;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    cursor: pointer;
    border-radius: 8px 8px 0 0;
    transition: color .15s, border-color .15s, background .15s;
}
.hg-tab:hover  { color: #FFFFFF !important;background: #754ffe; }
.hg-tab.active { color: #FFFFFF !important; border-bottom-color: #754ffe; background: #754ffe; }

.hg-pane textarea {
    border-radius: 12px;
    border: 1.5px solid #e5e7eb;
    font-family: ui-monospace, Menlo, monospace;
    font-size: .92rem;
    padding: .85rem 1rem;
}
.hg-pane textarea:focus { border-color: #754ffe; box-shadow: 0 0 0 3px rgba(117,79,254,.18); }
.hg-meta-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: .5rem;
    gap: .75rem;
    flex-wrap: wrap;
}
.hg-meta { color: #6b7280; font-size: .85rem; }
.hg-meta-warn { color: #b45309; font-size: .85rem; }

/* File drop zone */
.hg-drop {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 2rem 1.5rem;
    background: #f8f7ff;
    border: 2px dashed #c7baff;
    border-radius: 14px;
    cursor: pointer;
    transition: background .15s, border-color .15s;
}
.hg-drop:hover, .hg-drop-over { background: #efe9ff; border-color: #754ffe; }
.hg-drop-icon  { font-size: 2.25rem; color: #754ffe; margin-bottom: .5rem; }
.hg-drop-title { font-size: 1rem; color: #1a1a2e; }
.hg-drop-sub   { color: #6b7280; font-size: .85rem; margin-top: .35rem; }

.hg-file-info {
    display: flex;
    align-items: center;
    gap: .75rem;
    margin-top: .85rem;
    padding: .65rem .85rem;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    font-size: .92rem;
}
.hg-file-size { color: #6b7280; font-size: .82rem; }

/* Verify */
.hg-verify-help { color: #6b7280; font-size: .9rem; margin-bottom: .65rem; }
.hg-pane[data-pane="verify"] input {
    font-family: ui-monospace, Menlo, monospace;
    font-size: .92rem;
    border-radius: 12px;
    border: 1.5px solid #e5e7eb;
    padding: .75rem 1rem;
}
.hg-pane[data-pane="verify"] input:focus { border-color: #754ffe; box-shadow: 0 0 0 3px rgba(117,79,254,.18); }

/* Options */
.hg-options {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    margin-top: 1rem;
    padding: .75rem 1rem;
    background: #f8f7ff;
    border: 1px solid #ede9fe;
    border-radius: 12px;
}
.hg-option { display: flex; align-items: center; gap: .5rem; }
.hg-option-label { color: #1a1a2e; font-weight: 600; font-size: .85rem; }

/* Result rows */
.hg-results { margin-top: 1rem; display: flex; flex-direction: column; gap: .65rem; }
.hg-row {
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    padding: .85rem 1rem;
    transition: border-color .15s, box-shadow .15s;
}
.hg-row:hover { border-color: #c7baff; box-shadow: 0 2px 12px rgba(117,79,254,.08); }
.hg-row-head { display: flex; align-items: center; gap: .65rem; flex-wrap: wrap; }
.hg-algo { color: #754ffe; font-size: 1rem; }
.hg-row-sub { color: #6b7280; font-size: .78rem; }
.hg-hash {
    margin-top: .5rem;
    font-family: ui-monospace, Menlo, monospace;
    font-size: .88rem;
    word-break: break-all;
    color: #1a1a2e;
    background: #f8f7ff;
    padding: .55rem .75rem;
    border-radius: 8px;
    border: 1px solid #ede9fe;
    line-height: 1.5;
}

/* Verify badges */
.hg-verify-badge { display: inline-flex; }
.hg-badge {
    display: inline-flex;
    align-items: center;
    padding: .15rem .55rem;
    border-radius: 100px;
    font-size: .78rem;
    font-weight: 600;
    border: 1px solid transparent;
}
.hg-badge-ok  { background: rgba(22,163,74,.12); color: #15803d; border-color: rgba(22,163,74,.3); }
.hg-badge-bad { background: rgba(220,38,38,.12); color: #b91c1c; border-color: rgba(220,38,38,.3); }

/* Error */
.hg-error {
    margin-top: 1rem;
    padding: .75rem 1rem;
    border-radius: 10px;
    background: rgba(220,38,38,.08);
    border: 1px solid rgba(220,38,38,.25);
    color: #b91c1c;
    font-size: .92rem;
}

/* Responsive */
@media (max-width: 575.98px) {
    .hg-options { flex-direction: column; align-items: flex-start; }
    .hg-options #hgCopyAll { margin-left: 0 !important; width: 100%; }
    .hg-row-head { flex-direction: column; align-items: flex-start; gap: .35rem; }
    .hg-copy { align-self: flex-end; }
}

/* Dark mode */
[data-theme="dark"] .hg-tabs { border-bottom-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .hg-tab  { color: #9ca3af; }
[data-theme="dark"] .hg-tab:hover,
[data-theme="dark"] .hg-tab.active { color: #c7baff; background: rgba(117,79,254,.12); }
[data-theme="dark"] .hg-pane textarea,
[data-theme="dark"] .hg-pane[data-pane="verify"] input {
    background: var(--clr-card, #1d1c35);
    color: #f1f5f9;
    border-color: var(--clr-border, #2d2b4e);
}
[data-theme="dark"] .hg-drop      { background: rgba(117,79,254,.10); border-color: rgba(117,79,254,.35); }
[data-theme="dark"] .hg-drop:hover,
[data-theme="dark"] .hg-drop-over { background: rgba(117,79,254,.18); }
[data-theme="dark"] .hg-drop-title { color: #f1f5f9; }
[data-theme="dark"] .hg-options   { background: rgba(117,79,254,.08); border-color: rgba(117,79,254,.25); }
[data-theme="dark"] .hg-option-label { color: #f1f5f9; }
[data-theme="dark"] .hg-row,
[data-theme="dark"] .hg-file-info { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .hg-hash      { background: rgba(117,79,254,.10); border-color: rgba(117,79,254,.30); color: #e2e2f0; }
[data-theme="dark"] .hg-row-sub,
[data-theme="dark"] .hg-meta,
[data-theme="dark"] .hg-file-size,
[data-theme="dark"] .hg-verify-help { color: #9ca3af; }

.btn-check:checked+.btn, .btn.active, .btn.show, .btn:first-child:active, :not(.btn-check)+.btn:active{
        color: var(--bs-btn-active-color) !important;
}

/* ============================================================
   UNIX TIMESTAMP CONVERTER — .uc-*
   ============================================================ */
#ucWrap { max-width: 920px; margin: 0 auto; }

.uc-tabs {
    display: flex;
    gap: .35rem;
    border-bottom: 2px solid #e5e7eb;
    margin-bottom: 1rem;
    flex-wrap: wrap;
    align-items: center;
}
/* Reset button defaults from theme + give the rules enough specificity to win */
#ucWrap .uc-tab,
#ucWrap button.uc-tab {
    appearance: none !important;
    -webkit-appearance: none !important;
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
    border: 0 !important;
    border-bottom: 2px solid transparent !important;
    margin: 0 -2px 0 0 !important;
    padding: .65rem 1rem !important;
    font-family: 'Inter', system-ui, sans-serif !important;
    font-weight: 600 !important;
    font-size: .95rem !important;
    line-height: 1.4 !important;
    color: #6b7280 !important;
    text-transform: none !important;
    text-decoration: none !important;
    letter-spacing: 0 !important;
    cursor: pointer !important;
    border-radius: 8px 8px 0 0 !important;
    box-shadow: none !important;
    transition: color .15s, border-color .15s, background .15s !important;
    margin-bottom: -2px !important;
}
#ucWrap .uc-tab i,
#ucWrap button.uc-tab i { color: inherit !important; }

#ucWrap .uc-tab:hover,
#ucWrap button.uc-tab:hover {
    color: #754ffe !important;
    background: rgba(117,79,254,.06) !important;
    border-bottom-color: rgba(117,79,254,.4) !important;
}
#ucWrap .uc-tab.active,
#ucWrap button.uc-tab.active {
    color: #754ffe !important;
    background: rgba(117,79,254,.10) !important;
    border-bottom-color: #754ffe !important;
}
#ucWrap .uc-tab.active:hover,
#ucWrap button.uc-tab.active:hover {
    color: #5c3dd8 !important;
    background: rgba(117,79,254,.14) !important;
}
#ucWrap .uc-tab:focus,
#ucWrap .uc-tab:focus-visible,
#ucWrap button.uc-tab:focus,
#ucWrap button.uc-tab:focus-visible {
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(117,79,254,.18) !important;
}
.uc-now-btn { margin-bottom: 8px; }

.uc-live {
    background: #f8f7ff;
    border: 1px solid #ede9fe;
    border-radius: 12px;
    padding: .65rem 1rem;
    margin-bottom: 1rem;
    font-size: .9rem;
    color: #4b5563;
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    align-items: center;
}
.uc-live-label { color: #6b7280; font-size: .82rem; text-transform: uppercase; letter-spacing: .05em; }
.uc-live strong { color: #754ffe; font-family: ui-monospace, Menlo, monospace; font-size: 1rem; }
.uc-live-sub { color: #6b7280; font-size: .82rem; font-family: ui-monospace, Menlo, monospace; }

.uc-label { font-weight: 600; font-size: .92rem; color: #1a1a2e; margin-bottom: .4rem; display: block; }
.uc-mono { font-family: ui-monospace, Menlo, monospace; font-size: .95rem; }

.uc-detected {
    margin-top: .5rem;
    font-size: .85rem;
    color: #6b7280;
    min-height: 1.2rem;
}
.uc-detected.ok  { color: #15803d; }
.uc-detected.err { color: #b91c1c; }

.uc-tz-toggle { margin-top: .65rem; display: flex; gap: 1rem; flex-wrap: wrap; }
.uc-radio { font-size: .9rem; color: #1a1a2e; cursor: pointer; user-select: none; }
.uc-radio input { margin-right: .35rem; vertical-align: -2px; }

.uc-results {
    margin-top: 1rem;
    display: flex;
    flex-direction: column;
    gap: .5rem;
}
.uc-result-row {
    display: grid;
    grid-template-columns: 130px 1fr auto;
    gap: .85rem;
    align-items: center;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 10px;
    padding: .65rem .85rem;
}
.uc-result-row:hover { border-color: #c7baff; }
.uc-result-label { color: #6b7280; font-size: .82rem; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.uc-result-label small { display: block; font-size: .68rem; text-transform: none; color: #9ca3af; font-weight: 500; margin-top: .1rem; }
.uc-result-val {
    font-family: ui-monospace, Menlo, monospace;
    font-size: .92rem;
    color: #1a1a2e;
    word-break: break-all;
    background: #f8f7ff;
    padding: .35rem .55rem;
    border-radius: 6px;
}

.uc-batch-actions {
    margin-top: .65rem;
    display: flex;
    gap: .5rem;
    align-items: center;
    flex-wrap: wrap;
}
.uc-meta { color: #6b7280; font-size: .85rem; margin-right: auto; }
.uc-batch-table-wrap { overflow-x: auto; margin-top: .85rem; }
.uc-batch-table { width: 100%; border-collapse: collapse; font-size: .88rem; }
.uc-batch-table th, .uc-batch-table td {
    padding: .5rem .75rem;
    border-bottom: 1px solid #e5e7eb;
    text-align: left;
    font-family: ui-monospace, Menlo, monospace;
}
.uc-batch-table th { background: #f8f7ff; color: #4b5563; font-weight: 700; font-size: .78rem; text-transform: uppercase; letter-spacing: .04em; }
.uc-batch-table tr:hover td { background: #fafaff; }
.uc-cell-err { color: #b91c1c; font-style: italic; }

.uc-snippets {
    margin-top: 1.25rem;
    background: #f8f7ff;
    border: 1px solid #ede9fe;
    border-radius: 12px;
    padding: .8rem 1.1rem;
}
.uc-snippets summary {
    cursor: pointer;
    font-weight: 600;
    color: #1a1a2e;
    list-style: none;
}
.uc-snippets summary::-webkit-details-marker { display: none; }
.uc-snippets summary::after {
    content: '\F4FE';
    font-family: 'bootstrap-icons';
    margin-left: .35rem;
    color: #754ffe;
    transition: transform .2s;
}
.uc-snippets[open] summary::after { transform: rotate(45deg); }
.uc-snippets-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: .75rem;
    margin-top: .85rem;
}
.uc-snip {
    background: #fff;
    border: 1px solid #ede9fe;
    border-radius: 8px;
    padding: .65rem .85rem;
}
.uc-snip strong { display: block; color: #754ffe; font-size: .82rem; text-transform: uppercase; letter-spacing: .04em; margin-bottom: .35rem; }
.uc-snip pre { margin: 0; font-family: ui-monospace, Menlo, monospace; font-size: .8rem; line-height: 1.55; color: #1a1a2e; white-space: pre-wrap; word-break: break-all; }

.uc-error {
    margin-top: 1rem;
    padding: .75rem 1rem;
    border-radius: 10px;
    background: rgba(220,38,38,.08);
    border: 1px solid rgba(220,38,38,.25);
    color: #b91c1c;
    font-size: .92rem;
}

/* Responsive */
@media (max-width: 575.98px) {
    .uc-result-row { grid-template-columns: 1fr; gap: .35rem; }
    .uc-result-label { letter-spacing: 0; }
    .uc-snippets-grid { grid-template-columns: 1fr; }
    .uc-now-btn { margin-left: 0 !important; }
}

/* Dark mode */
[data-theme="dark"] .uc-tabs { border-bottom-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] #ucWrap .uc-tab,
[data-theme="dark"] #ucWrap button.uc-tab { color: #9ca3af !important; }
[data-theme="dark"] #ucWrap .uc-tab:hover,
[data-theme="dark"] #ucWrap button.uc-tab:hover { color: #c7baff !important; background: rgba(117,79,254,.14) !important; }
[data-theme="dark"] #ucWrap .uc-tab.active,
[data-theme="dark"] #ucWrap button.uc-tab.active { color: #c7baff !important; background: rgba(117,79,254,.18) !important; border-bottom-color: #c7baff !important; }
[data-theme="dark"] .uc-live,
[data-theme="dark"] .uc-snippets { background: rgba(117,79,254,.10); border-color: rgba(117,79,254,.30); }
[data-theme="dark"] .uc-live-label,
[data-theme="dark"] .uc-live-sub,
[data-theme="dark"] .uc-meta { color: #9ca3af; }
[data-theme="dark"] .uc-result-row,
[data-theme="dark"] .uc-snip { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .uc-result-val { background: rgba(117,79,254,.10); color: #e2e2f0; }
[data-theme="dark"] .uc-result-label,
[data-theme="dark"] .uc-batch-table th { color: #9ca3af; }
[data-theme="dark"] .uc-batch-table th { background: rgba(117,79,254,.10); }
[data-theme="dark"] .uc-batch-table td,
[data-theme="dark"] .uc-snip pre { color: #e2e2f0; }
[data-theme="dark"] .uc-snip strong { color: #c7baff; }
[data-theme="dark"] .uc-label,
[data-theme="dark"] .uc-radio { color: #f1f5f9; }

/* ============================================================
   BMI CALCULATOR — .bmi-*
   ============================================================ */
#bmiWrap { max-width: 920px; margin: 0 auto; }

.bmi-units {
    display: flex;
    gap: .35rem;
    margin-bottom: 1rem;
    background: #f8f7ff;
    border: 1px solid #ede9fe;
    border-radius: 12px;
    padding: .35rem;
}
/* High-specificity rules to override theme button defaults (Astra etc.) */
#bmiWrap .bmi-unit-btn,
#bmiWrap button.bmi-unit-btn {
    flex: 1 !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    background: transparent !important;
    background-color: transparent !important;
    background-image: none !important;
    border: 0 !important;
    padding: .65rem 1rem !important;
    border-radius: 10px !important;
    font-family: 'Inter', system-ui, sans-serif !important;
    font-size: .92rem !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
    color: #6b7280 !important;
    text-transform: none !important;
    text-decoration: none !important;
    letter-spacing: 0 !important;
    cursor: pointer !important;
    box-shadow: none !important;
    transition: background .15s, color .15s, box-shadow .15s !important;
}
#bmiWrap .bmi-unit-btn i,
#bmiWrap button.bmi-unit-btn i { color: inherit !important; }

#bmiWrap .bmi-unit-btn:hover,
#bmiWrap button.bmi-unit-btn:hover {
    color: #754ffe !important;
    background: rgba(117,79,254,.10) !important;
}
#bmiWrap .bmi-unit-btn.active,
#bmiWrap button.bmi-unit-btn.active {
    background: #fff !important;
    color: #754ffe !important;
    box-shadow: 0 1px 6px rgba(117,79,254,.18) !important;
}
#bmiWrap .bmi-unit-btn.active:hover,
#bmiWrap button.bmi-unit-btn.active:hover {
    background: #fff !important;
    color: #5c3dd8 !important;
    box-shadow: 0 2px 10px rgba(117,79,254,.25) !important;
}
#bmiWrap .bmi-unit-btn:focus,
#bmiWrap .bmi-unit-btn:focus-visible,
#bmiWrap button.bmi-unit-btn:focus,
#bmiWrap button.bmi-unit-btn:focus-visible {
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(117,79,254,.18) !important;
}

.bmi-input-card {
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 14px;
    padding: 1.5rem;
    box-shadow: 0 2px 12px rgba(117,79,254,.06);
}
.bmi-input-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-bottom: 1rem;
}
.bmi-input-group { display: flex; flex-direction: column; }
.bmi-label { font-weight: 600; font-size: .9rem; color: #1a1a2e; margin-bottom: .4rem; }
.bmi-ftin { display: grid; grid-template-columns: 1fr 1fr; gap: .55rem; }
.bmi-actions { display: flex; gap: .5rem; }
.bmi-error {
    margin-top: .85rem;
    padding: .6rem .85rem;
    border-radius: 8px;
    background: rgba(220,38,38,.08);
    border: 1px solid rgba(220,38,38,.25);
    color: #b91c1c;
    font-size: .9rem;
}

.bmi-result { margin-top: 1.25rem; }

.bmi-headline {
    text-align: center;
    padding: 2rem 1.5rem;
    border-radius: 18px;
    background: linear-gradient(135deg, #754ffe 0%, #5c3dd8 100%);
    color: #fff;
    box-shadow: 0 12px 32px rgba(117,79,254,.25);
}
.bmi-headline-label {
    font-size: .82rem;
    text-transform: uppercase;
    letter-spacing: .12em;
    opacity: .85;
    margin-bottom: .35rem;
}
.bmi-headline-value {
    font-size: clamp(2.4rem, 6vw, 3.4rem);
    font-weight: 800;
    line-height: 1;
    letter-spacing: -.02em;
}
.bmi-headline-unit { font-size: .35em; font-weight: 600; opacity: .85; margin-left: .25em; vertical-align: super; }
.bmi-category {
    display: inline-block;
    margin-top: .85rem;
    padding: .35rem 1rem;
    border-radius: 100px;
    font-weight: 700;
    font-size: .92rem;
    background: rgba(255,255,255,.18);
    color: #fff;
    border: 1px solid rgba(255,255,255,.3);
}
.bmi-cat-under   { background: rgba(96,165,250,.25); border-color: rgba(96,165,250,.5); }
.bmi-cat-healthy { background: rgba(34,197,94,.25);  border-color: rgba(34,197,94,.5); }
.bmi-cat-over    { background: rgba(245,158,11,.30); border-color: rgba(245,158,11,.55); }
.bmi-cat-obese   { background: rgba(220,38,38,.30);  border-color: rgba(220,38,38,.55); }

.bmi-gauge { margin-top: 1.25rem; }
.bmi-gauge-track {
    position: relative;
    display: flex;
    height: 14px;
    border-radius: 100px;
    overflow: hidden;
    background: #e5e7eb;
}
.bmi-gauge-band { display: block; }
.bmi-band-under   { background: #60a5fa; }
.bmi-band-healthy { background: #22c55e; }
.bmi-band-over    { background: #f59e0b; }
.bmi-band-obese   { background: #dc2626; }
.bmi-gauge-marker {
    position: absolute;
    top: -4px;
    width: 4px;
    height: 22px;
    background: #1a1a2e;
    border-radius: 2px;
    transform: translateX(-50%);
    transition: left .25s ease;
    box-shadow: 0 2px 6px rgba(0,0,0,.25);
}
.bmi-gauge-legend {
    display: flex;
    flex-wrap: wrap;
    gap: .6rem 1.1rem;
    margin-top: .65rem;
    font-size: .82rem;
    color: #6b7280;
}
.bmi-dot {
    display: inline-block;
    width: 10px; height: 10px;
    border-radius: 50%;
    margin-right: .35rem;
    vertical-align: -1px;
}
.bmi-dot-under   { background: #60a5fa; }
.bmi-dot-healthy { background: #22c55e; }
.bmi-dot-over    { background: #f59e0b; }
.bmi-dot-obese   { background: #dc2626; }

.bmi-detail-grid {
    margin-top: 1rem;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .85rem;
}
.bmi-detail-card {
    display: flex;
    gap: .85rem;
    align-items: center;
    padding: 1rem 1.1rem;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
}
.bmi-detail-icon {
    width: 44px; height: 44px;
    border-radius: 12px;
    background: rgba(117,79,254,.12);
    color: #754ffe;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.3rem;
    flex-shrink: 0;
}
.bmi-detail-label { font-size: .82rem; color: #6b7280; margin-bottom: .15rem; }
.bmi-detail-value { font-size: 1.05rem; font-weight: 700; color: #1a1a2e; }

.bmi-categories {
    margin-top: 1rem;
    padding: 1.1rem 1.25rem;
    background: #f8f7ff;
    border: 1px solid #ede9fe;
    border-radius: 12px;
}
.bmi-categories-title { font-weight: 700; color: #1a1a2e; font-size: .95rem; margin-bottom: .65rem; }
.bmi-cat-list { list-style: none; padding: 0; margin: 0; }
.bmi-cat-list li {
    display: grid;
    grid-template-columns: 22px 1fr auto;
    align-items: center;
    gap: .5rem;
    padding: .35rem 0;
    border-bottom: 1px dashed #ede9fe;
    font-size: .92rem;
    color: #1a1a2e;
}
.bmi-cat-list li:last-child { border-bottom: 0; }
.bmi-cat-list li span:last-child { color: #6b7280; font-family: ui-monospace, Menlo, monospace; font-size: .85rem; }
.bmi-disclaimer {
    margin: .85rem 0 0;
    font-size: .82rem;
    color: #6b7280;
    line-height: 1.5;
}

@media (max-width: 575.98px) {
    .bmi-input-grid,
    .bmi-detail-grid { grid-template-columns: 1fr; }
    .bmi-gauge-legend { font-size: .78rem; }
}

[data-theme="dark"] .bmi-units,
[data-theme="dark"] .bmi-categories { background: rgba(117,79,254,.10); border-color: rgba(117,79,254,.30); }
[data-theme="dark"] #bmiWrap .bmi-unit-btn,
[data-theme="dark"] #bmiWrap button.bmi-unit-btn { color: #9ca3af !important; }
[data-theme="dark"] #bmiWrap .bmi-unit-btn:hover,
[data-theme="dark"] #bmiWrap button.bmi-unit-btn:hover { color: #c7baff !important; background: rgba(117,79,254,.18) !important; }
[data-theme="dark"] #bmiWrap .bmi-unit-btn.active,
[data-theme="dark"] #bmiWrap button.bmi-unit-btn.active { background: var(--clr-card, #1d1c35) !important; color: #c7baff !important; }
[data-theme="dark"] .bmi-input-card,
[data-theme="dark"] .bmi-detail-card { background: var(--clr-card, #1d1c35); border-color: var(--clr-border, #2d2b4e); }
[data-theme="dark"] .bmi-label,
[data-theme="dark"] .bmi-categories-title,
[data-theme="dark"] .bmi-detail-value,
[data-theme="dark"] .bmi-cat-list li { color: #f1f5f9; }
[data-theme="dark"] .bmi-detail-label,
[data-theme="dark"] .bmi-gauge-legend,
[data-theme="dark"] .bmi-disclaimer { color: #9ca3af; }
[data-theme="dark"] .bmi-cat-list li { border-bottom-color: rgba(117,79,254,.25); }
[data-theme="dark"] .bmi-gauge-track { background: var(--clr-card, #1d1c35); }
[data-theme="dark"] .bmi-gauge-marker { background: #f1f5f9; }

/* ============================================================
   SPLIT PDF — .sp-* (sits on top of .aib-* shared layout)
   ============================================================ */

/* Outer editor card — mirrors #aibEditor */
#spEditor {
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 16px;
  overflow: hidden;
  background: var(--clr-card, #fff);
}

/* Preview panel — override AIB centering + checkerboard (we have a grid, not a single canvas) */
#spWrap .aib-preview-panel.sp-preview-panel {
  display: block;
  align-items: stretch;
  justify-content: stretch;
  background-color: var(--clr-card, #fff);
  background-image: none;
  padding: 1.25rem;
  max-height: 560px;
  overflow-y: auto;
}
#spWrap.aib-fullscreen .aib-preview-panel.sp-preview-panel {
  max-height: 100vh;
}

.sp-preview-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-bottom: .85rem;
  margin-bottom: .85rem;
  border-bottom: 1px solid var(--clr-border, #e5e7eb);
}
.sp-file-name {
  font-weight: 600;
  color: var(--clr-text, #1a1a2e);
  font-size: .95rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
  min-width: 0;
}
.sp-file-pages {
  font-size: .8rem;
  font-weight: 600;
  color: var(--clr-primary, #754ffe);
  background: rgba(117,79,254,.1);
  padding: .25rem .6rem;
  border-radius: 100px;
  flex-shrink: 0;
}

.sp-progress { padding: 0 0 1rem; }

.sp-thumbs {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap: .65rem;
}

.sp-thumb {
  position: relative;
  background: var(--clr-bg, #f8fafc);
  border: 2px solid var(--clr-border, #e5e7eb);
  border-radius: 10px;
  padding: .35rem;
  text-align: center;
  cursor: default;
  transition: border-color .2s, transform .15s, background .2s;
}
#spWrap.mode-each .sp-thumb { cursor: pointer; }
#spWrap.mode-each .sp-thumb:hover {
  transform: translateY(-2px);
  border-color: var(--clr-primary, #754ffe);
}
.sp-thumb img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 6px;
  box-shadow: 0 1px 5px rgba(15,23,42,.08);
}
.sp-thumb-num {
  display: inline-block;
  margin-top: .3rem;
  font-size: .78rem;
  font-weight: 600;
  color: var(--clr-muted, #6b7280);
}
.sp-thumb-check {
  position: absolute;
  top: .5rem;
  right: .5rem;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--clr-primary, #754ffe);
  color: #fff;
  display: none;
  align-items: center;
  justify-content: center;
  font-size: .85rem;
  box-shadow: 0 2px 6px rgba(117,79,254,.3);
}
.sp-thumb.selected {
  border-color: var(--clr-primary, #754ffe);
  background: rgba(117,79,254,.06);
}
.sp-thumb.selected .sp-thumb-check { display: inline-flex; }

.sp-pane code {
  background: var(--clr-bg, #f1f5f9);
  padding: 1px 5px;
  border-radius: 4px;
  font-size: .85em;
  color: var(--clr-text, #1a1a2e);
}

.sp-summary {
  margin-top: 1rem !important;
  padding: .9rem 1rem;
  background: var(--clr-bg, #f8fafc);
  border: 1px dashed var(--clr-border, #e5e7eb);
  border-radius: 10px;
}
.sp-summary-row {
  display: flex;
  align-items: center;
  gap: .55rem;
  font-size: .88rem;
  color: var(--clr-text, #1a1a2e);
}
.sp-summary-row + .sp-summary-row { margin-top: .35rem; }
.sp-summary-row .bi { color: var(--clr-primary, #754ffe); font-size: 1rem; }
.sp-summary-hint { color: var(--clr-muted, #6b7280) !important; font-size: .8rem; }
.sp-summary-hint .bi { color: #16a34a; }

.sp-error {
  margin-top: 1rem;
  padding: .75rem 1rem;
  background: #fef2f2;
  color: #b91c1c;
  border: 1px solid #fecaca;
  border-radius: 10px;
  font-size: .9rem;
}

/* Mode tab active state — reuse .aib-pos-btn but slightly tighter */
#spWrap .sp-mode-btn { font-size: .82rem; padding: .55rem .35rem; }

/* Fullscreen — mirrors #aibWrap.aib-fullscreen pattern */
#spWrap.aib-fullscreen {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: var(--clr-card, #fff);
  display: flex;
  flex-direction: column;
  padding: 0;
  margin: 0;
  max-width: none;
}
#spWrap.aib-fullscreen #spEditor {
  flex: 1;
  border: none;
  border-radius: 0;
  overflow: hidden;
  display: flex !important;
  flex-direction: column;
}
#spWrap.aib-fullscreen .aib-editor-wrap {
  flex: 1;
  min-height: unset;
}
#spWrap.aib-fullscreen .aib-preview-side {
  position: relative;
}
#spWrap.aib-fullscreen .aib-preview-panel {
  max-height: 100vh;
}
#spWrap.aib-fullscreen .sp-thumbs {
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
}
#spWrap.aib-fullscreen .aib-fs-close { display: flex; }

/* Dark mode */
[data-theme="dark"] .sp-thumb {
  background: rgba(117,79,254,.05);
  border-color: rgba(117,79,254,.2);
}
[data-theme="dark"] .sp-thumb.selected { background: rgba(117,79,254,.16); }
[data-theme="dark"] .sp-summary {
  background: rgba(117,79,254,.05);
  border-color: rgba(117,79,254,.25);
}
[data-theme="dark"] .sp-preview-head { border-color: rgba(117,79,254,.2); }
[data-theme="dark"] .sp-file-pages {
  background: rgba(117,79,254,.18);
  color: var(--clr-primary-light, #a78bfa);
}
[data-theme="dark"] .sp-pane code {
  background: rgba(117,79,254,.12);
  color: var(--clr-text, #f1f5f9);
}
[data-theme="dark"] .sp-error {
  background: rgba(239,68,68,.12);
  border-color: rgba(239,68,68,.3);
  color: #fca5a5;
}

@media (max-width: 575.98px) {
  .sp-thumbs { grid-template-columns: repeat(auto-fill, minmax(85px, 1fr)); gap: .5rem; }
  .sp-preview-panel { padding: .75rem; }
  #spWrap .sp-mode-btn { font-size: .72rem; padding: .45rem .2rem; }
}

/* ============================================================
   JSON FORMATTER — .jf-* (sits on top of .aib-* shared layout)
   ============================================================ */

#jfEditor {
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 16px;
  overflow: hidden;
  background: var(--clr-card, #fff);
}

/* Override AIB centering/checkerboard for code workspace */
#jfWrap .aib-preview-panel.jf-panel {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: stretch;
  background-color: var(--clr-card, #fff);
  background-image: none;
  padding: 0;
  overflow: hidden;
  max-height: 640px;
}

.jf-tabs {
  display: flex;
  gap: 0;
  background: var(--clr-bg, #f8fafc);
  border-bottom: 1px solid var(--clr-border, #e5e7eb);
  flex-shrink: 0;
}
.jf-tab {
  background: transparent;
  border: 0;
  border-right: 1px solid var(--clr-border, #e5e7eb);
  padding: .65rem 1.1rem;
  font-size: .85rem;
  font-weight: 600;
  color: var(--clr-muted, #6b7280);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  transition: color .2s, background .2s, border-color .2s;
}
.jf-tab:hover { color: var(--clr-text, #1a1a2e); background: rgba(117,79,254,.04); }
.jf-tab.active {
  color: var(--clr-primary, #754ffe);
  background: var(--clr-card, #fff);
  border-bottom-color: var(--clr-primary, #754ffe);
}

.jf-panes {
  flex: 1;
  min-height: 0;
  position: relative;
  overflow: hidden;
}
.jf-pane {
  height: 100%;
  overflow: auto;
}

.jf-textarea {
  width: 100%;
  height: 100%;
  min-height: 320px;
  border: 0;
  outline: none;
  padding: 1rem 1.1rem;
  font-family: 'SF Mono', Menlo, Consolas, 'Courier New', monospace;
  font-size: .88rem;
  line-height: 1.55;
  background: var(--clr-card, #fff);
  color: var(--clr-text, #1a1a2e);
  resize: none;
  box-sizing: border-box;
}
.jf-textarea:focus { background: var(--clr-card, #fff); }

.jf-output {
  margin: 0;
  padding: 1rem 1.1rem;
  font-family: 'SF Mono', Menlo, Consolas, 'Courier New', monospace;
  font-size: .88rem;
  line-height: 1.55;
  white-space: pre;
  overflow: auto;
  background: var(--clr-card, #fff);
  color: var(--clr-text, #1a1a2e);
  min-height: 320px;
}
.jf-output.jf-output-tree {
  white-space: normal;
  padding: 1rem 1.1rem;
}


.jf-placeholder {
  color: var(--clr-muted, #6b7280);
  font-family: var(--font, 'Inter', sans-serif);
  font-style: italic;
  display: block;
  padding: 1.5rem .25rem;
}

/* Syntax color tokens */
.jf-key   { color: #7c3aed; font-weight: 600; }
.jf-str   { color: #16a34a; }
.jf-num   { color: #2563eb; }
.jf-bool  { color: #ea580c; font-weight: 600; }
.jf-null  { color: #6b7280; font-style: italic; }

/* Tree view */
.jf-tree-node { padding-left: 0; }
.jf-tree-head {
  display: flex;
  align-items: center;
  gap: .35rem;
  cursor: default;
}
.jf-tree-toggle,
.jf-tree-toggle:hover,
.jf-tree-toggle:focus,
.jf-tree-toggle:active,
.jf-tree-toggle:focus-visible {
  background: transparent !important;
  background-color: transparent !important;
  border: 0 !important;
  outline: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  color: var(--clr-muted, #6b7280);
  cursor: pointer;
  font-size: .7rem;
  width: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transform: none !important;
}
.jf-tree-toggle:hover,
.jf-tree-toggle:focus { color: var(--clr-primary, #754ffe) !important; }
[data-theme="dark"] .jf-tree-toggle:hover,
[data-theme="dark"] .jf-tree-toggle:focus { color: var(--clr-primary-light, #a78bfa) !important; }
.jf-tree-key {
  color: #7c3aed;
  font-weight: 600;
}
.jf-tree-bracket { color: var(--clr-muted, #6b7280); }
.jf-tree-count {
  color: var(--clr-muted, #6b7280);
  font-size: .75rem;
  margin-left: .35rem;
  font-style: italic;
}
.jf-tree-children {
  margin-left: 1.25rem;
  border-left: 1px dashed rgba(117,79,254,.2);
  padding-left: .75rem;
}
.jf-tree-tail { padding-left: 1.6rem; }
.jf-tree-node.collapsed > .jf-tree-children,
.jf-tree-node.collapsed > .jf-tree-tail { display: none; }
.jf-tree-node.collapsed > .jf-tree-head::after {
  content: ' ... ';
  color: var(--clr-muted, #6b7280);
  margin-left: .35rem;
}

/* Status bar */
.jf-statusbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .55rem 1rem;
  border-top: 1px solid var(--clr-border, #e5e7eb);
  background: var(--clr-bg, #f8fafc);
  flex-shrink: 0;
  font-family: var(--font, 'Inter', sans-serif);
}
.jf-status-pill {
  display: inline-flex;
  align-items: center;
  font-size: .78rem;
  font-weight: 600;
  padding: .3rem .65rem;
  border-radius: 100px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}
.jf-status-pill.jf-flash { animation: jfFlash .6s ease; }
@keyframes jfFlash {
  0%, 100% { transform: scale(1); }
  20% { transform: scale(1.08); }
}
.jf-status-empty   { background: rgba(107,114,128,.12); color: #475569; }
.jf-status-valid   { background: rgba(22,163,74,.12);  color: #16a34a; }
.jf-status-invalid { background: rgba(239,68,68,.12);  color: #b91c1c; }
.jf-line { font-weight: 500; opacity: .85; margin-left: .3rem; }
.jf-size {
  font-size: .75rem;
  color: var(--clr-muted, #6b7280);
  font-weight: 500;
  flex-shrink: 0;
}

.jf-privacy-note {
  font-size: .75rem;
  color: var(--clr-muted, #6b7280);
  background: rgba(22,163,74,.08);
  border: 1px solid rgba(22,163,74,.2);
  padding: .55rem .75rem;
  border-radius: 8px;
  margin: 0;
  line-height: 1.45;
}
.jf-privacy-note .bi { color: #16a34a; }

/* Mode buttons sizing */
#jfWrap .jf-mode-btn,
#jfWrap .jf-indent-btn { font-size: .82rem; padding: .5rem .35rem; }

/* Fullscreen */
#jfWrap.aib-fullscreen {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: var(--clr-card, #fff);
  display: flex;
  flex-direction: column;
  padding: 0;
  margin: 0;
  max-width: none;
}
#jfWrap.aib-fullscreen #jfEditor {
  flex: 1;
  border: none;
  border-radius: 0;
  overflow: hidden;
  display: flex !important;
  flex-direction: column;
}
#jfWrap.aib-fullscreen .aib-editor-wrap { flex: 1; min-height: unset; }
#jfWrap.aib-fullscreen .aib-preview-side { position: relative; }
#jfWrap.aib-fullscreen .aib-preview-panel.jf-panel { max-height: 100vh; }
#jfWrap.aib-fullscreen .aib-fs-close { display: flex; }

/* Dark mode */
[data-theme="dark"] .jf-tabs { background: rgba(117,79,254,.06); border-color: rgba(117,79,254,.2); }
[data-theme="dark"] .jf-tab { border-color: rgba(117,79,254,.15); color: #cbd5e1; }
[data-theme="dark"] .jf-tab:hover { background: rgba(117,79,254,.1); color: #fff; }
[data-theme="dark"] .jf-tab.active {
  background: var(--clr-card, #1d1c35);
  color: var(--clr-primary-light, #a78bfa);
  border-bottom-color: var(--clr-primary-light, #a78bfa);
}
[data-theme="dark"] .jf-textarea,
[data-theme="dark"] .jf-output {
  background: var(--clr-card, #1d1c35);
  color: #e2e8f0;
}
[data-theme="dark"] .jf-statusbar { background: rgba(117,79,254,.05); border-color: rgba(117,79,254,.2); }
[data-theme="dark"] .jf-key   { color: #c4b5fd; }
[data-theme="dark"] .jf-str   { color: #86efac; }
[data-theme="dark"] .jf-num   { color: #93c5fd; }
[data-theme="dark"] .jf-bool  { color: #fdba74; }
[data-theme="dark"] .jf-null  { color: #9ca3af; }
[data-theme="dark"] .jf-tree-key { color: #c4b5fd; }
[data-theme="dark"] .jf-tree-bracket,
[data-theme="dark"] .jf-tree-count { color: #9ca3af; }
[data-theme="dark"] .jf-privacy-note {
  background: rgba(22,163,74,.12);
  border-color: rgba(22,163,74,.25);
  color: #cbd5e1;
}

/* Mobile */
@media (max-width: 575.98px) {
  .jf-tab { font-size: .75rem; padding: .55rem .65rem; }
  .jf-textarea, .jf-output { font-size: .8rem; padding: .75rem .85rem; min-height: 260px; }
  .jf-statusbar { padding: .5rem .75rem; }
  .jf-status-pill { font-size: .72rem; }
  #jfWrap .jf-mode-btn,
  #jfWrap .jf-indent-btn { font-size: .72rem; padding: .45rem .2rem; }
}

/* ============================================================
   COMPRESS PDF — mobile responsive fixes (375px)
   ============================================================ */
@media (max-width: 575.98px) {
  /* Prevent any overflow at the wrap level */
  #cpdfWrap, #cpUploadZone, #cpEditor {
    max-width: 100%;
    overflow-x: hidden;
  }

  /* File head row: let filename shrink properly via flex */
  .cpdf-file-head {
    padding: 12px;
    gap: 8px;
  }
  .cpdf-file-name {
    max-width: 100%;
    min-width: 0;
    font-size: .82rem;
  }
  .cpdf-file-size { font-size: .72rem; }

  /* Stack option cards into a single column on small phones */
  .cpdf-opt-grid {
    grid-template-columns: 1fr;
    gap: 8px;
  }
  .cpdf-opt-card { padding: 12px 10px; }

  /* Body padding eats less of the 375px viewport */
  .cpdf-body { padding: 14px; }

  /* Size compare row: wrap cleanly, don't push width */
  .cpdf-size-compare {
    padding: 12px;
    gap: 10px;
    flex-direction: column;
  }
  .cpdf-size-arrow { transform: rotate(90deg); }
  .cpdf-size-val { font-size: .95rem; }

  /* Custom options notice / radio row */
  .cpdf-custom-wrap { padding: 12px; }
  .cpdf-radio-row { gap: 12px; }
  .cpdf-notice { padding: 10px 12px; font-size: .75rem; }

  /* The "Change" button after the filename */
  .cpdf-file-head .btn-outline-secondary {
    padding: 4px 10px;
    font-size: .75rem;
  }
}

/* ============================================================
   SIGN PDF — .sgn-* (sits on top of .aib-* shared layout)
   ============================================================ */

#sgnEditor {
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 16px;
  overflow: hidden;
  background: var(--clr-card, #fff);
}

#sgnWrap .aib-preview-panel.sgn-preview-panel {
  display: block;
  background-color: var(--clr-bg, #f8fafc);
  background-image: none;
  padding: 0;
  overflow-y: auto;
  overflow-x: hidden;
  max-height: 760px;
}
/* Sticky pagebar so user can navigate while scrolled down */
#sgnWrap .sgn-pagebar { position: sticky; top: 0; z-index: 5; }

.sgn-pagebar {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .7rem 1rem;
  background: var(--clr-card, #fff);
  border-bottom: 1px solid var(--clr-border, #e5e7eb);
  flex-shrink: 0;
}
.sgn-pageinfo {
  font-weight: 600;
  font-size: .85rem;
  color: var(--clr-text, #1a1a2e);
  min-width: 110px;
  text-align: center;
}
.sgn-file-name {
  font-size: .8rem;
  color: var(--clr-muted, #6b7280);
  margin-left: auto;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 50%;
}

.sgn-progress { padding: 1rem; }

.sgn-stage {
  position: relative;
  margin: 1rem auto;
  background: #fff;
  box-shadow: 0 4px 24px rgba(15, 23, 42, .12);
  border-radius: 4px;
  overflow: hidden;
}
.sgn-stage.sgn-place-mode { cursor: crosshair; }
.sgn-page-canvas {
  display: block;
  pointer-events: none;
}

.sgn-overlay {
  position: absolute;
  border: 2px dashed rgba(117, 79, 254, .55);
  background: rgba(117, 79, 254, .04);
  cursor: move;
  user-select: none;
  box-sizing: border-box;
}
.sgn-overlay.selected { border-color: var(--clr-primary, #754ffe); background: rgba(117, 79, 254, .1); }
.sgn-overlay img {
  display: block;
  width: 100%;
  height: 100%;
  pointer-events: none;
  user-select: none;
}
button.sgn-overlay-del,
button.sgn-overlay-del:hover,
button.sgn-overlay-del:focus,
button.sgn-overlay-del:active,
button.sgn-overlay-del:focus-visible {
  position: absolute;
  top: -10px;
  right: -10px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #ef4444 !important;
  background-color: #ef4444 !important;
  color: #fff !important;
  border: 0 !important;
  outline: none !important;
  padding: 0 !important;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .8rem;
  line-height: 1;
  cursor: pointer;
  z-index: 2;
  box-shadow: 0 1px 4px rgba(0,0,0,.18) !important;
}
button.sgn-overlay-del:hover { background: #dc2626 !important; background-color: #dc2626 !important; }
.sgn-overlay-handle {
  position: absolute;
  bottom: -6px;
  right: -6px;
  width: 14px;
  height: 14px;
  background: var(--clr-primary, #754ffe);
  border: 2px solid #fff;
  border-radius: 50%;
  cursor: nwse-resize;
  z-index: 2;
}

.sgn-hint {
  font-size: .8rem;
  color: var(--clr-muted, #6b7280);
  text-align: center;
  margin: 0;
  padding: .65rem 1rem;
  background: rgba(117, 79, 254, .04);
  border-top: 1px solid var(--clr-border, #e5e7eb);
  flex-shrink: 0;
}

/* Signature pad */
.sgn-pad-wrap {
  background: #fff;
  border: 2px dashed var(--clr-border, #e5e7eb);
  border-radius: 8px;
  padding: 4px;
}
.sgn-pad {
  display: block;
  width: 100%;
  height: 140px;
  background: #fff;
  cursor: crosshair;
  touch-action: none;
}

.sgn-input {
  font-family: inherit;
  font-size: .9rem;
  border-radius: 8px;
}

.sgn-type-preview {
  margin-top: .7rem;
  padding: .85rem;
  background: #fff;
  border: 1px dashed var(--clr-border, #e5e7eb);
  border-radius: 8px;
  font-size: 1.6rem;
  text-align: center;
  color: var(--clr-text, #1a1a2e);
  min-height: 60px;
  font-family: 'Great Vibes', cursive;
}

.sgn-img-preview {
  display: none;
  margin-top: .7rem;
  max-width: 100%;
  background: #fff;
  border: 1px dashed var(--clr-border, #e5e7eb);
  border-radius: 8px;
  padding: 6px;
}

.sgn-summary {
  margin: 0;
  padding: .7rem .85rem;
  background: var(--clr-bg, #f8fafc);
  border: 1px dashed var(--clr-border, #e5e7eb);
  border-radius: 10px;
  font-size: .85rem;
  color: var(--clr-text, #1a1a2e);
  display: flex;
  align-items: center;
  gap: .55rem;
}
.sgn-summary .bi { color: var(--clr-primary, #754ffe); font-size: 1rem; }

.sgn-error {
  margin-top: 1rem;
  padding: .75rem 1rem;
  background: #fef2f2;
  color: #b91c1c;
  border: 1px solid #fecaca;
  border-radius: 10px;
  font-size: .9rem;
}

#sgnWrap .sgn-mode-btn { font-size: .82rem; padding: .55rem .35rem; }

/* Fullscreen — mirrors aib pattern */
#sgnWrap.aib-fullscreen {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: var(--clr-card, #fff);
  display: flex;
  flex-direction: column;
  padding: 0;
  margin: 0;
  max-width: none;
}
#sgnWrap.aib-fullscreen #sgnEditor {
  flex: 1;
  border: none;
  border-radius: 0;
  overflow: hidden;
  display: flex !important;
  flex-direction: column;
}
#sgnWrap.aib-fullscreen .aib-editor-wrap {
  flex: 1;
  min-height: unset;
}
#sgnWrap.aib-fullscreen .aib-preview-side {
  position: relative;
}
#sgnWrap.aib-fullscreen .aib-preview-panel.sgn-preview-panel {
  max-height: 100vh;
  overflow-y: auto;
}
#sgnWrap.aib-fullscreen .aib-fs-close { display: flex; }

/* In fullscreen, pin the hint to the bottom of the preview-side viewport */
#sgnWrap.aib-fullscreen #sgnHint {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 270px;          /* width of the .aib-sidebar */
  margin: 0;
  z-index: 100;
  border-top: 1px solid var(--clr-border, #e5e7eb);
  box-shadow: 0 -2px 12px rgba(15, 23, 42, .08);
}
@media (max-width: 768px) {
  #sgnWrap.aib-fullscreen #sgnHint { right: 0; }
}

/* Dark mode */
[data-theme="dark"] #sgnWrap .aib-preview-panel.sgn-preview-panel { background: var(--clr-bg, #0d0c1a); }
[data-theme="dark"] .sgn-pagebar { background: var(--clr-card, #1d1c35); border-color: rgba(117,79,254,.2); }
[data-theme="dark"] .sgn-stage { background: var(--clr-card, #1d1c35); }
[data-theme="dark"] .sgn-hint { background: rgba(117,79,254,.08); border-color: rgba(117,79,254,.2); }
[data-theme="dark"] .sgn-pad-wrap { background: var(--clr-card, #1d1c35); border-color: rgba(117,79,254,.25); }
[data-theme="dark"] .sgn-pad { background: var(--clr-card, #1d1c35); }
[data-theme="dark"] .sgn-type-preview, [data-theme="dark"] .sgn-img-preview {
  background: var(--clr-card, #1d1c35); border-color: rgba(117,79,254,.25); color: #e2e8f0;
}
[data-theme="dark"] .sgn-summary { background: rgba(117,79,254,.05); border-color: rgba(117,79,254,.25); }
[data-theme="dark"] .sgn-error { background: rgba(239,68,68,.12); border-color: rgba(239,68,68,.3); color: #fca5a5; }
[data-theme="dark"] .sgn-overlay { background: rgba(117,79,254,.1); border-color: rgba(117,79,254,.5); }

/* Mobile */
@media (max-width: 575.98px) {
  .sgn-pagebar { padding: .55rem .65rem; flex-wrap: wrap; }
  .sgn-pageinfo { font-size: .75rem; min-width: 90px; }
  .sgn-file-name { display: none; }
  .sgn-pad { height: 110px; }
  .sgn-type-preview { font-size: 1.25rem; min-height: 48px; }
  #sgnWrap .sgn-mode-btn { font-size: .72rem; padding: .45rem .2rem; }
}

/* ============================================================
   MEME GENERATOR — .mg-* (on top of .aib-* shared layout)
   ============================================================ */

#mgEditor {
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 16px;
  overflow: hidden;
  background: var(--clr-card, #fff);
}

#mgWrap .aib-preview-panel.mg-preview-panel {
  display: block;
  background-color: var(--clr-bg, #f8fafc);
  background-image: none;
  padding: 1rem;
  overflow-y: auto;
  overflow-x: hidden;
  max-height: 760px;
}

.mg-stage {
  position: relative;
  margin: 0 auto;
  background: #fff;
  box-shadow: 0 4px 24px rgba(15, 23, 42, .12);
  border-radius: 4px;
  overflow: hidden;
  user-select: none;
}
.mg-canvas { display: block; pointer-events: none; }

.mg-text-overlay {
  position: absolute;
  cursor: move;
  padding: 4px 6px;
  border: 2px dashed transparent;
  border-radius: 4px;
  line-height: 1.05;
  text-align: center;
  white-space: pre-wrap;
  max-width: 95%;
}
.mg-text-overlay:hover { border-color: rgba(117, 79, 254, .35); }
.mg-text-overlay.selected { border-color: var(--clr-primary, #754ffe); background: rgba(117, 79, 254, .04); }
.mg-text-span {
  display: block;
  pointer-events: none;
  -webkit-text-stroke: 4px #000;
  paint-order: stroke fill;
}
button.mg-text-del,
button.mg-text-del:hover,
button.mg-text-del:focus,
button.mg-text-del:active {
  position: absolute;
  top: -10px;
  right: -10px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #ef4444 !important;
  background-color: #ef4444 !important;
  color: #fff !important;
  border: 0 !important;
  outline: none !important;
  padding: 0 !important;
  display: none;
  align-items: center;
  justify-content: center;
  font-size: .8rem;
  line-height: 1;
  cursor: pointer;
  z-index: 2;
  box-shadow: 0 1px 4px rgba(0,0,0,.18) !important;
}
.mg-text-overlay.selected button.mg-text-del { display: flex; }
button.mg-text-del:hover { background: #dc2626 !important; background-color: #dc2626 !important; }

.mg-hint {
  font-size: .8rem;
  color: var(--clr-muted, #6b7280);
  text-align: center;
  margin: .85rem 0 0;
  padding: .6rem .85rem;
  background: rgba(117, 79, 254, .06);
  border-radius: 8px;
}

.mg-input {
  font-family: inherit;
  font-size: .9rem;
  border-radius: 8px;
}

.mg-color-row {
  display: flex;
  gap: .55rem;
  align-items: center;
}
.mg-color {
  width: 44px;
  height: 36px;
  padding: 0;
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 8px;
  cursor: pointer;
}
.mg-color-hex {
  flex: 1;
  font-size: .85rem;
  font-family: 'SF Mono', Menlo, Consolas, monospace;
  text-transform: lowercase;
  border-radius: 8px;
}

#mgWrap .mg-fmt-btn { font-size: .82rem; padding: .55rem .35rem; }

/* Fullscreen */
#mgWrap.aib-fullscreen {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: var(--clr-card, #fff);
  display: flex;
  flex-direction: column;
  padding: 0;
  margin: 0;
  max-width: none;
}
#mgWrap.aib-fullscreen #mgEditor {
  flex: 1;
  border: none;
  border-radius: 0;
  overflow: hidden;
  display: flex !important;
  flex-direction: column;
}
#mgWrap.aib-fullscreen .aib-editor-wrap { flex: 1; min-height: unset; }
#mgWrap.aib-fullscreen .aib-preview-side { position: relative; }
#mgWrap.aib-fullscreen .aib-preview-panel.mg-preview-panel { max-height: 100vh; }
#mgWrap.aib-fullscreen .aib-fs-close { display: flex; }

/* Dark mode */
[data-theme="dark"] #mgWrap .aib-preview-panel.mg-preview-panel { background: var(--clr-bg, #0d0c1a); }
[data-theme="dark"] .mg-stage { background: var(--clr-card, #1d1c35); }
[data-theme="dark"] .mg-hint { background: rgba(117,79,254,.08); color: #cbd5e1; }
[data-theme="dark"] .mg-color { border-color: rgba(117,79,254,.25); }
[data-theme="dark"] .mg-color-hex { background: rgba(117,79,254,.05); border-color: rgba(117,79,254,.25); color: #e2e8f0; }

/* Mobile */
@media (max-width: 575.98px) {
  #mgWrap .aib-preview-panel.mg-preview-panel { padding: .6rem; max-height: 560px; }
  .mg-hint { font-size: .75rem; }
  .mg-color { width: 38px; height: 34px; }
  #mgWrap .mg-fmt-btn { font-size: .72rem; padding: .45rem .2rem; }
}

/* === Profile Photo Maker (.pp-*) ============================ */
#ppWrap .aib-preview-panel.pp-preview {
  display: flex;
  align-items: stretch;
  justify-content: stretch;
  background-color: var(--clr-card, #fff);
  background-image: none;
  padding: 0 !important;
  min-height: 560px;
}
.pp-stage {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  width: 100%;
  flex: 1 1 auto;
  min-height: 100%;
  background-color: #fff;
  background-image:
    linear-gradient(45deg, #cbd5e1 25%, transparent 25%, transparent 75%, #cbd5e1 75%),
    linear-gradient(45deg, #cbd5e1 25%, transparent 25%, transparent 75%, #cbd5e1 75%);
  background-size: 22px 22px;
  background-position: 0 0, 11px 11px;
  border-radius: 0;
  padding: 1.5rem 1.5rem 4.5rem;
}
.pp-canvas-wrap {
  position: relative;
  width: 100%;
  max-width: 460px;
  display: flex;
  align-items: center;
  justify-content: center;
}
#ppCanvas {
  max-width: 100%;
  width: 100%;
  height: auto;
  aspect-ratio: 1 / 1;
  display: block;
  background: transparent;
  cursor: grab;
  user-select: none;
  touch-action: none;
}
.pp-loader {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .75rem;
  background: rgba(255,255,255,.85);
  border-radius: 12px;
  z-index: 5;
}
.pp-loader-spinner {
  width: 40px;
  height: 40px;
  border: 3px solid rgba(117,79,254,.2);
  border-top-color: #754ffe;
  border-radius: 50%;
  animation: pp-spin 0.9s linear infinite;
}
.pp-loader-text { font-size: .85rem; color: #475569; }
@keyframes pp-spin { to { transform: rotate(360deg); } }
[data-theme="dark"] .pp-loader { background: rgba(13,12,26,.85); }
[data-theme="dark"] .pp-loader-text { color: #cbd5e1; }
#ppCanvas:active { cursor: grabbing; }
.pp-hint {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  margin: 0;
  font-size: .82rem;
  color: var(--clr-muted, #64748b);
  text-align: center;
  background: #fff;
  border-top: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 0;
  padding: .65rem .75rem;
  max-width: none;
  z-index: 4;
}

#ppWrap .pp-dual-row {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: flex-start;
  gap: .75rem;
  width: 100%;
}
#ppWrap .pp-dual-col {
  flex: 1 1 0;
  min-width: 0;
}
#ppWrap .pp-dual-col-ring { flex: 1 1 auto; }
#ppWrap .pp-dual-col-color {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: .35rem;
}
#ppWrap .pp-ring-color {
  width: 48px;
  height: 38px;
  padding: 2px;
  cursor: pointer;
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 8px;
}
#ppWrap .pp-dual-col .aib-form-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: .35rem;
  margin-bottom: .35rem;
}
#ppWrap .pp-dual-col input[type="range"] { width: 100%; max-width: 100%; }
#ppWrap .pp-dual-col .aib-form-val { font-size: .78rem; white-space: nowrap; }
#ppWrap .pp-dual-col .aib-form-label { font-size: .78rem; }
@media (max-width: 420px) {
  #ppWrap .pp-dual-row { flex-direction: row; }
}

#ppWrap .pp-zoom-row {
  width: 100%;
  max-width: 460px;
  display: flex;
  align-items: center;
  gap: .6rem;
  background: rgba(255,255,255,.85);
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 999px;
  padding: .4rem .7rem;
  box-shadow: 0 4px 14px rgba(15,23,42,.06);
}
#ppWrap .pp-zoom-label {
  font-size: .78rem;
  font-weight: 600;
  color: #475569;
  white-space: nowrap;
}
#ppWrap .pp-zoom-btn {
  flex: 0 0 auto;
  width: 30px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--clr-border, #e5e7eb);
  background: #fff;
  color: #111;
  border-radius: 50%;
  cursor: pointer;
  transition: background .15s, border-color .15s, transform .1s;
  padding: 0;
}
#ppWrap .pp-zoom-btn:hover {
  background: rgba(117,79,254,.08);
  border-color: var(--clr-primary, #754ffe);
  color: #111;
}
#ppWrap .pp-zoom-btn:active { transform: scale(.92); }
#ppWrap .pp-zoom-btn i { font-size: .95rem; line-height: 1; }
#ppWrap .pp-zoom-range {
  flex: 1 1 auto;
  margin: 0;
  height: 4px;
}
#ppWrap .pp-zoom-val {
  flex: 0 0 auto;
  min-width: 42px;
  text-align: right;
  font-size: .78rem;
  font-weight: 600;
  color: #475569;
  white-space: nowrap;
}
[data-theme="dark"] #ppWrap .pp-zoom-row { background: rgba(29,28,53,.85); border-color: rgba(117,79,254,.25); }
[data-theme="dark"] #ppWrap .pp-zoom-label,
[data-theme="dark"] #ppWrap .pp-zoom-val { color: #cbd5e1; }
[data-theme="dark"] #ppWrap .pp-zoom-btn { background: #1d1c35; border-color: rgba(117,79,254,.25); color: #e2e8f0; }

/* Border ring + color row */
#ppWrap .pp-ring-row {
  display: flex;
  align-items: center;
  gap: .75rem;
}
#ppWrap .pp-ring-swatch {
  position: relative;
  flex: 0 0 auto;
  width: 38px;
  height: 38px;
  border-radius: 10px;
  cursor: pointer;
  display: block;
  margin: 0;
  box-shadow: inset 0 0 0 1px var(--clr-border, #e5e7eb);
  overflow: hidden;
}
#ppWrap .pp-ring-color {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
  padding: 0;
  border: 0;
}
#ppWrap .pp-ring-swatch-dot {
  position: absolute;
  inset: 4px;
  border-radius: 7px;
  background: #000;
  display: block;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.4);
}
#ppWrap .pp-ring-slider {
  flex: 1 1 auto;
  min-width: 0;
}
#ppWrap .pp-ring-slider input[type="range"] { margin: 0; width: 100%; }
#ppWrap .pp-ring-val {
  flex: 0 0 auto;
  min-width: 42px;
  text-align: right;
  font-size: .82rem;
  font-weight: 600;
  color: var(--clr-muted, #64748b);
}
[data-theme="dark"] #ppWrap .pp-ring-swatch { box-shadow: inset 0 0 0 1px rgba(117,79,254,.25); }
[data-theme="dark"] #ppWrap .pp-ring-val { color: #cbd5e1; }


#ppWrap .pp-effect-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .5rem;
}
#ppWrap .pp-effect-grid .pp-fx-color { grid-column: 1 / -1; }
#ppWrap .pp-fx-btn {
  font-size: .8rem;
  padding: .45rem .35rem;
  color: #111;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .4rem;
  position: relative;
  cursor: pointer;
  margin: 0;
}
#ppWrap .pp-fx-color-input {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
  padding: 0;
  border: 0;
}
#ppWrap .pp-fx-color-dot {
  width: 16px;
  height: 16px;
  border-radius: 4px;
  background: #754ffe;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.15);
  flex: 0 0 auto;
  display: inline-block;
}
#ppWrap .pp-fx-btn:hover,
#ppWrap .pp-fx-btn:focus,
#ppWrap .pp-fx-btn:active { color: #111 !important; }
#ppWrap .pp-fx-btn.active {
  background: rgba(117,79,254,.12);
  border-color: var(--clr-primary, #754ffe);
  color: #111 !important;
}
#ppWrap .pp-fx-btn.active:hover { background: rgba(117,79,254,.18); color: #111 !important; }
[data-theme="dark"] #ppWrap .pp-fx-btn { color: #e2e8f0; }
[data-theme="dark"] #ppWrap .pp-fx-btn:hover,
[data-theme="dark"] #ppWrap .pp-fx-btn.active { color: #fff !important; }

#ppWrap .pp-shape-btn,
#ppWrap .pp-fmt-btn {
  font-size: .85rem;
  padding: .5rem .25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .35rem;
  color: #111;
}
#ppWrap .pp-shape-btn:hover,
#ppWrap .pp-fmt-btn:hover,
#ppWrap .pp-shape-btn:focus,
#ppWrap .pp-fmt-btn:focus,
#ppWrap .pp-shape-btn:active,
#ppWrap .pp-fmt-btn:active { color: #111 !important; }
#ppWrap .pp-shape-btn.active,
#ppWrap .pp-fmt-btn.active {
  background: rgba(117,79,254,.12);
  border-color: var(--clr-primary, #754ffe);
  color: #111 !important;
}
#ppWrap .pp-shape-btn.active:hover,
#ppWrap .pp-fmt-btn.active:hover { color: #111 !important; background: rgba(117,79,254,.18); }
#ppWrap .pp-shape-btn i,
#ppWrap .pp-fmt-btn i { font-size: 1rem; }

#ppEditor {
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 16px;
  overflow: hidden;
  background: var(--clr-card, #fff);
}

/* Fullscreen */
#ppWrap.aib-fullscreen {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: var(--clr-bg, #fff);
  padding: 1rem;
  overflow: auto;
}
#ppWrap.aib-fullscreen .aib-editor-wrap { height: 100%; }
#ppWrap.aib-fullscreen .aib-preview-panel.pp-preview { max-height: 100vh; min-height: 100vh; }
#ppWrap.aib-fullscreen #ppCanvas { max-width: min(80vmin, 560px); }
#ppWrap.aib-fullscreen .aib-fs-close { display: flex; }

/* Dark mode */
[data-theme="dark"] #ppWrap .aib-preview-panel.pp-preview { background: var(--clr-bg, #0d0c1a); }
[data-theme="dark"] .pp-stage {
  background-color: #14132a;
  background-image:
    linear-gradient(45deg, #1f1e3a 25%, transparent 25%, transparent 75%, #1f1e3a 75%),
    linear-gradient(45deg, #1f1e3a 25%, transparent 25%, transparent 75%, #1f1e3a 75%);
  background-size: 22px 22px;
  background-position: 0 0, 11px 11px;
}
[data-theme="dark"] .pp-hint { background: #1d1c35; border-top-color: rgba(117,79,254,.25); }
[data-theme="dark"] #ppCanvas { background: transparent; }
[data-theme="dark"] .pp-hint { background: rgba(117,79,254,.1); color: #cbd5e1; }
[data-theme="dark"] #ppWrap .pp-shape-btn,
[data-theme="dark"] #ppWrap .pp-fmt-btn { color: #e2e8f0; }
[data-theme="dark"] #ppWrap .pp-shape-btn:hover,
[data-theme="dark"] #ppWrap .pp-fmt-btn:hover,
[data-theme="dark"] #ppWrap .pp-shape-btn.active,
[data-theme="dark"] #ppWrap .pp-fmt-btn.active { color: #fff !important; }

/* Mobile */
@media (max-width: 575.98px) {
  #ppWrap .aib-preview-panel.pp-preview { padding: .6rem; min-height: 480px; }
  #ppCanvas { max-width: 100%; }
  .pp-hint { font-size: .75rem; }
  #ppWrap .pp-shape-btn,
  #ppWrap .pp-fmt-btn { font-size: .78rem; padding: .42rem .15rem; }
}


/* ── Chrome Extension Icon Generator (.cei-*) ─────────────────────────── */
#ceiWrap { position: relative; }

/* ── Top bar (source filename + actions) ── */
#ceiWrap .cei-top-bar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem;
  padding: .85rem 1.1rem;
  background: var(--clr-card, #fff);
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 14px;
  margin-bottom: 1.25rem;
  flex-wrap: wrap;
}
#ceiWrap .cei-source-info {
  display: flex; align-items: center; gap: .6rem;
  min-width: 0;
  font-size: .9rem;
  color: var(--clr-text, #0f172a);
}
#ceiWrap .cei-source-info > i {
  width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(117,79,254,.12);
  color: var(--clr-primary, #754ffe);
  border-radius: 8px;
  font-size: 1rem;
  flex: 0 0 32px;
}
#ceiWrap .cei-source-info #ceiSrcName {
  font-weight: 600;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  max-width: 320px;
}
#ceiWrap .cei-src-dim {
  font-size: .76rem; color: var(--clr-muted, #64748b);
  background: var(--clr-bg-soft, #f1f5f9);
  padding: .2rem .6rem;
  border-radius: 999px;
  font-weight: 600;
}
#ceiWrap .cei-top-actions { display: flex; align-items: center; gap: .5rem; }
#ceiWrap .cei-icon-btn {
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--clr-bg-soft, #f1f5f9);
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 10px;
  color: var(--clr-text, #0f172a);
  cursor: pointer;
  transition: background .15s ease;
}
#ceiWrap .cei-icon-btn:hover { background: var(--clr-bg-hover, #e2e8f0); }

/* ── Tile grid (cleaner, larger) ── */
#ceiWrap .cei-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  margin-bottom: 1.5rem;
}
#ceiWrap .cei-tile {
  background: var(--clr-card, #fff);
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 16px;
  padding: 0;
  display: flex; flex-direction: column;
  overflow: hidden;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
#ceiWrap .cei-tile:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(15,23,42,.08);
  border-color: rgba(117,79,254,.35);
}
#ceiWrap .cei-tile-head {
  display: flex; flex-direction: column;
  align-items: center;
  text-align: center;
  padding: .9rem 1rem .65rem;
  background: linear-gradient(180deg, rgba(117,79,254,.06), transparent);
  border-bottom: 1px solid var(--clr-border, #e5e7eb);
}
#ceiWrap .cei-tile-label {
  font-size: 1.05rem; font-weight: 800;
  color: var(--clr-text, #0f172a);
  letter-spacing: -.01em;
}
#ceiWrap .cei-tile-use {
  font-size: .72rem;
  color: var(--clr-muted, #64748b);
  margin-top: 3px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
}
#ceiWrap .cei-tile-canvas {
  height: 180px;
  display: flex; align-items: center; justify-content: center;
  background-image:
    linear-gradient(45deg, #f1f5f9 25%, transparent 25%),
    linear-gradient(-45deg, #f1f5f9 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, #f1f5f9 75%),
    linear-gradient(-45deg, transparent 75%, #f1f5f9 75%);
  background-size: 16px 16px;
  background-position: 0 0, 0 8px, 8px -8px, -8px 0;
  background-color: #fff;
  padding: .5rem;
}
#ceiWrap .cei-tile-canvas canvas {
  image-rendering: pixelated;
  background: transparent;
  display: block;
  max-width: 128px; max-height: 128px;
}
#ceiWrap .cei-tile[data-size="16"]  canvas { width: 16px;  height: 16px;  }
#ceiWrap .cei-tile[data-size="32"]  canvas { width: 32px;  height: 32px;  }
#ceiWrap .cei-tile[data-size="48"]  canvas { width: 48px;  height: 48px;  }
#ceiWrap .cei-tile[data-size="128"] canvas { width: 128px; height: 128px; image-rendering: auto; }
#ceiWrap .cei-dl-btn,
#ceiWrap .cei-dl-btn:link,
#ceiWrap .cei-dl-btn:visited {
  font-size: .8rem;
  border-radius: 0;
  border: 0;
  border-top: 1px solid var(--clr-border, #e5e7eb);
  padding: .7rem .5rem;
  width: 100%;
  background: transparent !important;
  color: var(--clr-primary, #754ffe) !important;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .35rem;
  transition: background .15s ease, color .15s ease;
  cursor: pointer;
  line-height: 1.2;
  text-decoration: none;
  box-shadow: none;
}
#ceiWrap .cei-dl-btn i { color: inherit !important; }
#ceiWrap .cei-dl-btn:hover,
#ceiWrap .cei-dl-btn:focus,
#ceiWrap .cei-dl-btn:focus-visible,
#ceiWrap .cei-dl-btn:active {
  background: rgba(117,79,254,.1) !important;
  color: var(--clr-primary, #754ffe) !important;
  border-top-color: rgba(117,79,254,.3) !important;
  outline: none !important;
  box-shadow: none !important;
}

/* ── Manifest snippet (always visible after upload) ── */
#ceiWrap .cei-manifest {
  background: #0f172a;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid #1e293b;
  margin-bottom: 1.25rem;
  box-shadow: 0 4px 14px rgba(15,23,42,.08);
}
#ceiWrap .cei-manifest-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: .75rem 1.1rem;
  background: #1e293b;
  color: #e0e7ff;
}
#ceiWrap .cei-manifest-title {
  display: inline-flex; align-items: center; gap: .55rem;
  font-size: .85rem;
  font-weight: 600;
  color: #cbd5e1;
}
#ceiWrap .cei-manifest-title i { color: #a5b4fc; }
#ceiWrap .cei-manifest-title code {
  color: #fde68a;
  background: rgba(255,255,255,.06);
  padding: .12rem .5rem;
  border-radius: 6px;
  font-size: .8rem;
}
#ceiWrap .cei-copy-btn {
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  color: #fff;
  border-radius: 8px;
  padding: .35rem .85rem;
  font-size: .8rem;
  font-weight: 600;
  display: inline-flex; align-items: center;
  transition: background .15s ease;
}
#ceiWrap .cei-copy-btn:hover { background: rgba(255,255,255,.18); }
#ceiWrap .cei-copy-btn.is-copied {
  background: #10b981;
  border-color: #10b981;
}
#ceiWrap .cei-manifest-code {
  margin: 0;
  padding: 1.1rem 1.35rem;
  color: #e2e8f0;
  font: 13.5px/1.65 ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  white-space: pre;
  overflow-x: auto;
  background: transparent;
}

/* ── Primary action (ZIP) ── */
#ceiWrap .cei-actions {
  display: flex; gap: .7rem;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 1.25rem;
}
#ceiWrap .cei-zip-btn {
  min-width: 280px;
  padding: .9rem 1.8rem;
  font-size: 1rem;
  border-radius: 12px;
}
#ceiWrap .cei-manifest { margin-bottom: 0; }

/* ── Toast ── */
#ceiWrap .cei-toast {
  position: fixed;
  left: 50%; bottom: 32px;
  transform: translateX(-50%);
  padding: .7rem 1.2rem;
  border-radius: 999px;
  font-size: .9rem; font-weight: 600;
  color: #fff;
  z-index: 9999;
  box-shadow: 0 12px 30px rgba(15,23,42,.2);
}
#ceiWrap .cei-toast.is-success { background: #10b981; }
#ceiWrap .cei-toast.is-error   { background: #ef4444; }

/* ── Fullscreen ── */
#ceiWrap.cei-fullscreen {
  position: fixed;
  inset: 0;
  background: var(--clr-bg, #fff);
  z-index: 9000;
  overflow: auto;
  padding: 1.5rem;
}
#ceiWrap.cei-fullscreen .aib-fs-close { display: flex; }
#ceiWrap .aib-fs-close { display: none; }

/* ── Upload drag-over ── */
#ceiUploadZone.is-drag-over {
  border-color: var(--clr-primary, #754ffe);
  background: rgba(117, 79, 254, .04);
}

/* ── Dark mode ── */
[data-theme="dark"] #ceiWrap .cei-tile-canvas {
  background-color: #1d1c35;
  background-image:
    linear-gradient(45deg, #2a2950 25%, transparent 25%),
    linear-gradient(-45deg, #2a2950 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, #2a2950 75%),
    linear-gradient(-45deg, transparent 75%, #2a2950 75%);
}
[data-theme="dark"] #ceiWrap .cei-top-bar,
[data-theme="dark"] #ceiWrap .cei-tile {
  background: #1d1c35;
  border-color: rgba(117,79,254,.2);
}
[data-theme="dark"] #ceiWrap .cei-tile-head {
  background: linear-gradient(180deg, rgba(117,79,254,.18), transparent);
  border-bottom-color: rgba(117,79,254,.2);
}
[data-theme="dark"] #ceiWrap .cei-icon-btn {
  background: #14132a;
  border-color: rgba(117,79,254,.2);
  color: #f1f5f9;
}
[data-theme="dark"] #ceiWrap .cei-dl-btn {
  border-top-color: rgba(117,79,254,.2);
  color: #a5b4fc;
}
[data-theme="dark"] #ceiWrap .cei-dl-btn:hover {
  background: rgba(117,79,254,.18);
}

/* ── Responsive ── */
@media (max-width: 991.98px) {
  #ceiWrap .cei-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 575.98px) {
  #ceiWrap .cei-tile-canvas { height: 150px; }
  #ceiWrap .cei-tile[data-size="128"] canvas { width: 100px; height: 100px; }
  #ceiWrap .cei-zip-btn { min-width: 0; width: 100%; }
  #ceiWrap .cei-actions { flex-direction: column; }
  #ceiWrap .cei-source-info #ceiSrcName { max-width: 160px; }
  #ceiWrap .cei-manifest-code { font-size: 12px; padding: .9rem 1rem; }
}


/* ── Website Color Palette Extractor (.wcp-*) URL-first ──────────────── */
#wcpWrap { position: relative; }

/* URL input area */
#wcpWrap .wcp-input-area {
  background: var(--clr-card, #fff);
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 14px;
  padding: 1.25rem;
}
#wcpWrap .wcp-input-area .input-group .form-control {
  font-size: 1rem;
  border-color: var(--clr-border, #e5e7eb);
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
}
#wcpWrap .wcp-input-area .input-group .form-control:focus {
  border-color: var(--clr-primary, #754ffe);
  box-shadow: 0 0 0 .15rem rgba(117,79,254,.18);
}
#wcpWrap .wcp-sub {
  font-size: .85rem;
  color: var(--clr-muted, #64748b);
  margin: 0;
  display: flex; align-items: flex-start; gap: .35rem;
}
#wcpWrap .wcp-sub i { color: var(--clr-primary, #754ffe); margin-top: 2px; flex: 0 0 auto; }

/* Error + loading */
#wcpWrap .wcp-alert {
  margin-top: 1rem;
  padding: .85rem 1.1rem;
  border-radius: 12px;
  font-size: .9rem;
  font-weight: 600;
}
#wcpWrap .wcp-alert-danger {
  background: rgba(239,68,68,.12);
  border: 1px solid rgba(239,68,68,.3);
  color: #b91c1c;
}
#wcpWrap .wcp-loading {
  margin-top: 1rem;
  padding: 2rem 1rem;
  background: var(--clr-card, #fff);
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 14px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 1rem;
  color: var(--clr-muted, #64748b);
}
#wcpWrap .wcp-loading p { margin: 0; font-size: .9rem; }
#wcpWrap .wcp-spinner {
  width: 44px; height: 44px;
  border: 3px solid rgba(117,79,254,.15);
  border-top-color: var(--clr-primary, #754ffe);
  border-radius: 50%;
  animation: wcpSpin 1s linear infinite;
}
@keyframes wcpSpin { to { transform: rotate(360deg); } }

/* Result bar */
#wcpWrap .wcp-result-bar {
  margin-top: 1.25rem;
  background: var(--clr-card, #fff);
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 12px;
  padding: .8rem 1.1rem;
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap;
  gap: .85rem;
}
#wcpWrap .wcp-result-info {
  display: inline-flex; align-items: center; gap: .5rem;
  font-size: .9rem; color: var(--clr-text, #0f172a);
  font-weight: 600;
  min-width: 0;
}
#wcpWrap .wcp-result-info i {
  color: var(--clr-primary, #754ffe);
  flex: 0 0 auto;
}
#wcpWrap .wcp-result-info #wcpResultUrl {
  font-family: ui-monospace, monospace;
  font-size: .82rem;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  max-width: 380px;
}
#wcpWrap .wcp-result-stats {
  display: flex; gap: 1rem;
  font-size: .78rem;
  color: var(--clr-muted, #64748b);
}
#wcpWrap .wcp-result-stats strong {
  color: var(--clr-primary, #754ffe);
  font-size: .9rem;
}

/* Controls row */
#wcpWrap .wcp-controls {
  margin-top: 1rem;
  background: var(--clr-card, #fff);
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 12px;
  padding: 1rem 1.1rem;
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap;
  gap: 1.5rem;
}
#wcpWrap .wcp-control-group {
  display: flex; align-items: center; gap: .75rem;
  flex-wrap: wrap;
}
#wcpWrap .wcp-control-label {
  font-size: .85rem; font-weight: 700;
  color: var(--clr-text, #0f172a);
}
#wcpWrap .wcp-range {
  width: 160px;
  accent-color: var(--clr-primary, #754ffe);
}
#wcpWrap .wcp-control-val {
  font-size: .85rem; font-weight: 700;
  color: var(--clr-primary, #754ffe);
  background: rgba(117,79,254,.12);
  padding: .15rem .55rem; border-radius: 6px;
  font-family: ui-monospace, monospace;
  min-width: 32px; text-align: center;
}
#wcpWrap .wcp-control-suffix {
  font-size: .82rem; color: var(--clr-muted, #64748b);
}
#wcpWrap .wcp-sort-row {
  display: flex; gap: .25rem;
  background: var(--clr-bg-soft, #f1f5f9);
  border-radius: 10px;
  padding: 3px;
}
#wcpWrap .wcp-sort-btn {
  background: transparent;
  border: 0;
  padding: .45rem .85rem;
  font-size: .78rem; font-weight: 600;
  color: var(--clr-muted, #64748b);
  border-radius: 7px;
  cursor: pointer;
  transition: background .15s ease, color .15s ease;
}
#wcpWrap .wcp-sort-btn:hover { color: var(--clr-text, #0f172a); }
#wcpWrap .wcp-sort-btn.is-active {
  background: #fff;
  color: var(--clr-primary, #754ffe);
  box-shadow: 0 1px 3px rgba(15,23,42,.06);
}

/* Palette grid */
#wcpWrap .wcp-palette-grid {
  margin-top: 1rem;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: .75rem;
}
#wcpWrap .wcp-swatch {
  border-radius: 12px;
  padding: 0;
  display: flex; flex-direction: column;
  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease;
  overflow: hidden;
  min-height: 160px;
  position: relative;
  border: 1px solid rgba(15,23,42,.08);
}
#wcpWrap .wcp-swatch:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(15,23,42,.12);
}
#wcpWrap .wcp-swatch-top {
  display: flex; justify-content: space-between; align-items: center;
  padding: .55rem .65rem 0;
}
#wcpWrap .wcp-swatch-pct {
  font-size: .68rem; font-weight: 700;
  background: rgba(255,255,255,.25);
  padding: .12rem .45rem; border-radius: 999px;
  letter-spacing: .04em;
}
#wcpWrap .wcp-swatch-copy {
  background: rgba(255,255,255,.22);
  border: 0; color: inherit;
  width: 26px; height: 26px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 7px;
  cursor: pointer;
  transition: background .15s ease;
}
#wcpWrap .wcp-swatch-copy:hover { background: rgba(255,255,255,.38); }
#wcpWrap .wcp-swatch-meta {
  margin-top: auto;
  padding: .55rem .7rem .7rem;
}
#wcpWrap .wcp-swatch-hex {
  font-family: ui-monospace, monospace;
  font-size: 1.05rem; font-weight: 700;
  letter-spacing: .02em;
}
#wcpWrap .wcp-swatch-rgb,
#wcpWrap .wcp-swatch-hsl {
  font-family: ui-monospace, monospace;
  font-size: .68rem; opacity: .82;
  margin-top: 2px;
}

/* Export row */
#wcpWrap .wcp-export-row {
  margin-top: 1.25rem;
  display: flex; gap: .55rem;
  flex-wrap: wrap;
  justify-content: center;
}

/* Toast */
#wcpWrap .wcp-toast {
  position: fixed;
  left: 50%; bottom: 32px;
  transform: translateX(-50%);
  padding: .7rem 1.2rem;
  border-radius: 999px;
  font-size: .9rem; font-weight: 600;
  color: #fff; z-index: 9999;
  box-shadow: 0 12px 30px rgba(15,23,42,.2);
}
#wcpWrap .wcp-toast.is-success { background: #10b981; }
#wcpWrap .wcp-toast.is-error   { background: #ef4444; }

/* Dark mode */
[data-theme="dark"] #wcpWrap .wcp-input-area,
[data-theme="dark"] #wcpWrap .wcp-result-bar,
[data-theme="dark"] #wcpWrap .wcp-controls,
[data-theme="dark"] #wcpWrap .wcp-loading {
  background: #1d1c35; border-color: rgba(117,79,254,.2);
}
[data-theme="dark"] #wcpWrap .wcp-sort-row { background: #14132a; }
[data-theme="dark"] #wcpWrap .wcp-sort-btn.is-active { background: #1d1c35; }
[data-theme="dark"] #wcpWrap .wcp-input-area .input-group .form-control {
  background: #14132a;
  border-color: rgba(117,79,254,.25);
  color: #f1f5f9;
}

/* Mobile */
@media (max-width: 575.98px) {
  #wcpWrap .wcp-palette-grid { grid-template-columns: repeat(2, 1fr); }
  #wcpWrap .wcp-controls { flex-direction: column; align-items: stretch; gap: 1rem; }
  #wcpWrap .wcp-export-row .btn { flex: 1 1 calc(50% - .3rem); }
  #wcpWrap .wcp-result-info #wcpResultUrl { max-width: 200px; }
}

/* ── Website Typography Extractor (.wtp-*) ───────────────────────────── */
#wtpWrap { position: relative; }

#wtpWrap .wtp-input-area {
  background: var(--clr-card, #fff);
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 14px;
  padding: 1.25rem;
}
#wtpWrap .wtp-input-area .input-group .form-control {
  font-size: 1rem;
  border-color: var(--clr-border, #e5e7eb);
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
}
#wtpWrap .wtp-input-area .input-group .form-control:focus {
  border-color: var(--clr-primary, #754ffe);
  box-shadow: 0 0 0 .15rem rgba(117,79,254,.18);
}
#wtpWrap .wtp-sub {
  font-size: .85rem;
  color: var(--clr-muted, #64748b);
  margin: 0;
  display: flex; align-items: flex-start; gap: .35rem;
}
#wtpWrap .wtp-sub i { color: var(--clr-primary, #754ffe); margin-top: 2px; flex: 0 0 auto; }

#wtpWrap .wtp-alert {
  margin-top: 1rem;
  padding: .85rem 1.1rem;
  border-radius: 12px;
  font-size: .9rem;
  font-weight: 600;
}
#wtpWrap .wtp-alert-danger {
  background: rgba(239,68,68,.12);
  border: 1px solid rgba(239,68,68,.3);
  color: #b91c1c;
}
#wtpWrap .wtp-loading {
  margin-top: 1rem;
  padding: 2rem 1rem;
  background: var(--clr-card, #fff);
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 14px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 1rem;
  color: var(--clr-muted, #64748b);
}
#wtpWrap .wtp-loading p { margin: 0; font-size: .9rem; }
#wtpWrap .wtp-spinner {
  width: 44px; height: 44px;
  border: 3px solid rgba(117,79,254,.15);
  border-top-color: var(--clr-primary, #754ffe);
  border-radius: 50%;
  animation: wtpSpin 1s linear infinite;
}
@keyframes wtpSpin { to { transform: rotate(360deg); } }

#wtpWrap .wtp-result-bar {
  margin-top: 1.25rem;
  background: var(--clr-card, #fff);
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 12px;
  padding: .8rem 1.1rem;
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: .85rem;
}
#wtpWrap .wtp-result-info {
  display: inline-flex; align-items: center; gap: .5rem;
  font-size: .9rem; color: var(--clr-text, #0f172a);
  font-weight: 600; min-width: 0;
}
#wtpWrap .wtp-result-info i {
  color: var(--clr-primary, #754ffe); flex: 0 0 auto;
}
#wtpWrap .wtp-result-info #wtpResultUrl {
  font-family: ui-monospace, monospace;
  font-size: .82rem;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  max-width: 360px;
}
#wtpWrap .wtp-result-stats {
  display: flex; gap: 1rem; align-items: center;
  font-size: .78rem; color: var(--clr-muted, #64748b);
  flex-wrap: wrap;
}
#wtpWrap .wtp-result-stats strong {
  color: var(--clr-primary, #754ffe); font-size: .9rem;
}
#wtpWrap .wtp-family-pill {
  display: inline-flex; align-items: center; gap: .4rem;
  background: rgba(117,79,254,.12);
  color: var(--clr-primary, #754ffe);
  padding: .25rem .65rem;
  border-radius: 999px;
  font-size: .78rem; font-weight: 600;
  max-width: 280px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

#wtpWrap .wtp-controls {
  margin-top: 1rem;
  background: var(--clr-card, #fff);
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 12px;
  padding: 1rem 1.1rem;
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: .85rem;
}
#wtpWrap .wtp-control-group {
  display: flex; align-items: center; gap: .65rem;
  flex-wrap: wrap; flex: 1 1 auto;
}
#wtpWrap .wtp-control-label {
  font-size: .8rem; font-weight: 700;
  color: var(--clr-text, #0f172a);
  text-transform: uppercase; letter-spacing: .08em;
}
#wtpWrap .wtp-sample-input {
  flex: 1; min-width: 200px;
  padding: .45rem .75rem;
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 8px;
  font-size: .9rem;
  background: var(--clr-card, #fff);
  color: var(--clr-text, #0f172a);
}
#wtpWrap .wtp-sample-input:focus {
  outline: none;
  border-color: var(--clr-primary, #754ffe);
  box-shadow: 0 0 0 .15rem rgba(117,79,254,.18);
}

/* Typography spec sheet - the BMW-style layout */
#wtpWrap .wtp-spec-sheet {
  margin-top: 1.25rem;
  background: var(--clr-card, #fff);
  border: 1px solid var(--clr-border, #e5e7eb);
  border-radius: 14px;
  overflow: hidden;
}
#wtpWrap .wtp-spec-row {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 1.5rem;
  padding: 1.5rem 1.75rem;
  border-bottom: 1px solid var(--clr-border, #e5e7eb);
  align-items: center;
}
#wtpWrap .wtp-spec-row:last-child { border-bottom: 0; }
#wtpWrap .wtp-spec-row:hover { background: var(--clr-bg-soft, #fafbfc); }
#wtpWrap .wtp-spec-label {
  display: flex; flex-direction: column; gap: .25rem;
}
#wtpWrap .wtp-spec-tier {
  font-size: .72rem; font-weight: 800;
  letter-spacing: .12em;
  color: var(--clr-text, #0f172a);
  text-transform: uppercase;
}
#wtpWrap .wtp-spec-values {
  font-size: .72rem;
  color: var(--clr-muted, #64748b);
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
  letter-spacing: .02em;
}
#wtpWrap .wtp-spec-preview {
  color: var(--clr-text, #0f172a);
  word-break: break-word;
  /* font-size, weight, family etc set inline per spec */
}

#wtpWrap .wtp-toast {
  position: fixed;
  left: 50%; bottom: 32px;
  transform: translateX(-50%);
  padding: .7rem 1.2rem;
  border-radius: 999px;
  font-size: .9rem; font-weight: 600;
  color: #fff; z-index: 9999;
  box-shadow: 0 12px 30px rgba(15,23,42,.2);
}
#wtpWrap .wtp-toast.is-success { background: #10b981; }
#wtpWrap .wtp-toast.is-error   { background: #ef4444; }

/* Dark mode */
[data-theme="dark"] #wtpWrap .wtp-input-area,
[data-theme="dark"] #wtpWrap .wtp-result-bar,
[data-theme="dark"] #wtpWrap .wtp-controls,
[data-theme="dark"] #wtpWrap .wtp-loading,
[data-theme="dark"] #wtpWrap .wtp-spec-sheet {
  background: #1d1c35; border-color: rgba(117,79,254,.2);
}
[data-theme="dark"] #wtpWrap .wtp-spec-row { border-bottom-color: rgba(117,79,254,.15); }
[data-theme="dark"] #wtpWrap .wtp-spec-row:hover { background: #232148; }
[data-theme="dark"] #wtpWrap .wtp-spec-tier,
[data-theme="dark"] #wtpWrap .wtp-spec-preview { color: #f1f5f9; }
[data-theme="dark"] #wtpWrap .wtp-input-area .input-group .form-control,
[data-theme="dark"] #wtpWrap .wtp-sample-input {
  background: #14132a; border-color: rgba(117,79,254,.25); color: #f1f5f9;
}

/* Mobile */
@media (max-width: 767.98px) {
  #wtpWrap .wtp-spec-row { grid-template-columns: 1fr; gap: .55rem; padding: 1rem; }
}

/* Empty row state (no rule found for a tag) */
#wtpWrap .wtp-spec-row.is-empty .wtp-spec-tier { color: var(--clr-muted, #94a3b8); }
#wtpWrap .wtp-spec-row.is-empty .wtp-empty-preview {
  color: var(--clr-muted, #94a3b8);
  font-style: italic;
  font-size: .9rem;
}
#wtpWrap .wtp-spec-family {
  font-size: .68rem;
  color: var(--clr-muted, #64748b);
  font-family: ui-monospace, monospace;
  margin-top: 2px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

/* ── Footer logo CLS prevention (matches widget HTML width=150 + native 948x232 aspect) ── */
img.footer-logo {
  width: 150px !important;
  height: auto !important;
  aspect-ratio: 948 / 232;
  display: block;
  max-width: 150px;
}

