:root{
  --bg:#fafbfc; --fg:#1a1a1a; --muted:#666;
  --accent:#0b5fff; --accent-d:#0742b8; --accent-l:#eef3ff;
  --card:#fff; --border:#e3e6ea; --code-bg:#1e1e2e;
  --ok:#2e7d32; --warn:#f5b400; --err:#c62828;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);
  font-family:-apple-system,"Segoe UI","Noto Sans KR",sans-serif;
  line-height:1.75;font-size:16px}
.wrap{max-width:980px;margin:0 auto;padding:0 22px}

.site-header{background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;padding-top:14px;padding-bottom:14px}
.site-header h1{font-size:18px;margin:0}
.site-header h1 a{color:var(--fg);text-decoration:none}
.site-header nav a{margin-left:16px;color:var(--muted);text-decoration:none;font-size:14px}
.site-header nav a:hover{color:var(--accent)}
.site-header nav a.active{color:var(--accent);font-weight:600}

main{padding:30px 0 60px}
h1.page-title{font-size:32px;margin:10px 0 4px}
h2{font-size:24px;margin-top:42px;border-bottom:2px solid var(--accent);padding-bottom:6px}
h3{font-size:19px;margin-top:30px;color:var(--accent-d)}
h4{font-size:16px;color:var(--accent-d);margin-top:22px}
a{color:var(--accent)}
p,li{font-size:16px}
.lead{font-size:17px;color:#444}

.hero{background:linear-gradient(135deg,#eef3ff,#fff);padding:32px;border-radius:14px;border:1px solid var(--border);margin-top:20px}
.hero h2{margin-top:0;border:none;font-size:26px}
.hero p{margin:8px 0}

.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin:24px 0}
.card{display:block;padding:20px;background:var(--card);border:1px solid var(--border);border-radius:12px;text-decoration:none;color:var(--fg);transition:.15s}
.card:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:0 6px 20px rgba(11,95,255,.12)}
.card .num{display:inline-block;font-size:12px;font-weight:700;color:var(--accent);background:var(--accent-l);padding:3px 9px;border-radius:20px;margin-bottom:8px}
.card h3{margin:0 0 6px;color:var(--fg);font-size:17px}
.card p{margin:0;color:var(--muted);font-size:14px}

.note,.tip,.warn{padding:14px 18px;border-radius:8px;margin:18px 0;border-left:4px solid}
.note{background:#fff8e1;border-color:var(--warn)}
.tip{background:#e8f5e9;border-color:var(--ok)}
.warn{background:#ffebee;border-color:var(--err)}

figure{margin:24px 0;text-align:center}
figcaption{color:var(--muted);font-size:13.5px;margin-top:8px}
svg,canvas{max-width:100%;height:auto}

pre{background:var(--code-bg);color:#e6e6e6;padding:16px 18px;border-radius:8px;overflow-x:auto;font-size:13.5px;line-height:1.6}
code{font-family:"JetBrains Mono","Consolas",monospace}
:not(pre)>code{background:#eef0f4;padding:2px 6px;border-radius:4px;font-size:0.92em;color:#c7254e}

.demo{background:#fff;border:1px solid var(--border);border-radius:12px;padding:20px;margin:24px 0;box-shadow:0 2px 8px rgba(0,0,0,.03)}
.demo h4{margin-top:0;color:var(--accent-d)}
.demo canvas{display:block;margin:12px auto;background:#fafbfc;border:1px solid var(--border);border-radius:6px}
.controls{display:flex;flex-wrap:wrap;gap:14px;margin-top:14px}
.controls label{font-size:13px;color:#444;display:flex;flex-direction:column;gap:4px;min-width:140px}
.controls input[type=range]{width:160px}
.controls .val{color:var(--accent);font-weight:600;font-family:Consolas,monospace}
.controls button{padding:8px 16px;background:var(--accent);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:13px}
.controls button:hover{background:var(--accent-d)}
.controls button.alt{background:#fff;color:var(--accent);border:1px solid var(--accent)}

.toc{background:#fff;border:1px solid var(--border);border-radius:10px;padding:18px 26px;margin:24px 0}
.toc h4{margin-top:0}
.toc ol{margin:6px 0 0;padding-left:22px}
.toc li{margin:4px 0;font-size:15px}

.prevnext{display:flex;justify-content:space-between;gap:12px;margin-top:60px;padding-top:20px;border-top:1px solid var(--border)}
.prevnext a{flex:1;text-decoration:none;padding:14px 18px;border:1px solid var(--border);border-radius:8px;background:#fff;color:var(--fg);transition:.15s}
.prevnext a:hover{border-color:var(--accent);color:var(--accent)}
.prevnext a small{display:block;color:var(--muted);font-size:12px}
.prevnext a.next{text-align:right}

.site-footer{border-top:1px solid var(--border);background:#fff;padding:24px 0;color:var(--muted);font-size:13px;text-align:center;margin-top:60px}

table{border-collapse:collapse;margin:18px 0;width:100%;font-size:14.5px}
th,td{border:1px solid var(--border);padding:8px 12px;text-align:left}
th{background:var(--accent-l);color:var(--accent-d)}

.katex{font-size:1.05em !important}
.katex-display{margin:18px 0 !important;overflow-x:auto;overflow-y:hidden}
