/* Speedelly — tool.css : shared styles for tool pages (liquid glass) */
:root{--t1:var(--text);--t2:var(--text2);--t3:var(--text3)}
.pg{padding:clamp(1.5rem,5vw,3.5rem) 0}
.crumb{font-size:.74rem;color:var(--t3);margin-bottom:1rem;display:flex;gap:.4rem;flex-wrap:wrap;align-items:center}
.crumb a{color:var(--t3);text-decoration:none}.crumb a:hover{color:var(--accent)}
.hero{text-align:center;margin-bottom:1.75rem}
.hero h1{font-size:clamp(1.6rem,4vw,2.4rem);font-weight:800;letter-spacing:-.04em;margin-bottom:.5rem;line-height:1.05}
.hero h1 em{font-style:normal;background:linear-gradient(135deg,var(--ac,var(--accent)),var(--ac2,var(--accent2)));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero p{color:var(--t2);font-size:.95rem;max-width:560px;margin:0 auto}
.box{background:var(--glass);backdrop-filter:blur(18px) saturate(160%);border:1px solid var(--glass-border);border-radius:24px;padding:clamp(1.25rem,3vw,2rem);margin-bottom:1.5rem;box-shadow:var(--s1)}
.priv{display:inline-flex;align-items:center;gap:.4rem;font-size:.7rem;font-weight:600;color:var(--green);background:rgba(22,163,74,.1);border:1px solid rgba(22,163,74,.2);padding:.25rem .7rem;border-radius:99px;margin-bottom:1rem}
.btn{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(120deg,var(--ac,var(--accent)),var(--ac2,var(--accent2)));color:#fff;border:none;border-radius:12px;padding:.75rem 1.8rem;font-size:1rem;font-weight:800;cursor:pointer;transition:transform .15s,filter .15s;font-family:var(--font)}
.btn:hover{filter:brightness(1.08);transform:translateY(-1px)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}
.btn.ghost{background:none;border:1px solid var(--border2);color:var(--t1)}
.row{display:flex;gap:.7rem;flex-wrap:wrap;align-items:center;margin-bottom:1rem}
.ti,select,textarea.ti{width:100%;max-width:420px;background:var(--bg3);border:1.5px solid var(--border2);border-radius:12px;padding:.72rem 1rem;color:var(--t1);font-size:.95rem;font-family:var(--font);outline:none;transition:border-color .15s}
.ti:focus,select:focus,textarea.ti:focus{border-color:var(--ac,var(--accent))}
textarea.ti{resize:vertical;min-height:90px;font-family:var(--mono);font-size:.85rem;max-width:100%}
select{cursor:pointer;max-width:240px}
label.fld{display:block;font-size:.74rem;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.35rem}
.field{margin-bottom:1rem;flex:1;min-width:160px}
.metrics{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;margin:1.5rem 0}
.metric{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:.85rem 1.25rem;text-align:center;min-width:100px;flex:1}
.metric .v{font-size:1.5rem;font-weight:700;font-family:var(--mono);line-height:1}
.metric .l{font-size:.62rem;color:var(--t3);text-transform:uppercase;letter-spacing:.08em;margin-top:.35rem}
.bars{display:flex;flex-direction:column;gap:.6rem;margin-top:1rem}
.bar{display:grid;grid-template-columns:130px 1fr 70px;gap:.6rem;align-items:center;font-size:.82rem}
.bar .track{height:10px;border-radius:99px;background:var(--bg4);overflow:hidden}
.bar .fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--ac,var(--accent)),var(--ac2,var(--accent2)));transition:width .5s ease}
.bar .val{text-align:right;font-family:var(--mono);font-weight:700}
.dots{display:flex;flex-wrap:wrap;gap:.35rem;margin:.75rem 0}
.dot{padding:.18rem .55rem;border-radius:4px;font-size:.72rem;font-weight:700;font-family:var(--mono)}
.dot.good{background:rgba(22,163,74,.12);color:var(--green)}
.dot.ok{background:rgba(217,119,6,.14);color:var(--yellow)}
.dot.bad{background:rgba(220,38,38,.12);color:var(--red)}
table.tbl{width:100%;border-collapse:collapse;font-size:.84rem;margin-top:.5rem}
table.tbl th,table.tbl td{text-align:left;padding:.6rem .7rem;border-bottom:1px solid var(--border)}
table.tbl th{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--t3);cursor:pointer;white-space:nowrap}
table.tbl tr:hover td{background:var(--bg3)}
table.tbl td.num{font-family:var(--mono);text-align:right}
.note{font-size:.78rem;color:var(--t3);line-height:1.6;margin-top:.75rem}
.codeblk{background:var(--bg4);border:1px solid var(--border2);border-radius:12px;padding:1rem;font-family:var(--mono);font-size:.78rem;line-height:1.6;color:var(--t1);white-space:pre-wrap;overflow-x:auto;margin-top:.75rem;position:relative}
.copybtn{position:absolute;top:.6rem;right:.6rem;font-size:.68rem;font-weight:700;padding:.25rem .6rem;border-radius:6px;border:1px solid var(--border2);background:var(--bg2);color:var(--t2);cursor:pointer}
.score-ring{width:140px;height:140px;margin:0 auto;position:relative}
.score-ring .num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:2.2rem;font-weight:800;font-family:var(--mono)}
.kv{display:grid;grid-template-columns:max-content 1fr;gap:.4rem 1rem;font-size:.84rem;margin-top:.5rem}
.kv b{color:var(--t3);font-weight:600}.kv span{font-family:var(--mono);word-break:break-all}
.ad{background:var(--bg2);border:1px dashed var(--border2);border-radius:12px;padding:.75rem;text-align:center;margin:1.5rem 0;min-height:90px;display:flex;align-items:center;justify-content:center;color:var(--t4);font-size:.7rem}
.sep{padding:1.75rem 0;border-top:1px solid var(--border);margin-top:1.5rem}
.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}
.ic{background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:1.25rem}
.ic h3{font-size:.9rem;font-weight:700;margin-bottom:.5rem}
.ic p,.ic li{font-size:.85rem;color:var(--t2);line-height:1.7}.ic ul{padding-left:1.1rem;list-style:disc}
.faq{margin-top:1.75rem}
.faq h2{font-size:1.3rem;font-weight:800;letter-spacing:-.02em;margin-bottom:1rem;text-align:center}
.qa{background:var(--bg2);border:1px solid var(--border);border-radius:14px;margin-bottom:.6rem;overflow:hidden}
.qa summary{padding:.95rem 1.15rem;font-weight:700;font-size:.9rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:1rem}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{content:'+';color:var(--accent);font-weight:800}
.qa[open] summary::after{content:'−'}
.qa p{padding:0 1.15rem 1.05rem;font-size:.85rem;color:var(--t2);line-height:1.7;margin:0}
.related{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:1rem}
.related a{font-size:.8rem;font-weight:600;padding:.4rem .9rem;border-radius:99px;border:1px solid var(--border2);color:var(--t2);text-decoration:none;background:var(--bg2);transition:all .15s}
.related a:hover{color:var(--accent);border-color:var(--accent)}
.drop{border:2px dashed var(--border2);border-radius:16px;padding:2rem;text-align:center;cursor:pointer;transition:all .15s;color:var(--t2)}
.drop:hover,.drop.over{border-color:var(--ac,var(--accent));background:var(--bg3)}
.list{margin-top:1rem;max-height:340px;overflow:auto;border:1px solid var(--border);border-radius:12px}
.list .li{display:flex;justify-content:space-between;gap:1rem;padding:.55rem .9rem;border-bottom:1px solid var(--border);font-size:.82rem}
.list .li:last-child{border-bottom:none}
.list .li .nm{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.list .li .sz{font-family:var(--mono);color:var(--t3);flex-shrink:0}
