@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&family=Noto+Sans+KR:wght@400;500;700&display=swap";*{box-sizing:border-box}html,body{margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Inter,Noto Sans KR,-apple-system,BlinkMacSystemFont,sans-serif;font-size:15px;line-height:1.7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background .25s ease,color .25s ease}#root{width:100%;min-height:100vh}:root[data-theme=dark]{--bg: #0a0e1a;--bg-1: #0f1423;--bg-2: #151b2e;--bg-3: #1c2339;--border: #1f2742;--border-strong: #2d365a;--text: #e8ecf4;--text-muted: #9aa5bd;--text-faint: #5f6a85;--primary: #67d9e4;--primary-soft: rgba(103, 217, 228, .1);--primary-strong: #8ee6ee;--secondary: #b8a7f2;--accent: #f4c578;--success: #8cdc97;--danger: #f38280;--code-kw: #c4b5fd;--code-reg: #86efac;--code-num: #fdba74;--code-str: #7dd3fc;--code-cmt: #5f6a85;--shadow: 0 4px 20px rgba(0,0,0,.3);--shadow-sm: 0 1px 3px rgba(0,0,0,.2)}:root[data-theme=mocha]{--bg: #1e1e2e;--bg-1: #181825;--bg-2: #313244;--bg-3: #45475a;--border: #313244;--border-strong: #45475a;--text: #cdd6f4;--text-muted: #a6adc8;--text-faint: #6c7086;--primary: #89dceb;--primary-soft: rgba(137, 220, 235, .12);--primary-strong: #b4befe;--secondary: #cba6f7;--accent: #f9e2af;--success: #a6e3a1;--danger: #f38ba8;--code-kw: #cba6f7;--code-reg: #f5c2e7;--code-num: #fab387;--code-str: #a6e3a1;--code-cmt: #6c7086;--shadow: 0 4px 20px rgba(17, 17, 27, .4);--shadow-sm: 0 1px 3px rgba(17, 17, 27, .25)}:root[data-theme=gruvbox]{--bg: #282828;--bg-1: #1d2021;--bg-2: #3c3836;--bg-3: #504945;--border: #3c3836;--border-strong: #504945;--text: #ebdbb2;--text-muted: #bdae93;--text-faint: #928374;--primary: #8ec07c;--primary-soft: rgba(142, 192, 124, .12);--primary-strong: #b8bb26;--secondary: #d3869b;--accent: #fabd2f;--success: #b8bb26;--danger: #fb4934;--code-kw: #fb4934;--code-reg: #b8bb26;--code-num: #d3869b;--code-str: #b8bb26;--code-cmt: #928374;--shadow: 0 4px 20px rgba(0, 0, 0, .5);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--dot-color: rgba(168, 153, 132, .1)}:root[data-theme=light]{--bg: #fafbfc;--bg-1: #ffffff;--bg-2: #f3f5f9;--bg-3: #eaeef4;--border: #e1e6ef;--border-strong: #c9d1df;--text: #1a1f36;--text-muted: #5c6579;--text-faint: #8b94a8;--primary: #0891a8;--primary-soft: rgba(8, 145, 168, .08);--primary-strong: #067389;--secondary: #6d51c4;--accent: #c27913;--success: #16803c;--danger: #c12828;--code-kw: #7c3aed;--code-reg: #15803d;--code-num: #c2410c;--code-str: #0369a1;--code-cmt: #94a3b8;--shadow: 0 4px 20px rgba(0,0,0,.06);--shadow-sm: 0 1px 3px rgba(0,0,0,.04)}body{background-color:var(--bg);background-image:radial-gradient(var(--dot-color, transparent) 1px,transparent 1px);background-size:22px 22px;background-position:0 0;color:var(--text)}::selection{background:var(--primary-soft)}.app{display:grid;grid-template-columns:280px 1fr;min-height:100vh}.sidebar{background:var(--bg-1);border-right:1px solid var(--border);padding:28px 0 40px;position:sticky;top:0;height:100vh;overflow-y:auto;display:flex;flex-direction:column}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.brand{padding:0 28px 24px;border-bottom:1px solid var(--border);margin-bottom:16px}.brand .logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:17px;letter-spacing:-.01em;color:var(--text)}.brand .logo-mark{width:28px;height:28px;border-radius:7px;background:linear-gradient(135deg,var(--primary),var(--secondary));display:flex;align-items:center;justify-content:center;color:#0a0e1a;font-weight:800;font-size:13px;box-shadow:var(--shadow-sm)}.brand .sub{font-size:12px;color:var(--text-faint);margin-top:6px;letter-spacing:.02em}.nav-group{padding:4px 12px;flex:1}.nav-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-faint);padding:14px 16px 8px;font-weight:600}.nav-item{display:flex;align-items:center;gap:12px;padding:9px 14px;border-radius:7px;color:var(--text-muted);cursor:pointer;font-size:13.5px;-webkit-user-select:none;user-select:none;transition:all .15s ease;margin-bottom:2px}.nav-item:hover{background:var(--bg-2);color:var(--text)}.nav-item.active{background:var(--primary-soft);color:var(--primary);font-weight:600}.nav-item .num{font-size:11px;font-family:JetBrains Mono,monospace;width:22px;color:var(--text-faint);text-align:center}.nav-item.active .num{color:var(--primary)}.nav-item .titles{display:flex;flex-direction:column;line-height:1.3}.nav-item .titles .en{font-size:11px;color:var(--text-faint);font-weight:400}.nav-item.active .titles .en{color:var(--primary-strong);opacity:.75}.sidebar-footer{padding:16px 28px 0;border-top:1px solid var(--border);margin:16px 16px 0;display:flex;justify-content:space-between;align-items:center}.theme-toggle{background:var(--bg-2);border:1px solid var(--border);color:var(--text-muted);width:36px;height:36px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.theme-toggle:hover{border-color:var(--primary);color:var(--primary)}.main{padding:0;max-width:100%;overflow-x:hidden}.hero{padding:56px 64px 28px;border-bottom:1px solid var(--border);background:linear-gradient(to bottom,var(--bg-1) 0%,var(--bg) 100%)}.breadcrumb{font-size:12px;color:var(--text-faint);letter-spacing:.05em;text-transform:uppercase;font-weight:600;margin-bottom:10px;display:flex;align-items:center;gap:8px}.breadcrumb .sep{color:var(--border-strong)}.breadcrumb .cur{color:var(--primary)}.hero h1{font-size:36px;font-weight:800;letter-spacing:-.025em;margin:0 0 8px;color:var(--text);line-height:1.15}.hero h1 .en{font-size:16px;font-weight:500;color:var(--text-faint);letter-spacing:0;margin-left:12px}.hero .tagline{font-size:16px;color:var(--text-muted);max-width:720px;line-height:1.65}.section-body{padding:36px 64px 80px;max-width:960px}h2{font-size:22px;font-weight:700;letter-spacing:-.015em;margin:44px 0 14px;color:var(--text);display:flex;align-items:baseline;gap:10px;position:relative;padding-left:14px}h2:before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;background:linear-gradient(180deg,var(--primary),var(--primary-strong));border-radius:2px}h2:first-child{margin-top:0}h2 .en{font-size:12px;font-weight:500;color:var(--text-faint);letter-spacing:.02em}h3{font-size:16px;font-weight:600;margin:28px 0 10px;color:var(--primary);letter-spacing:-.01em}h3 .en{font-size:12px;color:var(--text-faint);font-weight:400;margin-left:6px}p{margin:8px 0;color:var(--text)}ul,ol{padding-left:22px}ul li,ol li{margin:5px 0;color:var(--text)}b,strong{font-weight:600;color:var(--text)}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}code{font-family:JetBrains Mono,ui-monospace,monospace;font-size:12.5px;background:var(--bg-2);padding:2px 7px;border-radius:4px;color:var(--code-num);border:1px solid var(--border);font-weight:500}pre{background:var(--bg-1);padding:18px 20px;border-radius:10px;border:1px solid var(--border);overflow-x:auto;font-size:12.5px;line-height:1.65;margin:14px 0;box-shadow:var(--shadow-sm)}pre code{background:none;padding:0;border:none;color:var(--text);font-family:JetBrains Mono,Menlo,DejaVu Sans Mono,Consolas,ui-monospace,monospace;font-weight:400;font-variant-ligatures:none;font-feature-settings:"liga" 0,"calt" 0;letter-spacing:0;text-rendering:geometricPrecision}pre::-webkit-scrollbar{height:6px}pre::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.kw{color:var(--code-kw);font-weight:600}.reg{color:var(--code-reg);font-weight:500}.cmt{color:var(--code-cmt);font-style:italic}.num{color:var(--code-num)}.table-wrap{border:1px solid var(--border);border-radius:10px;overflow:hidden;margin:16px 0;box-shadow:var(--shadow-sm)}table{border-collapse:collapse;width:100%;font-size:13.5px}th,td{text-align:left;padding:11px 18px;border-bottom:1px solid var(--border)}th{background:var(--bg-2);color:var(--text);font-weight:600;font-size:12.5px;letter-spacing:.02em}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--bg-2)}td code{font-size:12px}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:14px 0}.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:14px 0}@media (max-width: 900px){.grid2,.grid3{grid-template-columns:1fr}}.card{background:var(--bg-1);border:1px solid var(--border);border-radius:10px;padding:18px 20px;transition:border-color .15s ease,transform .15s ease,box-shadow .15s ease}.card:hover{border-color:var(--border-strong);transform:translateY(-1px);box-shadow:0 4px 14px #0000002e}.card h4{margin:0 0 8px;color:var(--primary);font-size:14px;font-weight:600;letter-spacing:-.01em}.card p{margin:6px 0 10px;color:var(--text-muted);font-size:13.5px}.card .tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.tag{display:inline-flex;align-items:center;font-size:11px;padding:3px 9px;border-radius:12px;background:var(--bg-2);color:var(--text-muted);border:1px solid var(--border);font-weight:500;font-family:JetBrains Mono,monospace;letter-spacing:.01em}.tag.info{background:var(--primary-soft);color:var(--primary);border-color:transparent}.tag.new{background:#8cdc971f;color:var(--success);border-color:transparent}.tag.hot{background:#f382801f;color:var(--danger);border-color:transparent}.tag.warn{background:#f4c5781f;color:var(--accent);border-color:transparent}.callout{position:relative;padding:18px 20px 16px 22px;background:var(--primary-soft);border:1px solid var(--border);border-left:3px solid var(--primary);border-radius:8px;margin:22px 0 18px;font-size:13.5px;line-height:1.65;color:var(--text);box-shadow:var(--shadow-sm)}.callout>.icon{display:none}.callout:before{content:"NOTE";position:absolute;top:-9px;left:14px;font-size:10px;font-weight:700;letter-spacing:.14em;color:var(--primary);background:var(--bg);border:1px solid var(--border-strong);padding:2px 9px;border-radius:999px;font-family:JetBrains Mono,monospace;text-transform:uppercase}.callout.warn{background:#fabd2f14;border-left-color:var(--accent);border-color:#fabd2f38}.callout.warn:before{content:"WARNING";color:var(--accent);border-color:#fabd2f66}.callout.danger{background:#fb493414;border-left-color:var(--danger);border-color:#fb493438}.callout.danger:before{content:"CAUTION";color:var(--danger);border-color:#fb493466}.diagram{background:var(--bg-1);border:1px solid var(--border);padding:20px 24px;border-radius:10px;margin:16px 0;font-family:JetBrains Mono,Menlo,DejaVu Sans Mono,Consolas,ui-monospace,monospace;font-size:12px;line-height:1.5;white-space:pre;overflow-x:auto;color:var(--text);box-shadow:var(--shadow-sm);font-variant-ligatures:none;font-feature-settings:"liga" 0,"calt" 0;letter-spacing:0;text-rendering:geometricPrecision;-moz-tab-size:4;tab-size:4}.el-stack{display:flex;flex-direction:column;gap:8px;margin:16px 0}.el-row{display:grid;grid-template-columns:90px 1fr auto;padding:16px 22px;background:var(--bg-1);border:1px solid var(--border);border-radius:10px;align-items:center;gap:16px;position:relative;overflow:hidden;transition:all .15s ease}.el-row:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px}.el-row.el3:before{background:var(--danger)}.el-row.el2:before{background:var(--accent)}.el-row.el1:before{background:var(--primary)}.el-row.el0:before{background:var(--success)}.el-row:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.el-row .lvl{font-weight:800;font-size:18px;color:var(--text);letter-spacing:-.02em;font-family:JetBrains Mono,monospace}.el-row .desc{color:var(--text);font-weight:500;font-size:14px}.el-row .desc .sub{display:block;color:var(--text-muted);font-size:12.5px;font-weight:400;margin-top:2px}.el-row .note{color:var(--text-faint);font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:600}.bus-diagram{display:flex;gap:10px;margin:14px 0;flex-wrap:wrap}.bus-ch{background:var(--bg-1);border:1px solid var(--border);padding:12px 18px;border-radius:10px;min-width:130px;box-shadow:var(--shadow-sm);transition:all .15s ease}.bus-ch:hover{border-color:var(--primary);transform:translateY(-1px)}.bus-ch .name{color:var(--primary);font-weight:700;font-family:JetBrains Mono,monospace;font-size:14px;margin-bottom:3px}.bus-ch .dir{color:var(--text-muted);font-size:11.5px}.quiz-progress{background:var(--bg-1);border:1px solid var(--border);border-radius:12px;padding:20px 24px;margin:16px 0 24px;display:flex;align-items:center;gap:20px;box-shadow:var(--shadow-sm)}.quiz-progress .stats{display:flex;gap:24px;flex:1}.quiz-progress .stat{display:flex;flex-direction:column;gap:2px}.quiz-progress .stat .label{font-size:11px;text-transform:uppercase;color:var(--text-faint);letter-spacing:.08em;font-weight:600}.quiz-progress .stat .value{font-size:22px;font-weight:700;color:var(--text);font-family:JetBrains Mono,monospace}.quiz-progress .stat.correct .value{color:var(--success)}.quiz-progress .stat.score .value{color:var(--primary)}.progress-bar-wrap{flex:1;height:6px;background:var(--bg-3);border-radius:3px;overflow:hidden;max-width:220px}.progress-bar{height:100%;background:linear-gradient(90deg,var(--primary),var(--secondary));transition:width .3s ease}.quiz-q{background:var(--bg-1);border:1px solid var(--border);padding:22px 26px;border-radius:12px;margin:14px 0;box-shadow:var(--shadow-sm)}.quiz-q .q-header{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px}.quiz-q .q-num{background:var(--primary-soft);color:var(--primary);font-weight:700;font-size:11px;padding:4px 10px;border-radius:6px;font-family:JetBrains Mono,monospace;letter-spacing:.05em;flex-shrink:0;margin-top:2px}.quiz-q .q-text{font-weight:600;font-size:15px;color:var(--text);line-height:1.55}.quiz-opt{display:flex;align-items:center;gap:12px;padding:11px 16px;margin:6px 0;background:var(--bg-2);border:1px solid var(--border);border-radius:8px;cursor:pointer;font-size:13.5px;transition:all .15s ease;color:var(--text)}.quiz-opt:hover{border-color:var(--primary);background:var(--primary-soft)}.quiz-opt .letter{width:26px;height:26px;border-radius:6px;background:var(--bg-3);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;color:var(--text-muted);font-family:JetBrains Mono,monospace;flex-shrink:0}.quiz-opt.correct{background:#8cdc971a;border-color:var(--success);color:var(--success)}.quiz-opt.correct .letter{background:var(--success);color:var(--bg)}.quiz-opt.wrong{background:#f382801a;border-color:var(--danger);color:var(--danger)}.quiz-opt.wrong .letter{background:var(--danger);color:var(--bg)}.quiz-opt.disabled{cursor:default}.quiz-opt.disabled:hover{background:var(--bg-2)}.quiz-opt.correct.disabled:hover{background:#8cdc971a}.quiz-opt.wrong.disabled:hover{background:#f382801a}.quiz-explain{margin-top:14px;padding:12px 16px;background:var(--bg-2);border-left:3px solid var(--primary);border-radius:0 8px 8px 0;font-size:13px;color:var(--text-muted);line-height:1.65}.quiz-explain b{color:var(--text)}.btn{background:var(--primary);color:#0a0e1a;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;font-family:inherit;transition:all .15s ease;letter-spacing:.01em}.btn:hover{background:var(--primary-strong);transform:translateY(-1px)}.btn.ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.btn.ghost:hover{border-color:var(--primary);color:var(--primary)}.page-nav{display:flex;gap:12px;margin-top:48px;padding-top:24px;border-top:1px solid var(--border)}.page-nav .btn-nav{flex:1;padding:16px 20px;background:var(--bg-1);border:1px solid var(--border);border-radius:10px;cursor:pointer;text-align:left;transition:all .15s ease;display:flex;flex-direction:column;gap:4px;font-family:inherit}.page-nav .btn-nav:hover{border-color:var(--primary);background:var(--primary-soft)}.page-nav .btn-nav .label{font-size:11px;text-transform:uppercase;color:var(--text-faint);letter-spacing:.08em;font-weight:600}.page-nav .btn-nav .title{color:var(--text);font-weight:600;font-size:14px}.page-nav .btn-nav.next{text-align:right}.page-nav .btn-nav.disabled{opacity:.4;cursor:default;pointer-events:none}footer{padding:20px 28px;color:var(--text-faint);font-size:12px;line-height:1.7;border-top:1px solid var(--border);margin-top:24px}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease}.nav-toggle{display:none;position:fixed;top:14px;left:14px;z-index:50;width:42px;height:42px;background:var(--bg-1);border:1px solid var(--border);border-radius:8px;cursor:pointer;padding:0;flex-direction:column;align-items:center;justify-content:center;gap:4px;box-shadow:var(--shadow-sm)}.nav-toggle .bar{display:block;width:18px;height:2px;background:var(--text);border-radius:1px;transition:transform .2s ease,opacity .2s ease}.app.nav-open .nav-toggle .bar:nth-child(1){transform:translateY(6px) rotate(45deg)}.app.nav-open .nav-toggle .bar:nth-child(2){opacity:0}.app.nav-open .nav-toggle .bar:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.nav-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;background:#0006;opacity:0;transition:opacity .2s ease;pointer-events:none}@media (max-width: 900px){.app{grid-template-columns:1fr}.nav-toggle{display:flex}.sidebar{position:fixed;top:0;left:0;bottom:0;width:280px;max-width:85vw;z-index:40;transform:translate(-100%);transition:transform .25s ease;box-shadow:4px 0 24px #00000026;height:100vh}.app.nav-open .sidebar{transform:translate(0)}.app.nav-open .nav-backdrop{display:block;opacity:1;pointer-events:auto}.hero{padding:64px 20px 20px}.hero h1{font-size:26px;flex-wrap:wrap}.hero h1 .en{font-size:14px}.breadcrumb{font-size:11px;flex-wrap:wrap}.section-body{padding:24px 20px 40px}.section-body h2{font-size:20px}.section-body h3{font-size:16px}.section-body h4{font-size:14px}.section-body p,.section-body li{font-size:14px;line-height:1.65}.section-body pre{font-size:11.5px;padding:12px;overflow-x:auto}.section-body table{font-size:12.5px}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.diagram{font-size:10.5px;padding:12px;overflow-x:auto}.grid2,.grid3{grid-template-columns:1fr;gap:10px}.card{padding:14px}.callout{padding:12px 14px;gap:10px}.page-nav{grid-template-columns:1fr;gap:10px}footer{padding:20px;font-size:12px}}@media (max-width: 480px){.hero{padding:60px 16px 16px}.hero h1{font-size:22px}.section-body{padding:20px 16px 32px}.section-body pre{font-size:11px}.section-body table{font-size:12px}}
