/* Tiny Tools — shared styles. Keep it small. */
:root{
  --ink:#161a1d; --muted:#5b6670; --bg:#fbfcfd; --card:#fff; --line:#e6eaee;
  --accent:#0b6e5f; --accent-ink:#fff; --soft:#eef6f4; --warn:#9a5b00; --warn-bg:#fff6e6;
  --mono:ui-monospace,SFMono-Regular,Menlo,Consolas,"Liberation Mono",monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font:16px/1.6 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg)}
.wrap{max-width:760px;margin:0 auto;padding:0 20px}
a{color:var(--accent)}
header.site{padding:20px 0;border-bottom:1px solid var(--line)}
header.site .wrap{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
header.site .logo{font-weight:800;letter-spacing:-.02em;font-size:1.15rem;color:var(--ink);text-decoration:none}
header.site nav a{color:var(--muted);text-decoration:none;font-size:.92rem;margin-left:14px}
header.site nav a:hover{color:var(--accent)}
main{padding:36px 0 8px}
h1{font-size:2rem;line-height:1.18;letter-spacing:-.02em;margin-bottom:10px}
h2{font-size:1.3rem;margin:34px 0 12px;letter-spacing:-.01em}
h3{font-size:1.05rem;margin:22px 0 8px}
p{margin:12px 0}
.lede{font-size:1.12rem;color:var(--muted);margin-bottom:8px}
ul,ol{margin:10px 0 10px 1.3em}
li{margin:6px 0}
code,kbd{font-family:var(--mono);font-size:.92em;background:var(--soft);padding:1px 5px;border-radius:5px}
.tool{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px;margin:18px 0}
label{display:block;font-weight:600;font-size:.92rem;margin:12px 0 5px}
label .hint{font-weight:400;color:var(--muted);font-size:.86rem}
input[type=text],input[type=url],input[type=number],select,textarea{
  width:100%;font:inherit;padding:9px 11px;border:1px solid var(--line);border-radius:9px;background:#fff;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:2px solid var(--soft);border-color:var(--accent)}
textarea{resize:vertical;min-height:84px;font-family:var(--mono);font-size:.92rem}
.row{display:flex;gap:12px;flex-wrap:wrap}
.row>*{flex:1;min-width:140px}
.opts{display:flex;gap:14px 22px;flex-wrap:wrap;margin-top:6px}
.opts label{display:flex;align-items:center;gap:7px;font-weight:400;margin:0}
.opts input[type=checkbox]{width:auto}
button,.btn{font:inherit;font-weight:600;cursor:pointer;border:0;border-radius:9px;padding:10px 16px;background:var(--accent);color:var(--accent-ink)}
button:hover,.btn:hover{filter:brightness(1.08)}
button.ghost{background:var(--soft);color:var(--accent)}
.out{margin-top:14px}
.out .box{font-family:var(--mono);font-size:.95rem;background:var(--soft);border:1px solid var(--line);border-radius:9px;padding:12px 14px;word-break:break-all;white-space:pre-wrap}
.muted{color:var(--muted)}
.warn{background:var(--warn-bg);color:var(--warn);border:1px solid #f0dcb4;border-radius:9px;padding:9px 12px;font-size:.92rem;margin-top:10px}
table{border-collapse:collapse;width:100%;font-size:.92rem;margin:10px 0}
th,td{text-align:left;padding:7px 9px;border-bottom:1px solid var(--line);vertical-align:top}
th{color:var(--muted);font-weight:600}
td.mono,th.mono{font-family:var(--mono)}
.cardgrid{display:grid;grid-template-columns:1fr;gap:14px;margin:18px 0}
@media(min-width:560px){.cardgrid{grid-template-columns:1fr 1fr}}
.cardgrid a{display:block;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px 18px;text-decoration:none;color:var(--ink)}
.cardgrid a:hover{border-color:var(--accent)}
.cardgrid a strong{display:block;font-size:1.05rem;margin-bottom:3px}
.cardgrid a span{color:var(--muted);font-size:.92rem}
.crumb{font-size:.9rem;color:var(--muted);margin-bottom:14px}
.crumb a{text-decoration:none}
hr{border:0;border-top:1px solid var(--line);margin:30px 0}
footer.site{border-top:1px solid var(--line);margin-top:44px;padding:22px 0 56px;color:var(--muted);font-size:.9rem}
footer.site a{color:var(--muted)}
.content{font-size:.98rem}
.content h2{font-size:1.2rem}
details{margin:8px 0;border:1px solid var(--line);border-radius:9px;padding:6px 12px}
summary{cursor:pointer;font-weight:600}

/* Support / Ko-fi callout — end of page */
.support{background:linear-gradient(135deg,#fdf6e3,#fffaf0);border:1px solid var(--line);border-radius:14px;padding:24px 26px;margin:44px 0 8px;text-align:center}
.support h3{font-size:1.1rem;margin:0 0 6px;letter-spacing:-.01em}
.support p{color:var(--muted);font-size:.95rem;margin:0 0 14px;line-height:1.5}
.support .ko{display:inline-block;background:#ff5e5b;color:#fff;font-weight:600;padding:11px 22px;border-radius:9px;text-decoration:none}
.support .ko:hover{filter:brightness(1.08)}
.support .ko::before{content:"☕  "}