/* ===== shared styles for utility tool pages ===== */
.toolwrap{margin-top:24px;display:grid;grid-template-columns:1fr 300px;gap:20px}
@media(max-width:820px){.toolwrap{grid-template-columns:1fr}}
.tdrop{position:relative;border:2px dashed var(--line);border-radius:22px;background:var(--card,rgba(22,24,35,.6));padding:50px 22px;text-align:center;cursor:pointer;transition:.25s}
.tdrop:hover,.tdrop.drag{border-color:var(--accent);transform:translateY(-2px)}
.tdrop .ic{width:64px;height:64px;margin:0 auto 14px;border-radius:18px;background:linear-gradient(135deg,var(--accent),var(--accent2));display:grid;place-items:center;box-shadow:0 12px 40px var(--glow)}
.tdrop h3{font-size:19px;margin-bottom:6px}
.tdrop span{color:var(--dim);font-size:14px}
.tstage{background:var(--stage,#0f111a);border:1px solid var(--line);border-radius:18px;padding:14px;min-height:320px;display:grid;place-items:center;position:relative;overflow:hidden}
.tstage img,.tstage canvas{max-width:100%;max-height:480px;border-radius:10px;display:block}
.checker{background-image:linear-gradient(45deg,#2a2d3a 25%,transparent 25%),linear-gradient(-45deg,#2a2d3a 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#2a2d3a 75%),linear-gradient(-45deg,transparent 75%,#2a2d3a 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0}
.tpanel{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:20px;display:flex;flex-direction:column;gap:15px;height:fit-content}
.tfield{display:flex;flex-direction:column;gap:7px}
.tfield label{font-size:11px;font-weight:700;color:var(--dim);text-transform:uppercase;letter-spacing:1.2px}
.trow{display:flex;gap:8px;flex-wrap:wrap}
.tseg{flex:1;min-width:60px;padding:9px 0;border-radius:10px;border:1px solid var(--line);background:transparent;color:var(--text);font-weight:700;font-size:13px;cursor:pointer;font-family:inherit;transition:.15s}
.tseg.sel{background:var(--accent);border-color:var(--accent);color:#fff}
.trange{display:flex;align-items:center;gap:10px}
.trange input[type=range]{flex:1;accent-color:var(--accent)}
.trange b{font-size:13px;min-width:44px;text-align:right}
.tinput{background:var(--stage,#0f111a);border:1px solid var(--line);border-radius:9px;padding:9px 11px;color:var(--text);font-family:inherit;font-size:14px;width:100%}
.tbtn{display:flex;align-items:center;justify-content:center;gap:8px;padding:13px 0;border-radius:12px;border:none;cursor:pointer;font-weight:700;font-size:15px;font-family:inherit;text-decoration:none;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;transition:.2s}
.tbtn:hover{transform:translateY(-2px);box-shadow:0 10px 30px var(--glow)}
.tbtn.ghost{background:transparent;border:1px solid var(--line);color:var(--dim)}
.tbtn.ghost:hover{color:var(--text);transform:none;box-shadow:none}
.tinfo{font-size:12px;color:var(--dim);display:flex;flex-direction:column;gap:4px}
.tinfo b{color:var(--text)}
.tloading{position:absolute;inset:0;display:none;flex-direction:column;align-items:center;justify-content:center;background:rgba(11,12,16,.8);color:var(--accent);gap:12px;z-index:5}
[data-theme=light] .tloading{background:rgba(244,241,236,.85)}
.tloading.on{display:flex}
.tspin{width:42px;height:42px;border:4px solid rgba(255,94,58,.2);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.terr{display:none;align-items:center;gap:8px;color:#ff6b6b;font-size:13px;background:rgba(255,107,107,.1);padding:10px 12px;border-radius:10px}
.terr.on{display:flex}
.toolnav{display:flex;gap:8px;flex-wrap:wrap;margin-top:20px}
.toolnav a{font-size:13px;color:var(--dim);text-decoration:none;padding:7px 13px;border:1px solid var(--line);border-radius:99px;transition:.15s}
.toolnav a:hover,.toolnav a.active{color:var(--text);border-color:var(--accent)}
/* crop overlay */
.cropbox{position:absolute;border:2px solid var(--accent);box-shadow:0 0 0 9999px rgba(0,0,0,.5);cursor:move}
.crophandle{position:absolute;width:14px;height:14px;background:var(--accent);border-radius:3px}

/* ===== progress bar + percent (added) ===== */
.tprog{width:100%;max-width:240px;height:6px;background:rgba(255,255,255,.12);border-radius:99px;overflow:hidden;margin-top:6px}
.tprog>i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:99px;transition:width .25s ease}
.tpct{font-family:'Space Mono',monospace;font-size:13px;color:var(--accent2);margin-top:2px}
.tloading .tsub{font-size:12px;color:var(--dim)}

/* ===== toolnav hover tooltip ===== */
.toolnav a{position:relative}
.toolnav a[data-tip]::after{content:attr(data-tip);position:absolute;left:50%;top:calc(100% + 8px);transform:translateX(-50%) translateY(4px);
  background:var(--panel,#161823);color:var(--text,#eef0f7);border:1px solid var(--line,#272a38);border-radius:9px;
  padding:7px 11px;font-size:12px;font-weight:500;white-space:nowrap;opacity:0;pointer-events:none;transition:.18s;z-index:60;
  box-shadow:0 8px 24px rgba(0,0,0,.35)}
.toolnav a[data-tip]:hover::after{opacity:1;transform:translateX(-50%) translateY(0)}
@media(max-width:640px){.toolnav a[data-tip]::after{display:none}}
