:root{--paper-0: #fbf6ea;--paper-1: #f5ecd9;--paper-2: #ede1c7;--paper-3: #e2d3b3;--paper-4: #c9b78f;--ink-0: #1c150c;--ink-1: #2e251a;--ink-2: #4a3d2c;--ink-3: #6b5a42;--ink-4: #8d7a5e;--ink-5: #b29b78;--accent: #8a3324;--accent-soft: #b75c4a;--accent-tint: #e7c8be;--accent-wash: #f3dfd6;--sage: #5c7148;--sage-soft: #91a47a;--sage-wash: #dde4cf;--ochre: #a8761d;--ochre-soft: #c89647;--ochre-wash: #ecdcb4;--serif: "Newsreader", "Source Serif 4", Georgia, serif;--sans: "Inter", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--mono: "JetBrains Mono", ui-monospace, Menlo, monospace;--r-1: 2px;--r-2: 4px;--r-3: 6px;--r-4: 10px;--shadow-1: 0 1px 0 rgba(28, 21, 12, .04), 0 1px 2px rgba(28, 21, 12, .04);--shadow-2: 0 1px 0 rgba(28, 21, 12, .05), 0 4px 12px -4px rgba(28, 21, 12, .08);--shadow-3: 0 1px 0 rgba(28, 21, 12, .06), 0 12px 28px -12px rgba(28, 21, 12, .18)}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--paper-1);color:var(--ink-1);font-family:var(--sans);font-size:clamp(14px,15px + .1vw,16px);line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}html{scrollbar-gutter:stable}body{background-image:radial-gradient(circle at 25% 20%,rgba(138,51,36,.015) 0,transparent 40%),radial-gradient(circle at 80% 70%,rgba(28,21,12,.018) 0,transparent 40%);min-height:100vh}h1,h2,h3,h4,h5,.serif{font-family:var(--serif);color:var(--ink-0);letter-spacing:-.01em;font-weight:500}h1{font-size:clamp(24px,5vw,36px);line-height:1.15}h2{font-size:clamp(20px,3.5vw,26px);line-height:1.2}h3{font-size:clamp(17px,2.5vw,20px);line-height:1.3}.mono{font-family:var(--mono);font-feature-settings:"tnum"}.tnum{font-variant-numeric:tabular-nums}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none;color:inherit}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}input,textarea{font-family:inherit;color:inherit}::selection{background:var(--accent-wash);color:var(--ink-0)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;min-height:44px;border-radius:var(--r-3);font-size:13px;font-weight:500;font-family:var(--sans);border:1px solid transparent;transition:background .12s,border .12s,color .12s;white-space:nowrap;-webkit-tap-highlight-color:transparent}.btn-primary{background:var(--ink-1);color:var(--paper-0)}.btn-primary:hover{background:var(--ink-0)}.btn-accent{background:var(--accent);color:var(--paper-0)}.btn-accent:hover{background:#6f2a1d}.btn-ghost{background:transparent;color:var(--ink-2);border-color:var(--paper-4)}.btn-ghost:hover{background:var(--paper-2);border-color:var(--ink-4)}.btn-quiet{background:transparent;color:var(--ink-3)}.btn-quiet:hover{color:var(--ink-1);background:var(--paper-2)}.btn-sm{padding:5px 10px;font-size:12px}.btn-lg{padding:11px 20px;font-size:14px}.btn-add{width:44px;height:44px;border-radius:50%;border:1px solid var(--paper-4);background:var(--paper-0);color:var(--ink-3);display:inline-flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:26px;line-height:1;font-weight:400;text-decoration:none;cursor:pointer;transition:background .18s,border-color .18s,color .18s,transform .12s;flex-shrink:0;box-shadow:var(--shadow-1)}.btn-add:hover{background:var(--accent);border-color:var(--accent);color:var(--paper-0)}.btn-add:active{transform:scale(.96)}.card{background:var(--paper-0);border:1px solid var(--paper-4);border-radius:var(--r-4);box-shadow:var(--shadow-1)}.pill{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:100px;font-size:11px;font-weight:500;letter-spacing:.02em;background:var(--paper-2);color:var(--ink-3);border:1px solid var(--paper-4)}.pill-accent{background:var(--accent-wash);color:var(--accent);border-color:var(--accent-tint)}.pill-sage{background:var(--sage-wash);color:var(--sage);border-color:color-mix(in oklab,var(--sage),transparent 70%)}.pill-ochre{background:var(--ochre-wash);color:var(--ochre);border-color:color-mix(in oklab,var(--ochre),transparent 70%)}.dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.dot-untouched{background:var(--paper-4)}.dot-progress{background:var(--ochre)}.dot-passed{background:var(--sage)}.dot-weak{background:var(--accent)}.kp-kind-badge{flex-shrink:0;font-size:10px;line-height:1;padding:3px 5px;border-radius:var(--r-1, 4px);background:var(--paper-3);color:var(--ink-4);letter-spacing:.04em}.app-root{min-height:100vh;display:flex;flex-direction:column}.topbar{height:52px;display:flex;align-items:center;padding:0 24px;border-bottom:1px solid var(--paper-4);background:var(--paper-1);gap:16px;position:sticky;top:0;z-index:30}.topbar-brand{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:18px;font-weight:500;color:var(--ink-0);letter-spacing:-.01em;text-decoration:none}.topbar-brand .mark{width:22px;height:22px;background:var(--accent);border-radius:2px;display:grid;place-items:center;color:var(--paper-0);font-family:var(--serif);font-size:14px;font-style:italic;font-weight:600}.topbar-crumbs{display:flex;align-items:center;gap:8px;color:var(--ink-3);font-size:13px}.topbar-crumbs .sep{color:var(--ink-5)}.topbar-crumbs a,.topbar-crumbs .crumb{color:var(--ink-3);cursor:pointer;text-decoration:none}.topbar-crumbs a:hover,.topbar-crumbs .crumb-current{color:var(--ink-1)}.topbar-spacer{flex:1}.topbar-user{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-3)}.avatar{width:28px;height:28px;background:var(--paper-3);color:var(--ink-1);border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:600;font-family:var(--serif)}.topbar-hamburger{display:none;width:44px;height:44px;align-items:center;justify-content:center;background:none;border:none;color:var(--ink-2);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:var(--r-2)}.topbar-hamburger:hover{background:var(--paper-2)}.topbar-mobile-menu{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#1c150c4d;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.topbar-mobile-menu-inner{position:absolute;top:52px;right:12px;background:var(--paper-0);border:1px solid var(--paper-4);border-radius:var(--r-4);box-shadow:var(--shadow-3);padding:8px;min-width:180px;display:flex;flex-direction:column}.topbar-mobile-link{display:flex;align-items:center;padding:12px 16px;font-size:14px;color:var(--ink-1);background:none;border:none;border-radius:var(--r-3);cursor:pointer;-webkit-tap-highlight-color:transparent;text-align:left;width:100%}.topbar-mobile-link:hover{background:var(--paper-2)}.topbar-mobile-divider{height:1px;background:var(--paper-3);margin:4px 8px}@media (max-width: 760px){.topbar-hamburger{display:flex}.topbar-mobile-menu{display:block}.topbar-user,.topbar-course-actions,.topbar-divider{display:none}}.margin-note{font-family:var(--serif);font-style:italic;color:var(--ink-3);font-size:13px;line-height:1.5}.book-rule{height:1px;background:linear-gradient(to right,transparent,var(--paper-4),transparent);margin:16px 0}@keyframes page-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.page-in{animation:page-in .28s ease-out}.create-course-page{padding:48px 48px 120px}@keyframes blink{50%{opacity:0}}.caret{display:inline-block;width:6px;height:1em;background:var(--accent);vertical-align:-2px;margin-left:2px;animation:blink .9s steps(2) infinite}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:var(--paper-4);border-radius:100px;border:2px solid var(--paper-1)}*::-webkit-scrollbar-thumb:hover{background:var(--ink-5)}.input{width:100%;background:var(--paper-0);border:1px solid var(--paper-4);border-radius:var(--r-3);padding:10px 12px;font-size:14px;color:var(--ink-1);transition:border .12s,box-shadow .12s}.input:focus{outline:none;border-color:var(--ink-3);box-shadow:0 0 0 3px var(--paper-3)}.input::placeholder{color:var(--ink-5)}.textarea{min-height:80px;resize:vertical;line-height:1.6}.label{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-4);font-weight:600;margin-bottom:6px;display:block}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skel{background:linear-gradient(90deg,var(--paper-2) 0%,var(--paper-3) 50%,var(--paper-2) 100%);background-size:200% 100%;animation:shimmer 1.6s infinite linear;border-radius:var(--r-2)}.tooltip{position:relative}.tooltip[data-tip]:hover:after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:var(--ink-0);color:var(--paper-0);padding:4px 8px;border-radius:var(--r-2);font-size:11px;white-space:nowrap;z-index:100;pointer-events:none}.login-page{min-height:100vh;display:grid;grid-template-columns:1.1fr 1fr;background:var(--paper-1)}.login-decor{position:relative;background:linear-gradient(135deg,var(--accent) 0%,#5a1f15 100%);display:flex;align-items:center;justify-content:center;padding:60px;color:var(--paper-0);overflow:hidden}.login-decor:before{content:"";position:absolute;top:24px;right:24px;bottom:24px;left:24px;border:1px solid rgba(251,246,234,.18);pointer-events:none}.login-quote{max-width:420px;position:relative;z-index:1}.login-quote-mark{font-family:var(--serif);font-size:120px;line-height:.5;font-style:italic;color:#fbf6ea59;margin-bottom:8px}.login-quote-text{font-family:var(--serif);font-size:38px;font-style:italic;line-height:1.25;color:var(--paper-0)}.login-quote-attr{margin-top:16px;font-size:13px;letter-spacing:.04em;color:#fbf6eab3}.login-quote-rule{width:60px;height:1px;background:#fbf6ea66;margin:32px 0}.login-quote-sub{font-family:var(--serif);font-size:18px;line-height:1.55;color:#fbf6ead9}.login-form-wrap{display:flex;align-items:center;justify-content:center;padding:60px}.login-form{width:100%;max-width:380px;padding:36px 32px}.login-mobile-welcome{display:none}@media (max-width: 760px){.login-mobile-welcome{display:block;margin-bottom:20px}.login-mobile-tagline{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--ink-3);line-height:1.6;text-align:center;margin:0}}@media (max-width: 480px){.login-form-wrap{padding:24px 16px}.login-form{padding:24px 20px}.login-tabs button{font-size:13px;padding:10px 0}.form-row{margin-bottom:14px}}.login-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:1px solid var(--paper-4)}.login-tabs button{flex:1;padding:10px 0;color:var(--ink-4);font-size:14px;border-bottom:2px solid transparent;margin-bottom:-1px}.login-tabs button.on{color:var(--ink-0);border-color:var(--accent);font-weight:600}.form-row{margin-bottom:16px}.login-footnote{text-align:center;margin-top:18px;font-size:11px;color:var(--ink-4);letter-spacing:.04em}.course-shelf{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(270px,100%),1fr));gap:24px;margin-top:24px}.course-card{background:var(--paper-0);border:1px solid var(--paper-4);border-radius:var(--r-4);overflow:hidden;cursor:pointer;transition:transform .18s,box-shadow .18s,border-color .18s;box-shadow:var(--shadow-1);display:flex;flex-direction:column;min-height:240px;text-decoration:none;color:inherit}.course-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-3);border-color:var(--ink-4)}.course-spine{height:110px;position:relative;display:flex;align-items:flex-end;padding:16px;color:var(--paper-0);background:var(--accent)}.course-spine:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(45deg,transparent 0 14px,rgba(0,0,0,.05) 14px 15px);pointer-events:none}.course-spine-title{font-family:var(--serif);font-size:22px;font-style:italic;line-height:1.15;position:relative;z-index:1}.course-body{padding:16px 18px 18px;flex:1;display:flex;flex-direction:column}.course-title{font-size:17px;line-height:1.25;color:var(--ink-0)}.course-sub{font-size:12px;color:var(--ink-4);margin-top:4px;font-family:var(--serif);font-style:italic}.course-meta{margin-top:16px;display:flex;align-items:center;gap:10px;font-size:12px;color:var(--ink-3)}.course-progress-track{flex:1;height:4px;background:var(--paper-3);border-radius:100px;overflow:hidden}.course-progress-fill{height:100%;background:var(--accent);border-radius:100px;transition:width .3s}.course-stats{margin-top:auto;padding-top:12px;display:flex;gap:16px;font-size:12px;color:var(--ink-3);border-top:1px solid var(--paper-3)}.course-card-add{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:transparent;border:1px dashed var(--paper-4);color:var(--ink-3);text-align:center;padding:32px;cursor:pointer;text-decoration:none}.course-card-add:hover{border-color:var(--accent);color:var(--ink-1)}.add-plus{font-size:36px;color:var(--accent);font-family:var(--serif);font-weight:300;line-height:1}.upload-drop{margin-top:20px;padding:56px;border:2px dashed var(--paper-4);background:var(--paper-0);border-radius:var(--r-4);display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:border .15s,background .15s}.upload-drop:hover{border-color:var(--accent);background:var(--accent-wash)}.upload-drop-icon{font-size:42px;color:var(--accent);font-family:var(--serif)}.upload-tips{margin-top:36px;display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.upload-tip{display:flex;gap:14px}.upload-tip-num{font-size:22px;color:var(--accent);line-height:1}.upload-tip-title{font-size:15px;color:var(--ink-0);margin-bottom:4px}.upload-progress{padding:24px 28px}.progress-track{height:6px;background:var(--paper-3);border-radius:100px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:100px;transition:width .18s}.upload-stages{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:24px}.upload-stage{display:flex;gap:10px;align-items:flex-start;padding:12px;border-radius:var(--r-3);border:1px solid var(--paper-3);opacity:.55}.upload-stage.active{opacity:1;border-color:var(--accent-tint);background:var(--accent-wash)}.upload-stage.done{opacity:1}.upload-stage-marker{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;background:var(--paper-2);color:var(--ink-3);font-size:12px;font-family:var(--mono);flex-shrink:0}.upload-stage.done .upload-stage-marker{background:var(--sage);color:var(--paper-0)}.upload-stage.active .upload-stage-marker{background:var(--accent);color:var(--paper-0)}.upload-stage-label{font-weight:500;color:var(--ink-1);font-size:13px}.upload-spinner{width:12px;height:12px;border:2px solid var(--paper-0);border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite;display:inline-block}.upload-spinner.big{width:18px;height:18px;border-color:var(--accent);border-top-color:transparent;border-width:2.5px}@keyframes spin{to{transform:rotate(360deg)}}.course-page{display:grid;grid-template-columns:320px 1fr;min-height:calc(100vh - 52px)}.tree-sidebar{border-right:1px solid var(--paper-4);background:var(--paper-0);display:flex;flex-direction:column;height:calc(100vh - 52px);position:sticky;top:52px;min-height:0;overflow:hidden}.tree-header{padding:16px 20px;border-bottom:1px solid var(--paper-3)}.tree-header-title{font-size:15px;color:var(--ink-0);margin-bottom:8px}.tree-header-meta{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-3);margin-bottom:10px}.tree-legend{display:flex;gap:12px;font-size:11px;color:var(--ink-4)}.tree-legend>span{display:flex;align-items:center;gap:4px}.tree-scroll{overflow-y:auto;padding:8px 0;flex:1}.tree{font-size:13px}.tree-row{display:flex;align-items:center;gap:6px;padding:4px 12px 4px 14px;cursor:pointer;color:var(--ink-2);-webkit-user-select:none;user-select:none;position:relative;text-decoration:none}.tree-row:hover{background:var(--paper-2)}.tree-row .indent{width:12px;flex-shrink:0}.tree-row .twirl{font-size:9px;color:var(--ink-4);width:10px;flex-shrink:0;transition:transform .12s}.tree-row .twirl.open{transform:rotate(90deg)}.tree-row .tree-glyph.current{color:var(--accent);font-weight:700;width:8px}.tree-row .tree-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-row .tree-meta{font-family:var(--mono);font-size:10px;color:var(--ink-5);font-feature-settings:"tnum"}.tree-row-chapter{font-family:var(--serif);font-size:14px;color:var(--ink-0);font-weight:500;padding-top:8px;padding-bottom:6px}.tree-row-section{font-size:13px;color:var(--ink-1)}.tree-row-kp{color:var(--ink-2);padding-left:8px}.tree-row.is-current{background:var(--accent-wash);color:var(--ink-0);font-weight:500;position:relative}.tree-row.is-current:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--accent)}.tree-dense .tree-row{padding-top:2px;padding-bottom:2px;font-size:12px}.tree-dense .tree-row-chapter{font-size:13px;padding-top:6px}.course-main{padding:32px 48px 80px;max-width:880px}.gen-hero{position:relative;background:var(--paper-0);border:1px solid var(--paper-4);border-radius:var(--r-4);padding:28px 30px 24px;margin-bottom:28px;overflow:hidden;box-shadow:var(--shadow-2);animation:page-in .45s ease-out}.gen-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 0% 100%,rgba(138,51,36,.05) 0,transparent 38%),radial-gradient(circle at 100% 0%,rgba(168,118,29,.04) 0,transparent 42%);pointer-events:none}.gen-hero>*{position:relative;z-index:1}.gen-hero-head{display:flex;align-items:center;gap:12px;margin-bottom:18px}.gen-quill{color:var(--accent);flex-shrink:0;transform-origin:6px 20px;animation:gen-quill-bob 2.6s ease-in-out infinite}@keyframes gen-quill-bob{0%,to{transform:rotate(-6deg) translateY(0)}25%{transform:rotate(-12deg) translateY(-1px)}50%{transform:rotate(-2deg) translateY(-3px)}75%{transform:rotate(-9deg) translateY(-1px)}}.gen-title-text{font-family:var(--serif);font-size:22px;font-style:italic;color:var(--ink-0);font-weight:500;letter-spacing:.01em}.gen-dots{display:inline-block;margin-left:4px;letter-spacing:2px;color:var(--accent)}.gen-dots span{display:inline-block;opacity:.2;animation:gen-dot-fade 1.5s infinite}.gen-dots span:nth-child(1){animation-delay:0s}.gen-dots span:nth-child(2){animation-delay:.25s}.gen-dots span:nth-child(3){animation-delay:.5s}@keyframes gen-dot-fade{0%,80%,to{opacity:.2}30%,50%{opacity:1}}.gen-count{margin-left:auto;font-size:13px;color:var(--ink-2);letter-spacing:.02em}.gen-progress-track{height:5px;background:var(--paper-3);border-radius:100px;overflow:hidden;margin-bottom:28px;position:relative}.gen-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent) 0%,var(--accent-soft) 50%,var(--accent) 100%);background-size:200% 100%;animation:gen-ink-flow 2.4s linear infinite;border-radius:100px;transition:width .8s ease}@keyframes gen-ink-flow{0%{background-position:100% 0}to{background-position:-100% 0}}.gen-stages{display:flex;align-items:flex-start;margin-bottom:28px;position:relative}.gen-stage{flex:1;display:flex;flex-direction:column;align-items:center;gap:10px;position:relative;padding:0 8px}.gen-stage-dot{width:14px;height:14px;border-radius:50%;background:var(--paper-2);border:1.5px solid var(--paper-4);position:relative;z-index:2;transition:background .4s,border-color .4s}.gen-stage-label{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--ink-4);text-align:center;white-space:nowrap;transition:color .4s,font-weight .4s}.gen-stage-line{position:absolute;top:7px;left:50%;width:calc(100% - 8px);height:1.5px;background:var(--paper-3);z-index:1;transition:background .6s}.gen-stage-done .gen-stage-dot{background:var(--accent);border-color:var(--accent)}.gen-stage-done .gen-stage-line{background:var(--accent)}.gen-stage-done .gen-stage-label{color:var(--ink-2)}.gen-stage-active .gen-stage-dot{background:var(--accent);border-color:var(--accent);animation:gen-stage-pulse 1.6s ease-out infinite}.gen-stage-active .gen-stage-label{color:var(--accent);font-weight:500}@keyframes gen-stage-pulse{0%{box-shadow:0 0 #8a332473,0 0 #8a332440}70%{box-shadow:0 0 0 8px #8a332400,0 0 0 16px #8a332400}to{box-shadow:0 0 #8a332400,0 0 #8a332400}}.gen-progress-indeterminate{animation:gen-ink-flow 2.4s linear infinite,gen-progress-slide 2.6s cubic-bezier(.5,0,.5,1) infinite}@keyframes gen-progress-slide{0%{margin-left:-30%;width:30%}50%{margin-left:50%;width:50%}to{margin-left:100%;width:30%}}.gen-blurb{background:var(--paper-1);border:1px solid var(--paper-3);border-radius:var(--r-3);padding:18px 22px 20px;position:relative;animation:gen-blurb-in .6s cubic-bezier(.2,.7,.2,1)}@keyframes gen-blurb-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.gen-blurb:before{content:"";position:absolute;top:22px;left:0;width:3px;height:28px;background:var(--accent);border-radius:0 2px 2px 0}.gen-blurb-label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-4);margin-bottom:4px}.gen-blurb-title{font-size:19px;font-style:italic;color:var(--ink-0);font-weight:500;margin-bottom:10px}.gen-blurb-body{display:flex;flex-direction:column;gap:2px}.gen-blurb-line{font-family:var(--serif);font-size:14px;color:var(--ink-2);line-height:1.7;opacity:0;animation:gen-blurb-line-in .5s ease-out forwards}@keyframes gen-blurb-line-in{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:translateY(0)}}.gen-footnote{margin-top:16px;text-align:center;font-size:12px}.tree-skel{padding:16px 18px;display:flex;flex-direction:column;gap:14px}.tree-skel-row{height:12px;border-radius:2px;opacity:0;animation:shimmer 1.8s linear infinite,tree-skel-in .35s ease-out forwards}@keyframes tree-skel-in{to{opacity:1}}.continue-card{background:var(--paper-0);border:1px solid var(--paper-4);border-radius:var(--r-4);padding:24px 28px;position:relative;overflow:hidden}.continue-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent)}.continue-label{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-4);font-weight:600;margin-bottom:6px}.continue-title{font-family:var(--serif);font-size:26px;color:var(--ink-0);line-height:1.2}.continue-crumb{font-size:12px;color:var(--ink-4);margin-top:6px}.continue-summary{margin-top:14px;font-family:var(--serif);font-size:16px;color:var(--ink-2);line-height:1.55;max-width:560px}.ch-overview{display:flex;flex-direction:column;gap:6px}.ch-row{display:grid;grid-template-columns:18px 1.5fr 2fr auto;align-items:center;gap:16px;padding:10px 14px;border-radius:var(--r-2)}.ch-row:hover{background:var(--paper-2)}.ch-name{font-size:14px;color:var(--ink-1)}.ch-bar{display:flex;gap:2px}.ch-bar-cell{flex:1;height:14px;border-radius:1px;position:relative}.ch-bar-cell.cur:after{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border:1.5px solid var(--accent);border-radius:2px}.ch-counts{font-size:12px}.dialogue-page{display:grid;grid-template-columns:260px 1fr 300px;height:calc(100vh - 52px);position:relative}.dialogue-left{grid-column:1;grid-row:1}.dialogue-center{grid-column:2;grid-row:1}.dialogue-right{grid-column:3;grid-row:1}.dialogue-left{border-right:1px solid var(--paper-4);background:var(--paper-0);display:flex;flex-direction:column;overflow:hidden;min-height:0;min-width:0}.dialogue-left-head{padding:16px 18px;border-bottom:1px solid var(--paper-3)}.dialogue-crumb{font-size:11px;color:var(--ink-3);margin-top:8px;line-height:1.55;font-feature-settings:"tnum"}.dialogue-left-foot{padding:12px;border-top:1px solid var(--paper-3)}.dialogue-center{display:flex;flex-direction:column;background:var(--paper-1);position:relative;min-width:0;min-height:0;overflow:hidden}.dialogue-mobile-nav,.dialogue-mobile-kp-title{display:none}.dialogue-header{padding:16px 32px;border-bottom:1px solid var(--paper-4);display:flex;align-items:flex-end;justify-content:space-between;gap:16px;background:var(--paper-1)}.dialogue-header-actions{display:flex;gap:8px;align-items:center}.dialogue-stream{flex:1 1 0;min-height:0;overflow-y:auto;padding:28px 32px 12px}.dialogue-stream-inner{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:24px}.msg-opener{text-align:center;margin:4px 0 8px}.msg-opener-rule{height:1px;background:linear-gradient(to right,transparent,var(--paper-4),transparent);margin:8px 0}.msg-opener-text{font-size:13px;font-style:italic;color:var(--ink-3);font-family:var(--serif)}.thinking-dots{display:inline-flex;align-items:center;gap:6px;padding:4px 2px}.thinking-dots span{width:7px;height:7px;border-radius:50%;background:var(--ink-4);animation:think-bounce 1.3s ease-in-out infinite}.thinking-dots span:nth-child(1){animation-delay:0s}.thinking-dots span:nth-child(2){animation-delay:.18s}.thinking-dots span:nth-child(3){animation-delay:.36s}@keyframes think-bounce{0%,80%,to{transform:scale(.65);opacity:.3}35%{transform:scale(1);opacity:.95;background:var(--accent)}}.msg-pending{display:inline-flex;align-items:center;gap:12px;padding:2px 4px}.msg-pending-quill{color:var(--accent);flex-shrink:0;transform-origin:6px 20px;animation:gen-quill-bob 2.6s ease-in-out infinite}.msg-pending-text{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--ink-3)}.msg-user{display:flex;justify-content:flex-end}.msg-bubble-user{background:var(--ink-1);color:var(--paper-0);padding:12px 16px;border-radius:14px 14px 4px;max-width:80%;line-height:1.55;font-size:14.5px}.msg-ai{display:flex;gap:14px;align-items:flex-start}.msg-ai-mark{flex-shrink:0;padding-top:2px}.msg-ai-mark .mark{width:28px;height:28px;background:var(--accent);color:var(--paper-0);border-radius:4px;display:grid;place-items:center;font-family:var(--serif);font-style:italic;font-weight:600}.msg-ai-mark .mark.mark-img{object-fit:cover;background:var(--paper-3)}.msg-ai-body{flex:1;min-width:0}.msg-bubble-ai{background:var(--paper-0);border:1px solid var(--paper-3);padding:14px 18px;border-radius:4px 14px 14px;line-height:1.65;color:var(--ink-1);font-family:var(--serif);font-size:16px}.msg-bubble-ai strong{color:var(--ink-0);font-weight:600}.msg-code{background:var(--paper-2);border:1px solid var(--paper-4);padding:10px 12px;margin:10px 0;border-radius:var(--r-2);font-family:var(--mono);font-size:12.5px;line-height:1.5;white-space:pre;overflow-x:auto;color:var(--ink-1)}.msg-meta{margin-top:8px;font-size:11px;color:var(--ink-4);display:flex;align-items:center;gap:6px}.dialogue-composer{border-top:1px solid var(--paper-4);padding:14px 32px 20px;background:var(--paper-1)}.composer-suggestions{display:flex;gap:8px;margin-bottom:12px;max-width:720px;margin-left:auto;margin-right:auto;flex-wrap:wrap}.suggest-chip{padding:6px 12px;background:var(--paper-0);border:1px solid var(--paper-4);border-radius:100px;font-size:12.5px;color:var(--ink-2);cursor:pointer;transition:border .12s,color .12s}.suggest-chip:hover{border-color:var(--accent);color:var(--accent)}.suggest-chip:disabled{opacity:.5;cursor:default}.composer-input-row{max-width:720px;margin:0 auto;background:var(--paper-0);border:1px solid var(--paper-4);border-radius:var(--r-3);padding:4px 4px 4px 12px;display:flex;gap:8px;align-items:flex-end;transition:border .12s}.composer-input-row:focus-within{border-color:var(--ink-3);box-shadow:0 0 0 3px var(--paper-3)}.composer-input{flex:1;border:none;background:transparent;resize:none;outline:none;padding:10px 0;font-size:14.5px;color:var(--ink-1);line-height:1.55;font-family:var(--sans);max-height:160px}.composer-input::placeholder{color:var(--ink-5);font-size:13.5px}.composer-actions{display:flex;gap:4px;padding-bottom:6px}.dialogue-right{border-left:1px solid var(--paper-4);background:var(--paper-1);padding:16px;display:flex;flex-direction:column;gap:14px;overflow-y:auto;min-height:0;min-width:0}.right-card{padding:16px}.right-card-title{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-4);font-weight:600;margin-bottom:12px}.right-divider{height:1px;background:var(--paper-3);margin:14px 0}.right-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px}.turn-gauge{position:relative;text-align:center}.turn-gauge-foot{font-size:11px;margin-top:2px}.rescue-list{display:flex;flex-direction:column;gap:6px}.rescue-btn{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:var(--r-3);background:transparent;text-align:left;font-size:13px;color:var(--ink-1);cursor:pointer;transition:background .12s;width:100%}.rescue-btn:hover{background:var(--paper-2)}.rescue-glyph{font-size:18px;width:24px;flex-shrink:0;text-align:center}.rescue-btn .margin-note{font-size:11px;margin-top:2px}.keyphrase-cloud{display:flex;flex-wrap:wrap;gap:6px}.keyphrase{padding:4px 10px;background:var(--paper-2);border:1px solid var(--paper-4);border-radius:100px;font-size:12px;color:var(--ink-2);font-family:var(--serif);font-style:italic}.exercise-list{display:flex;flex-direction:column;gap:16px}.exercise-card{padding:24px 28px}.exercise-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}.exercise-num{font-size:11px;color:var(--ink-4);letter-spacing:.08em;font-weight:600}.exercise-meta{display:flex;gap:6px;flex-wrap:wrap}.exercise-q{font-family:var(--serif);font-size:18px;color:var(--ink-0);line-height:1.45;margin-bottom:16px}.exercise-options{display:flex;flex-direction:column;gap:8px}.exercise-option{display:flex;gap:12px;align-items:flex-start;padding:12px 14px;background:var(--paper-1);border:1px solid var(--paper-4);border-radius:var(--r-3);font-size:14px;color:var(--ink-1);cursor:pointer;text-align:left;transition:border .12s,background .12s}.exercise-option:hover:not(:disabled){border-color:var(--ink-4);background:var(--paper-2)}.exercise-option.sel{border-color:var(--accent);background:var(--accent-wash)}.exercise-option.right{border-color:var(--sage);background:var(--sage-wash)}.exercise-option.wrong{border-color:var(--accent);background:var(--accent-wash);text-decoration:line-through;text-decoration-color:var(--accent)}.opt-letter{width:24px;height:24px;display:grid;place-items:center;border-radius:var(--r-2);background:var(--paper-2);border:1px solid var(--paper-4);font-size:12px;color:var(--ink-3);flex-shrink:0}.exercise-option.sel .opt-letter{background:var(--accent);color:var(--paper-0);border-color:var(--accent)}.exercise-option.right .opt-letter{background:var(--sage);color:var(--paper-0);border-color:var(--sage)}.opt-mark{margin-left:auto;font-weight:700}.exercise-option.right .opt-mark{color:var(--sage)}.exercise-option.wrong .opt-mark{color:var(--accent)}.exercise-short{display:flex;flex-direction:column;gap:8px}.rich-toolbar{display:flex;gap:4px;align-items:center;padding:6px 8px;background:var(--paper-1);border:1px solid var(--paper-4);border-radius:var(--r-3) var(--r-3) 0 0;border-bottom:none;font-size:13px}.rich-toolbar>button{padding:4px 10px;background:transparent;border-radius:var(--r-2);color:var(--ink-2)}.rich-toolbar>button:hover{background:var(--paper-3);color:var(--ink-0)}.rich-sep{width:1px;height:16px;background:var(--paper-4)}.exercise-short .input{border-radius:0 0 var(--r-3) var(--r-3)}.exercise-feedback{margin-top:16px;padding:12px 14px 12px 16px;background:var(--paper-1);border-left:2px solid var(--accent);border-radius:var(--r-2);font-family:var(--serif);font-size:14.5px;line-height:1.6;color:var(--ink-2)}.exercise-feedback-mark{font-family:var(--sans);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);font-weight:600;margin-bottom:4px}.exercise-submit-bar{margin-top:24px;padding:16px 20px;background:var(--paper-0);border:1px solid var(--paper-4);border-radius:var(--r-4);display:flex;align-items:center;justify-content:space-between;gap:16px;position:sticky;bottom:16px;box-shadow:var(--shadow-2)}.grading-card{padding:20px 24px;margin-bottom:24px}.grading-stages{margin-top:14px;display:flex;gap:8px}.grading-stage{padding:6px 12px;background:var(--paper-2);border-radius:100px;font-size:12px;color:var(--ink-4)}.grading-stage.active{background:var(--accent-wash);color:var(--accent)}.grading-stage.done{background:var(--sage-wash);color:var(--sage)}.grade-banner{padding:24px 28px;margin-bottom:32px;display:flex;gap:28px;align-items:center;background:linear-gradient(135deg,var(--paper-0),var(--accent-wash));border-color:var(--accent-tint)}.grade-score{display:flex;align-items:baseline;flex-shrink:0}.grade-score-num{font-size:64px;color:var(--accent);line-height:.95;font-weight:500}.grade-score-of{font-size:16px;color:var(--ink-3);margin-left:4px}.grade-summary{flex:1}.grade-actions{margin-top:14px;display:flex;gap:8px;flex-wrap:wrap}.result-card{padding:32px}.result-header{display:flex;gap:28px;align-items:center}.result-score-circle{position:relative;width:120px;height:120px;flex-shrink:0}.result-score-num{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-size:36px;color:var(--ink-0)}.result-divider{height:1px;background:var(--paper-3);margin:24px 0}.result-finds-title{font-family:var(--serif);font-size:18px;color:var(--ink-0);margin-bottom:12px}.result-find-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.result-find-list li{display:flex;gap:12px;align-items:flex-start;font-size:14px;color:var(--ink-2);line-height:1.55}.result-find-list li .dot{margin-top:7px;flex-shrink:0}.result-actions{display:flex;gap:12px;justify-content:center}.report-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:36px}.stat-card{background:var(--paper-0);border:1px solid var(--paper-4);border-radius:var(--r-4);padding:18px 20px}.stat-num{font-size:36px;color:var(--ink-0);line-height:1;font-weight:500}.stat-unit{font-size:16px;color:var(--ink-3)}.stat-label{font-size:12px;color:var(--ink-4);margin:4px 0 12px;letter-spacing:.04em}.stat-bar{height:4px;background:var(--paper-3);border-radius:100px;overflow:hidden}.stat-bar-fill{height:100%;border-radius:100px}.stat-segs{display:flex;gap:3px;margin-top:4px}.stat-seg{flex:1;height:6px;border-radius:1px;background:var(--paper-3)}.seg-passed{background:var(--sage)}.seg-progress{background:var(--ochre)}.seg-untouched{background:var(--paper-3)}.report-cols{display:grid;grid-template-columns:1fr 1fr;gap:32px}.weak-list,.history-list{display:flex;flex-direction:column;gap:10px}.weak-item{padding:14px 16px}.weak-item-head{display:flex;align-items:center;gap:10px;margin-bottom:6px}.weak-item-note{font-family:var(--serif);font-size:14px;color:var(--ink-2);font-style:italic;line-height:1.55}.weak-item-foot{display:flex;justify-content:space-between;align-items:center;margin-top:10px}.history-row{display:flex;gap:14px;align-items:center;padding:12px 14px}.history-row-bar{width:6px;height:36px;background:var(--paper-3);border-radius:100px;overflow:hidden;display:flex;align-items:flex-end}.history-row-bar-fill{width:100%;border-radius:100px}.history-row-body{flex:1}.history-row-score{display:flex;align-items:baseline;gap:2px}.config-locked{padding:16px 20px;background:var(--paper-0);border-color:var(--accent-tint);margin-top:16px}.config-locked-head{display:flex;align-items:center;gap:10px;font-size:14px;margin-bottom:8px}.config-locked-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:6px 24px;font-size:13px;color:var(--ink-2);font-family:var(--serif)}.config-locked-list li{position:relative;padding-left:16px}.config-locked-list li:before{content:"✦";position:absolute;left:0;color:var(--accent);font-size:10px;top:4px}.config-fields{display:flex;flex-direction:column;gap:28px;margin-top:12px}.config-field{display:grid;grid-template-columns:56px 1fr;gap:16px;align-items:flex-start}.config-field-num{font-size:28px;color:var(--accent);font-weight:300;line-height:1;padding-top:6px;text-align:right}.casting-page{max-width:1280px;margin:0 auto;padding:28px 32px 80px;min-height:100vh;opacity:1!important;animation:none!important}.casting-back-wrap{margin-bottom:10px}.casting-head{position:relative;display:grid;grid-template-columns:auto 1fr auto;align-items:start;gap:24px;margin-bottom:4px}.casting-titleblock{max-width:720px;padding-top:4px}.casting-eyebrow{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;color:var(--ink-4);margin-bottom:6px;text-transform:uppercase}.casting-title{margin:0 0 12px;font-size:calc(38px * var(--type-scale, 1));line-height:1.1;letter-spacing:-.012em}.casting-lede{margin:0;font-family:var(--serif);font-size:15.5px;line-height:1.7;color:var(--ink-2)}.casting-lede em{font-style:italic;color:var(--accent)}.casting-portrait{position:relative;justify-self:center;align-self:center;width:140px;height:140px;border:1px solid var(--paper-4);border-radius:var(--r-3);background:var(--paper-0);overflow:hidden;cursor:pointer;display:grid;place-items:center;transition:border-color .15s}.casting-portrait:hover{border-color:var(--accent)}.casting-portrait-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.casting-portrait-plus{position:relative;z-index:1;font-family:var(--serif);font-size:30px;line-height:1;color:var(--ink-4);transition:opacity .15s}.casting-portrait.is-filled:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--accent);opacity:0;transition:opacity .15s}.casting-portrait.is-filled .casting-portrait-plus{opacity:0;color:var(--paper-0)}.casting-portrait.is-filled:hover:after{opacity:.45}.casting-portrait.is-filled:hover .casting-portrait-plus{opacity:1}.casting-portrait.is-uploading{cursor:progress}.casting-portrait.is-uploading .casting-portrait-plus{opacity:1}.casting-portrait.is-filled.is-uploading:after{opacity:.45}.casting-ornament{font-family:var(--serif);color:var(--accent-soft);font-size:36px;line-height:1;padding-top:6px;-webkit-user-select:none;user-select:none}.casting-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(0,1fr);gap:36px;align-items:start;margin-top:20px}.casting-form{display:flex;flex-direction:column;gap:28px}.casting-section{display:flex;flex-direction:column;gap:12px;animation:casting-fade-up .55s ease-out both}.casting-section:nth-of-type(1){animation-delay:80ms}.casting-section:nth-of-type(2){animation-delay:.22s}@keyframes casting-fade-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.casting-section-head{display:grid;grid-template-columns:48px 1fr;gap:18px;align-items:start}.casting-section-num{font-family:var(--serif);font-size:40px;line-height:1;color:var(--accent);font-weight:400;text-align:center;padding-top:2px;-webkit-user-select:none;user-select:none}.casting-section-title{margin:0;font-size:22px;letter-spacing:-.005em}.casting-section-sub{margin-top:4px;max-width:560px;font-size:13px;line-height:1.6}.manuscript-input{width:100%;background:var(--paper-0);border:1px solid var(--paper-3);border-left:3px solid var(--accent-tint);border-radius:var(--r-2);padding:16px 18px;font-family:var(--serif);font-size:15px;line-height:1.75;color:var(--ink-1);resize:vertical;min-height:240px;transition:border-color .15s,box-shadow .15s;outline:none;box-shadow:inset 0 1px #fff6,var(--shadow-1);background-image:repeating-linear-gradient(to bottom,transparent 0,transparent calc(1.75em - 1px),rgba(178,155,120,.08) calc(1.75em - 1px),rgba(178,155,120,.08) 1.75em)}.manuscript-input::placeholder{color:var(--ink-5);font-style:italic}.manuscript-input:focus{border-color:var(--paper-4);border-left-color:var(--accent);box-shadow:inset 0 1px #fff6,0 0 0 3px var(--accent-wash)}.manuscript-input:disabled{background-color:var(--paper-1);opacity:.7}.manuscript-input-sm{min-height:130px;font-size:14.5px;line-height:1.65}.casting-divider{position:relative;text-align:center;margin:4px 0}.casting-divider:before,.casting-divider:after{content:"";position:absolute;top:50%;width:calc(50% - 24px);height:1px;background:linear-gradient(to right,transparent,var(--paper-4),transparent)}.casting-divider:before{left:0}.casting-divider:after{right:0}.casting-divider span{font-family:var(--serif);color:var(--accent-soft);font-size:14px;letter-spacing:.2em}.casting-status{display:flex;align-items:center;gap:14px;padding:14px 18px;background:var(--paper-0);border:1px solid var(--paper-3);border-radius:var(--r-3);box-shadow:var(--shadow-1)}.casting-status-dot{width:10px;height:10px;border-radius:50%;background:var(--ink-4);flex-shrink:0;box-shadow:0 0 0 3px var(--paper-1)}.casting-status-text{flex:1;min-width:0}.casting-status-label{font-family:var(--serif);font-size:15px;color:var(--ink-1);margin-bottom:2px}.casting-status-hint{font-size:12.5px!important;line-height:1.4}.casting-status-dots{color:var(--accent);display:inline-flex;gap:4px;margin-left:6px}.casting-status-ready .casting-status-dot{background:var(--sage)}.casting-status-saving .casting-status-dot,.casting-status-regenerating .casting-status-dot{background:var(--accent)}.casting-status-dirty .casting-status-dot{background:var(--ochre)}.casting-status-stale .casting-status-dot{background:var(--ochre-soft)}.casting-status-empty .casting-status-dot{background:var(--ink-5)}.casting-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.casting-actions-meta{margin-left:auto;font-size:12.5px;font-family:var(--serif);font-style:italic}.casting-footnote{font-size:12.5px!important;color:var(--ink-3)!important;padding:14px 0 0;border-top:1px dashed var(--paper-4);font-style:italic;font-family:var(--serif)}.audition{position:sticky;top:76px;display:flex;flex-direction:column;height:calc(100vh - 100px);min-height:520px;background:var(--paper-0);border:1px solid var(--paper-3);border-radius:var(--r-4);box-shadow:var(--shadow-2);overflow:hidden;animation:audition-curtain-rise .6s ease-out .32s both}@keyframes audition-curtain-rise{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.audition-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 20px 12px}.audition-eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--ink-4);text-transform:uppercase;margin-bottom:2px}.audition-title{margin:0;font-size:19px;color:var(--ink-0)}.audition-curtain{height:6px;background:linear-gradient(to bottom,var(--accent) 0,var(--accent) 1px,transparent 1px,transparent 3px,var(--accent-soft) 3px,var(--accent-soft) 4px,transparent 4px);opacity:.5;margin:0 20px;position:relative}.audition-curtain:before,.audition-curtain:after{content:"❖";position:absolute;top:-6px;font-size:11px;color:var(--accent-soft)}.audition-curtain:before{left:-8px}.audition-curtain:after{right:-8px}.audition-stage{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:14px;contain:layout paint;scroll-behavior:smooth}.audition-streaming-text{display:inline;white-space:pre-wrap;word-break:break-word}.audition-empty{margin:auto;text-align:center;max-width:260px;color:var(--ink-3);display:flex;flex-direction:column;align-items:center;gap:10px}.audition-empty-glyph{font-family:var(--serif);color:var(--accent-soft);font-size:32px;line-height:1}.audition-empty-text{font-size:16px;font-style:italic;color:var(--ink-2);line-height:1.5}.audition-empty-hint{font-size:12px!important;color:var(--ink-4)!important}.audition .msg-bubble-ai{font-size:14.5px;padding:10px 14px;line-height:1.55}.audition .msg-bubble-user{font-size:14px;padding:8px 12px}.audition .msg-ai-mark .mark{width:24px;height:24px;font-size:12px}.audition-error{color:var(--accent);font-size:13px;padding:6px 20px 0;font-family:var(--serif);font-style:italic}@media (max-width: 1180px){.dialogue-page{grid-template-columns:220px 1fr 260px}}@media (max-width: 980px){.course-page{grid-template-columns:260px 1fr}.dialogue-page{grid-template-columns:200px 1fr}.dialogue-right{display:none}.report-cols,.upload-tips,.upload-stages,.report-stats{grid-template-columns:1fr 1fr}.casting-grid,.casting-head{grid-template-columns:1fr}.casting-ornament{display:none}.audition{position:static;height:520px;min-height:0}.topbar-nav-links{display:none}}@media (max-width: 760px){.topbar{padding:0 16px;gap:10px}.topbar-brand span{display:none}.topbar-crumbs{font-size:12px}.topbar-user span,.topbar-nav-links,.topbar-course-actions{display:none}.login-page{grid-template-columns:1fr}.login-decor{display:none}.login-form-wrap{padding:24px 16px}.login-form{padding:24px 20px}.course-shelf{grid-template-columns:1fr;gap:16px}.course-page{grid-template-columns:1fr}.tree-sidebar{height:auto;position:static;max-height:45vh;border-right:none;border-bottom:1px solid var(--paper-4)}.course-main{padding:20px 16px 60px}.dialogue-page{grid-template-columns:1fr}.dialogue-left{display:none}.dialogue-mobile-nav{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--paper-3);background:var(--paper-0);min-height:44px}.dialogue-mobile-kp-title{display:block;font-family:var(--serif);font-size:14px;color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.dialogue-header{padding:12px 16px}.dialogue-stream{padding:16px}.dialogue-composer{padding:12px 16px 16px}.report-cols,.upload-tips,.upload-stages,.report-stats{grid-template-columns:1fr}.upload-drop{padding:32px 16px}.create-course-page{padding:24px 16px 80px}.exercise-card{padding:16px}.exercise-submit-bar{padding:12px 16px;flex-wrap:wrap}.assessment-buckets{grid-template-columns:1fr}.assessment-summary{grid-template-columns:1fr;text-align:center}.casting-page{padding:20px 16px 60px}.casting-head{grid-template-columns:1fr;gap:16px;text-align:center}.casting-portrait{justify-self:center;width:110px;height:110px}.casting-ornament{display:none}.casting-grid{grid-template-columns:1fr;gap:24px}.casting-section-head{grid-template-columns:36px 1fr;gap:12px}.casting-section-num{font-size:30px}.casting-title{font-size:clamp(24px,6vw,32px)}}@media (max-width: 480px){h1{font-size:clamp(20px,6vw,28px)}h2{font-size:clamp(18px,5vw,22px)}.topbar{height:48px;padding:0 12px}.topbar-brand .mark{width:20px;height:20px;font-size:12px}.avatar{width:24px;height:24px;font-size:10px}.course-shelf{gap:12px}.course-card{min-height:200px}.course-spine{height:90px;padding:12px}.course-spine-title{font-size:18px}.course-body{padding:12px 14px 14px}.course-title{font-size:15px}.msg-bubble-user{max-width:90%;font-size:14px;padding:10px 14px}.msg-bubble-ai{font-size:15px;padding:12px 14px}.composer-input{font-size:16px}.paper-composer{border-radius:12px;padding:10px 48px 10px 12px}.btn{min-height:44px;padding:10px 16px}.btn-sm{min-height:36px;padding:6px 12px}.btn-add{width:40px;height:40px}.input{font-size:16px;padding:12px}.manuscript-input{font-size:16px;padding:14px;min-height:200px}}.assessment-page{min-height:calc(100vh - 64px);padding:32px 24px 80px;background:var(--paper-1)}.assessment-shell{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:20px}.assessment-head{padding:8px 4px 4px}.assessment-card{padding:24px 28px}.assessment-card-title{font-family:JetBrains Mono,monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:12px}.assessment-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 0}.assessment-error{padding:8px 0}.assessment-summary{display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:center}.assessment-summary-text{flex:1}.assessment-ring{display:flex;align-items:center;justify-content:center;flex-shrink:0}.assessment-warning{margin-top:18px;padding:12px 16px;background:var(--accent-wash);border-left:3px solid var(--accent);color:var(--ink-1);font-size:13px;line-height:1.6;border-radius:2px}.assessment-warning strong{color:var(--accent)}.assessment-buckets{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.assessment-bucket{background:var(--paper-2);border:1px solid var(--paper-3);border-radius:4px;padding:16px;min-height:140px}.assessment-bucket.bucket-covered{border-left:3px solid #557a4b}.assessment-bucket.bucket-partial{border-left:3px solid #b78c2c}.assessment-bucket.bucket-untouched{border-left:3px solid var(--ink-4);opacity:.85}.assessment-bucket-head{display:flex;align-items:center;gap:8px;margin-bottom:12px}.assessment-bucket-glyph{font-family:JetBrains Mono,monospace;font-size:16px;width:20px;text-align:center}.bucket-covered .assessment-bucket-glyph{color:#557a4b}.bucket-partial .assessment-bucket-glyph{color:#b78c2c}.bucket-untouched .assessment-bucket-glyph{color:var(--ink-4)}.assessment-bucket-title{font-family:Newsreader,serif;font-size:14px;color:var(--ink-0);flex:1}.assessment-bucket-count{font-size:12px;color:var(--ink-3)}.assessment-bucket-empty{font-size:12px;color:var(--ink-4);padding:8px 0}.assessment-bucket-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.assessment-concept-name{font-family:Newsreader,serif;font-size:13px;color:var(--ink-0);font-weight:500}.assessment-concept-detail{font-size:11px;color:var(--ink-3);margin-top:2px;line-height:1.5}.assessment-difficulty{display:flex;gap:12px;flex-wrap:wrap}.assessment-radio{display:flex;flex-direction:column;gap:4px;padding:12px 16px;border:1px solid var(--paper-3);background:var(--paper-2);border-radius:3px;cursor:pointer;flex:1;min-width:140px;transition:border-color .15s,background .15s}.assessment-radio:hover{border-color:var(--ink-4)}.assessment-radio.is-selected{border-color:var(--accent);background:var(--accent-wash)}.assessment-radio input{position:absolute;opacity:0;pointer-events:none}.assessment-radio-label{font-size:14px;color:var(--ink-0)}.assessment-stepper{display:flex;align-items:center;gap:12px}.assessment-stepper-num{font-size:24px;color:var(--ink-0);min-width:36px;text-align:center}.assessment-actions{display:flex;justify-content:space-between;align-items:center;margin-top:8px}.upload-drop.is-drag-active{border-color:var(--accent);background:var(--accent-wash);transform:scale(1.005);box-shadow:0 0 0 3px var(--accent-tint)}.upload-drop.is-filled{border-style:solid;border-color:#557a4b}.upload-drop.is-filled .upload-drop-icon{color:#557a4b}.paper-composer{position:relative;max-width:720px;margin:0 auto;background:var(--paper-0);border:1px solid var(--paper-3);border-radius:14px;padding:12px 56px 12px 16px;box-shadow:0 1px 0 var(--paper-2) inset,0 2px 6px #1c150c0a;transition:border-color .15s,box-shadow .15s}.paper-composer:focus-within{border-color:var(--accent-soft);box-shadow:0 0 0 3px var(--accent-tint),0 1px 0 var(--paper-2) inset}.paper-composer-input{width:100%;border:none;background:transparent;outline:none;resize:none;padding:0;font-family:var(--sans);font-size:14.5px;color:var(--ink-1);line-height:1.6;max-height:160px}.paper-composer-input::placeholder{color:var(--ink-5);font-size:13.5px}.paper-composer-input:disabled{color:var(--ink-4);cursor:not-allowed}.paper-composer-send{position:absolute;right:8px;bottom:8px;width:36px;height:36px;border-radius:50%;border:none;background:var(--accent);color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .18s ease,background .15s,opacity .15s;box-shadow:0 2px 4px #8a332440}.paper-composer-send:hover:not(:disabled){transform:scale(1.06) rotate(-6deg);background:var(--accent-soft)}.paper-composer-send:active:not(:disabled){transform:scale(.96)}.paper-composer-send:disabled{background:var(--paper-3);color:var(--ink-5);cursor:not-allowed;box-shadow:none}.paper-composer-compact{margin:0 16px 16px;max-width:none;padding:10px 50px 10px 14px;border-radius:12px}.paper-composer-compact .paper-composer-send{width:32px;height:32px;right:6px;bottom:6px}.paper-composer-compact .paper-composer-input{font-size:14px}.dialogue-loading-overlay{grid-column:1 / -1;display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 64px);background:var(--paper-1);animation:page-in .3s ease}.dialogue-loading-card{display:flex;flex-direction:column;align-items:center;gap:14px;padding:48px 64px;background:var(--paper-0);border:1px solid var(--paper-3);border-radius:16px;box-shadow:0 4px 14px #1c150c0d;max-width:360px;text-align:center}.loading-quill{animation:loading-quill-bob 2.4s ease-in-out infinite}@keyframes loading-quill-bob{0%,to{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-4px) rotate(3deg)}}.loading-skeleton-stack{width:100%;display:flex;flex-direction:column;gap:8px;margin-top:12px}.skeleton-line{height:10px;border-radius:6px;background:linear-gradient(90deg,var(--paper-2) 0%,var(--paper-3) 50%,var(--paper-2) 100%);background-size:200% 100%;animation:shimmer 1.6s linear infinite}.exercise-loading{display:flex;justify-content:center;padding:48px 0 80px;animation:page-in .3s ease}.exercise-loading-card{display:flex;flex-direction:column;align-items:center;gap:14px;padding:40px 56px;background:var(--paper-0);border:1px solid var(--paper-3);border-radius:16px;box-shadow:0 4px 14px #1c150c0d;max-width:420px;text-align:center}.exercise-loading-quill{animation:loading-quill-bob 2.4s ease-in-out infinite}.exercise-loading-stage{display:inline-flex;align-items:center;gap:8px;color:var(--ink-0);animation:page-in .4s ease}.exercise-loading-glyph{font-size:20px}.exercise-loading-bar{width:240px;height:4px;border-radius:4px;background:var(--paper-2);overflow:hidden;margin-top:6px}.exercise-loading-bar-fill{height:100%;width:40%;border-radius:4px;background:linear-gradient(90deg,transparent 0%,var(--accent) 50%,transparent 100%);animation:exercise-bar-sweep 1.6s ease-in-out infinite}@keyframes exercise-bar-sweep{0%{transform:translate(-100%)}to{transform:translate(350%)}}.diary-page-root{max-width:1240px;margin:0 auto;padding:28px 32px 100px;opacity:1!important;animation:none!important}.diary-head{display:grid;grid-template-columns:1fr auto;align-items:end;gap:24px;padding-bottom:18px;border-bottom:1px solid var(--paper-4)}.diary-eyebrow{font-family:var(--serif);font-style:italic;font-size:12px;letter-spacing:.28em;color:var(--ink-4);text-transform:uppercase}.diary-head h1{margin:6px 0 4px;font-size:calc(38px * var(--type-scale, 1));letter-spacing:-.012em}.diary-subtitle{font-family:var(--serif);color:var(--ink-3);font-style:italic;font-size:16px}.diary-head-meta{text-align:right;font-family:var(--serif);color:var(--ink-3);font-size:13px;line-height:1.7}.diary-head-meta .num{font-family:var(--serif);font-size:32px;color:var(--ink-0);display:block;line-height:1}.diary-head-meta .num-unit{font-size:14px;color:var(--ink-4);margin-left:4px}.diary-head-ornament{margin-top:8px;font-family:var(--serif);color:var(--accent);letter-spacing:.4em;font-size:14px}.diary-body{margin-top:28px;display:grid;grid-template-columns:minmax(190px,220px) minmax(0,1fr) minmax(190px,240px);gap:24px;align-items:start}.diary-toc{position:sticky;top:72px;border-right:1px solid var(--paper-4);padding-right:18px;margin-right:-6px;max-height:calc(100vh - 100px);overflow-y:auto}.diary-toc-title{font-family:var(--serif);font-style:italic;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-4);margin-bottom:14px;padding-bottom:8px;border-bottom:1px dotted var(--paper-4)}.diary-toc-list{display:flex;flex-direction:column;gap:2px}.diary-toc-item{display:grid;grid-template-columns:8px 1fr;align-items:start;gap:10px;padding:9px 10px 9px 0;border-radius:var(--r-2);cursor:pointer;position:relative;transition:background .14s;background:none;border:none;text-align:left;width:100%;font:inherit;color:inherit}.diary-toc-item:hover,.diary-toc-item.active{background:var(--paper-2)}.diary-toc-item.active:before{content:"";position:absolute;left:-19px;top:0;bottom:0;width:3px;background:var(--accent);border-radius:0 2px 2px 0}.diary-toc-stamp{width:8px;height:8px;border-radius:50%;margin-top:8px;flex-shrink:0}.diary-toc-stamp.ink-oxblood{background:var(--accent)}.diary-toc-stamp.ink-sage{background:var(--sage)}.diary-toc-stamp.ink-pending{background:var(--paper-1);border:1.5px dashed var(--ink-5)}.diary-toc-date{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--ink-4)}.diary-toc-kp{font-family:var(--serif);font-size:14px;color:var(--ink-1);margin-top:2px;line-height:1.35}.diary-toc-item.active .diary-toc-kp{color:var(--ink-0)}.diary-toc-item.pending .diary-toc-kp{color:var(--ink-3);font-style:italic}.diary-toc-aux{display:flex;align-items:center;gap:6px;margin-top:3px;font-size:10.5px;color:var(--ink-4);font-family:var(--serif);font-style:italic}.diary-toc-aux .retry-tag{background:var(--accent-wash);color:var(--accent);padding:0 6px;border-radius:100px;font-style:normal;font-family:var(--mono);font-size:9.5px;letter-spacing:.04em}.diary-spread{position:relative;background:var(--paper-0);border:1px solid var(--paper-4);border-radius:var(--r-3);box-shadow:0 1px #1c150c0a,0 14px 36px -16px #1c150c2e,inset 0 0 0 1px #fff6;padding:56px 64px 72px;min-height:720px;font-family:var(--serif);background-image:radial-gradient(circle at 16% 18%,rgba(168,118,29,.04) 0,transparent 36%),radial-gradient(circle at 84% 76%,rgba(138,51,36,.03) 0,transparent 38%),repeating-linear-gradient(to bottom,transparent 0,transparent 33px,rgba(178,155,120,.05) 33px,rgba(178,155,120,.05) 34px)}@keyframes page-turn{0%{opacity:0;transform:translate(8px) rotateY(-2deg)}to{opacity:1;transform:translate(0) rotateY(0)}}.diary-spread.turning{animation:page-turn .32s ease-out}.diary-spread:before{content:"";position:absolute;top:0;bottom:0;left:0;width:18px;background:linear-gradient(to right,rgba(28,21,12,.1) 0%,rgba(28,21,12,.04) 40%,transparent 100%);border-radius:var(--r-3) 0 0 var(--r-3);pointer-events:none}.diary-entry-top{display:flex;align-items:baseline;justify-content:space-between;gap:16px;padding-bottom:12px;border-bottom:1px solid var(--paper-3);margin-bottom:28px;min-width:0}.diary-entry-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-4);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.diary-entry-eyebrow .sep{color:var(--paper-4);margin:0 8px}.diary-entry-eyebrow .retry{color:var(--accent)}.diary-entry-folio{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--ink-4);white-space:nowrap;flex-shrink:0;display:flex;align-items:baseline;gap:12px}.diary-entry-folio .retry-chip{font-family:var(--mono);font-style:normal;background:var(--accent-wash);color:var(--accent);border:1px solid var(--accent-tint);font-size:10px;letter-spacing:.08em;padding:2px 8px;border-radius:100px}.diary-entry-folio .roman{font-variant:small-caps;letter-spacing:.1em;color:var(--ink-2)}.diary-entry-date{display:flex;align-items:baseline;gap:18px;margin:0 0 6px}.diary-entry-date-cn{font-family:var(--serif);font-size:32px;color:var(--ink-0);font-weight:500;letter-spacing:.02em}.diary-entry-date-weather{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--ink-3)}.diary-entry-date-weather:before{content:"·";margin-right:10px;color:var(--ink-5)}.diary-entry-kp{font-family:var(--serif);font-style:italic;font-size:15.5px;color:var(--ink-3);margin:0 0 36px}.diary-entry-body{font-family:var(--serif);font-size:17px;line-height:1.95;color:var(--ink-1);text-align:justify;-webkit-hyphens:auto;hyphens:auto;text-wrap:pretty}.diary-entry-body p{margin:0 0 18px;text-indent:2em}.diary-entry-body p:first-child{text-indent:0}.diary-entry-body p:first-child:first-letter{font-family:var(--serif);font-style:italic;font-weight:500}.diary-entry-body em{color:var(--ink-2)}.diary-entry-body strong{color:var(--ink-0);font-weight:500}.diary-entry-body p.has-dropcap{text-indent:0}.dropcap-char{font-family:var(--serif);float:left;font-size:3.8em;line-height:.86;padding:6px 12px 0 0;margin-top:4px;color:var(--accent);font-style:italic;font-weight:500}.diary-fleuron{text-align:center;margin:22px 0 26px;color:var(--paper-4);font-family:var(--serif);font-size:16px;letter-spacing:.6em}.diary-fleuron span{color:var(--accent);opacity:.7}.diary-sign{display:flex;align-items:flex-end;justify-content:flex-end;gap:14px;margin-top:40px}.diary-sign-rule{width:56px;height:1px;background:var(--ink-4);margin-bottom:14px}.diary-sign-stamp{width:38px;height:38px;border-radius:4px;background:var(--accent);color:var(--paper-0);display:grid;place-items:center;font-family:var(--serif);font-style:italic;font-size:18px;font-weight:500;flex-shrink:0;transform:rotate(-3deg);box-shadow:inset 0 0 0 1.5px #fff6,0 1px #1c150c26;letter-spacing:-.02em}.diary-sign-stamp.ink-sage{background:var(--sage)}.diary-sign-text{text-align:right;white-space:nowrap}.diary-sign-name{font-family:Caveat,Newsreader,cursive;font-size:20px;color:var(--ink-0);line-height:1;letter-spacing:.04em}.diary-sign-name.ink-sage{color:var(--sage)}.diary-sign-name.ink-oxblood{color:var(--accent)}.diary-sign-postscript{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--ink-3);margin-top:4px}.diary-page-footer{position:absolute;bottom:24px;left:64px;right:64px;display:flex;align-items:center;justify-content:space-between;gap:12px;font-family:var(--serif);font-style:italic;font-size:11.5px;color:var(--ink-5);letter-spacing:.04em}.diary-page-footer .ornament{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;color:var(--paper-4);letter-spacing:.4em}.diary-page-footer .ornament:before,.diary-page-footer .ornament:after{content:"";flex:0 1 60px;height:1px;background:linear-gradient(to right,transparent,var(--paper-4),transparent)}.diary-pen-change{margin:-16px 0 36px;padding:14px 18px 14px 22px;border-left:2px solid var(--accent-tint);background:var(--accent-wash);border-radius:0 var(--r-3) var(--r-3) 0;font-family:var(--serif);font-style:italic;font-size:14px;color:var(--ink-2);display:flex;align-items:center;gap:14px}.diary-pen-change-glyph{font-size:22px;color:var(--accent);line-height:1}.diary-pen-change-line{display:flex;flex-direction:column;gap:1px}.diary-pen-change-line .from-to{font-family:var(--mono);font-style:normal;font-size:11px;letter-spacing:.06em;color:var(--ink-4)}.diary-pending{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:100px 40px;text-align:center;color:var(--ink-3);gap:18px}.diary-pending-glyph{font-family:var(--serif);font-size:56px;color:var(--ink-5);position:relative;display:inline-block}.diary-pending-glyph:after{content:"";position:absolute;bottom:-8px;left:50%;width:4px;height:4px;border-radius:50%;background:var(--accent);opacity:0;animation:ink-drop 2.4s ease-in-out infinite}@keyframes ink-drop{0%{opacity:0;transform:translate(-50%,-10px)}40%{opacity:.8;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,30px) scale(.4)}}.diary-pending-text{font-family:var(--serif);font-size:19px;font-style:italic;color:var(--ink-2)}.diary-pending-hint{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--ink-4);max-width:320px;line-height:1.7}.diary-pending-author{margin-top:14px;display:flex;align-items:center;gap:10px;color:var(--ink-3);font-size:13px;font-style:italic}.diary-margin{position:sticky;top:72px;padding-left:8px;border-left:1px dotted var(--paper-4);font-family:var(--serif);color:var(--ink-3);font-size:13px}.diary-margin-title{font-family:var(--serif);font-style:italic;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-4);margin-bottom:18px;padding-bottom:8px;border-bottom:1px dotted var(--paper-4)}.diary-margin-block{margin-bottom:22px}.diary-margin-key{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-4);margin-bottom:4px}.diary-margin-val{font-family:var(--serif);font-size:14px;color:var(--ink-1);font-style:italic;line-height:1.6}.diary-margin-val.score{font-family:var(--serif);font-style:normal;font-size:32px;color:var(--ink-0);line-height:1;display:flex;align-items:baseline;gap:4px}.diary-margin-val.score .over{font-family:var(--mono);font-size:12px;color:var(--ink-4);letter-spacing:.04em}.diary-margin-pencil{font-family:var(--serif);font-style:italic;font-size:12.5px;color:var(--ink-3);margin-top:6px;padding-left:12px;position:relative;line-height:1.6}.diary-margin-pencil:before{content:"";position:absolute;left:0;top:7px;width:6px;height:1px;background:var(--ink-4)}.diary-margin-weakness{background:linear-gradient(to bottom,transparent 0,transparent 90%,var(--accent-wash) 90%,var(--accent-wash) 100%);padding:2px 0;font-style:italic}.diary-margin-stamp{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border-radius:100px;font-size:11px;font-family:var(--sans);font-weight:500;font-style:normal}.diary-margin-stamp.passed{background:var(--sage-wash);color:var(--sage)}.diary-margin-stamp.weak{background:var(--accent-wash);color:var(--accent)}.diary-margin-stamp.progress{background:var(--ochre-wash);color:var(--ochre)}.diary-margin-actions{margin-top:28px;display:flex;flex-direction:column;gap:0}.diary-margin-link{width:100%;display:flex;align-items:stretch;padding:0;background:transparent;border:none;text-align:left;cursor:pointer;position:relative;transition:opacity .2s ease}.diary-margin-link+.diary-margin-link{margin-top:8px}.diary-margin-link:hover{opacity:1}.diary-margin-link:hover .diary-margin-link-line{background:var(--accent);height:100%;top:0}.diary-margin-link:hover .diary-margin-link-label{color:var(--accent)}.diary-margin-link:hover .diary-margin-link-kp{color:var(--accent);opacity:.8}.diary-margin-link:hover svg{stroke:var(--accent);transform:translate(2px)}.diary-margin-link-line{display:block;width:2px;height:60%;background:var(--paper-3);border-radius:1px;position:absolute;left:0;top:20%;transition:all .25s ease}.diary-margin-link-inner{display:flex;align-items:center;gap:10px;padding:10px 14px;margin-left:6px;flex:1;min-width:0}.diary-margin-link-label{font-family:var(--serif);font-size:13.5px;color:var(--ink-2);letter-spacing:.02em;transition:color .2s ease;white-space:nowrap}.diary-margin-link-kp{font-family:var(--serif);font-size:12px;color:var(--ink-4);opacity:.7;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:120px;transition:all .2s ease;flex-shrink:1}.diary-margin-link svg{flex-shrink:0;margin-left:auto;color:var(--ink-4);opacity:.5;transition:all .2s ease}.diary-nav-pill,.diary-nav-pill-divider,.diary-margin-cta,.diary-margin-cta-glyph,.diary-margin-cta-text,.diary-margin-cta-kp{display:none}.diary-nav{margin-top:28px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px;padding:0 4px}.diary-nav-side{font-family:var(--serif);color:var(--ink-4);font-size:13px}.diary-nav-side.left{text-align:left}.diary-nav-side.right{text-align:right}.diary-nav-btn{display:inline-flex;align-items:baseline;gap:10px;background:none;color:var(--ink-2);font-family:var(--serif);font-size:14px;transition:color .14s}.diary-nav-btn:hover:not(:disabled){color:var(--accent)}.diary-nav-btn:disabled{color:var(--ink-5);cursor:default}.diary-nav-btn .arrow{font-size:18px}.diary-nav-btn .peek{font-family:var(--serif);font-style:italic;font-size:12px;color:var(--ink-4);margin-top:2px;display:block;max-width:180px;line-height:1.45;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.diary-nav-folio{font-family:var(--serif);font-style:italic;color:var(--ink-3);font-size:13px;letter-spacing:.04em;display:flex;align-items:center;gap:8px;white-space:nowrap}.diary-nav-folio .num{font-family:var(--serif);font-size:20px;color:var(--ink-0)}.diary-nav-folio .kbd{display:inline-flex;align-items:center;gap:4px;font-family:var(--mono);font-style:normal;font-size:10.5px;color:var(--ink-4);margin-left:6px}.diary-nav-folio .kbd kbd{background:var(--paper-2);border:1px solid var(--paper-4);border-radius:3px;padding:1px 5px;font-size:10px}@media (max-width: 1100px){.diary-body{grid-template-columns:178px minmax(0,1fr) 196px;gap:18px}.diary-spread{padding:40px 38px 64px;min-height:660px}.diary-page-footer{left:38px;right:38px}.diary-entry-body{font-size:16px;line-height:1.88}.diary-entry-date-cn{font-size:28px}.diary-head h1{font-size:calc(32px * var(--type-scale, 1))}.diary-toc{padding-right:14px}.diary-toc-kp{font-size:13.5px}.diary-sign-name{font-size:26px}.diary-sign-stamp{width:34px;height:34px;font-size:16px}}@media (max-width: 880px){.diary-body{grid-template-columns:1fr}.diary-toc,.diary-margin{position:static;border:none;padding:0;max-height:none}.diary-spread{padding:24px 20px 48px;min-height:auto}.diary-page-footer{left:20px;right:20px}.diary-entry-body{font-size:15px;line-height:1.8}.diary-entry-date-cn{font-size:24px}.diary-head h1{font-size:clamp(24px,6vw,32px)}.diary-toc-title,.diary-margin-title{margin-bottom:10px}.diary-nav{gap:12px}}
