/* DNS Detail — Style System v5 — Royal Blue */
:root{--accent:#4169E1;--accent-hover:#3457c9;--accent-light:#eef2fd;--accent-subtle:#4169E115;--bg-page:#f8f9fb;--bg-card:#fff;--bg-input:#fff;--bg-code:#f4f5f7;--bg-header:#fff;--bg-dropdown:#fff;--border:#e5e7eb;--border-input:#d1d5db;--text-primary:#1e293b;--text-secondary:#64748b;--text-muted:#94a3b8;--text-inverse:#fff;--pass-bg:#ecfdf5;--pass-border:#a7f3d0;--pass-text:#065f46;--pass-icon:#10b981;--warn-bg:#fffbeb;--warn-border:#fde68a;--warn-text:#92400e;--warn-icon:#f59e0b;--error-bg:#fef2f2;--error-border:#fecaca;--error-text:#991b1b;--error-icon:#ef4444;--info-bg:#eef2fd;--info-border:#bfcffc;--info-text:#1e40af;--info-icon:#4169E1;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-full:9999px;--ease:cubic-bezier(.4,0,.2,1);--dur:200ms;--header-h:64px;--container-max:1100px;--container-pad:24px}
[data-theme="dark"]{--bg-page:#0f1117;--bg-card:#1a1d27;--bg-input:#1a1d27;--bg-code:#242837;--bg-header:#14161e;--bg-dropdown:#1a1d27;--border:#2d3140;--border-input:#3d4155;--text-primary:#f1f3f5;--text-secondary:#9ca3af;--text-muted:#6b7280;--accent-light:#4169E118;--accent-subtle:#4169E110;--pass-bg:#065f4620;--pass-border:#065f4650;--pass-text:#6ee7b7;--warn-bg:#92400e20;--warn-border:#92400e50;--warn-text:#fcd34d;--error-bg:#991b1b20;--error-border:#991b1b50;--error-text:#fca5a5;--info-bg:#1e40af20;--info-border:#1e40af50;--info-text:#93c5fd}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;color:var(--text-primary);background:var(--bg-page);line-height:1.6;-webkit-font-smoothing:antialiased;min-height:100vh;display:flex;flex-direction:column;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}
main{flex:1}a{color:var(--accent);text-decoration:none;transition:color var(--dur) var(--ease)}a:hover{color:var(--accent-hover)}
img,svg{display:block;max-width:100%}.container{width:100%;max-width:var(--container-max);margin:0 auto;padding:0 var(--container-pad)}.hidden{display:none!important}

/* ═══ HEADER ═══ */
.site-header{background:var(--bg-header);border-bottom:1px solid var(--border);height:var(--header-h);z-index:100;transition:background var(--dur) var(--ease)}
.header-inner{max-width:var(--container-max);margin:0 auto;padding:0 var(--container-pad);height:100%;display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo{display:flex;align-items:center;flex-shrink:0}.logo-svg{height:22px;width:auto}.logo-icon{fill:var(--accent)}.logo-text{fill:var(--text-primary);transition:fill var(--dur) var(--ease)}
.main-nav{display:flex;align-items:center;gap:8px}
.nav-list{display:flex;align-items:center;list-style:none;gap:4px}
.nav-list>li>a{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;color:var(--text-secondary);border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.03em;transition:color var(--dur) var(--ease),background var(--dur) var(--ease);white-space:nowrap}
.nav-list>li>a:hover{color:var(--text-primary);background:var(--accent-subtle)}
.nav-list>li>a svg{flex-shrink:0;opacity:.6}
.chevron{transition:transform var(--dur) var(--ease);margin-left:-2px}.has-dropdown.open .chevron{transform:rotate(180deg)}
.has-dropdown{position:relative}
.nav-actions{display:flex;align-items:center;gap:8px;margin-left:12px}
.header-mobile-actions{display:none;align-items:center;gap:8px}
.theme-toggle{width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-full);cursor:pointer;transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease);flex-shrink:0}
.theme-toggle:hover{border-color:var(--accent)}
.theme-toggle svg{stroke:var(--text-secondary)}
.icon-moon{display:none}[data-theme="dark"] .icon-sun{display:none}[data-theme="dark"] .icon-moon{display:block}
.mobile-toggle{display:none;align-items:center;justify-content:center;width:38px;height:38px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer}
.mobile-toggle svg{stroke:var(--text-primary)}

/* ═══ DROPDOWN — click-based, no hover ═══ */
.dropdown-mega{display:none;position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%);min-width:520px;background:var(--bg-dropdown);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 24px;z-index:200;animation:ddIn .25s var(--ease)}
@keyframes ddIn{from{opacity:0;transform:translateX(-50%) translateY(-4px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
/* Only open via JS click — removed hover rule */
.has-dropdown.open .dropdown-mega{display:block}
.dropdown-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px 32px}
.dropdown-grid a{display:flex;align-items:center;gap:12px;padding:10px 12px;font-size:14px;font-weight:500;color:var(--text-primary);border-radius:var(--radius-sm);transition:background var(--dur) var(--ease),color var(--dur) var(--ease);white-space:nowrap}
.dropdown-grid a:hover{background:var(--accent-subtle);color:var(--accent)}
.dropdown-grid a svg{flex-shrink:0;stroke:var(--accent)}

/* ═══ COFFEE ═══ */
.btn-coffee{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:#ffdd00;color:#1a1a1a;font-size:13px;font-weight:600;border-radius:var(--radius-full);transition:transform var(--dur) var(--ease);white-space:nowrap}
.btn-coffee:hover{color:#1a1a1a;transform:translateY(-1px)}
.btn-coffee svg{stroke:#1a1a1a}.btn-coffee--full{width:100%;justify-content:center;padding:12px 16px}

/* ═══ MOBILE ═══ */
.mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:300;opacity:0;transition:opacity .3s var(--ease)}
.mobile-overlay.is-open{display:block;opacity:1}
.mobile-menu{position:fixed;top:0;right:0;bottom:0;width:min(340px,85vw);background:var(--bg-card);display:flex;flex-direction:column;transform:translateX(100%);transition:transform .3s var(--ease);z-index:301}
.mobile-overlay.is-open .mobile-menu{transform:translateX(0)}
.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}
.mobile-menu-title{font-size:18px;font-weight:700;color:var(--text-primary)}
.mobile-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;border-radius:var(--radius-sm)}.mobile-close svg{stroke:var(--text-secondary)}.mobile-close:hover svg{stroke:var(--text-primary)}
.mobile-nav-list{flex:1;overflow-y:auto;padding:12px 16px;list-style:none}
.mobile-nav-list li a{display:flex;align-items:center;gap:16px;padding:14px 12px;font-size:15px;font-weight:500;color:var(--text-primary);border-radius:var(--radius-sm);transition:background var(--dur) var(--ease)}
.mobile-nav-list li a:hover{background:var(--accent-subtle)}
.mobile-nav-list li a svg{flex-shrink:0;stroke:var(--accent)}
.mobile-divider{height:1px;background:var(--border);margin:8px 12px}
.mobile-menu-footer{padding:16px 24px;border-top:1px solid var(--border)}

/* ═══ HERO ═══ */
.hero{padding:80px 0 60px;text-align:center}
.hero-title{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;letter-spacing:-.02em;margin-bottom:12px}
.hero-subtitle{font-size:clamp(1rem,2vw,1.15rem);color:var(--text-secondary);margin-bottom:40px}

/* ═══ SEARCH ═══ */
.search-form{max-width:640px;margin:0 auto}.search-form--compact{max-width:560px}
.search-input-wrap{display:flex;align-items:center;background:var(--bg-input);border:2px solid var(--border-input);border-radius:var(--radius-md);overflow:hidden;transition:border-color var(--dur) var(--ease)}
.search-input-wrap:focus-within{border-color:var(--accent)}
.search-input-wrap.input-error{border-color:var(--error-icon)!important}
.search-icon{margin-left:16px;stroke:var(--text-muted);flex-shrink:0}
.search-input-wrap input[type="search"]{flex:1;padding:14px 12px;border:none;outline:none;background:transparent;font-family:inherit;font-size:15px;color:var(--text-primary);min-width:0}
.search-input-wrap input[type="search"]::placeholder{color:var(--text-muted)}
input[type="search"]::-webkit-search-cancel-button{-webkit-appearance:none}
.btn-primary{display:inline-flex;align-items:center;gap:6px;padding:14px 28px;margin:4px;background:var(--accent);color:var(--text-inverse);font-family:inherit;font-size:14px;font-weight:600;border:none;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;transition:background var(--dur) var(--ease),transform 80ms var(--ease);flex-shrink:0;text-transform:uppercase;letter-spacing:.04em}
.btn-primary:hover{background:var(--accent-hover)}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{opacity:.65;cursor:not-allowed}
.btn-spinner{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
.search-error{margin-top:10px;padding:10px 16px;font-size:13px;color:var(--error-text);background:var(--error-bg);border:1px solid var(--error-border);border-radius:var(--radius-sm);text-align:left}

/* ═══ QUICK TOOLS ═══ */
.quick-tools{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-top:36px}
.tool-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;font-size:12px;font-weight:500;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em;transition:border-color var(--dur) var(--ease),color var(--dur) var(--ease),background var(--dur) var(--ease)}
.tool-chip:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-subtle)}
.tool-chip svg{flex-shrink:0;width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2}

/* ═══ REPORT ═══ */
.report-header{padding:48px 0 32px;text-align:center}
.report-title{font-size:clamp(1.5rem,3vw,2rem);font-weight:700;letter-spacing:-.02em;margin-bottom:6px}
.report-subtitle{font-size:1rem;color:var(--text-secondary);margin-bottom:28px}
.report-subtitle strong{color:var(--accent);font-weight:600}
.error-card{display:flex;align-items:center;gap:14px;padding:20px 24px;background:var(--error-bg);border:1px solid var(--error-border);border-radius:var(--radius-md);color:var(--error-text);margin-bottom:32px}
.error-card svg{flex-shrink:0;stroke:var(--error-icon)}
.site-footer{padding:24px 0;text-align:center;font-size:13px;color:var(--text-muted);border-top:1px solid var(--border);background:var(--bg-card);transition:background var(--dur) var(--ease)}

/* ═══ DASHBOARD HERO ═══ */
.report-dashboard{padding-bottom:8px;margin-bottom:0}
.dashboard-hero{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:23px 23px;display:grid;grid-template-columns:1fr auto 1fr;gap:40px;align-items:center;margin-bottom:0}
.dash-domain{display:flex;align-items:center;gap:16px}
.dash-domain-icon{width:56px;height:56px;border-radius:var(--radius-full);background:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dash-domain-icon svg{stroke:white;width:28px;height:28px}
.dash-domain-text h2{font-size:1.25rem;font-weight:700;color:var(--text-primary);line-height:1.3}
.dash-domain-text p{font-size:13px;color:var(--text-secondary);margin-top:2px}
.dash-domain-text .dash-date{font-size:12px;color:var(--text-muted);margin-top:4px}
.dash-grade{text-align:center}
.grade-box{width:72px;height:72px;margin:0 auto 8px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;font-family:'JetBrains Mono',monospace}
.grade-box--a{background:#ecfdf5;color:#059669;border:2px solid #a7f3d0}
.grade-box--b{background:#eef2fd;color:#4169E1;border:2px solid #bfcffc}
.grade-box--c{background:#fffbeb;color:#d97706;border:2px solid #fde68a}
.grade-box--d{background:#fff7ed;color:#ea580c;border:2px solid #fed7aa}
.grade-box--f{background:#fef2f2;color:#dc2626;border:2px solid #fecaca}
.grade-score{font-family:'JetBrains Mono',monospace;font-size:1.1rem;font-weight:700;color:var(--text-primary)}
.grade-score span{font-weight:400;color:var(--text-muted)}
.grade-label{font-size:12px;color:var(--text-muted);margin-top:2px}
.dash-bars{display:flex;flex-direction:column;gap:14px;min-width:0}
.bar-row{display:flex;align-items:center;gap:12px}
.bar-dot{width:12px;height:12px;border-radius:var(--radius-full);flex-shrink:0}
.bar-dot--error{background:#ef4444}.bar-dot--warn{background:#f59e0b}.bar-dot--info{background:#4169E1}.bar-dot--pass{background:#10b981}
.bar-label{font-size:13px;font-weight:500;color:var(--text-primary);min-width:120px}
.bar-track{flex:1;height:10px;background:var(--bg-code);border-radius:var(--radius-full);overflow:hidden;min-width:100px}
.bar-fill{height:100%;border-radius:var(--radius-full);transition:width .8s var(--ease)}
.bar-fill--error{background:#ef4444}.bar-fill--warn{background:#f59e0b}.bar-fill--info{background:#4169E1}.bar-fill--pass{background:#10b981}
.bar-count{font-family:'JetBrains Mono',monospace;font-size:14px;font-weight:700;color:var(--text-primary);min-width:24px;text-align:right}

/* ═══ TABLE RESULTS ═══ */
.results-table-section{padding-top:20px;padding-bottom:60px}
.results-table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}
.results-table{width:100%;border-collapse:collapse}
.results-table thead th{background:var(--bg-code);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);padding:12px 16px;text-align:left;border-bottom:2px solid var(--border);white-space:nowrap;border-right:1px solid var(--border)}
.results-table thead th:last-child{border-right:none}
.results-table .col-category{width:100px}.results-table .col-status{width:52px;text-align:center}.results-table .col-test{width:190px}
/* Info column header with inline buttons */
.results-table .col-info{display:flex;align-items:center;justify-content:space-between;gap:12px}
.th-actions{display:inline-flex;align-items:center;gap:8px;margin-left:auto}
.processed-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:500;color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-full);white-space:nowrap;text-transform:none;letter-spacing:0}
.processed-badge svg{flex-shrink:0;stroke:var(--text-muted)}
.btn-pdf-sm{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;background:var(--accent);color:white;font-family:inherit;font-size:11px;font-weight:600;border:none;border-radius:var(--radius-full);cursor:pointer;transition:background var(--dur) var(--ease);white-space:nowrap;text-transform:none;letter-spacing:0}
.btn-pdf-sm:hover{background:var(--accent-hover)}
.btn-pdf-sm svg{flex-shrink:0;stroke:white}

.results-table tbody td{padding:14px 16px;font-size:13.5px;color:var(--text-primary);border-bottom:1px solid var(--border);vertical-align:top;line-height:1.65}
.results-table tbody tr:last-child td{border-bottom:none}
.results-table .td-category{font-weight:600;font-size:13px;color:var(--text-secondary);letter-spacing:.02em;border-right:1px solid var(--border);background:var(--bg-card)!important;vertical-align:top;padding-top:18px}
.results-table .td-status{text-align:center;vertical-align:top;padding-top:16px;border-right:1px solid var(--border)}
.results-table .td-status svg{display:inline-block;flex-shrink:0}
.results-table .td-test{font-weight:600;font-size:13px;color:var(--text-primary);border-right:1px solid var(--border)}
.results-table .td-info{font-size:13px;color:var(--text-secondary);line-height:1.7;white-space:pre-wrap;word-break:break-word}
.results-table .td-info strong{color:var(--text-primary);font-weight:600}
.results-table tr.row--warn{background:var(--warn-bg)}.results-table tr.row--error{background:var(--error-bg)}
.results-table tr.row--warn td{border-bottom-color:var(--warn-border)}.results-table tr.row--error td{border-bottom-color:var(--error-border)}
.results-table tbody tr:hover td:not(.td-category){background:var(--accent-subtle)}
.results-table tbody tr.row--warn:hover td:not(.td-category){background:color-mix(in srgb,var(--warn-bg) 70%,var(--accent-subtle))}
.results-table tbody tr.row--error:hover td:not(.td-category){background:color-mix(in srgb,var(--error-bg) 70%,var(--accent-subtle))}
.status-icon--pass svg{stroke:var(--pass-icon)}.status-icon--warn svg{stroke:var(--warn-icon)}.status-icon--error svg{stroke:var(--error-icon)}.status-icon--info svg{stroke:var(--info-icon)}

/* ═══ RESPONSIVE ═══ */
@media(max-width:900px){.dropdown-mega{min-width:440px}.nav-list>li>a{padding:8px 10px;font-size:12px}.dashboard-hero{grid-template-columns:1fr;gap:24px;padding:24px}.dash-bars{width:100%}}
@media(max-width:720px){:root{--header-h:56px;--container-pad:16px}.main-nav{display:none}.header-mobile-actions{display:flex}.hero{padding:48px 0 36px}.hero-title{font-size:1.5rem}.hero-subtitle{font-size:.95rem;margin-bottom:28px}.search-input-wrap{flex-direction:column;border-radius:var(--radius-md)}.search-input-wrap input[type="search"]{width:100%;padding:14px 16px}.search-icon{display:none}.btn-primary{width:calc(100% - 8px);justify-content:center;margin:0 4px 4px;padding:14px 20px}.quick-tools{gap:6px}.tool-chip{font-size:11px;padding:5px 10px}.report-header{padding:32px 0 20px}.mobile-toggle{display:flex}.results-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.results-table{min-width:700px}.dashboard-hero{grid-template-columns:1fr;gap:20px;padding:20px}.bar-label{min-width:100px}.th-actions{display:none}}
@media(max-width:400px){.dash-domain-icon{width:44px;height:44px}.dash-domain-icon svg{width:22px;height:22px}.grade-box{width:56px;height:56px;font-size:1.5rem}}
@media print{.site-header,.site-footer,.search-form,.quick-tools,.theme-toggle,.mobile-toggle,.btn-coffee,.mobile-overlay,.header-mobile-actions,.th-actions{display:none!important}body{background:#fff;color:#000}.results-table tr{break-inside:avoid}.dashboard-hero{border:1px solid #ddd}}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}