:root{--bg:#f7f3ea;--surface:#fffdf7;--surface-alt:#f0ebde;--rule:#1a1612;--rule-soft:#c9c2af;--rule-faint:#e3dccc;--ink-1:#14110d;--ink-2:#3d362d;--ink-3:#7a7367;--accent:#7a1f1f;--accent-hover:#531414;--accent-tint:#f3eae6;--accent-ring:rgba(122,31,31,0.22);--hue-easy:#2f5d3a;--hue-easy-bg:#eaf1e8;--hue-med:#7a5510;--hue-med-bg:#f6efdc;--hue-hard:#8a2020;--hue-hard-bg:#f3e3e1;--done-bg:#edf3eb;--done-ink:#2f5d3a;--radius-sm:3px;--radius-md:4px;--radius-lg:6px;--font-serif:"Source Han Serif SC","Songti SC","STSong","SimSun","Noto Serif","Source Serif Pro","Times New Roman",serif;--font-display:"Source Han Serif SC","Songti SC","STSong","Noto Serif","Source Serif Pro","Times New Roman",serif;--font-ui:"Inter","Helvetica Neue","PingFang SC","Microsoft YaHei",system-ui,sans-serif;--font-mono:"JetBrains Mono","SF Mono",Menlo,Consolas,monospace;--fs-xs:12.5px;--fs-sm:14px;--fs-md:16.5px;--fs-lg:19px;--fs-xl:23px;--fs-2xl:28px;--fs-3xl:34px;--ease-out:cubic-bezier(0.22,1,0.36,1)}*,:after,:before{box-sizing:border-box}html{-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility}body{margin:0;font-family:var(--font-serif);font-feature-settings:"kern","liga","calt";background:var(--bg);color:var(--ink-1);line-height:1.78;font-size:var(--fs-md);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--accent);text-decoration:none;text-underline-offset:3px;text-decoration-thickness:.6px;transition:color .18s var(--ease-out)}a:hover{color:var(--accent-hover);text-decoration:underline}::selection{background:var(--accent-tint);color:var(--accent-hover)}.container{max-width:880px;margin:0 auto;padding:0 28px}.main-content{padding-top:44px;padding-bottom:80px}.topbar{position:-webkit-sticky;position:sticky;top:0;z-index:100;background:rgba(247,243,234,.94);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--rule)}.topbar-inner{min-height:64px;display:flex;align-items:center;justify-content:space-between;gap:16px}.topbar nav{display:flex;gap:2px}.topbar nav a{font-family:var(--font-ui);color:var(--ink-2);font-size:var(--fs-sm);letter-spacing:.02em;padding:6px 12px;border-radius:var(--radius-sm);transition:color .18s var(--ease-out);text-decoration:none}.topbar nav a:hover{background:transparent;color:var(--accent);text-decoration:none}.brand{font-family:var(--font-display);font-weight:600;font-size:var(--fs-lg);letter-spacing:.01em;color:var(--ink-1);text-decoration:none}.brand:hover,.topbar-auth-link{color:var(--accent);text-decoration:none}.topbar-auth-link{font-family:var(--font-ui);font-size:var(--fs-sm);letter-spacing:.04em;padding:6px 14px;border-radius:var(--radius-sm);border:1px solid var(--accent);text-transform:uppercase;transition:background .18s,color .18s}.topbar-auth-link:hover{background:var(--accent);color:var(--surface);text-decoration:none}.topbar-user{display:flex;align-items:center;gap:10px}.topbar-username{font-family:var(--font-ui);font-size:var(--fs-sm);color:var(--ink-2);max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-signout{font-family:var(--font-ui);font-size:var(--fs-xs);letter-spacing:.06em;text-transform:uppercase;padding:4px 10px;background:none;color:var(--ink-3);border:1px solid var(--rule-soft);border-radius:var(--radius-sm)}.topbar-signout:hover{background:var(--surface-alt);color:var(--ink-1);border-color:var(--rule)}.topbar-fav-link{font-family:var(--font-ui);font-size:var(--fs-sm);color:var(--ink-3);text-decoration:none;padding:2px 0;letter-spacing:.02em;transition:color .18s}.topbar-fav-link:hover{color:var(--accent);text-decoration:none}h1{font-size:var(--fs-2xl);line-height:1.25;letter-spacing:-.005em;margin:0 0 18px}h1,h2{font-family:var(--font-display);font-weight:600;color:var(--ink-1)}h2{font-size:var(--fs-xl);line-height:1.3;margin:24px 0 12px}h3{font-family:var(--font-display);font-size:var(--fs-lg);font-weight:600;line-height:1.35;color:var(--ink-1);margin:20px 0 8px}p{margin:0 0 12px}.section-gap{display:grid;grid-gap:28px;gap:28px;margin-bottom:32px}.stack{display:grid;grid-gap:14px;gap:14px}.muted{color:var(--ink-3);letter-spacing:.01em}.error,.muted{font-size:var(--fs-sm);font-family:var(--font-ui)}.error{color:var(--accent)}.card{background:var(--surface);border:1px solid var(--rule-faint);border-radius:var(--radius-md);padding:24px 26px}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:18px}.grid-2,.grid-3{display:grid;gap:18px}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:18px}.grid-2 .card,.grid-3 .card{transition:border-color .2s var(--ease-out);display:flex;flex-direction:column;gap:10px}.grid-2 .card:hover,.grid-3 .card:hover{border-color:var(--rule)}.grid-2 .card h2,.grid-3 .card h2{margin:0}.meta-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.tag{font-family:var(--font-ui);display:inline-flex;align-items:center;border:1px solid var(--rule-soft);background:transparent;color:var(--ink-2);border-radius:2px;padding:2px 8px;font-size:var(--fs-xs);letter-spacing:.06em;text-transform:uppercase;line-height:1.6}.form-grid{display:grid;grid-gap:16px;gap:16px}label{font-family:var(--font-ui);display:grid;grid-gap:6px;gap:6px;font-size:var(--fs-sm);letter-spacing:.02em;color:var(--ink-2)}input,select,textarea{font-family:var(--font-serif);font-size:var(--fs-md);border:1px solid var(--rule-soft);border-radius:var(--radius-sm);padding:10px 12px;background:var(--surface);color:var(--ink-1);transition:border-color .18s,box-shadow .18s;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}button{font-family:var(--font-ui);font-size:var(--fs-sm);font-weight:500;letter-spacing:.06em;text-transform:uppercase;background:var(--ink-1);color:var(--surface);border:1px solid var(--ink-1);border-radius:var(--radius-sm);padding:9px 22px;cursor:pointer;transition:background .18s,color .18s}button:hover{background:var(--accent);border-color:var(--accent)}button:active{transform:translateY(1px)}button[disabled]{opacity:.45;cursor:not-allowed}button[disabled]:active{transform:none}.secondary-button{background:transparent;color:var(--ink-1);border:1px solid var(--rule-soft)}.secondary-button:hover{background:transparent;color:var(--accent);border-color:var(--accent)}hr{border:none;border-top:1px solid var(--rule-faint);margin:12px 0}.asset-grid{display:grid;grid-gap:14px;gap:14px}.asset-image{max-width:100%;border-radius:var(--radius-sm);border:1px solid var(--rule-faint)}.markdown p{margin:6px 0}.markdown ol,.markdown ul{margin:8px 0;padding-left:24px}.markdown ul li::marker{color:var(--ink-3)}.markdown-inline,.markdown-inline>span{display:inline}.markdown table{border-collapse:collapse;width:100%;margin:14px 0;font-size:var(--fs-sm);font-family:var(--font-ui);overflow-x:auto;display:block}.markdown thead{background:var(--surface-alt)}.markdown td,.markdown th{border:1px solid var(--rule-soft);padding:8px 14px;text-align:left;white-space:nowrap}.markdown th{font-weight:600;color:var(--ink-1);letter-spacing:.02em}.markdown tr:nth-child(2n){background:rgba(240,235,222,.4)}.markdown .katex-display{margin:.6rem 0;text-align:left;overflow-x:auto}.markdown .katex{font-size:1.02em}.breadcrumb{font-family:var(--font-ui);display:flex;align-items:center;gap:8px;font-size:var(--fs-xs);letter-spacing:.08em;text-transform:uppercase;flex-wrap:wrap;margin-bottom:16px}.breadcrumb,.breadcrumb a{color:var(--ink-3)}.breadcrumb a:hover{color:var(--accent)}.breadcrumb-sep:before{content:"·";color:var(--ink-3);font-size:14px}.problem-list{display:flex;flex-direction:column;background:transparent;border-top:1px solid var(--rule)}.problem-card{display:grid;grid-template-columns:64px 1fr auto;align-items:baseline;grid-gap:18px;gap:18px;padding:18px 4px;background:transparent;text-decoration:none;color:inherit;border-bottom:1px solid var(--rule-faint);transition:background .15s;min-height:64px}.problem-card:hover{background:var(--surface);text-decoration:none}.problem-card-header{display:contents}.problem-card-no{font-family:var(--font-display);font-weight:600;font-size:var(--fs-md);color:var(--accent);letter-spacing:.01em;white-space:nowrap}.problem-card-action{font-family:var(--font-ui);font-size:var(--fs-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}.problem-card-stem{grid-column:2;font-family:var(--font-serif);font-size:var(--fs-md);color:var(--ink-1);line-height:1.65;max-height:84px;overflow:hidden}.problem-card-stem .markdown p{margin:0}.problem-card-meta{grid-column:2;font-family:var(--font-ui);font-size:var(--fs-xs);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3)}.problem-excerpt{max-height:140px;overflow:hidden;font-size:var(--fs-md)}.problem-excerpt .markdown{color:var(--ink-1)}.problem-excerpt .markdown p:first-child{margin-top:4px}.answer-reveal-section{margin:0}.answer-reveal{border:1px solid var(--rule-faint);border-radius:var(--radius-sm);background:var(--surface);padding:0 20px 4px}.answer-reveal-summary{cursor:pointer;list-style:none;display:flex;flex-wrap:wrap;align-items:baseline;gap:10px 16px;padding:14px 0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.answer-reveal-summary::-webkit-details-marker{display:none}.answer-reveal-summary-title{font-family:var(--font-display);font-size:var(--fs-lg);font-weight:600;letter-spacing:.005em;color:var(--ink-1)}.answer-reveal-summary-hint{font-family:var(--font-ui);font-size:var(--fs-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}.answer-reveal-body{padding-bottom:14px}.answer-reveal-subheading{font-family:var(--font-display);margin-top:8px;color:var(--ink-1);font-size:var(--fs-md);font-weight:600}.cs{margin-top:40px}.cs-header{padding-bottom:14px;border-bottom:1px solid var(--rule)}.cs-title{margin:0;font-family:var(--font-display);font-size:var(--fs-lg);font-weight:600;color:var(--ink-1);display:flex;align-items:baseline;gap:8px}.cs-count{font-family:var(--font-ui);font-size:var(--fs-xs);letter-spacing:.08em;color:var(--ink-3);font-weight:400;text-transform:uppercase}.cs-list{margin-top:4px}.cs-item+.cs-item{border-top:1px solid var(--rule-faint)}.cs-empty{padding:40px 0;text-align:center;color:var(--ink-3);font-family:var(--font-ui);font-size:var(--fs-sm);letter-spacing:.02em;margin:0}.cs-pager{display:flex;align-items:center;justify-content:space-between;padding:18px 0 8px;border-top:1px solid var(--rule-faint);margin-top:4px}.cs-page-btn{font-family:var(--font-ui);font-size:var(--fs-xs);letter-spacing:.06em;text-transform:uppercase;color:var(--accent);text-decoration:none;transition:color .15s}.cs-page-btn:hover{color:var(--accent-hover)}.cs-page-info{font-family:var(--font-ui);font-size:var(--fs-xs);letter-spacing:.04em;color:var(--ink-3)}.cs-compose{border-top:1px solid var(--rule-faint);padding-top:24px;margin-top:8px}.ci{display:flex;gap:14px;padding:18px 0}.ci--nested{padding:12px 0}.ci-avatar{width:36px;height:36px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--surface);font-family:var(--font-ui);font-size:13px;font-weight:600;letter-spacing:.02em;-webkit-user-select:none;-moz-user-select:none;user-select:none}.ci--nested .ci-avatar{width:28px;height:28px;font-size:11px}.ci-body{flex:1 1;min-width:0}.ci-author{display:flex;align-items:center;gap:8px;font-size:var(--fs-xs);letter-spacing:.04em;color:var(--ink-3);margin-bottom:4px}.ci-author,.ci-badge{font-family:var(--font-ui)}.ci-badge{font-size:9.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent);border-radius:2px;padding:0 5px;line-height:1.6}.ci-text{margin:0 0 8px;font-family:var(--font-serif);font-size:var(--fs-md);line-height:1.7;color:var(--ink-1);white-space:pre-wrap;word-break:break-word}.ci--nested .ci-text{font-size:var(--fs-sm)}.ci-footer{display:flex;align-items:center;justify-content:space-between}.ci-time{font-family:var(--font-ui);font-size:var(--fs-xs);letter-spacing:.04em;color:var(--ink-3)}.ci-actions{gap:16px}.ci-actions,.ci-btn{display:flex;align-items:center}.ci-btn{background:none;border:none;padding:0;cursor:pointer;gap:4px;font-family:var(--font-ui);font-size:var(--fs-xs);letter-spacing:.04em;color:var(--ink-3);transition:color .15s;line-height:1;text-transform:none}.ci-btn:hover{color:var(--ink-1)}.ci-like-btn--on{color:var(--accent)!important}.ci-reply-trigger:hover{color:var(--accent)}.ci-expand-btn{display:inline-flex;align-items:center;gap:4px;background:none;border:none;padding:6px 0 0;cursor:pointer;font-family:var(--font-ui);font-size:var(--fs-xs);letter-spacing:.06em;color:var(--ink-3);transition:color .15s}.ci-expand-btn:hover{color:var(--accent)}.ci-expand-btn:disabled{opacity:.5;cursor:default}.ci-children{margin-top:10px;padding-left:14px;border-left:1px solid var(--rule-faint)}.cf textarea{width:100%;resize:vertical;min-height:90px;padding:12px 14px;border:1px solid var(--rule-soft);border-radius:var(--radius-sm);background:var(--surface);font-family:var(--font-serif);font-size:var(--fs-md);color:var(--ink-1);line-height:1.65;transition:border-color .18s,box-shadow .18s;box-sizing:border-box}.cf textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.cf textarea::placeholder{color:var(--ink-3)}.cf--compact textarea{min-height:68px;font-size:var(--fs-sm);margin-top:10px}.cf-footer{display:flex;justify-content:flex-end;margin-top:10px}.cf-submit{font-family:var(--font-ui);font-size:var(--fs-xs);font-weight:500;letter-spacing:.08em;text-transform:uppercase;background:var(--ink-1);color:var(--surface);border:1px solid var(--ink-1);border-radius:var(--radius-sm);padding:8px 20px;cursor:pointer;transition:background .18s,border-color .18s}.cf-submit:hover{background:var(--accent);border-color:var(--accent)}.cf-submit:active{transform:translateY(1px)}.cf-submit:disabled{opacity:.45;cursor:default;transform:none}.comment-login-prompt{font-family:var(--font-ui);font-size:var(--fs-sm);color:var(--ink-3);padding:12px 0;letter-spacing:.02em}.problem-detail-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding-bottom:14px;border-bottom:1px solid var(--rule);margin-bottom:18px}.problem-detail-title-row h1{margin:0;flex:1 1}.fav-btn{display:inline-flex;align-items:center;gap:6px;flex-shrink:0;margin-top:8px;padding:5px 12px;background:transparent;border:1px solid var(--rule-soft);border-radius:var(--radius-sm);font-family:var(--font-ui);font-size:var(--fs-xs);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);cursor:pointer;transition:color .18s,border-color .18s,background .18s;white-space:nowrap}.fav-btn:hover{background:transparent}.fav-btn--on,.fav-btn:hover{color:var(--accent);border-color:var(--accent)}.fav-btn--on{background:var(--accent-tint)}.fav-btn svg{transition:transform .15s var(--ease-out)}.fav-btn--on svg{transform:scale(1.1)}.fav-btn:disabled{opacity:.55;cursor:default}.done-btn{display:inline-flex;align-items:center;gap:6px;flex-shrink:0;margin-top:8px;padding:5px 12px;background:transparent;border:1px solid var(--rule-soft);border-radius:var(--radius-sm);font-family:var(--font-ui);font-size:var(--fs-xs);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);cursor:pointer;transition:color .18s,border-color .18s,background .18s;white-space:nowrap}.done-btn:hover{background:transparent}.done-btn--on,.done-btn:hover{color:var(--done-ink);border-color:var(--done-ink)}.done-btn--on{background:var(--done-bg)}.done-btn svg{transition:transform .15s var(--ease-out)}.done-btn--on svg{transform:scale(1.05)}.done-btn:disabled{opacity:.55;cursor:default}.problem-detail-actions{display:flex;align-items:flex-start;gap:8px;flex-shrink:0;flex-wrap:wrap}.fav-page-header{display:flex;align-items:baseline;gap:12px;padding-bottom:18px;border-bottom:1px solid var(--rule);margin-bottom:8px}.fav-page-title{margin:0;font-family:var(--font-display);font-size:var(--fs-2xl);font-weight:600;letter-spacing:-.005em;color:var(--ink-1)}.fav-page-count{font-family:var(--font-ui);font-size:var(--fs-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}.fav-list{display:flex;flex-direction:column}.fav-row{display:flex;align-items:center;gap:14px;padding:16px 0;border-bottom:1px solid var(--rule-faint)}.fav-row-main{flex:1 1;min-width:0;display:flex;flex-direction:column;gap:5px}.fav-row-meta{display:flex;align-items:center;gap:8px}.fav-subject-tag{font-family:var(--font-ui);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);background:transparent;border:1px solid var(--rule-soft);border-radius:2px;padding:1px 6px}.fav-qno{font-family:var(--font-display);font-size:var(--fs-sm);color:var(--accent);font-weight:600}.fav-diff{font-family:var(--font-ui);font-size:10px;letter-spacing:.08em;text-transform:uppercase;border-radius:2px;padding:1px 6px}.fav-diff--easy{color:var(--hue-easy);background:var(--hue-easy-bg)}.fav-diff--medium{color:var(--hue-med);background:var(--hue-med-bg)}.fav-diff--hard{color:var(--hue-hard);background:var(--hue-hard-bg)}.fav-row-title{font-family:var(--font-serif);font-size:var(--fs-md);color:var(--ink-1);text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color .15s}.fav-row-title:hover{color:var(--accent);text-decoration:none}.fav-remove-btn{flex-shrink:0;background:transparent;border:1px solid var(--rule-soft);border-radius:var(--radius-sm);padding:4px 10px;font-family:var(--font-ui);font-size:var(--fs-xs);letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);cursor:pointer;transition:color .15s,border-color .15s}.fav-remove-btn:hover{color:var(--accent);border-color:var(--accent)}.fav-empty-state{padding:56px 0;text-align:center;color:var(--ink-3);font-family:var(--font-ui);font-size:var(--fs-sm);letter-spacing:.02em}.fav-empty-link{display:inline-block;margin-top:14px;font-size:var(--fs-sm);letter-spacing:.04em;color:var(--accent)}.fav-row--skeleton{pointer-events:none}.inline-form{margin-top:10px;gap:10px}.inline-form,.inline-links{display:flex;flex-wrap:wrap}.inline-links{gap:20px;align-items:center}.inline-links a{letter-spacing:.08em;text-transform:uppercase}.inline-links a,.pager{font-family:var(--font-ui);font-size:var(--fs-xs)}.pager{display:flex;justify-content:space-between;align-items:center;letter-spacing:.06em}@keyframes skeleton-pulse{0%,to{opacity:.45}50%{opacity:.2}}.skeleton-card{min-height:100px}.skeleton-heading,.skeleton-heading-sm,.skeleton-text,.skeleton-text-short{background:var(--rule-soft);border-radius:2px;animation:skeleton-pulse 1.4s ease-in-out infinite}.skeleton-heading{height:24px;width:42%;margin-bottom:12px}.skeleton-heading-sm{height:18px;width:52%;margin-bottom:10px}.skeleton-text{height:14px;width:100%;margin-bottom:8px}.skeleton-text-short{height:14px;width:32%;margin-bottom:8px}.skeleton-comment{display:flex;gap:12px;padding:16px 0;border-top:1px solid var(--rule-faint)}.skeleton-comment-avatar{width:36px;height:36px;border-radius:50%;flex-shrink:0;background:var(--rule-soft);animation:skeleton-pulse 1.4s ease-in-out infinite}.skeleton-comment-body{flex:1 1}.subject-list{display:flex;flex-direction:column;background:transparent;border-top:1px solid var(--rule)}.subject-card{display:flex;align-items:baseline;gap:28px;padding:28px 4px;border-bottom:1px solid var(--rule-faint);text-decoration:none;color:inherit;transition:background .15s}.subject-card:hover{background:var(--surface);text-decoration:none}.subject-num{color:var(--ink-3);font-weight:400;font-style:italic;flex-shrink:0;width:38px;letter-spacing:.02em}.subject-num,.subject-title{font-family:var(--font-display);font-size:var(--fs-xl)}.subject-title{font-weight:600;letter-spacing:-.002em;color:var(--ink-1);flex:1 1;min-width:0}.subject-arrow{font-family:var(--font-display);font-size:var(--fs-lg);color:var(--ink-3);flex-shrink:0;transition:color .15s,transform .2s var(--ease-out)}.subject-card:hover .subject-arrow{color:var(--accent);transform:translateX(6px)}.chapter-label{font-family:var(--font-ui);font-size:var(--fs-xs);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin:0 0 4px}.chapter-card{display:flex;flex-direction:column;gap:6px}.chapter-card h2{margin:0;font-size:var(--fs-lg);line-height:1.4;font-weight:600}.chapter-card .muted{margin:4px 0 6px}@media (max-width:720px){.container{padding:0 18px}.main-content{padding-top:28px;padding-bottom:56px}body{font-size:16px;line-height:1.72}h1{font-size:var(--fs-xl)}h2{font-size:var(--fs-lg)}.grid-2,.grid-3{grid-template-columns:1fr}.card{padding:18px}.problem-card{grid-template-columns:56px 1fr auto;padding:16px 4px;gap:14px}.subject-card{padding:22px 4px;gap:18px}.inline-form{flex-direction:column}.topbar-inner{min-height:54px}}@media (min-width:480px) and (max-width:720px){.grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}}