:root{--bg-primary: #f5f7fa;--bg-secondary: #ffffff;--bg-tertiary: #edf0f5;--text-primary: #1a1a2e;--text-secondary: #4a4a6a;--text-muted: #8888a0;--accent: #0077cc;--accent-dim: #005599;--accent-glow: rgba(0, 119, 204, .12);--pass: #008800;--warn: #b86e00;--fail: #cc0000;--skip: #4a5568;--border: #d0d4dc;--border-subtle: #e4e8ee;--mono: "JetBrains Mono", "Fira Code", "Cascadia Code", "Consolas", monospace;--sans: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--radius: 8px;--radius-lg: 10px;--transition: .15s ease;--explain-bg: rgba(0, 119, 204, .06);--explain-border: rgba(0, 119, 204, .15)}[data-theme=dark]{--bg-primary: #1a1a2e;--bg-secondary: #16213e;--bg-tertiary: #0f3460;--text-primary: #e0e0e0;--text-secondary: #a0a0a0;--text-muted: #888888;--accent: #00d4ff;--accent-dim: #0088aa;--accent-glow: rgba(0, 212, 255, .15);--pass: #44ff44;--warn: #ffaa00;--fail: #ff4444;--skip: #94a3b8;--border: #2a2a4a;--border-subtle: #222240;--explain-bg: rgba(0, 212, 255, .06);--explain-border: rgba(0, 212, 255, .12)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.5;font-size:14px}.mono{font-family:var(--mono);font-size:.875em}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.app{max-width:960px;margin:0 auto;padding:1.5rem 1rem;min-height:100vh;display:flex;flex-direction:column}.main{flex:1}.skip-link{position:absolute;left:-9999px;top:0;background:var(--accent);color:#fff;padding:.5rem 1rem;z-index:100;border-radius:0 0 var(--radius) 0;font-size:.875rem}.skip-link:focus{left:0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.header{display:flex;align-items:center;gap:12px;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border-subtle)}.logo{font-family:var(--mono);font-size:1.75rem;font-weight:700;letter-spacing:-.5px;background:linear-gradient(135deg,var(--accent),#7b68ee);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tagline{font-size:.875rem;color:var(--text-muted)}.header-actions{margin-left:auto;display:flex;gap:6px}.header-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius);cursor:pointer;font-size:1rem;transition:color var(--transition),border-color var(--transition),background var(--transition)}.header-btn:hover{color:var(--text-primary);border-color:var(--text-secondary);background:var(--accent-glow)}.host-input{display:flex;gap:.5rem;margin-bottom:.5rem}.host-input__field-wrap{flex:1;position:relative;min-width:0}.host-input__field{width:100%;padding:.5rem 2rem .5rem .75rem;font-family:var(--mono);font-size:1rem;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius);outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.host-input__field::placeholder{color:var(--text-muted)}.host-input__field:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}.host-input__clear{position:absolute;right:6px;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:24px;height:24px;font-size:14px;line-height:1;color:var(--text-muted);background:none;border:none;border-radius:50%;cursor:pointer;padding:0;transition:color var(--transition),background var(--transition);z-index:10}.host-input__clear:hover{color:var(--text-primary);background:var(--bg-tertiary)}.host-input__history{position:relative;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.25rem;max-height:200px;overflow-y:auto;z-index:50}.host-input__history-item{display:block;width:100%;padding:6px 10px;background:none;border:none;color:var(--text-primary);text-align:left;cursor:pointer;font-size:.8125rem;transition:background var(--transition)}.host-input__history-item:hover,.host-input__history-item--active{background:var(--bg-tertiary)}.host-input__history-item+.host-input__history-item{border-top:1px solid var(--border-subtle)}.host-input__submit{padding:.5rem 1.25rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);cursor:pointer;font-family:var(--mono);font-size:.875rem;font-weight:500;transition:background var(--transition),box-shadow var(--transition)}.host-input__submit:hover:not(:disabled){background:var(--accent-dim);box-shadow:0 0 12px var(--accent-glow)}.host-input__submit:disabled{opacity:.5;cursor:not-allowed}.host-input__presets{display:flex;gap:6px;margin-bottom:1rem}.host-input__preset{padding:2px 8px;background:none;border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius);cursor:pointer;font-family:var(--mono);font-size:.75rem;transition:color var(--transition),border-color var(--transition)}.host-input__preset:hover:not(:disabled){color:var(--text-primary);border-color:var(--text-secondary)}.welcome{margin-top:2rem}.welcome-tagline{text-align:center;font-size:.9375rem;color:var(--text-secondary);margin-bottom:1.5rem}.welcome-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.welcome-card{display:flex;flex-direction:column;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;transition:border-color var(--transition)}.welcome-card:hover{border-color:var(--text-muted)}.welcome-card-title{font-family:var(--mono);font-size:.875rem;font-weight:600;color:var(--accent);margin-bottom:6px}.welcome-card-desc{font-size:.8125rem;color:var(--text-secondary);line-height:1.5;margin-bottom:12px;flex:1}.welcome-example{display:block;width:100%;padding:6px 10px;background:var(--accent-glow);border:1px solid var(--border-subtle);border-radius:var(--radius);color:var(--accent);font-family:var(--mono);font-size:.8125rem;cursor:pointer;text-align:left;transition:background var(--transition),border-color var(--transition)}.welcome-example:hover{background:var(--bg-tertiary);border-color:var(--accent)}.welcome-example+.welcome-example{margin-top:6px}.loading-indicator{display:flex;align-items:center;justify-content:center;gap:10px;padding:2rem 0;color:var(--text-secondary);font-size:.875rem}.spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-banner{padding:.75rem 1rem;background:#cc000014;border:1px solid var(--fail);border-radius:var(--radius);color:var(--fail);font-size:.875rem;margin-bottom:1rem}[data-theme=dark] .error-banner{background:#ff44441a}.warnings{display:flex;flex-direction:column;gap:.5rem}.warning-banner{padding:.5rem .75rem;background:#b86e0014;border:1px solid var(--warn);border-radius:var(--radius);color:var(--warn);font-size:.875rem}[data-theme=dark] .warning-banner{background:#ffaa001a}.results{display:flex;flex-direction:column;gap:1rem}.results-toolbar{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem 0;flex-wrap:wrap}.results-summary{display:flex;align-items:center;gap:6px;font-size:.8125rem;color:var(--text-secondary)}.results-summary-sep{color:var(--text-muted)}.results-summary-item{font-family:var(--mono)}.results-actions{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.results-actions__left,.results-actions__right{display:flex;gap:4px}.filter-toggle{padding:3px 10px;background:none;border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius);cursor:pointer;font-family:var(--mono);font-size:.75rem;transition:color var(--transition),border-color var(--transition),background var(--transition)}.filter-toggle:hover{color:var(--text-primary);border-color:var(--text-secondary)}.filter-toggle--active{background:var(--accent);border-color:var(--accent);color:#fff}.filter-toggle--active:hover{background:var(--accent-dim);border-color:var(--accent-dim);color:#fff}.validation-summary{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:1rem}.verdict--pass{color:var(--pass)}.verdict--warn{color:var(--warn)}.verdict--fail{color:var(--fail)}.verdict--skip{color:var(--skip)}.validation-summary__checks{display:flex;flex-wrap:wrap;gap:6px;margin-top:.5rem}.check{padding:2px 8px;border-radius:var(--radius);font-size:.8125rem;font-family:var(--mono);border:1px solid var(--border-subtle);background:var(--bg-tertiary);transition:border-color var(--transition)}.check--pass{color:var(--pass);border-color:var(--pass)}.check--warn{color:var(--warn);border-color:var(--warn)}.check--fail{color:var(--fail);border-color:var(--fail)}.check--skip{color:var(--skip)}.port-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border-subtle);padding-bottom:0}.port-tabs__tab{padding:8px 16px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);cursor:pointer;font-family:var(--mono);font-size:.8125rem;transition:color var(--transition),border-color var(--transition)}.port-tabs__tab:hover{color:var(--text-primary)}.port-tabs__tab--active{color:var(--accent);border-bottom-color:var(--accent)}.ip-card{border:1px solid var(--border);border-radius:var(--radius-lg);border-left:3px solid var(--border);overflow:hidden;background:var(--bg-secondary)}.ip-card--pass{border-left-color:var(--pass)}.ip-card--warn{border-left-color:var(--warn)}.ip-card--fail,.ip-card--error{border-left-color:var(--fail)}.ip-card__header{display:flex;align-items:center;gap:.5rem;padding:10px 14px;width:100%;background:var(--bg-tertiary);border:none;border-bottom:1px solid var(--border-subtle);color:var(--text-primary);cursor:pointer;text-align:left;font-family:inherit;font-size:inherit;transition:background var(--transition)}.ip-card__header:hover:not(:disabled){background:var(--bg-primary)}[data-card-active]{outline:2px solid var(--accent);outline-offset:-1px;border-radius:var(--radius-lg)}.ip-card__header:disabled{cursor:default}.ip-card__left{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.ip-card__ip{font-weight:600;font-family:var(--mono);font-size:.875rem}.ip-card__version{font-size:.6875rem;color:var(--text-muted);padding:1px 6px;border:1px solid var(--border);border-radius:3px;font-family:var(--sans);text-transform:uppercase;letter-spacing:.5px}.ip-card__error{color:var(--fail);font-size:.8125rem;flex:1}.ip-card__meta{display:flex;align-items:center;gap:4px;flex:1;justify-content:center}.ip-card__badge{font-size:.6875rem;font-family:var(--mono);color:var(--text-muted);padding:1px 5px;border:1px solid var(--border-subtle);border-radius:3px;white-space:nowrap}.ip-card__days{font-size:.6875rem;font-family:var(--mono);font-weight:600;padding:1px 6px;border-radius:3px;flex-shrink:0}.ip-card__days--pass{color:var(--pass);border:1px solid var(--pass)}.ip-card__days--warn{color:var(--warn);border:1px solid var(--warn)}.ip-card__days--fail{color:var(--fail);border:1px solid var(--fail)}.ip-card__chevron{font-size:.875rem;color:var(--text-muted);transition:transform var(--transition);flex-shrink:0}.ip-card__chevron--open{transform:rotate(90deg)}.ip-card__leaf-summary{display:flex;align-items:center;gap:6px;padding:6px 14px;font-size:.75rem;font-family:var(--mono);color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);overflow-x:auto;white-space:nowrap}.ip-card__leaf-sep{color:var(--border)}.ip-card__validation{display:flex;align-items:center;gap:4px;padding:6px 14px;border-bottom:1px solid var(--border-subtle)}.ip-card__chip{font-size:.6875rem;font-family:var(--mono);padding:1px 6px;border-radius:3px;border:1px solid var(--border-subtle)}.ip-card__chip--pass{color:var(--pass);border-color:var(--pass)}.ip-card__chip--fail{color:var(--fail);border-color:var(--fail)}.validation-reason{padding:6px 14px;font-size:.8125rem;color:var(--fail);background:color-mix(in srgb,var(--fail) 6%,transparent);line-height:1.4;border-bottom:1px solid var(--border-subtle)}.unified-ip{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-secondary)}.unified-ip__header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:8px 14px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-subtle)}.unified-ip__ips{display:flex;flex-wrap:wrap;gap:4px;min-width:0}.unified-ip__ip-badge{font-family:var(--mono);font-size:.75rem;color:var(--text-secondary)}.unified-ip__ip-badge+.unified-ip__ip-badge:before{content:"/";margin-right:4px;color:var(--text-muted)}.unified-ip__header-right{flex-shrink:0}.unified-ip__consistent-badge{font-family:var(--mono);font-size:.75rem;font-weight:500;color:var(--pass);padding:1px 8px;border:1px solid var(--pass);border-radius:var(--radius);white-space:nowrap}.unified-ip__timings{display:flex;flex-wrap:wrap;gap:0;padding:0;border-bottom:1px solid var(--border-subtle);font-family:var(--mono);font-size:.75rem}.unified-ip__timing{padding:4px 14px;color:var(--text-muted);white-space:nowrap}.unified-ip__timing-val{color:var(--accent)}.unified-ip .ip-card__validation{border-bottom:1px solid var(--border-subtle)}.unified-ip .ip-card__body .tls-params,.unified-ip .ip-card__body .chain-view,.unified-ip .ip-card__body .cert-details,.unified-ip .ip-card__body .dns-section{border:none;border-radius:0;border-bottom:1px solid var(--border-subtle)}.unified-ip .ip-card__body>:last-child,.unified-ip .ip-card__body>:last-child>:last-child{border-bottom:none}.ip-card__cert-toolbar{display:flex;justify-content:flex-end;padding:6px 14px;border-bottom:1px solid var(--border-subtle)}.ip-card__body .tls-params,.ip-card__body .chain-view,.ip-card__body .cert-details,.ip-card__body .dns-section{border:none;border-radius:0;border-bottom:1px solid var(--border-subtle)}.ip-card__body>:last-child,.ip-card__body>:last-child>:last-child{border-bottom:none}.tls-params{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem}.tls-params h2{font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.tls-params__table{width:100%;border-collapse:collapse}.tls-params__table th{text-align:left;padding:4px 12px 4px 0;color:var(--text-muted);font-weight:500;font-size:.8125rem;white-space:nowrap;width:1%}.tls-params__table td{padding:4px 0;font-family:var(--mono);font-size:.8125rem}.chain-view{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem}.chain-view h2{font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem}.chain-view__chain{display:flex;align-items:center;gap:.5rem;overflow-x:auto;padding:.25rem 0}.chain-view__arrow{color:var(--text-muted);font-size:1.25rem;flex-shrink:0}.chain-view__cert{border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;min-width:160px;background:var(--bg-primary);transition:border-color var(--transition)}.chain-view__cert:hover{border-color:var(--text-muted)}.chain-view__position{font-size:.6875rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:4px}.chain-view__subject{font-family:var(--mono);font-size:.8125rem;font-weight:500;margin-bottom:4px;word-break:break-all}.chain-view__cert--root-inferred{border-style:dashed;opacity:.7}.chain-view__inferred{font-size:.6875rem;color:var(--text-muted);font-style:italic}.chain-view__arrow--broken{color:var(--fail);font-weight:700}.chain-view__cert--expired{border-color:var(--fail)}.chain-view__cert--unknown-issuer{border-color:var(--warn);border-width:2px}.chain-view__cert--root-untrusted{border-color:var(--fail);border-style:dashed;opacity:.7}.chain-view__days{font-size:.75rem;color:var(--text-secondary)}.chain-view__key{font-size:.75rem;color:var(--text-muted)}.cert-detail{border:1px solid var(--border-subtle);border-radius:var(--radius);overflow:hidden}.cert-detail__toggle{width:100%;padding:8px 12px;background:var(--bg-secondary);border:none;color:var(--text-primary);text-align:left;cursor:pointer;font-family:var(--mono);font-size:.8125rem;transition:background var(--transition)}.cert-detail__toggle:hover{background:var(--bg-tertiary)}.cert-detail__body{padding:.75rem}.cert-detail__table{width:100%;border-collapse:collapse}.cert-detail__table th{text-align:left;padding:3px 12px 3px 0;color:var(--text-muted);font-weight:500;font-size:.8125rem;white-space:nowrap;width:1%}.cert-detail__table td{padding:3px 0;word-break:break-all;font-size:.8125rem}.consistency-view{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem}.consistency-view__title{font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem;display:flex;align-items:center;gap:8px}.consistency-view__desc{font-size:.8125rem;color:var(--text-muted);margin-bottom:.5rem}.consistency-view__badges{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:.5rem}.consistency-badge{padding:2px 8px;border-radius:var(--radius);font-size:.8125rem;font-family:var(--mono);border:1px solid var(--border-subtle)}.consistency-badge--match{color:var(--pass);border-color:var(--pass)}.consistency-badge--mismatch{color:var(--warn);border-color:var(--warn)}.consistency-view__mismatches{display:flex;flex-direction:column;gap:.5rem}.consistency-view__mismatch{padding:.5rem;border:1px solid var(--border-subtle);border-radius:var(--radius);background:var(--bg-primary)}.consistency-view__mismatch strong{display:block;margin-bottom:.25rem;font-size:.8125rem}.consistency-view__value{font-size:.75rem;color:var(--text-secondary)}.dns-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.dns-section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem}.dns-section__toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0;background:none;border:none;color:var(--text-primary);cursor:pointer;font-family:inherit;font-size:inherit;text-align:left}.dns-section__toggle-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:.875rem;font-weight:600;color:var(--text-secondary)}.dns-section__count{font-size:.6875rem;font-family:var(--mono);color:var(--text-muted);padding:1px 6px;border:1px solid var(--border);border-radius:3px}.dns-section__body{margin-top:.75rem}.dns-section__title{font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.dns-section__empty{color:var(--text-muted);font-size:.8125rem}.dns-records{list-style:none;display:flex;flex-direction:column;gap:4px}.dns-records__item{padding:4px 8px;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius);font-size:.8125rem;word-break:break-all}.badge{font-size:.6875rem;padding:1px 6px;border-radius:3px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.badge--pass{color:var(--pass);border:1px solid var(--pass)}.badge--fail{color:var(--fail);border:1px solid var(--fail)}.badge--warn{color:var(--warn);border:1px solid var(--warn)}.badge--skip{color:var(--skip);border:1px solid var(--skip)}.detail-toggle{background:none;border:1px solid var(--border);color:var(--text-muted);padding:2px 8px;border-radius:var(--radius);cursor:pointer;font-size:.75rem;font-family:var(--mono);transition:color var(--transition),border-color var(--transition)}.detail-toggle:hover{color:var(--text-primary);border-color:var(--text-secondary)}.eco-link{font-size:.75rem;color:var(--text-muted);text-decoration:none;transition:color var(--transition)}.eco-link:hover{color:var(--accent);text-decoration:none}.eco-link--badge{margin-left:2px}.ip-eco{display:flex;justify-content:flex-end;padding:2px 12px 4px}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fade-in .15s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;max-width:480px;width:90vw;max-height:80vh;overflow-y:auto;animation:modal-in .15s ease}.modal__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.modal__header h2{font-size:1.125rem;font-weight:600}.modal__close{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;font-size:20px;color:var(--text-muted);background:none;border:none;border-radius:var(--radius);cursor:pointer;transition:color var(--transition),background var(--transition)}.modal__close:hover{color:var(--text-primary);background:var(--bg-tertiary)}.help-section+.help-section{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-subtle)}.help-section__title{font-size:.8125rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.help-syntax{display:block;padding:6px 10px;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius);font-family:var(--mono);font-size:.875rem;color:var(--accent);margin-bottom:6px}.help-desc{font-size:.8125rem;color:var(--text-secondary);line-height:1.5}.help-desc+.help-desc{margin-top:8px}.help-keys{display:flex;flex-direction:column;gap:4px;margin-top:6px}.help-key{display:flex;align-items:center;gap:10px;font-size:.8125rem}.help-key kbd{display:inline-flex;align-items:center;justify-content:center;min-width:28px;padding:2px 6px;background:var(--bg-primary);border:1px solid var(--border);border-radius:4px;font-family:var(--mono);font-size:.75rem;color:var(--text-primary)}.help-key span{color:var(--text-secondary)}.export-buttons{display:flex;gap:6px;justify-content:center}.export-buttons__btn{padding:4px 12px;background:none;border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius);cursor:pointer;font-size:.75rem;font-family:var(--mono);transition:color var(--transition),border-color var(--transition)}.export-buttons__btn:hover{color:var(--text-primary);border-color:var(--text-secondary)}.footer{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:2rem;padding-top:1rem;padding-bottom:env(safe-area-inset-bottom);border-top:1px solid var(--border-subtle);font-size:.75rem;color:var(--text-muted)}.footer-link{color:var(--text-muted);transition:color var(--transition)}.footer-link:hover{color:var(--accent);text-decoration:none}.footer-sep{color:var(--border)}.footer-text{font-family:var(--mono)}.footer-info{text-align:center;color:var(--text-muted);font-size:.8125rem;font-family:var(--mono);padding-top:.5rem}.explain-card{padding:8px 12px;margin:6px 0;background:var(--explain-bg);border:1px solid var(--explain-border);border-radius:var(--radius);font-size:.8125rem;color:var(--text-secondary);line-height:1.5}.check-explanations{display:grid;grid-template-columns:auto 1fr;gap:2px 10px}.check-explanations dt{font-family:var(--mono);font-weight:600;font-size:.8125rem;color:var(--text-primary)}.check-explanations dd{font-size:.8125rem}.ip-badge{font-size:.6875rem;padding:1px 5px;border-radius:3px;border:1px solid;white-space:nowrap}.ip-badge--cloud{color:var(--accent);border-color:var(--accent)}.ip-badge--type{color:var(--text-secondary);border-color:var(--border)}.ip-badge--threat{color:var(--fail);border-color:var(--fail)}.ip-badge--org{color:var(--text-muted);border-color:var(--border-subtle)}@media(max-width:768px){.app{padding:.75rem}.header{margin-bottom:1.5rem;padding-bottom:.75rem}.logo{font-size:1.375rem}.tagline{display:none}.host-input{flex-direction:column}.host-input__field-wrap,.host-input__submit{width:100%}.host-input__presets{justify-content:center;flex-wrap:wrap}.port-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.cert-detail__table th,.cert-detail__table td,.tls-params__table th,.tls-params__table td{font-size:.75rem;padding:2px 6px 2px 0}.cert-detail__table,.tls-params__table{display:block;overflow-x:auto}.validation-summary__checks{gap:4px}.check{font-size:.75rem;padding:1px 6px}.ip-card__header{flex-wrap:wrap}.ip-card__meta{justify-content:flex-start}.ip-card__leaf-summary{flex-wrap:wrap;white-space:normal}.export-buttons{flex-direction:column}.export-buttons__btn{width:100%}.chain-view__chain{flex-direction:column}.chain-view__arrow{transform:rotate(90deg)}.welcome-cards{grid-template-columns:1fr}}.quality-section__body{margin-top:.75rem}.quality-summary-count{font-size:.6875rem;font-family:var(--mono);padding:1px 6px;border-radius:3px}.quality-summary-count--pass{color:var(--pass);border:1px solid var(--pass)}.quality-summary-count--warn{color:var(--warn);border:1px solid var(--warn)}.quality-summary-count--fail{color:var(--fail);border:1px solid var(--fail)}.quality-hostname{margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-subtle)}.quality-port{margin-bottom:.5rem}.quality-port__header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-weight:500;font-size:.85rem}.quality-port__label{color:var(--text-secondary)}.quality-group{margin-bottom:.5rem}.quality-group__title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:.25rem}.quality-check{display:flex;gap:.5rem;align-items:baseline;padding:2px 0;font-size:.85rem}.quality-check__icon{flex-shrink:0;width:1.2em;text-align:center;font-size:.9em}.quality-check--pass .quality-check__icon{color:var(--pass)}.quality-check--warn .quality-check__icon{color:var(--warn)}.quality-check--fail .quality-check__icon{color:var(--fail)}.quality-check--skip .quality-check__icon{color:var(--skip)}.quality-check__label{font-weight:500;color:var(--text-primary);white-space:nowrap}.quality-check__sep{color:var(--text-muted);opacity:.5;flex-shrink:0}.quality-check__detail{color:var(--text-secondary);font-family:var(--mono);font-size:.92em}
