/* util-websites — shared base styles (dependency-free, mass-production template) */
:root{
  color-scheme: light dark;            /* 폼/스크롤바도 기기 테마 따름 */
  /* 라이트(기본) — OS가 라이트이거나 미지정일 때 */
  --bg:#ffffff; --panel:#f6f7f9; --panel2:#eef1f5; --border:#d9dee6;
  --fg:#1a1f29; --muted:#5b6472; --accent:#2563eb; --accent2:#0f9d6b; --danger:#b42318;
  --max:760px; --radius:14px; --space:clamp(16px,3vw,28px);
  font-synthesis:none;
}
@media (prefers-color-scheme: dark){   /* 기기가 다크면 자동 전환 */
  :root{
    --bg:#0f1115; --panel:#171a21; --panel2:#1e222b; --border:#2a2f3a;
    --fg:#e7eaf0; --muted:#9aa3b2; --accent:#4f8cff; --accent2:#34d399; --danger:#f87171;
  }
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; background:var(--bg); color:var(--fg);
  font:16px/1.6 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:var(--max);margin:0 auto;padding:var(--space)}
header.site{border-bottom:1px solid var(--border)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;padding-block:14px}
.brand{font-weight:700;letter-spacing:.2px}
.brand span{color:var(--accent)}
nav a{color:var(--muted);margin-left:18px;font-size:14px}
h1{font-size:clamp(24px,4vw,34px);line-height:1.2;margin:.2em 0 .3em}
.lede{color:var(--muted);margin:0 0 1.4em}
.intro{margin:0 0 1.6em;max-width:62ch}
.cat{font-size:18px;margin:1.8em 0 .2em;color:var(--fg);border-bottom:1px solid var(--border);padding-bottom:.3em}
.tool{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space)}
textarea{
  width:100%;min-height:220px;resize:vertical;background:var(--panel2);color:var(--fg);
  border:1px solid var(--border);border-radius:10px;padding:14px;font-size:16px;line-height:1.6;
}
textarea:focus{outline:2px solid var(--accent);outline-offset:1px}
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;margin-top:16px}
.stat{background:var(--panel2);border:1px solid var(--border);border-radius:10px;padding:12px 14px}
.stat .n{font-size:26px;font-weight:700;font-variant-numeric:tabular-nums}
.stat .l{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.limits{margin-top:16px;display:grid;gap:8px}
.limit{display:flex;justify-content:space-between;gap:12px;font-size:14px;padding:8px 12px;background:var(--panel2);border:1px solid var(--border);border-radius:8px}
.limit .ok{color:var(--accent2)} .limit .over{color:#f87171}
.toolbar{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
button{
  background:var(--panel2);color:var(--fg);border:1px solid var(--border);
  border-radius:8px;padding:9px 14px;font-size:14px;cursor:pointer
}
button:hover{border-color:var(--accent)}
.content{margin-top:36px}
.content h2{font-size:22px;margin-top:1.6em}
.faq dt{font-weight:600;margin-top:1em}
.faq dd{margin:.2em 0 0;color:var(--muted)}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:8px}
.card{display:block;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:18px}
.card:hover{border-color:var(--accent);text-decoration:none}
.card h3{margin:0 0 6px;font-size:17px;color:var(--fg)}
.card p{margin:0;color:var(--muted);font-size:14px}
.soon{opacity:.55;pointer-events:none}

/* --- shared form/result components (inherited by every tool) --- */
label{font-size:14px}
.field{display:flex;flex-direction:column;gap:6px;margin-top:14px}
.field > label{color:var(--muted)}
input[type=text],input[type=number],select{
  width:100%;background:var(--panel2);color:var(--fg);border:1px solid var(--border);
  border-radius:10px;padding:12px 14px;font-size:16px;font-variant-numeric:tabular-nums;min-height:44px
}
input:focus,select:focus{outline:2px solid var(--accent);outline-offset:1px}
input[type=range]{width:100%;accent-color:var(--accent);min-height:44px}
.options{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:8px;margin-top:14px}
.opt{display:flex;align-items:center;gap:10px;padding:10px 12px;min-height:44px;background:var(--panel2);
  border:1px solid var(--border);border-radius:10px;cursor:pointer;font-size:14px}
.opt:hover{border-color:var(--accent)}
.opt input{width:18px;height:18px;accent-color:var(--accent);min-height:0}
.output{display:flex;align-items:center;gap:10px;background:var(--panel2);border:1px solid var(--border);
  border-radius:10px;padding:14px;margin-top:14px;font-size:18px;font-variant-numeric:tabular-nums;
  word-break:break-all;min-height:56px}
.output code{font:16px/1.5 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;flex:1}
.outgrid{display:grid;gap:10px;margin-top:16px}
.outrow{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;background:var(--panel2);
  border:1px solid var(--border);border-radius:10px;padding:12px 14px}
.outrow .label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.outrow .val{font-size:15px;word-break:break-word}
.outrow .val:empty::after{content:"—";color:var(--muted)}
.result{margin-top:16px;background:var(--panel2);border:1px solid var(--border);border-radius:12px;padding:18px;text-align:center}
.result .n{font-size:34px;font-weight:700;font-variant-numeric:tabular-nums}
.result .l{font-size:13px;color:var(--muted);margin-top:4px}
.meter{height:8px;border-radius:6px;background:var(--panel2);border:1px solid var(--border);overflow:hidden;margin-top:14px}
.meter > i{display:block;height:100%;width:0;background:var(--accent2);transition:width .15s,background .15s}
.meter-label{display:flex;justify-content:space-between;font-size:13px;color:var(--muted);margin-top:8px}
.meter-label b{color:var(--fg);font-variant-numeric:tabular-nums}
.modes{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:4px}
.modes button[aria-pressed=true]{border-color:var(--accent);color:var(--accent)}
.copybtn{flex:none}
.error{color:var(--danger);font-size:14px;margin-top:14px}
.error[hidden]{display:none}

/* multi-line code output (JWT, formatted data) — theme-aware */
pre.code{margin-top:14px;background:var(--panel2);border:1px solid var(--border);border-radius:10px;
  padding:14px;overflow:auto;font:13px/1.5 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  white-space:pre-wrap;word-break:break-word;color:var(--fg);min-height:48px}
.note{font-size:13px;color:var(--muted);margin-top:10px}
/* line-by-line diff — colors derive from theme vars so AA holds in light & dark */
.diff{margin-top:16px;border:1px solid var(--border);border-radius:10px;overflow:auto;
  font:14px/1.6 ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}
.diff > div{padding:3px 12px;white-space:pre-wrap;word-break:break-word}
.diff .add{background:color-mix(in srgb,var(--accent2) 16%,transparent)}
.diff .del{background:color-mix(in srgb,var(--danger) 16%,transparent)}
.diff .add::before{content:"+ ";color:var(--accent2)}
.diff .del::before{content:"\2212 ";color:var(--danger)}
.diff .eq{color:var(--muted)}
.diff .eq::before{content:"\00a0\00a0"}

footer.site{border-top:1px solid var(--border);margin-top:48px;color:var(--muted);font-size:13px}
footer.site .wrap{padding-block:22px}
