/* Free Cookie Scanner tool */

.scanner-hero { text-align: center; }

.scanner-form { margin-top: 1.75rem; }

.scanner-input-row {
    display: flex;
    gap: 0.5rem;
    justify-content: center;
    flex-wrap: wrap;
}

.scanner-input {
    flex: 1 1 380px;
    max-width: 480px;
    padding: 0.85rem 1rem;
    font-size: 1rem;
    border: 1px solid var(--neutral-300, #cbd5e1);
    border-radius: 0.5rem;
    background: #fff;
}
.scanner-input:focus {
    outline: none;
    border-color: var(--primary, #1f376b);
    box-shadow: 0 0 0 3px rgba(31, 55, 107, 0.15);
}

.scanner-turnstile { margin: 1rem auto 0; display: flex; justify-content: center; }

.scanner-hint { margin-top: 0.75rem; font-size: 0.875rem; color: var(--neutral-500, #64748b); }

.scanner-error {
    margin: 1rem auto 0;
    max-width: 480px;
    padding: 0.75rem 1rem;
    border-radius: 0.5rem;
    background: #fef2f2;
    color: #b91c1c;
    border: 1px solid #fecaca;
    font-size: 0.9375rem;
}

/* Progress */
.scanner-progress-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.25rem 1.5rem;
    border: 1px solid var(--neutral-200, #e2e8f0);
    border-radius: 0.75rem;
    background: #fff;
}
.scanner-progress-title { font-weight: 600; }
.scanner-progress-step { font-size: 0.875rem; color: var(--neutral-500, #64748b); }
.scanner-spinner {
    width: 28px; height: 28px; flex: none;
    border: 3px solid var(--neutral-200, #e2e8f0);
    border-top-color: var(--primary, #1f376b);
    border-radius: 50%;
    animation: scanner-spin 0.8s linear infinite;
}
@keyframes scanner-spin { to { transform: rotate(360deg); } }

/* Verdict banner */
.scanner-verdict {
    display: flex;
    gap: 1.5rem;
    align-items: center;
    padding: 1.5rem 1.75rem;
    border-radius: 0.75rem;
    margin-bottom: 1.25rem;
    border: 1px solid var(--neutral-200, #e2e8f0);
}
.verdict-good { background: #f0fdf4; border-color: #bbf7d0; }
.verdict-warn { background: #fffbeb; border-color: #fde68a; }
.verdict-bad  { background: #fef2f2; border-color: #fecaca; }
.verdict-score { font-size: 2.75rem; font-weight: 800; line-height: 1; color: var(--primary, #1f376b); }
.verdict-score span { font-size: 1rem; font-weight: 600; color: var(--neutral-500, #64748b); }
.verdict-text h2 { margin: 0 0 0.25rem; font-size: 1.35rem; }
.verdict-text p { margin: 0; color: var(--neutral-600, #475569); }
.verdict-url { font-size: 0.8125rem; color: var(--neutral-500, #64748b); word-break: break-all; margin-top: 0.35rem !important; }

/* Panels */
.scanner-panel {
    padding: 1.1rem 1.35rem;
    border: 1px solid var(--neutral-200, #e2e8f0);
    border-radius: 0.75rem;
    background: #fff;
    margin-bottom: 1rem;
}
.scanner-panel h3 { margin: 0 0 0.4rem; font-size: 1.05rem; }
.scanner-panel p { margin: 0.2rem 0; }
.scanner-panel .muted { font-size: 0.8125rem; color: var(--neutral-500, #64748b); }
.panel-alert { background: #fef2f2; border-color: #fecaca; }
.panel-ok { background: #f0fdf4; border-color: #bbf7d0; }

.scanner-h3 { margin: 1.5rem 0 0.75rem; font-size: 1.1rem; }

/* Chips */
.chip-row { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-top: 0.5rem; }
.chip {
    display: inline-flex; align-items: center; gap: 0.35rem;
    padding: 0.3rem 0.6rem; border-radius: 999px; font-size: 0.8125rem;
    background: var(--neutral-100, #f1f5f9); color: var(--neutral-700, #334155);
}
.chip em { font-style: normal; opacity: 0.65; font-size: 0.75rem; }
.chip-bad { background: #fee2e2; color: #b91c1c; }
.chip-bad em { opacity: 0.75; }

/* Issues */
.scanner-issue {
    padding: 0.9rem 1.1rem; border-radius: 0.6rem; margin-bottom: 0.6rem;
    background: #fff; border: 1px solid var(--neutral-200, #e2e8f0);
    border-left: 4px solid var(--neutral-300, #cbd5e1);
}
.scanner-issue.sev-high { border-left-color: #dc2626; }
.scanner-issue.sev-medium { border-left-color: #f59e0b; }
.scanner-issue.sev-low { border-left-color: #64748b; }
.issue-head { display: flex; align-items: center; gap: 0.5rem; }
.issue-sev {
    text-transform: uppercase; font-size: 0.65rem; font-weight: 700; letter-spacing: 0.04em;
    padding: 0.15rem 0.45rem; border-radius: 4px; background: var(--neutral-100, #f1f5f9); color: var(--neutral-600, #475569);
}
.sev-high .issue-sev { background: #fee2e2; color: #b91c1c; }
.sev-medium .issue-sev { background: #fef3c7; color: #b45309; }
.scanner-issue p { margin: 0.4rem 0 0; font-size: 0.9375rem; color: var(--neutral-600, #475569); }

/* Cookies table */
.scanner-table-wrap { overflow-x: auto; border: 1px solid var(--neutral-200, #e2e8f0); border-radius: 0.6rem; }
.scanner-table { width: 100%; border-collapse: collapse; font-size: 0.875rem; }
.scanner-table th, .scanner-table td { padding: 0.6rem 0.8rem; text-align: left; border-bottom: 1px solid var(--neutral-100, #f1f5f9); }
.scanner-table th { background: var(--neutral-50, #f8fafc); font-weight: 600; }
.scanner-table .cookie-name { max-width: 20rem; word-break: break-all; } /* keep long cookie names from widening the table */
.scanner-table tr:last-child td { border-bottom: none; }
.chip-bad-sm { font-size: 0.7rem; padding: 0.1rem 0.4rem; border-radius: 4px; background: #fee2e2; color: #b91c1c; }

.scanner-cta { margin-top: 2rem; }

/* Evergreen content */
.scanner-content h2 { margin: 2.25rem 0 1rem; font-size: 1.5rem; }
.scanner-content > .container > h2:first-child { margin-top: 0; }
.scanner-content p { color: var(--neutral-600, #475569); line-height: 1.65; }

.scanner-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.scanner-step {
    padding: 1.25rem;
    border: 1px solid var(--neutral-200, #e2e8f0);
    border-radius: 0.75rem;
    background: #fff;
}
.scanner-step h3 { font-size: 1.05rem; margin: 0.6rem 0 0.4rem; }
.scanner-step p { margin: 0; font-size: 0.9375rem; }
.scanner-step-num {
    display: inline-flex; align-items: center; justify-content: center;
    width: 2rem; height: 2rem; border-radius: 50%;
    background: var(--primary, #1f376b); color: #fff; font-weight: 700;
}
@media (max-width: 640px) { .scanner-steps { grid-template-columns: 1fr; } }

.scanner-checklist { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.6rem; }
.scanner-checklist li {
    position: relative; padding-left: 1.75rem; color: var(--neutral-700, #334155); line-height: 1.55;
}
.scanner-checklist li::before {
    content: "✓"; position: absolute; left: 0; top: 0;
    color: #16a34a; font-weight: 700;
}

.scanner-faq { margin-top: 0.5rem; }
.scanner-faq .accordion-button { font-weight: 600; }
