/* ── 로그앤코딩 통합 강의 사이트 공용 테마 ────────────────────────── */
:root{
  --bg:#0f1320; --panel:#1a2030; --panel2:#232b40; --ink:#eef2ff; --muted:#9fb0d0;
  --accent:#4dd0e1; --accent2:#ffca28; --good:#66bb6a; --bad:#ef5350; --line:#33405c;
  --purple:#b388ff;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:-apple-system,"Apple SD Gothic Neo","Malgun Gothic",Segoe UI,Roboto,sans-serif;
  line-height:1.75;}
a{color:var(--accent)}

/* 상단 헤더 */
header.top{padding:34px 20px 24px;text-align:center;background:linear-gradient(160deg,#1b2440,#0f1320);
  border-bottom:1px solid var(--line)}
header.top .crumb{font-size:13px;color:var(--muted);margin-bottom:8px}
header.top .crumb a{color:var(--muted);text-decoration:none}
header.top .crumb a:hover{color:var(--accent)}
header.top h1{margin:0;font-size:28px;letter-spacing:-.5px}
header.top p{color:var(--muted);margin:8px 0 0}

/* 사이트 상단 바 (홈으로) */
.sitebar{position:sticky;top:0;z-index:40;background:rgba(15,19,32,.93);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);padding:10px 16px;display:flex;align-items:center;gap:14px}
.sitebar .brand{font-weight:800;letter-spacing:-.3px;color:var(--ink);text-decoration:none;font-size:15px}
.sitebar .brand span{color:var(--accent)}
.sitebar nav{margin-left:auto;display:flex;gap:4px;flex-wrap:wrap}
.sitebar nav a{color:var(--muted);text-decoration:none;font-size:13px;padding:5px 11px;border-radius:8px;border:1px solid transparent}
.sitebar nav a:hover,.sitebar nav a.active{color:var(--ink);background:var(--panel2);border-color:var(--line)}

nav.toc{position:sticky;top:45px;z-index:30;background:rgba(15,19,32,.93);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);padding:9px;display:flex;flex-wrap:wrap;gap:6px;justify-content:center}
nav.toc a{color:var(--muted);text-decoration:none;font-size:13px;padding:5px 10px;border-radius:8px;border:1px solid transparent}
nav.toc a:hover{color:var(--ink);background:var(--panel2);border-color:var(--line)}

main{max-width:900px;margin:0 auto;padding:24px 18px 90px}
section{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:26px 28px;margin:22px 0;
  box-shadow:0 8px 30px rgba(0,0,0,.25)}
h1,h2{letter-spacing:-.3px}
h2{font-size:23px;margin:28px 0 8px;color:var(--accent)}
h3{font-size:18px;color:var(--accent2);margin:24px 0 6px}
h4{font-size:15px;color:var(--purple);margin:18px 0 4px}
p,li{color:#dfe6f7}
.muted{color:var(--muted)}
strong,b{color:#fff}
hr{border:0;border-top:1px solid var(--line);margin:26px 0}

table{width:100%;border-collapse:collapse;margin:14px 0;font-size:14px}
th,td{border:1px solid var(--line);padding:8px 11px;text-align:left;vertical-align:top}
th{background:var(--panel2);color:var(--accent2)}

blockquote{margin:14px 0;background:#10243a;border-left:4px solid var(--accent);
  padding:12px 16px;border-radius:8px;color:#dfe6f7}
blockquote p{margin:6px 0}

code{background:#0b0f1a;padding:2px 6px;border-radius:5px;font-size:13px;color:var(--accent2);
  font-family:ui-monospace,Menlo,Consolas,monospace}
pre{background:#0b0f1a;border:1px solid var(--line);border-radius:10px;padding:14px 16px;overflow:auto;margin:14px 0}
pre code{background:none;padding:0;color:#e6edff;font-size:13px;line-height:1.6}

/* Pygments 코드 하이라이트 (다크) */
.codehilite{background:#0b0f1a;border:1px solid var(--line);border-radius:10px;margin:14px 0}
.codehilite pre{border:0;margin:0;background:none}
.codehilite .k,.codehilite .kd,.codehilite .kn{color:#c792ea}
.codehilite .s,.codehilite .s1,.codehilite .s2{color:#c3e88d}
.codehilite .c,.codehilite .c1,.codehilite .cm{color:#6b7a99;font-style:italic}
.codehilite .n,.codehilite .nn{color:#e6edff}
.codehilite .nf,.codehilite .nb{color:#82aaff}
.codehilite .mi,.codehilite .mf,.codehilite .m{color:#f78c6c}
.codehilite .o,.codehilite .p{color:#89ddff}

ul,ol{padding-left:22px}
li{margin:4px 0}

/* 페이저 */
.pager{display:flex;justify-content:space-between;gap:10px;margin-top:30px}
.pager a{flex:1;text-decoration:none;background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:14px 16px;color:var(--ink)}
.pager a:hover{border-color:var(--accent)}
.pager a.disabled{opacity:.35;pointer-events:none}
.pager .lbl{display:block;font-size:12px;color:var(--muted)}
.pager .r{text-align:right}

/* 카드 */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-top:18px}
.card{background:var(--panel2);border:1px solid var(--line);border-radius:16px;padding:20px;text-decoration:none;color:var(--ink);display:block;position:relative;overflow:hidden}
.card:hover{border-color:var(--accent);transform:translateY(-3px);transition:.15s}
.card .num{font-size:12px;color:var(--accent2);font-weight:700;letter-spacing:.4px}
.card h3{margin:8px 0 8px;color:var(--ink)}
.card p{font-size:14px;color:var(--muted);margin:0;line-height:1.6}
.card .badge{position:absolute;top:14px;right:14px;font-size:11px;padding:3px 9px;border-radius:20px;
  background:#0b0f1a;border:1px solid var(--line);color:var(--muted)}

.note{background:#10243a;border-left:4px solid var(--accent);padding:12px 16px;border-radius:8px;margin:14px 0}
.tip{background:#2a1d10;border-left:4px solid var(--accent2);padding:12px 16px;border-radius:8px;margin:14px 0}
.warn{background:#2a1015;border-left:4px solid var(--bad);padding:12px 16px;border-radius:8px;margin:14px 0}

footer{text-align:center;color:var(--muted);font-size:13px;padding:34px 20px;line-height:1.7;border-top:1px solid var(--line);margin-top:30px}

/* 홈 히어로 */
.hero{padding:60px 20px 30px;text-align:center;background:radial-gradient(1200px 400px at 50% -10%,#1c2748,transparent),linear-gradient(160deg,#161d33,#0f1320)}
.hero h1{font-size:38px;margin:0 0 10px;letter-spacing:-1px}
.hero .accent{color:var(--accent)}
.hero p{color:var(--muted);font-size:17px;max-width:640px;margin:0 auto}
.section-label{font-size:13px;color:var(--accent2);font-weight:700;letter-spacing:1px;text-transform:uppercase;margin:34px 0 4px}
