/* SEO Auditor Pro — App Styles */

:root {
    --ink: #0d1117; --ink-2: #1e2736; --ink-3: #374151; --muted: #6b7280;
    --border: #e5e7eb; --surface: #f9fafb; --surface-2: #f3f4f6;
    --accent: #3b5bdb; --accent-2: #4f46e5; --accent-glow: rgba(59,91,219,0.15);
    --success: #059669; --warning: #d97706; --danger: #dc2626;
    --success-bg: #ecfdf5; --warning-bg: #fffbeb; --danger-bg: #fef2f2;
}
*{-webkit-tap-highlight-color:transparent;box-sizing:border-box}
body{font-family:'DM Sans',sans-serif;background:var(--surface);color:var(--ink);overflow-x:hidden;min-height:100vh}
h1,h2,h3,.heading{font-family:'DM Sans',sans-serif}
body::before{content:'';position:fixed;inset:0;background-image:linear-gradient(rgba(59,91,219,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(59,91,219,.04) 1px,transparent 1px);background-size:40px 40px;pointer-events:none;z-index:0}
.page-wrap{position:relative;z-index:1}

/* Badge */
.badge-pill{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-family:'DM Sans',sans-serif;font-weight:700;font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:5px 14px;border-radius:100px}

/* Glass card */
.glass-card{background:rgba(255,255,255,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.9);box-shadow:0 2px 16px rgba(13,17,23,.07),0 1px 3px rgba(13,17,23,.05);border-radius:20px}

/* Input */
.search-input{font-family:'DM Sans',sans-serif;font-size:15px;font-weight:500;color:var(--ink);background:#fff;border:2px solid var(--border);border-radius:14px;padding:14px 14px 14px 44px;width:100%;outline:none;transition:border-color .2s,box-shadow .2s}
.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow)}
.search-input::placeholder{color:#9ca3af}

/* Buttons */
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-2) 100%);color:#fff;font-family:'DM Sans',sans-serif;font-weight:700;font-size:14px;padding:14px 28px;border-radius:14px;border:none;cursor:pointer;transition:all .2s;box-shadow:0 4px 14px rgba(59,91,219,.35);white-space:nowrap;min-height:44px}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(59,91,219,.45)}
.btn-primary:active{transform:scale(.97)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}
.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:#fff;color:var(--ink);font-family:'DM Sans',sans-serif;font-weight:700;font-size:13px;padding:10px 18px;border-radius:12px;border:1.5px solid var(--border);cursor:pointer;transition:all .2s;min-height:38px}
.btn-secondary:hover{background:var(--surface-2);border-color:#d1d5db}
.btn-secondary:active{transform:scale(.97)}
.btn-success{background:linear-gradient(135deg,#059669,#0e9f6e);color:#fff;box-shadow:0 4px 14px rgba(14,159,110,.35);border:none}
.btn-success:hover{box-shadow:0 6px 20px rgba(14,159,110,.45)}

/* Stat cards */
.stat-card{background:#fff;border:1.5px solid var(--border);border-radius:16px;padding:18px 20px;transition:box-shadow .2s,transform .2s}
.stat-card:hover{box-shadow:0 4px 16px rgba(13,17,23,.08);transform:translateY(-1px)}
.stat-label{font-family:'DM Sans',sans-serif;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.stat-value{font-family:'DM Sans',sans-serif;font-size:26px;font-weight:800;line-height:1}

/* Result list */
.result-list-wrap{background:#fff;border:1.5px solid var(--border);border-radius:20px;overflow:hidden}
.result-card{padding:18px 24px;border-bottom:1px solid var(--border);transition:background .15s}
.result-card:last-child{border-bottom:none}
.result-card:hover{background:var(--surface)}

/* Skeleton loader */
.skel{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;animation:skelShimmer 1.4s ease infinite;border-radius:6px;}
@keyframes skelShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skeleton-card{opacity:.85;pointer-events:none;}

/* Priority dots */
.dot-high{background:linear-gradient(135deg,#10b981,#059669)}
.dot-med{background:linear-gradient(135deg,#f59e0b,#d97706)}
.dot-low{background:linear-gradient(135deg,#9ca3af,#6b7280)}

/* Details toggle */
.details-content{display:none}
.details-content.active{display:block;animation:fadeSlide .25s ease}

/* Finish banner */
.finish-banner{background:linear-gradient(135deg,var(--ink-2) 0%,#0f172a 100%);border-radius:20px;padding:24px 28px}

/* Modal */
.modal{display:none;position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background:rgba(0,0,0,.55);animation:fadeIn .2s;overflow-y:auto;backdrop-filter:blur(2px)}
.modal-inner{background:#fff;margin:20px auto 40px;border-radius:24px;width:calc(100% - 32px);max-width:900px;max-height:92vh;overflow-y:auto;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 24px 64px rgba(13,17,23,.2)}
.modal-header{position:sticky;top:0;background:#fff;border-bottom:1.5px solid var(--border);padding:20px 24px;border-radius:24px 24px 0 0;z-index:10}

/* Tabs */
.tab-bar{display:flex;flex-wrap:wrap;gap:6px}
.tab-btn{font-family:'DM Sans',sans-serif;font-size:12px;font-weight:700;letter-spacing:.03em;padding:8px 14px;border-radius:10px;border:1.5px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:5px;min-height:36px}
.tab-btn:hover{background:#fff;color:var(--ink)}
.tab-btn.active{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;border-color:transparent;box-shadow:0 2px 8px rgba(59,91,219,.3)}

/* Score ring */
.score-ring{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'DM Sans',sans-serif;font-size:21px;font-weight:800}
.score-ring.good{background:var(--success-bg);color:var(--success);border:3px solid #a7f3d0}
.score-ring.warning{background:var(--warning-bg);color:var(--warning);border:3px solid #fde68a}
.score-ring.issue{background:var(--danger-bg);color:var(--danger);border:3px solid #fecaca}

/* Tags */
.tag{display:inline-block;padding:2px 8px;border-radius:5px;font-size:11px;font-weight:700;font-family:'DM Sans',sans-serif;text-transform:uppercase;letter-spacing:.04em}
.tag-good{background:var(--success-bg);color:var(--success)}
.tag-warn{background:var(--warning-bg);color:#b45309}
.tag-issue{background:var(--danger-bg);color:var(--danger)}
.tag-neutral{background:var(--surface-2);color:var(--muted)}
.tag-meta{background:#ede9fe;color:#5b21b6}

/* Section headers in modal */
.section-head{background:var(--surface);border-bottom:1.5px solid var(--border);padding:12px 16px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700;letter-spacing:.02em;color:var(--ink-3);display:flex;align-items:center;gap:6px}

/* Social previews */
.social-preview{background:#f0f2f5;border-radius:12px;padding:12px}
.fb-card{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.1)}
.fb-card-img{background:#e4e6eb;height:180px;display:flex;align-items:center;justify-content:center;color:#65676b;overflow:hidden}
.fb-card-body{padding:12px}
.fb-card-domain{color:#65676b;font-size:11px;text-transform:uppercase}
.fb-card-title{color:#1d2b3e;font-weight:700;font-size:15px;margin:4px 0}
.fb-card-desc{color:#65676b;font-size:13px}

/* Meta rows */
.meta-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--border);font-size:13px}
.meta-row:last-child{border-bottom:none}
.meta-key{color:var(--muted);font-weight:500;flex-shrink:0;margin-right:12px}
.meta-val{font-weight:600;color:var(--ink);text-align:right;word-break:break-all;max-width:65%}

/* Keyword bar */
.kw-bar-track{background:var(--border);border-radius:100px;height:6px}
.kw-bar-fill{border-radius:100px;height:6px;transition:width .7s ease}
.kw-bar-meta{background:linear-gradient(90deg,#5b21b6,#7c3aed)}
.kw-bar-body{background:linear-gradient(90deg,var(--accent),#818cf8)}
.kw-bar-title{background:linear-gradient(90deg,#1d4ed8,#06b6d4)}
.kw-bar-desc{background:linear-gradient(90deg,#7c3aed,#ec4899)}

/* Keyword copy card */
.kw-copy-card{background:#fff;border:1.5px solid var(--border);border-radius:14px;padding:16px;position:relative;transition:box-shadow .2s}
.kw-copy-card:hover{box-shadow:0 4px 14px rgba(13,17,23,.08)}
.kw-copy-btn{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;font-family:'DM Sans',sans-serif;padding:5px 11px;border-radius:8px;border:1.5px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;transition:all .15s}
.kw-copy-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.kw-copy-btn.copied,.btn-secondary.copied,.case-btn.copied{background:var(--success)!important;color:#fff!important;border-color:var(--success)!important}

/* Sitemap checker */
.sitemap-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px}
.sitemap-row:last-child{border-bottom:none}

/* Close btn */
.close-btn{width:32px;height:32px;border-radius:50%;background:var(--surface-2);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all .15s}
.close-btn:hover{background:var(--border);color:var(--ink)}

/* Progress bar */
.progress-bar{height:3px;background:linear-gradient(90deg,var(--accent),#818cf8,var(--accent));background-size:200% 100%;animation:shimmer 1.5s ease infinite;border-radius:100px}

/* Animations */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes fadeSlide{from{transform:translateY(-6px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.spin{animation:spin 1s linear infinite}
.pulse-anim{animation:pulse 2s ease infinite}

/* Scrollbar */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--surface-2);border-radius:10px}
::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:#94a3b8}

/* ── Side Panel ── */
#sidePanelOverlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;backdrop-filter:blur(2px);animation:fadeIn .2s}
#sidePanel{position:fixed;left:0;top:0;height:100%;width:270px;background:#fff;z-index:201;box-shadow:4px 0 32px rgba(13,17,23,.18);transform:translateX(-100%);transition:transform .3s cubic-bezier(.34,1.2,.64,1);display:flex;flex-direction:column;border-right:1.5px solid var(--border);}
#sidePanel.open{transform:translateX(0)}
#sidePanelOverlay.open{display:block}
.sp-header{background:linear-gradient(135deg,var(--accent),var(--accent-2));padding:20px 20px 16px;flex-shrink:0}
.sp-nav{flex:1;overflow-y:auto;padding:12px 10px}
.sp-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:11px;cursor:pointer;text-decoration:none;color:var(--ink-3);font-size:13px;font-weight:600;transition:all .15s;margin-bottom:2px}
.sp-item:hover{background:var(--surface-2);color:var(--accent)}
.sp-item.active{background:var(--accent-glow);color:var(--accent)}
.sp-item i{flex-shrink:0;width:16px;height:16px}
.sp-divider{height:1px;background:var(--border);margin:8px 12px}
.sp-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:6px 12px 4px}
#spToggleBtn{position:fixed;left:16px;top:16px;z-index:199;width:42px;height:42px;border-radius:12px;background:#fff;border:1.5px solid var(--border);box-shadow:0 2px 12px rgba(13,17,23,.1);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--ink)}
#spToggleBtn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ── Page view sections ── */
.page-section{display:none}
.page-section.active{display:block;animation:fadeSlide .25s ease}

/* ── Page breadcrumb bar ── */
#pageBreadcrumb{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#fff;border:1.5px solid var(--border);border-radius:14px;margin-bottom:20px;font-size:12px;font-weight:600}
#pageBreadcrumb .bc-sep{color:var(--muted)}
#pageBreadcrumb .bc-page{color:var(--accent)}

/* ── Domain strip badge ── */
.domain-badge{display:inline-flex;align-items:center;gap:5px;background:var(--surface-2);border:1.5px solid var(--border);border-radius:8px;padding:4px 10px;font-size:12px;font-weight:700;color:var(--ink-3);margin-bottom:10px;}

/* Icon sizes */
.icon{width:18px;height:18px;display:inline-block;vertical-align:middle}
.icon-sm{width:14px;height:14px;display:inline-block;vertical-align:middle}
.icon-lg{width:24px;height:24px;display:inline-block;vertical-align:middle}
.icon-xl{width:32px;height:32px;display:inline-block;vertical-align:middle}

/* Responsive — fluid mobile-first */
input,button,select,textarea{font-size:16px!important} /* prevent zoom on iOS */

/* Fluid type scale */
:root{
    --fs-xs:clamp(10px,2.5vw,11px);
    --fs-sm:clamp(12px,3vw,13px);
    --fs-base:clamp(13px,3.5vw,15px);
    --fs-lg:clamp(15px,4vw,17px);
    --fs-xl:clamp(18px,4.5vw,21px);
    --fs-2xl:clamp(22px,5.5vw,28px);
    --fs-3xl:clamp(26px,7vw,40px);
    --fs-4xl:clamp(30px,8vw,48px);
    --sp-1:clamp(4px,1vw,6px);
    --sp-2:clamp(8px,2vw,12px);
    --sp-3:clamp(12px,3vw,18px);
    --sp-4:clamp(16px,4vw,24px);
    --sp-5:clamp(20px,5vw,32px);
    --r-sm:10px;--r-md:14px;--r-lg:20px;
}
.stat-value{font-size:clamp(20px,5vw,26px)!important}
.stat-label{font-size:var(--fs-xs)}
.btn-primary{font-size:var(--fs-sm)!important;padding:clamp(10px,2.5vw,14px) clamp(16px,4vw,28px)}
.btn-secondary{font-size:var(--fs-xs)!important}
.search-input{font-size:var(--fs-base)!important;padding:clamp(11px,2.5vw,14px) clamp(11px,2.5vw,14px) clamp(11px,2.5vw,14px) clamp(38px,9vw,44px)}
.tab-btn{font-size:var(--fs-xs)!important;padding:clamp(6px,1.5vw,8px) clamp(10px,2.5vw,14px)}
.glass-card{border-radius:var(--r-lg)}
.stat-card{border-radius:clamp(12px,3vw,16px);padding:clamp(14px,3.5vw,18px) clamp(14px,3.5vw,20px)}
.result-card{padding:clamp(12px,3vw,18px) clamp(14px,3.5vw,24px)}

@media(max-width:640px){
    .modal-inner{border-radius:18px;max-height:96vh;margin:6px auto 20px}
    .score-ring{width:52px;height:52px;font-size:16px}
    .page-wrap.top{margin-top:69px}
    .glass-card{backdrop-filter:none!important;-webkit-backdrop-filter:none!important}
    .finish-banner{padding:18px 20px}
    #pageBreadcrumb{padding:8px 12px;font-size:11px}
    .badge-pill{font-size:10px;padding:4px 12px}
    .modal-header{padding:16px 18px}
    .modal-inner .p-5{padding:16px!important}
    .modal-inner .p-6{padding:18px!important}
    .sp-item{font-size:12px;padding:9px 10px}
    #sidePanel{width:260px}
}

/* DNS tools */
.dns-record-row{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border);flex-wrap:wrap;}
.dns-record-row:last-child{border-bottom:none}
select{appearance:auto;-webkit-appearance:auto}

/* Text Case Converter */
.case-btn{display:inline-flex;align-items:center;gap:6px;background:var(--surface);border:1.5px solid var(--border);color:var(--ink-3);font-size:var(--fs-xs);font-weight:700;padding:7px 14px;border-radius:var(--r-sm);cursor:pointer;transition:all .15s;letter-spacing:.02em;min-height:34px}
.case-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.case-btn.active{background:var(--accent);color:#fff;border-color:transparent;box-shadow:0 2px 8px rgba(59,91,219,.3)}
.case-textarea{font-family:'DM Mono',monospace,'DM Sans',sans-serif;font-size:var(--fs-sm);width:100%;border:2px solid var(--border);border-radius:var(--r-md);padding:clamp(10px,2.5vw,14px);outline:none;resize:vertical;color:var(--ink);background:#fff;transition:border-color .2s;line-height:1.6}
.case-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow)}
.case-stat{background:var(--surface-2);border-radius:var(--r-sm);padding:6px 12px;font-size:var(--fs-xs);font-weight:700;color:var(--muted)}

/* QR Generator */
.qr-preview-box{background:repeating-conic-gradient(#f0f0f0 0% 25%,#fff 0% 50%) 0 0/16px 16px;border-radius:var(--r-md);padding:20px;display:flex;align-items:center;justify-content:center;min-height:220px}
.qr-preview-box img{max-width:min(280px,100%);height:auto;border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.15)}
.color-swatch{width:28px;height:28px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1.5px var(--border);cursor:pointer;flex-shrink:0}

html{scroll-behavior:smooth}

/* ══════════════════════════════════════════════════════
   CODE FORMATTER, NUMBER GENERATOR, COLOUR GENERATOR
   ══════════════════════════════════════════════════════ */

/* Monospace DM Mono fallback stack */
@import url('https://fonts.googleapis.com/css2?family=DM+Mono:ital,wght@0,300;0,400;0,500;1,300;1,400&display=swap');

/* ── Shared: editor textarea ── */
.case-textarea {
    display: block;
    width: 100%;
    padding: 14px 16px;
    border: 1.5px solid var(--border);
    border-radius: 14px;
    background: #fff;
    color: var(--ink);
    font-family: 'DM Mono', 'Fira Mono', 'Consolas', monospace;
    font-size: 13px;
    line-height: 1.7;
    resize: vertical;
    outline: none;
    transition: border-color .2s, box-shadow .2s;
    box-sizing: border-box;
}
.case-textarea:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(59,91,219,.10);
}
.case-textarea[readonly] {
    background: var(--surface);
    cursor: default;
    color: var(--ink);
}

/* ── Shared: stat pill ── */
.case-stat {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    border-radius: 8px;
    background: var(--surface);
    border: 1.5px solid var(--border);
    font-size: 11px;
    font-weight: 700;
    color: var(--muted);
    white-space: nowrap;
}

/* ── Code formatter: responsive grid ── */
@media (max-width: 640px) {
    #cfGrid, #ngGrid, #cgGrid { grid-template-columns: 1fr !important; }
}

/* ── Colour generator: canvas cursor animation ── */
#cgCursor { transition: left .08s, top .08s; }

/* ── Colour generator: alpha slider track ── */
input[type="range"]#cgAlphaSlider {
    -webkit-appearance: none;
    appearance: none;
    height: 12px;
    border-radius: 6px;
    outline: none;
    cursor: pointer;
}
input[type="range"]#cgAlphaSlider::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 20px; height: 20px;
    border-radius: 50%;
    background: #fff;
    border: 2.5px solid rgba(0,0,0,.25);
    box-shadow: 0 1px 4px rgba(0,0,0,.2);
    cursor: pointer;
}

/* ── Hue slider track ── */
input[type="range"]#cgHueSlider {
    -webkit-appearance: none;
    appearance: none;
    height: 12px;
    border-radius: 6px;
    outline: none;
    cursor: pointer;
}
input[type="range"]#cgHueSlider::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 20px; height: 20px;
    border-radius: 50%;
    background: #fff;
    border: 2.5px solid rgba(0,0,0,.25);
    box-shadow: 0 1px 4px rgba(0,0,0,.2);
    cursor: pointer;
}

/* ── Number generator stats bar ── */
#ngStats { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }

/* ── Colour palette swatches hover effect ── */
#cgTints > div, #cgShades > div, #cgComplementary > div,
#cgAnalogous > div, #cgTriadic > div {
    position: relative;
}
#cgTints > div::after, #cgShades > div::after,
#cgComplementary > div::after, #cgAnalogous > div::after,
#cgTriadic > div::after {
    content: attr(title);
    position: absolute;
    bottom: calc(100% + 6px);
    left: 50%;
    transform: translateX(-50%);
    background: rgba(0,0,0,.85);
    color: #fff;
    font-size: 9px;
    font-family: 'DM Mono', monospace;
    font-weight: 500;
    padding: 3px 6px;
    border-radius: 5px;
    white-space: nowrap;
    pointer-events: none;
    opacity: 0;
    transition: opacity .15s;
    z-index: 10;
}
#cgTints > div:hover::after, #cgShades > div:hover::after,
#cgComplementary > div:hover::after, #cgAnalogous > div:hover::after,
#cgTriadic > div:hover::after { opacity: 1; }

/* ── CSS export block ── */
#cgCssExport {
    font-family: 'DM Mono', monospace;
    font-size: 12px;
    background: var(--surface);
    border: 1.5px solid var(--border);
    border-radius: 10px;
    padding: 12px 14px;
    line-height: 1.8;
    white-space: pre-wrap;
    word-break: break-all;
    color: var(--ink);
}

/* ── Input: focus highlight for colour inputs ── */
#cgR:focus { border-color: #ef4444 !important; box-shadow: 0 0 0 3px rgba(239,68,68,.12); }
#cgG:focus { border-color: #16a34a !important; box-shadow: 0 0 0 3px rgba(22,163,74,.12); }
#cgB:focus { border-color: #2563eb !important; box-shadow: 0 0 0 3px rgba(37,99,235,.12); }

/* ── Error bar ── */
#cfError {
    background: #fef2f2;
    border: 1.5px solid #fecaca;
    border-radius: 12px;
    padding: 10px 14px;
}
