/* components.css — Nav, buttons, inputs, cards, tabs, pills */

/* NAV */
nav{display:flex;align-items:center;justify-content:space-between;padding:16px clamp(16px,4vw,48px);border-bottom:1px solid var(--border);flex-shrink:0;gap:10px}
.logo{font-family:var(--font-display);font-weight:800;font-size:clamp(15px,3vw,19px);letter-spacing:-0.5px;display:flex;align-items:center;gap:8px;flex-shrink:0}
.logo span:first-of-type{color:var(--accent)}
.logo-sub{color:var(--muted)!important;font-size:12px;font-weight:400;font-family:var(--font-body)}
.logo-icon{width:30px;height:30px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.nav-right{display:flex;align-items:center;gap:10px}
.nav-badge{font-size:11px;background:rgba(0,229,255,0.08);color:var(--accent);border:1px solid rgba(0,229,255,0.2);padding:4px 10px;border-radius:100px;font-weight:500;white-space:nowrap}
@media(max-width:380px){.nav-badge{display:none}}
.step-indicator{display:flex;align-items:center;gap:6px}
.step-dot-nav{width:6px;height:6px;border-radius:50%;background:var(--surface3)}
.step-dot-nav.active{background:var(--accent)}
.step-dot-nav.done{background:var(--accent);opacity:0.4}

/* BUTTONS */
.btn-primary{width:100%;background:linear-gradient(135deg,var(--accent),#4fc3f7);color:#07090f;font-family:var(--font-display);font-weight:700;font-size:clamp(14px,2.5vw,15px);border:none;border-radius:var(--r3);padding:15px;cursor:pointer;transition:opacity 0.2s,transform 0.15s;display:flex;align-items:center;justify-content:center;gap:8px;min-height:50px;touch-action:manipulation}
.btn-primary:hover:not(:disabled){opacity:0.9;transform:translateY(-1px)}
.btn-primary:active{transform:scale(0.99)}
.btn-primary:disabled{opacity:0.35;cursor:not-allowed;transform:none}
.btn-secondary{background:transparent;border:1px solid var(--border2);color:var(--text);font-family:var(--font-body);font-size:13px;padding:9px 16px;border-radius:var(--r3);cursor:pointer;transition:background 0.2s,border-color 0.2s;white-space:nowrap;touch-action:manipulation}
.btn-secondary:hover{background:var(--surface);border-color:var(--border3)}
.btn-upgrade{background:linear-gradient(135deg,var(--accent2),#9d50f5);color:#fff;font-family:var(--font-display);font-weight:700;font-size:14px;border:none;border-radius:var(--r3);padding:12px 24px;cursor:pointer;transition:opacity 0.2s;touch-action:manipulation}
.btn-upgrade:hover{opacity:0.9}

/* CONSENT CHECKBOX */
.consent-wrap{margin-bottom:12px;padding:14px 16px;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--r3)}
.consent-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:13px;color:var(--muted2);line-height:1.5}
.consent-label input[type="checkbox"]{display:none}
.consent-check-box{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--border3);background:var(--surface3);flex-shrink:0;margin-top:1px;transition:all 0.2s;display:flex;align-items:center;justify-content:center}
.consent-label input:checked + .consent-check-box{background:var(--accent);border-color:var(--accent);color:#07090f;font-size:12px;font-weight:700}
.consent-label input:checked + .consent-check-box::after{content:'✓'}
.consent-text{flex:1}

/* INPUTS */
.input-section{max-width:520px;width:100%;margin-bottom:24px}
.input-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
@media(max-width:500px){.input-row{grid-template-columns:1fr}}
.input-wrap{position:relative}
.input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:16px;pointer-events:none;z-index:1}
.input-wrap input{width:100%;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--r3);padding:14px 14px 14px 42px;color:var(--text);font-family:var(--font-body);font-size:16px;outline:none;transition:border-color 0.2s,box-shadow 0.2s;min-height:50px}
.input-wrap input::placeholder{color:var(--muted);font-size:14px}
.input-wrap input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,229,255,0.08)}

/* TRUST ROW */
.trust-row{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:14px;color:var(--muted);font-size:11px;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:4px}
.trust-item::before{content:'✓';color:var(--green);font-size:10px}

/* STATUS PILLS */
.spill{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:600}
.spill::before{content:'●';font-size:7px}
.spill.pass{background:rgba(0,230,118,0.10);color:var(--green);border:1px solid rgba(0,230,118,0.20)}
.spill.fail{background:rgba(255,71,87,0.10);color:var(--red);border:1px solid rgba(255,71,87,0.20)}
.spill.warn{background:rgba(255,176,32,0.10);color:var(--amber);border:1px solid rgba(255,176,32,0.20)}
.spill.info{background:rgba(59,130,246,0.10);color:var(--blue);border:1px solid rgba(59,130,246,0.20)}
.spill.skip{background:rgba(255,255,255,0.04);color:var(--muted);border:1px solid var(--border)}

/* SEVERITY DOTS */
.check-sev{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0}
.sev-crit{background:var(--red);box-shadow:0 0 6px var(--red)}
.sev-high{background:#ff6b35;box-shadow:0 0 6px #ff6b35}
.sev-med{background:var(--amber);box-shadow:0 0 6px var(--amber)}
.sev-low{background:var(--green);box-shadow:0 0 6px var(--green)}
.sev-info{background:var(--blue);box-shadow:0 0 6px var(--blue)}

/* TABS */
.tab-bar{display:flex;gap:2px;margin-bottom:20px;border-bottom:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.tab-bar::-webkit-scrollbar{display:none}
.tab-btn{font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--muted);background:transparent;border:none;cursor:pointer;padding:10px 14px;border-bottom:2px solid transparent;transition:color 0.2s,border-color 0.2s;white-space:nowrap;margin-bottom:-1px;touch-action:manipulation}
.tab-btn:hover{color:var(--text)}
.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}
.tab-panel{display:none}
.tab-panel.active{display:block}

/* CARDS */
.card{background:var(--surface);border:1px solid var(--border2);border-radius:var(--r);padding:20px 22px;margin-bottom:14px}
@media(max-width:480px){.card{padding:16px 14px;border-radius:12px}}
.card-head{display:flex;align-items:center;gap:10px;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.card-head-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.card-head-title{font-family:var(--font-display);font-size:15px;font-weight:700;letter-spacing:-0.2px}
.card-head-sub{font-size:12px;color:var(--muted);margin-top:1px}
.card-head-badge{margin-left:auto;flex-shrink:0}
@media(max-width:420px){.card-head-badge{margin-left:0}}

/* STAT BOXES */
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}
@media(max-width:400px){.stat-grid{grid-template-columns:1fr 1fr}}
.stat-box{background:var(--surface2);border-radius:var(--r3);padding:12px 14px}
.stat-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:0.8px;margin-bottom:4px}
.stat-val{font-family:var(--font-display);font-size:20px;font-weight:800;letter-spacing:-0.5px}
.stat-sub{font-size:11px;color:var(--muted);margin-top:2px}

/* CHECK ROWS */
.checks-table{display:flex;flex-direction:column;gap:8px}
.check-row{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border-radius:var(--r3);border:1px solid var(--border);background:rgba(255,255,255,0.015);transition:background 0.15s}
.check-row:hover{background:rgba(255,255,255,0.025)}
.check-title{font-size:13px;font-weight:500;margin-bottom:3px}
.check-desc{font-size:12px;color:var(--muted2);line-height:1.5}

/* FIX ITEMS */
.fixes-list{display:flex;flex-direction:column;gap:12px}
.fix-item{display:flex;gap:12px;align-items:flex-start;padding:14px;background:rgba(255,255,255,0.02);border:1px solid var(--border);border-radius:var(--r3)}
.fix-num{width:26px;height:26px;border-radius:7px;background:linear-gradient(135deg,var(--accent),#60c8ff);color:#07090f;font-family:var(--font-display);font-weight:700;font-size:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.fix-priority{display:inline-block;font-size:10px;font-weight:600;letter-spacing:0.5px;padding:2px 8px;border-radius:100px;margin-bottom:4px;text-transform:uppercase}
.fp-urgent{background:rgba(255,71,87,0.10);color:var(--red);border:1px solid rgba(255,71,87,0.20)}
.fp-soon{background:rgba(255,176,32,0.10);color:var(--amber);border:1px solid rgba(255,176,32,0.20)}
.fp-later{background:rgba(0,230,118,0.10);color:var(--green);border:1px solid rgba(0,230,118,0.20)}
.fix-title{font-size:13px;font-weight:500;margin-bottom:3px}
.fix-desc{font-size:12px;color:var(--muted2);line-height:1.5}

/* AI BOX */
.ai-tag{display:inline-flex;align-items:center;gap:6px;background:rgba(124,58,237,0.12);color:#a78bfa;border:1px solid rgba(124,58,237,0.25);border-radius:100px;font-size:10px;font-weight:600;letter-spacing:0.8px;padding:3px 10px;margin-bottom:14px;text-transform:uppercase}
.ai-box{background:linear-gradient(135deg,rgba(124,58,237,0.08),rgba(0,229,255,0.04));border:1px solid rgba(124,58,237,0.25);border-radius:var(--r);padding:20px;font-size:14px;line-height:1.8;color:#c0ccdf}
.ai-box p{margin-bottom:12px}
.ai-box p:last-child{margin-bottom:0}

/* DNS CARDS */
.dns-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:18px}
@media(max-width:540px){.dns-grid{grid-template-columns:1fr}}
.dns-card{background:var(--surface2);border-radius:var(--r3);padding:14px;border:1px solid var(--border)}
.dns-card.ok{border-color:rgba(0,230,118,0.20)}
.dns-card.bad{border-color:rgba(255,71,87,0.20)}
.dns-card.warn{border-color:rgba(255,176,32,0.20)}
.dns-record-name{font-family:var(--font-display);font-size:13px;font-weight:700;margin-bottom:4px}
.dns-record-val{font-size:11px;color:var(--muted);font-family:monospace;word-break:break-all;margin-bottom:8px;line-height:1.4}

/* LOCK PANEL */
.lock-overlay{background:var(--surface);border:1px solid var(--border2);border-radius:var(--r);padding:28px 20px;text-align:center;margin-bottom:14px}
.lock-icon{font-size:32px;margin-bottom:10px}
.lock-title{font-family:var(--font-display);font-size:17px;font-weight:700;margin-bottom:8px}
.lock-desc{font-size:13px;color:var(--muted2);margin-bottom:18px;max-width:340px;margin-left:auto;margin-right:auto;line-height:1.5}

/* DISCLAIMER */
.disclaimer{text-align:center;font-size:11px;color:var(--muted);padding:18px 16px;border-top:1px solid var(--border);margin-top:20px;line-height:1.6}

/* SKIPPED NOTICE */
.skipped-notice{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,0.04);color:var(--muted);border:1px solid var(--border);border-radius:100px;font-size:10px;padding:2px 8px;margin-left:6px;vertical-align:middle}
.live-badge{display:inline-flex;align-items:center;gap:4px;background:rgba(0,229,255,0.08);color:var(--accent);border:1px solid rgba(0,229,255,0.2);border-radius:100px;font-size:9px;font-weight:600;padding:1px 6px;margin-left:6px;vertical-align:middle}
.demo-badge{display:inline-flex;align-items:center;gap:4px;background:rgba(255,255,255,0.04);color:var(--muted);border:1px solid var(--border);border-radius:100px;font-size:9px;padding:1px 6px;margin-left:6px;vertical-align:middle}
