:root{--h-primary: 200;--h-accent: 36;--h-success: 160;--h-danger: 354;--h-neutral: 218;--n-50: #f8fafc;--n-100: #f1f5f9;--n-200: #e2e8f0;--n-300: #cbd5e1;--n-400: #94a3b8;--n-500: #64748b;--n-600: #475569;--n-700: #334155;--n-800: #1e293b;--n-900: #0f172a;--p-50: #f0f9ff;--p-100: #e0f2fe;--p-200: #bae6fd;--p-300: #7dd3fc;--p-400: #38bdf8;--p-500: #0ea5e9;--p-600: #0284c7;--p-700: #0369a1;--p-800: #075985;--p-900: #0c4a6e;--a-100: #fef3c7;--a-300: #fcd34d;--a-500: #f59e0b;--a-600: #d97706;--a-700: #b45309;--s-100: #d1fae5;--s-600: #059669;--s-700: #047857;--w-100: #fef3c7;--w-600: #d97706;--w-700: #b45309;--d-100: #fee2e2;--d-500: #ef4444;--d-600: #dc2626;--d-700: #b91c1c;--bg: var(--n-50);--surface: #fff;--surface-2: var(--n-100);--border: var(--n-200);--border-strong: var(--n-300);--text: var(--n-900);--text-soft: var(--n-700);--text-muted: var(--n-500);--text-on-primary: #fff;--hero-grad: linear-gradient(135deg, var(--p-50) 0%, var(--a-100) 100%);--shadow-1: 0 1px 2px rgba(15, 23, 42, .04);--shadow-2: 0 1px 3px rgba(15, 23, 42, .06), 0 1px 2px rgba(15, 23, 42, .04);--shadow-3: 0 8px 24px rgba(15, 23, 42, .08), 0 2px 6px rgba(15, 23, 42, .04);--shadow-4: 0 24px 50px rgba(15, 23, 42, .16), 0 6px 12px rgba(15, 23, 42, .06);--shadow-focus: 0 0 0 3px rgba(14, 165, 233, .3);--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 20px;--r-2xl: 28px;--r-full: 999px;--header-h: 64px;--content-max: 1200px;--touch: 44px}*{box-sizing:border-box}html,body,#root{margin:0;padding:0}html{scroll-padding-top:calc(var(--header-h) + 12px)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Hiragino Kaku Gothic ProN,Noto Sans JP,Yu Gothic UI,sans-serif;color:var(--text);background:var(--bg);font-size:15px;line-height:1.7;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}body.lock-scroll{overflow:hidden}a{color:var(--p-700);text-decoration:none}a:hover{color:var(--p-800);text-decoration:underline;text-underline-offset:2px}button{font:inherit}::selection{background:#0ea5e959}:focus-visible{outline:none;box-shadow:var(--shadow-focus);border-radius:var(--r-sm)}.container{max-width:var(--content-max);margin:0 auto;padding:28px 20px}.site-header{position:sticky;top:0;z-index:50;height:var(--header-h);background:#ffffffd9;-webkit-backdrop-filter:saturate(180%) blur(8px);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--border);color:var(--text)}.site-header a{color:var(--text);text-decoration:none}.site-header a:hover{color:var(--p-700);text-decoration:none}.site-header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);padding-top:0;padding-bottom:0;gap:16px}.brand{font-size:22px;font-weight:800;letter-spacing:-.3px;display:inline-flex;align-items:center;gap:10px;color:var(--text)}.brand:before{content:"";width:12px;height:12px;border-radius:var(--r-full);background:var(--p-500);box-shadow:0 0 0 4px #0ea5e92e}.nav{display:flex;gap:4px;align-items:center}.nav-desktop a,.nav-desktop>button:not(.user-trigger){padding:8px 14px;border-radius:var(--r-md);font-size:14px;font-weight:500;color:var(--text-soft);background:transparent;border:1px solid transparent;transition:background .15s,color .15s;display:inline-flex;align-items:center;gap:6px;min-height:38px;cursor:pointer;text-decoration:none}.nav-desktop a:hover{background:var(--n-100);color:var(--text);text-decoration:none}.nav-desktop a.active{background:var(--p-50);color:var(--p-700);font-weight:600}.nav-desktop .btn-primary{background:var(--p-600);color:#fff;border-color:transparent;font-weight:600;box-shadow:var(--shadow-1)}.nav-desktop .btn-primary:hover{background:var(--p-700);color:#fff}.nav-desktop .btn-outline{background:transparent;color:var(--p-700);border:1px solid var(--p-200)}.nav-desktop .btn-outline:hover{background:var(--p-50);color:var(--p-800)}.hamburger{display:none;background:transparent;border:1px solid var(--border);color:var(--text);border-radius:var(--r-md);width:var(--touch);height:var(--touch);align-items:center;justify-content:center;cursor:pointer}.hamburger:hover{background:var(--n-100)}.mobile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:70;animation:fadeIn .18s ease-out}.mobile-drawer{position:fixed;top:0;right:0;bottom:0;width:min(320px,86vw);background:var(--surface);z-index:80;padding:20px;box-shadow:var(--shadow-4);transform:translate(100%);transition:transform .22s ease-out;overflow-y:auto;display:none}.mobile-drawer.open{transform:translate(0);display:flex;flex-direction:column;gap:18px}.drawer-user{display:flex;align-items:center;gap:12px;padding:14px;background:var(--p-50);border-radius:var(--r-md)}.drawer-user.guest{flex-direction:column;align-items:flex-start;gap:4px;padding:18px}.drawer-user.guest .brand{font-size:22px}.drawer-user-name{font-weight:700;font-size:15px;color:var(--text)}.drawer-user-email{color:var(--text-muted);font-size:12px;overflow:hidden;text-overflow:ellipsis;max-width:200px}.drawer-nav{display:flex;flex-direction:column;gap:4px}.drawer-nav a,.drawer-nav button{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--r-md);font-size:15px;color:var(--text);text-decoration:none;background:transparent;border:0;cursor:pointer;min-height:var(--touch);text-align:left;font-weight:500}.drawer-nav a:hover,.drawer-nav button:hover{background:var(--n-100);color:var(--text);text-decoration:none}.drawer-nav a.active{background:var(--p-50);color:var(--p-700);font-weight:700}.drawer-nav .drawer-cta{background:var(--p-600);color:#fff;justify-content:center;font-weight:700;margin-top:8px}.drawer-nav .drawer-cta:hover{background:var(--p-700);color:#fff}.drawer-link.danger{color:var(--d-700);margin-top:8px;border-top:1px solid var(--border);padding-top:16px}.drawer-link.danger:hover{background:var(--d-100);color:var(--d-700)}.user-menu{position:relative}.user-trigger{display:inline-flex;align-items:center;gap:8px;padding:4px 12px 4px 4px;border-radius:var(--r-full);background:var(--n-100);border:1px solid var(--border);color:var(--text);cursor:pointer;font-size:13px;min-height:38px;transition:background .15s}.user-trigger:hover{background:var(--n-200)}.avatar{width:30px;height:30px;border-radius:var(--r-full);background:var(--p-600);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}.avatar.lg{width:44px;height:44px;font-size:18px}.user-name{font-weight:600;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-dropdown{position:absolute;right:0;top:calc(100% + 8px);min-width:220px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-3);padding:6px;z-index:60;animation:fadeIn .12s ease-out}.user-info{padding:10px 12px 8px;border-bottom:1px solid var(--border);margin-bottom:4px}.user-email{font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis}.menu-item{display:flex;align-items:center;gap:8px;width:100%;text-align:left;background:transparent;border:0;padding:10px 12px;border-radius:var(--r-sm);color:var(--text);font-size:14px;cursor:pointer;text-decoration:none}.menu-item:hover{background:var(--n-100);color:var(--text);text-decoration:none}.menu-item.danger{color:var(--d-700)}.menu-item.danger:hover{background:var(--d-100);color:var(--d-700)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border-radius:var(--r-md);border:1px solid transparent;background:var(--n-100);color:var(--text);cursor:pointer;font-size:14px;font-weight:600;text-decoration:none;transition:background .15s,transform .05s,box-shadow .15s,border-color .15s,color .15s;white-space:nowrap;min-height:42px}.btn:hover{background:var(--n-200);text-decoration:none}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-sm{padding:6px 12px;font-size:13px;min-height:32px}.btn-lg{padding:13px 24px;font-size:15px;min-height:50px}.btn-primary{background:var(--p-600);color:#fff;border-color:transparent;box-shadow:var(--shadow-1)}.btn-primary:hover{background:var(--p-700);color:#fff;box-shadow:var(--shadow-2)}.btn-outline{background:var(--surface);color:var(--p-700);border-color:var(--p-200)}.btn-outline:hover{background:var(--p-50);border-color:var(--p-300);color:var(--p-800)}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover{background:var(--n-100);color:var(--text)}.btn-warn{background:var(--a-500);color:#fff}.btn-warn:hover{background:var(--a-600)}.btn-danger{background:var(--d-600);color:#fff}.btn-danger:hover{background:var(--d-700)}.btn-block{width:100%}.card{background:var(--surface);border-radius:var(--r-lg);padding:22px;box-shadow:var(--shadow-1);border:1px solid var(--border)}.muted{color:var(--text-muted)}.small{font-size:12px}.center{text-align:center}.error{color:var(--d-700);background:var(--d-100);border:1px solid #fecaca;padding:10px 14px;border-radius:var(--r-md);font-size:14px}.layout-two{display:grid;gap:24px;grid-template-columns:minmax(0,1fr) 300px}.sidebar{display:flex;flex-direction:column;gap:16px}.sidebar-title{margin:0 0 12px;font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-soft)}.grid{display:grid;gap:18px;margin-top:18px;grid-template-columns:repeat(auto-fill,minmax(290px,1fr))}.row-between{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}.row-actions{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}.page-head{display:flex;align-items:center;justify-content:space-between;margin:8px 0 22px;gap:12px}.page-head h1{margin:0;font-size:26px;letter-spacing:-.3px}.page-hero{display:flex;flex-direction:column;align-items:flex-start;gap:8px;padding:30px 32px;margin:8px 0 28px;border-radius:var(--r-xl);background:var(--hero-grad);border:1px solid var(--border);position:relative;overflow:hidden}.page-hero:after{content:"";position:absolute;right:-50px;top:-50px;width:220px;height:220px;background:radial-gradient(closest-side,rgba(14,165,233,.35),transparent);filter:blur(40px)}.page-hero h1{margin:0;font-size:30px;letter-spacing:-.5px}.page-hero p{margin:0;color:var(--text-soft);font-size:15px}.page-hero-icon{color:var(--p-600)}.article-card{display:flex;flex-direction:column;gap:10px;transition:transform .15s,box-shadow .15s,border-color .15s}.article-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-3);border-color:var(--p-200)}.article-title{font-size:16px;font-weight:700;color:var(--text);line-height:1.4}.article-title:hover{color:var(--p-700);text-decoration:none}.article-excerpt{margin:0;color:var(--text-soft);font-size:13px;line-height:1.65}.search-bar{display:flex;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-full);padding:4px 4px 4px 18px;box-shadow:var(--shadow-1);transition:border-color .15s,box-shadow .15s}.search-bar:focus-within{border-color:var(--p-400);box-shadow:var(--shadow-focus)}.search-icon{color:var(--text-muted);flex:0 0 auto}.search-bar input{border:0;outline:0;background:transparent;flex:1;padding:10px 12px;font-size:15px;min-height:var(--touch)}.search-submit{border-radius:var(--r-full);padding:10px 22px}.filter-status{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:14px;padding:8px 14px;background:var(--p-50);border-radius:var(--r-md);border:1px solid var(--p-100)}.quick-tags{display:flex;gap:8px;flex-wrap:nowrap;margin-top:16px;padding-bottom:4px;overflow-x:auto;scrollbar-width:thin}.quick-tag{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--r-full);background:var(--surface);border:1px solid var(--border);color:var(--text-soft);font-size:13px;white-space:nowrap}.quick-tag:hover{background:var(--n-100);color:var(--text);text-decoration:none}.quick-tag.active{background:var(--p-600);border-color:var(--p-600);color:#fff;font-weight:600}.quick-tag-count{color:var(--text-muted);font-size:11px}.quick-tag.active .quick-tag-count{color:#ffffffd9}.empty-block{padding:48px 24px;margin-top:16px;display:flex;flex-direction:column;align-items:center;gap:12px}.empty-icon{color:var(--p-300);margin-bottom:4px}.tags{display:flex;flex-wrap:wrap;gap:6px}.tag{background:var(--p-50);color:var(--p-700);padding:3px 10px;border-radius:var(--r-full);font-size:12px;font-weight:500;border:1px solid var(--p-100)}.tag:hover{background:var(--p-100);text-decoration:none}.tag-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.tag-list li{display:flex;align-items:center;gap:10px;font-size:14px}.tag-list li a{color:var(--text);font-weight:500;flex:1}.tag-list li a:hover{color:var(--p-700)}.rank{background:var(--p-100);color:var(--p-700);border-radius:var(--r-sm);width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex:0 0 auto}.rank.gold{background:#fef3c7;color:#b45309}.rank.silver{background:#e5e7eb;color:#374151}.rank.bronze{background:#fed7aa;color:#9a3412}.link-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;font-size:14px}.link-list a{color:var(--text);display:inline-flex;align-items:center;gap:6px}.link-list a:hover{color:var(--p-700)}.link-list a svg{opacity:.55}.collapse{background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);box-shadow:var(--shadow-1)}.collapse.inline{background:transparent;box-shadow:none;border-color:transparent;border-bottom:1px solid var(--border);border-radius:0}.collapse-head{display:flex;align-items:center;gap:8px;width:100%;background:transparent;border:0;padding:14px 18px;cursor:pointer;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-soft);border-radius:var(--r-lg)}.collapse-head:hover{color:var(--text)}.collapse-caret{transition:transform .2s;transform:rotate(-90deg);color:var(--text-muted);flex:0 0 auto}.collapse-caret.open{transform:rotate(0)}.collapse-title{flex:1;text-align:left}.collapse-aside{font-weight:500;text-transform:none;letter-spacing:0}.collapse-body{padding:0 18px 16px}.form{display:flex;flex-direction:column;gap:16px}.field{display:flex;flex-direction:column;gap:8px}.label-row{display:flex;align-items:baseline;gap:8px;font-weight:700;font-size:14px;color:var(--text)}.req{color:var(--d-600)}.hint{margin:0;font-size:12px;color:var(--text-muted)}.form input,.form textarea,.form select,.rich-textarea{border:1px solid var(--border);border-radius:var(--r-md);padding:12px 14px;font:inherit;background:var(--surface);color:var(--text);transition:border-color .15s,box-shadow .15s;width:100%;min-height:var(--touch)}.form input.input-lg{padding:14px 16px;font-size:16px}.form input:hover,.form textarea:hover{border-color:var(--border-strong)}.form input:focus,.form textarea:focus,.form select:focus,.rich-textarea:focus{outline:none;border-color:var(--p-500);box-shadow:var(--shadow-focus)}.form textarea,.rich-textarea{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:14px;line-height:1.75;resize:vertical}.inline-check{display:flex;align-items:center;gap:12px}.inline-check input{width:auto;min-height:0;transform:scale(1.2);accent-color:var(--p-600)}.check-label{display:flex;flex-direction:column;gap:2px;font-size:14px}.editor-shell{max-width:980px;margin:0 auto}.editor-form{gap:18px}.field-card{padding:20px 22px}.selected-tags{display:flex;flex-wrap:wrap;gap:6px;padding-top:6px}.tag-pill{display:inline-flex;align-items:center;gap:6px;background:var(--p-100);color:var(--p-800);border:1px solid var(--p-200);padding:4px 4px 4px 12px;border-radius:var(--r-full);font-size:12px;font-weight:600}.tag-pill-x{border:0;background:var(--p-200);color:var(--p-800);width:20px;height:20px;border-radius:var(--r-full);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.tag-pill-x:hover{background:var(--p-300)}.existing-tags{border-top:1px dashed var(--border);padding-top:14px;margin-top:6px}.existing-tags summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text-soft);padding:6px 0;-webkit-user-select:none;user-select:none}.existing-tags summary::-webkit-details-marker{display:none}.existing-tags .summary-caret{transition:transform .2s;transform:rotate(-90deg);color:var(--text-muted)}.existing-tags[open] .summary-caret{transform:rotate(0)}.tag-chips{display:flex;flex-wrap:wrap;gap:6px;padding-top:12px}.chip{display:inline-flex;align-items:center;gap:6px;background:var(--n-100);color:var(--text-soft);border:1px solid var(--border);padding:6px 12px;border-radius:var(--r-full);font-size:12px;cursor:pointer;transition:background .15s,border-color .15s,color .15s;min-height:32px}.chip:hover{background:var(--p-50);border-color:var(--p-200);color:var(--p-700)}.chip.selected{background:var(--p-100);border-color:var(--p-300);color:var(--p-800);font-weight:600}.chip.chip-ghost{background:transparent;border-style:dashed;color:var(--text-muted)}.chip.chip-ghost:hover{color:var(--p-700);border-style:solid}.chip-count{background:var(--surface);color:var(--text-muted);border-radius:var(--r-full);padding:0 6px;font-size:11px;font-weight:600}.chip.selected .chip-count{background:var(--p-50);color:var(--p-700)}.action-bar{position:sticky;bottom:16px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-3);z-index:4}.action-left{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.login-screen{min-height:calc(100vh - var(--header-h));display:flex;align-items:center;justify-content:center;padding:24px;position:relative;overflow:hidden}.login-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none}.blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4}.blob-1{width:360px;height:360px;background:var(--p-300);top:-100px;left:-100px}.blob-2{width:320px;height:320px;background:var(--a-300);bottom:-100px;right:-80px}.blob-3{width:240px;height:240px;background:var(--p-200);bottom:20%;left:30%;opacity:.25}.auth-card{max-width:440px;width:100%;margin:0;padding:36px 32px;position:relative;z-index:1}.auth-title{text-align:center;font-size:34px;margin:0;font-weight:800;letter-spacing:-.5px;color:var(--text)}.auth-title:before{content:"●";color:var(--p-500);font-size:.7em;margin-right:12px;vertical-align:middle}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:18px}.tab{background:transparent;border:0;border-bottom:2px solid transparent;padding:12px 18px;cursor:pointer;color:var(--text-muted);font-size:14px;font-weight:500;min-height:var(--touch)}.tab:hover{color:var(--text)}.tab.active{border-bottom-color:var(--p-600);color:var(--p-700);font-weight:700}.badge{display:inline-block;padding:1px 8px;border-radius:var(--r-full);font-size:11px;background:var(--p-100);color:var(--p-700);margin-left:6px;font-weight:600}.badge.published{background:var(--s-100);color:var(--s-700)}.badge.draft{background:var(--n-200);color:var(--n-700)}.article-view h1{margin-top:0}.article-head{padding-bottom:16px;border-bottom:1px solid var(--border);margin-bottom:18px}.article-head h1{font-size:30px;line-height:1.3;margin:0 0 8px;letter-spacing:-.4px}.prose{font-size:15px;line-height:1.85;color:var(--text);overflow-wrap:anywhere}.prose h1,.prose h2,.prose h3,.prose h4{margin-top:1.6em;margin-bottom:.6em;line-height:1.35;color:var(--text)}.prose h1{font-size:26px;border-bottom:1px solid var(--border);padding-bottom:.3em}.prose h2{font-size:21px;border-bottom:1px solid var(--border);padding-bottom:.25em}.prose h3{font-size:18px}.prose p{margin:.8em 0}.prose ul,.prose ol{padding-left:1.6em;margin:.8em 0}.prose li{margin:.25em 0}.prose a{color:var(--p-700);text-decoration:underline;text-underline-offset:2px}.prose code{background:var(--n-100);padding:.15em .4em;border-radius:4px;font-size:.9em;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;color:var(--p-800)}.prose pre{background:var(--n-900);color:var(--n-100);padding:14px 16px;border-radius:var(--r-md);overflow-x:auto;font-size:13px;line-height:1.6}.prose pre code{background:transparent;padding:0;color:inherit;font-size:inherit}.prose blockquote{border-left:4px solid var(--p-400);margin:1em 0;padding:.4em 1em;background:var(--p-50);color:var(--text-soft);border-radius:0 var(--r-md) var(--r-md) 0}.prose img{max-width:100%;height:auto;border-radius:var(--r-md)}.prose hr{border:0;border-top:1px solid var(--border);margin:2em 0}.prose table{border-collapse:collapse;width:100%;margin:1em 0;font-size:14px}.prose th,.prose td{border:1px solid var(--border);padding:8px 12px;text-align:left}.prose th{background:var(--n-100);font-weight:700}.prose .terms-grid{display:grid;gap:14px;grid-template-columns:1fr;margin:1.4em 0}@media (min-width: 760px){.prose .terms-grid{grid-template-columns:1fr 1fr}}.prose .term-card{background:linear-gradient(135deg,var(--p-50) 0%,var(--surface) 70%);border:1px solid var(--p-100);border-left:4px solid var(--p-500);border-radius:var(--r-md);padding:16px 18px 14px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow-1);transition:transform .15s,box-shadow .15s}.prose .term-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-2)}.prose .term-head{display:flex;align-items:center;flex-wrap:wrap;gap:6px}.prose .term-name{font-weight:800;color:var(--text);font-size:16px;letter-spacing:-.2px;margin-right:4px;line-height:1.3}.prose .term-tag{font-size:11px;padding:2px 10px;border-radius:var(--r-full);background:var(--surface);color:var(--p-700);font-weight:600;border:1px solid var(--p-200);white-space:nowrap}.prose .term-desc{margin:0;font-size:13.5px;line-height:1.78;color:var(--text-soft)}.prose .term-desc code{font-size:.88em;padding:.1em .35em}.prose .term-desc strong{color:var(--text)}.rich-editor{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);overflow:hidden;display:flex;flex-direction:column;min-height:480px;height:clamp(480px,65vh,760px)}.rich-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:4px;padding:10px 12px;background:var(--n-50);border-bottom:1px solid var(--border);flex:0 0 auto}.rich-tool-group{display:inline-flex;align-items:center;gap:2px}.rich-sep{display:inline-block;width:1px;height:20px;background:var(--border);margin:0 6px}.rich-tool{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:6px 10px;font-size:13px;color:var(--text);cursor:pointer;display:inline-flex;align-items:center;gap:4px;transition:background .12s,border-color .12s,color .12s;min-height:34px;min-width:34px;justify-content:center}.rich-tool:hover{background:var(--p-50);border-color:var(--p-200);color:var(--p-800)}.rich-tool.active{background:var(--p-600);border-color:var(--p-600);color:#fff}.rich-tool.bold{font-weight:800}.rich-tool.italic{font-style:italic;font-weight:600}.rich-tool.underline{text-decoration:underline;text-underline-offset:2px}.rich-tool.strike{text-decoration:line-through}.rich-color{display:inline-flex;gap:2px;align-items:center}.rich-color label{cursor:pointer;padding:4px 10px;position:relative}.rich-color input[type=color]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;width:100%;height:100%;cursor:pointer;border:0}.rich-textarea{flex:1 1 auto;border:0;border-radius:0;background:var(--surface);padding:18px 20px;resize:none;overflow-y:auto;min-height:0}.rich-textarea:focus{box-shadow:none;border:0}.course-grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.big-course-card{display:flex;flex-direction:column;border-radius:var(--r-xl);background:var(--surface);border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow-1);color:inherit;transition:transform .18s,box-shadow .18s,border-color .18s}.big-course-card:hover{text-decoration:none;transform:translateY(-4px);box-shadow:var(--shadow-3);border-color:var(--card-accent, var(--p-200))}.big-course-banner{height:110px;background:linear-gradient(135deg,var(--card-accent),var(--card-accent-2));position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}.big-course-banner:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 80% 20%,rgba(255,255,255,.35),transparent 50%),radial-gradient(circle at 20% 90%,rgba(255,255,255,.15),transparent 40%)}.big-course-letter{position:relative;z-index:1;font-size:56px;font-weight:800;color:#fffffff2;text-shadow:0 2px 10px rgba(0,0,0,.18);letter-spacing:1px}.big-course-body{padding:18px 20px 20px;display:flex;flex-direction:column;gap:8px}.big-course-body h2{margin:0;font-size:20px;color:var(--text)}.big-course-body p{margin:0;font-size:14px;color:var(--text-soft)}.big-course-footer{display:flex;align-items:center;justify-content:space-between;margin-top:6px}.chip-stat{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:var(--r-full);background:var(--p-50);color:var(--p-700);font-size:12px;font-weight:600}.big-course-go{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:600;color:var(--p-700);transition:transform .15s}.big-course-card:hover .big-course-go{transform:translate(2px)}.course-hero{border-radius:var(--r-2xl);padding:32px 36px;color:#fff;position:relative;overflow:hidden;box-shadow:var(--shadow-2)}.course-hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 90% -10%,rgba(255,255,255,.4),transparent 40%),radial-gradient(circle at 0% 100%,rgba(0,0,0,.15),transparent 50%);pointer-events:none}.course-hero-inner{position:relative;z-index:1;display:flex;flex-direction:column;gap:10px}.course-hero-back{align-self:flex-start;color:#fffffff2;font-size:13px;display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--r-full);background:#ffffff2e;border:1px solid rgba(255,255,255,.28);margin-bottom:10px}.course-hero-back:hover{background:#ffffff47;text-decoration:none;color:#fff}.course-hero-title{font-size:36px;margin:0;font-weight:800;letter-spacing:-.7px}.course-hero-desc{margin:0;opacity:.92;font-size:15px}.course-hero-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}.course-hero-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--r-full);background:#ffffff38;border:1px solid rgba(255,255,255,.3);font-size:13px;font-weight:600}.topic-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));margin-top:28px}.topic-card{background:var(--surface);border-radius:var(--r-lg);border:1px solid var(--border);overflow:hidden;cursor:pointer;text-align:left;display:flex;flex-direction:column;transition:transform .18s,box-shadow .18s,border-color .18s;padding:0;box-shadow:var(--shadow-1)}.topic-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-3);border-color:var(--card-accent, var(--p-200))}.topic-card-strip{height:4px;background:var(--card-accent)}.topic-card-body{padding:18px 18px 16px;display:flex;flex-direction:column;gap:10px}.topic-avatar{width:44px;height:44px;border-radius:var(--r-md);background:var(--card-accent-bg, var(--p-50));color:var(--card-accent, var(--p-700));display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:18px}.topic-avatar.lg{width:56px;height:56px;font-size:22px;border-radius:var(--r-lg)}.topic-card-title{margin:0;font-size:16px;line-height:1.35;color:var(--text)}.topic-card-desc{margin:0;font-size:13px;color:var(--text-soft);line-height:1.6;flex:1}.topic-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:4px;padding-top:10px;border-top:1px dashed var(--border)}.topic-card-action{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:600;color:var(--p-700)}.course-topic-view{display:flex;flex-direction:column;gap:18px;max-width:920px;margin:0 auto}.topic-actions-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.topic-header{display:flex;align-items:center;gap:16px;padding:8px 4px}.topic-title-lg{margin:0;font-size:30px;line-height:1.3;letter-spacing:-.5px}.topic-pager{display:grid;gap:10px;grid-template-columns:1fr 1fr;margin-top:8px}.topic-pager-btn{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 16px;cursor:pointer;text-align:left;color:var(--text);font-size:14px;transition:background .15s,border-color .15s}.topic-pager-btn:hover:not(:disabled){background:var(--p-50);border-color:var(--p-300)}.topic-pager-btn:disabled{opacity:.45;cursor:not-allowed}.topic-pager-btn.right{justify-content:flex-end;text-align:right;flex-direction:row}.topic-pager-btn.right .topic-pager-label{align-items:flex-end}.topic-pager-label{display:flex;flex-direction:column}.topic-pager-label span:last-child{font-weight:600}.chapter-no{font-size:11px;color:var(--text-muted);font-weight:600;letter-spacing:.04em;flex:0 0 auto}.chapter-no.inline{display:inline-block;margin-right:8px;padding:2px 8px;background:var(--p-100);color:var(--p-700);border-radius:var(--r-sm);font-size:12px}.chapter-view h2{margin-top:0}.progress{height:8px;background:var(--n-200);border-radius:var(--r-full);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--p-500) 0%,var(--p-400) 100%);border-radius:var(--r-full);transition:width .35s ease}.course-progress{display:flex;flex-direction:column;gap:6px;margin-top:6px}.course-progress-meta{display:flex;justify-content:space-between;align-items:baseline;font-size:12px}.course-progress-text{display:inline-flex;align-items:center;gap:4px;color:var(--text-soft);font-weight:600}.course-progress-icon{color:var(--s-600)}.course-progress-pct{color:var(--p-700);font-weight:700}.course-hero-progress{margin-top:14px;background:#ffffff2e;border-radius:var(--r-full);padding:2px}.course-hero-progress .progress{background:#ffffff2e;height:10px}.course-hero-progress .progress-fill{background:#fffffff2}.next-up-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 20px;margin:24px 0 18px;border-radius:var(--r-lg);background:linear-gradient(135deg,var(--p-50),var(--surface));border:1px solid var(--p-200);box-shadow:var(--shadow-1)}.next-up-title{display:flex;align-items:center;gap:10px;font-weight:700;font-size:17px;color:var(--text);margin-top:2px}.part-section{margin-top:32px}.part-section:first-of-type{margin-top:18px}.part-header{display:flex;align-items:center;gap:12px;margin-bottom:14px;padding-bottom:10px;border-bottom:2px solid var(--n-200)}.part-no-badge{background:var(--p-600);color:#fff;font-size:11px;font-weight:800;letter-spacing:.08em;padding:4px 10px;border-radius:var(--r-sm);white-space:nowrap}.part-title{margin:0;font-size:19px;font-weight:700;letter-spacing:-.2px;flex:1}.part-meta{flex:0 0 auto}.step-badge{display:inline-flex;align-items:center;font-family:JetBrains Mono,ui-monospace,monospace;font-size:11px;font-weight:800;letter-spacing:.06em;padding:3px 9px;background:var(--p-100);color:var(--p-800);border-radius:var(--r-sm)}.topic-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.topic-card.done .topic-card-strip{background:var(--s-600)}.topic-card.done{border-color:var(--s-100)}.topic-card.done .topic-card-title{color:var(--text-soft)}.topic-card.next-up{border-color:var(--p-400);box-shadow:0 0 0 3px #0ea5e926,var(--shadow-2)}.done-mark{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--r-full);background:var(--s-600);color:#fff}.next-pill{font-size:10px;font-weight:700;letter-spacing:.05em;padding:3px 8px;border-radius:var(--r-full);background:var(--p-600);color:#fff}.topic-part-label{font-size:11px;font-weight:700;letter-spacing:.06em;color:var(--p-700);text-transform:uppercase;margin-bottom:4px}.topic-avatar.lg{font-family:JetBrains Mono,ui-monospace,monospace;font-size:18px;letter-spacing:.04em}@media (max-width: 600px){.next-up-banner{flex-direction:column;align-items:stretch;gap:12px}.next-up-banner .btn{width:100%}.part-header{flex-wrap:wrap}.part-title{font-size:16px;flex:1 1 auto}}@media (max-width: 880px){:root{--header-h: 58px}.container{padding:18px 14px}.layout-two{grid-template-columns:1fr}.nav-desktop{display:none}.hamburger{display:inline-flex}.page-head{flex-direction:column;align-items:stretch}.page-head h1{font-size:22px}.page-head .btn{align-self:flex-start}.page-hero{padding:22px 20px;border-radius:var(--r-xl)}.page-hero h1{font-size:24px}.course-hero{padding:24px 20px;border-radius:var(--r-xl)}.course-hero-title{font-size:26px}.topic-grid{grid-template-columns:1fr 1fr;gap:12px}.topic-card-body{padding:14px 14px 12px}.topic-card-title{font-size:14px}.topic-pager{grid-template-columns:1fr}.topic-actions-top{flex-wrap:wrap}.topic-header{gap:12px}.topic-title-lg{font-size:22px}.action-bar{flex-direction:column;align-items:stretch;gap:8px}.action-left{justify-content:space-between}.action-left .btn{flex:1}.action-bar .btn-ghost{width:100%}.row-actions .btn{flex:1 1 auto}.search-bar input{font-size:16px}.rich-editor{min-height:380px;height:clamp(380px,60vh,600px)}.rich-toolbar{padding:8px}.rich-tool{padding:4px 8px;min-height:30px;min-width:30px;font-size:12px}}@media (max-width: 480px){.topic-grid{grid-template-columns:1fr}.big-course-banner{height:90px}.big-course-letter{font-size:44px}.quick-tags{margin-left:-14px;margin-right:-14px;padding:8px 14px}}.fade-in{animation:fadeIn .22s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
