.land{max-width:1180px;margin:0 auto;padding:0 28px}.land-nav{display:flex;align-items:center;justify-content:space-between;padding:26px 0 18px}.land-brand{display:flex;align-items:center;gap:12px;font-family:var(--f-kai);font-size:26px;letter-spacing:.2em}.land-brand .seal,.land-foot .seal{width:30px;height:30px;background:var(--cinnabar);border-radius:5px;color:#f3e9d8;font-family:var(--f-kai);font-size:15px;display:grid;place-items:center;box-shadow:0 1px 5px #8c2f2366}.land-links{display:flex;align-items:center;gap:26px}.land-links a{font-size:13px;letter-spacing:.25em;color:var(--ink-soft);text-decoration:none}.land-links a:hover{color:var(--ink)}.land-links a.btn-ink,.land-links a.btn-ink:hover{color:#f0e9d8}.btn-ink.small{padding:9px 20px;font-size:12px;text-decoration:none}.btn-ink.big{padding:14px 38px;font-size:15px;text-decoration:none;display:inline-block}.btn-ghost.big{display:inline-block;padding:13px 30px;font-size:14px;letter-spacing:.3em;text-indent:.3em;color:var(--ink-soft);border:1px solid rgba(43,38,32,.35);text-decoration:none;transition:all .3s;background:#fffcf466}.btn-ghost.big:hover{color:var(--ink);border-color:var(--ink);transform:translateY(-2px)}.hero{position:relative;display:flex;align-items:center;gap:48px;padding:26px 0 18px}.hero-body{position:relative;flex:1.3 1 500px;min-width:0}.hero-demo{flex:1 1 420px;max-width:560px;min-width:0;display:block;text-decoration:none;color:var(--ink);opacity:0;animation:landUp 1.1s cubic-bezier(.2,.7,.2,1) .45s forwards;transition:transform .35s cubic-bezier(.2,.7,.2,1)}.hero-demo:hover{transform:translateY(-4px)}.hd-mount{background:linear-gradient(160deg,#ffffff59,#fff0 40%),var(--silk);padding:13px;border:1px solid rgba(94,78,50,.35);box-shadow:var(--shadow-soft);position:relative}.hd-mount:after{content:"";position:absolute;inset:10px;border:1px solid rgba(140,47,35,.45);pointer-events:none}.hd-mount canvas{display:block;width:100%;height:auto;background:#f4eedd;box-shadow:inset 0 0 40px #78643c1a}.hd-panel{display:flex;align-items:center;gap:10px;margin-top:10px;background:var(--panel);border:1px solid var(--hairline);padding:9px 14px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.hd-tag{background:var(--cinnabar);color:#f3e9d8;font-family:var(--f-kai);font-size:11px;letter-spacing:.15em;padding:3px 7px 2px;border-radius:3px;flex:none}.hd-title{font-family:var(--f-kai);font-size:16px;letter-spacing:.12em;white-space:nowrap}.hd-note{margin-left:auto;font-size:11px;letter-spacing:.1em;color:var(--ink-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hero h1{font-family:var(--f-kai);font-weight:400;font-size:clamp(26px,4.8vw,56px);white-space:nowrap;line-height:1.25;letter-spacing:.12em;margin-bottom:22px;opacity:0;animation:landUp 1s cubic-bezier(.2,.7,.2,1) .1s forwards}.hero-dot{color:var(--cinnabar);margin:0 .12em}.hero-sub{font-size:15px;line-height:2.1;letter-spacing:.12em;color:var(--ink-soft);margin-bottom:34px;opacity:0;animation:landUp 1s ease .35s forwards}.hero-cta{display:flex;gap:16px;flex-wrap:wrap;align-items:center;opacity:0;animation:landUp 1s ease .55s forwards}.hero-hint{margin-top:18px;font-size:11px;letter-spacing:.3em;color:var(--ink-faint);opacity:0;animation:landUp 1s ease .75s forwards}@keyframes landUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.land-section{padding:30px 0}.land-h2{font-family:var(--f-kai);font-weight:400;font-size:30px;letter-spacing:.25em;display:flex;align-items:baseline;gap:18px;margin-bottom:28px}.land-h2:before{content:"";width:10px;height:10px;background:var(--cinnabar);border-radius:2px;align-self:center}.land-h2-sub{font-family:var(--f-body);font-size:12px;letter-spacing:.3em;color:var(--ink-faint)}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:22px}.feature{background:#f7f2e6cc;border:1px solid var(--hairline);padding:26px 24px 22px;position:relative;transition:transform .3s cubic-bezier(.2,.7,.2,1),box-shadow .3s}.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}.feature-g{position:absolute;right:14px;top:8px;font-family:var(--f-kai);font-size:54px;color:#2b262014}.feature h3{font-family:var(--f-kai);font-weight:400;font-size:19px;letter-spacing:.2em;margin-bottom:10px}.feature p{font-size:12.5px;line-height:1.9;letter-spacing:.06em;color:var(--ink-soft)}.masters-scroll{display:flex;gap:22px;overflow-x:auto;padding:6px 2px 16px;scroll-snap-type:x proximity}.masters-scroll::-webkit-scrollbar{height:6px}.masters-scroll::-webkit-scrollbar-thumb{background:#2b262040;border-radius:3px}.master-card{flex:none;scroll-snap-align:start;text-decoration:none;color:var(--ink);background:#f7f2e6d9;border:1px solid var(--hairline);box-shadow:0 3px 16px #3c32231f;padding:10px 10px 12px;transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s}.master-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-soft)}.master-img{position:relative;height:300px;background:#ece4d0;overflow:hidden}.master-img img{height:100%;width:auto;display:block;min-width:150px;object-fit:cover;transition:transform .6s ease}.master-card:hover .master-img img{transform:scale(1.03)}.master-level{position:absolute;top:8px;left:8px;font-family:var(--f-kai);font-size:11px;letter-spacing:.1em;padding:3px 7px 2px;border-radius:2px;color:#f3e9d8}.master-level.lv-易{background:#5a7a52}.master-level.lv-中{background:#8a6a36}.master-level.lv-难{background:var(--cinnabar)}.master-hover{position:absolute;inset:auto 0 0;padding:26px 0 10px;text-align:center;font-size:12px;letter-spacing:.35em;text-indent:.35em;color:#f3e9d8;background:linear-gradient(transparent,#2b2620c7);opacity:0;transition:opacity .35s}.master-card:hover .master-hover{opacity:1}.master-cap{display:flex;align-items:baseline;gap:10px;padding:10px 4px 0}.master-title{font-family:var(--f-kai);font-size:17px;letter-spacing:.08em}.master-artist{font-size:11px;color:var(--ink-faint);letter-spacing:.12em;margin-left:auto;white-space:nowrap}.masters-credit{display:block;margin-top:6px;font-size:10px;letter-spacing:.12em;color:#8a8071bf}@media(max-width:700px){.master-img{height:220px}}.gal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:22px}.gal-card{position:relative;background:#f7f2e6d9;border:1px solid var(--hairline);box-shadow:0 3px 16px #3c32231a;transition:transform .3s cubic-bezier(.2,.7,.2,1),box-shadow .3s}.gal-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}.gal-card a{display:block}.gal-card img{width:100%;aspect-ratio:3 / 2;object-fit:cover;display:block;border-bottom:1px solid var(--hairline)}.gal-missing{display:grid;place-items:center;aspect-ratio:3 / 2;font-family:var(--f-kai);font-size:14px;letter-spacing:.4em;text-indent:.4em;color:#2b26204d;border-bottom:1px solid var(--hairline)}.gal-featured{position:absolute;top:10px;left:10px;background:var(--cinnabar);color:#f3e9d8;font-family:var(--f-kai);font-size:12px;letter-spacing:.15em;padding:4px 8px 3px;border-radius:3px;box-shadow:0 2px 6px #8c2f2366}.gal-card figcaption{display:flex;align-items:baseline;gap:10px;padding:11px 14px}.gal-title{font-family:var(--f-kai);font-size:16px;letter-spacing:.08em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gal-author{font-size:11px;color:var(--ink-faint);letter-spacing:.1em;margin-left:auto;white-space:nowrap}.gal-curate{background:none;border:1px solid var(--hairline);font-size:10px;color:var(--ink-faint);letter-spacing:.1em;padding:3px 7px;border-radius:3px;white-space:nowrap}.gal-curate:hover{color:var(--cinnabar);border-color:var(--cinnabar)}.gal-empty{border:1px dashed rgba(43,38,32,.3);padding:44px 20px;text-align:center;font-size:13px;letter-spacing:.2em;color:var(--ink-faint)}.gal-empty a{color:var(--cinnabar-deep)}.level-group{margin-bottom:30px}.level-head{display:flex;align-items:center;gap:14px;margin-bottom:14px}.level-badge{font-family:var(--f-kai);font-size:14px;letter-spacing:.25em;text-indent:.1em;padding:5px 12px 4px;border-radius:3px;color:#f3e9d8}.level-badge.lv-入门{background:var(--ink-soft)}.level-badge.lv-进阶{background:#6a4f2e}.level-badge.lv-大成{background:var(--cinnabar);box-shadow:0 2px 7px #8c2f2359}.level-note{font-size:11px;letter-spacing:.3em;color:var(--ink-faint)}.lesson-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px}.lesson-card{position:relative;display:block;background:#f7f2e6d9;border:1px solid var(--hairline);padding:26px 26px 22px;text-decoration:none;color:var(--ink);overflow:hidden;transition:transform .3s cubic-bezier(.2,.7,.2,1),box-shadow .3s}.lesson-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}.lesson-glyph{position:absolute;right:-8px;bottom:-26px;font-family:var(--f-cao);font-size:130px;line-height:1;color:#2b262012;pointer-events:none}.lesson-no{font-family:var(--f-kai);font-size:13px;color:var(--cinnabar);letter-spacing:.3em;margin-bottom:8px}.lesson-card h3{font-family:var(--f-kai);font-weight:400;font-size:24px;letter-spacing:.15em;margin-bottom:4px}.lesson-sub{font-size:11px;letter-spacing:.25em;color:var(--ink-faint);margin-bottom:12px}.lesson-card p{font-size:12.5px;line-height:1.9;color:var(--ink-soft);letter-spacing:.05em;margin-bottom:16px;position:relative}.lesson-go{font-size:12px;letter-spacing:.3em;color:var(--cinnabar-deep)}.lesson-note{margin-top:20px;font-size:12px;letter-spacing:.15em;color:var(--ink-faint);text-align:center}.land-foot{display:flex;align-items:center;justify-content:center;gap:12px;padding:50px 0 40px;font-family:var(--f-kai);font-size:15px;letter-spacing:.3em;color:var(--ink-soft);border-top:1px solid var(--hairline);margin-top:30px}@media(max-width:940px){.hero{flex-direction:column;align-items:stretch;padding:10px 0 6px;gap:22px}.hero-body,.hero-demo{flex:0 0 auto}.hero-demo{order:-1;max-width:540px;width:100%;align-self:center;animation-delay:.1s}}@media(max-width:700px){.land{padding:0 16px}.land-nav{flex-wrap:wrap;gap:10px;padding:14px 0 10px}.hd-note{display:none}.hero{gap:14px;padding:2px 0 4px}.hero h1{margin-bottom:10px}.hero-sub{font-size:13px;line-height:1.85;margin-bottom:14px}.hero-cta{gap:10px}.btn-ink.big{padding:11px 24px;font-size:13px}.btn-ghost.big{padding:10px 18px;font-size:12px}.hero-hint{margin-top:10px;letter-spacing:.2em}.hd-panel{margin-top:8px;padding:7px 11px}.land-section{padding:16px 0}.land-h2{font-size:22px;margin-bottom:16px;gap:12px}.land-h2-sub{font-size:10px;letter-spacing:.2em}.features{grid-template-columns:1fr 1fr;gap:10px}.feature{padding:14px 13px 11px}.feature h3{font-size:15px;margin-bottom:6px;letter-spacing:.12em}.feature p{font-size:11px;line-height:1.75}.feature-g{font-size:36px;right:8px;top:4px}.masters-scroll{gap:12px;padding-bottom:12px}.master-img{height:190px}.master-card{padding:7px 7px 9px}.master-title{font-size:15px}.gal-grid{gap:13px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.gal-card figcaption{padding:8px 10px}.gal-empty{padding:28px 14px;font-size:12px}.level-group{margin-bottom:18px}.level-head{margin-bottom:10px}.lesson-grid{gap:12px}.lesson-card{padding:16px 16px 13px}.lesson-card h3{font-size:20px}.lesson-card p{font-size:11.5px;line-height:1.75;margin-bottom:10px}.lesson-note{margin-top:12px;font-size:11px;letter-spacing:.08em}.land-foot{padding:24px 0 22px;margin-top:14px;font-size:13px}}.ink-root{position:fixed;inset:0;overflow:hidden;z-index:5;font-family:var(--f-body);color:var(--ink);background:radial-gradient(120% 90% at 50% 0%,#fffcf48c,#fffcf400 60%),radial-gradient(140% 120% at 50% 110%,#96825f38,#96825f00 55%),var(--paper);user-select:none;-webkit-user-select:none}.ink-root:before{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;opacity:.5;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix type='saturate' values='0'/><feComponentTransfer><feFuncA type='linear' slope='0.07'/></feComponentTransfer></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>")}.ink-root:after{content:"";position:absolute;inset:0;pointer-events:none;z-index:0;background:radial-gradient(115% 100% at 50% 45%,transparent 62%,rgba(82,66,40,.14) 100%)}#vroot{position:relative;z-index:1;width:100%;height:100%}html.rot #vroot{position:fixed;top:0;left:100vw;left:100dvw;width:100vh;width:100dvh;height:100vw;height:100dvw;transform:rotate(90deg);transform-origin:left top}#edHeader{position:fixed;top:22px;left:24px;z-index:30;display:flex;align-items:center;gap:14px}#edHeader .back{display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--hairline);border-radius:20px;padding:8px 16px;font-size:12px;letter-spacing:.2em;color:var(--ink-soft);text-decoration:none;transition:all .3s;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}#edHeader .back:hover{color:var(--ink);border-color:#2b262073}#edHeader .save-state{font-size:11px;letter-spacing:.2em;color:var(--ink-faint)}#edHeader .save-state.busy{color:var(--cinnabar)}#app{position:relative;z-index:1;height:100%;display:grid;grid-template-columns:96px 1fr 96px;grid-template-rows:1fr 86px;grid-template-areas:"left stage right" "left bar   right"}#stageWrap{grid-area:stage;display:flex;align-items:center;justify-content:center;padding:30px 8px 10px;min-height:0}#mount{position:relative;background:linear-gradient(160deg,#ffffff59,#fff0 40%),var(--silk);padding:16px;border:1px solid rgba(94,78,50,.35);box-shadow:var(--shadow-soft);opacity:0;animation:inkFadeUp 1s ease .1s forwards}#mount:before{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='28' height='28'><path d='M14 2l12 12-12 12L2 14z' fill='none' stroke='rgba(120,98,60,0.18)' stroke-width='1'/></svg>");pointer-events:none}#mount:after{content:"";position:absolute;inset:13px;border:1px solid rgba(140,47,35,.5);pointer-events:none}#stage{position:relative;background:#f4eedd;box-shadow:inset 0 0 60px #78643c1f;font-size:0}#stage:before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.55;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='p'><feTurbulence type='fractalNoise' baseFrequency='0.012 0.05' numOctaves='3' seed='7' stitchTiles='stitch'/><feColorMatrix type='saturate' values='0'/><feComponentTransfer><feFuncA type='linear' slope='0.05'/></feComponentTransfer></filter><rect width='100%' height='100%' filter='url(%23p)'/></svg>")}#paper,#ghost{display:block;touch-action:none}#paper{position:relative;z-index:1}#ghost{position:absolute;inset:0;pointer-events:none;z-index:2}#underlay{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;z-index:0;pointer-events:none;display:none;filter:saturate(.92)}#stage.painting{cursor:none}#stage.placing{cursor:crosshair}@keyframes inkFadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}#cursorRing{position:fixed;z-index:50;pointer-events:none;border:1px solid rgba(43,38,32,.4);border-radius:50%;transform:translate(-50%,-50%);display:none}#cursorRing:after{content:"";position:absolute;left:50%;top:50%;width:2px;height:2px;background:#2b262099;border-radius:50%;transform:translate(-50%,-50%)}#brushCursor{position:fixed;left:0;top:0;z-index:51;pointer-events:none;display:none;will-change:transform;transform-origin:0 0;filter:drop-shadow(3px 7px 7px rgba(50,40,25,.28))}#brushCursor svg{display:block;overflow:visible;position:relative;left:-20px;top:-130px;transition:transform .12s ease}#brushCursor .bris{transform-origin:20px 92px;transition:transform .12s ease}#brushCursor.down .bris{transform:scaleY(.86) scaleX(1.2)}#brushCursor.down svg{transform:translateY(5.3px)}#sideTitle{position:fixed;top:34px;right:26px;z-index:5;display:flex;flex-direction:column;align-items:center;gap:14px;opacity:0;animation:inkFadeUp 1.2s ease .4s forwards;pointer-events:none}#sideTitle .vt{writing-mode:vertical-rl;font-family:var(--f-kai);font-size:24px;letter-spacing:.3em;color:var(--ink);max-height:50vh;overflow:hidden}#sideTitle .vsub{writing-mode:vertical-rl;font-size:10px;letter-spacing:.5em;color:var(--ink-faint)}#sideTitle .mini-seal{width:22px;height:22px;background:var(--cinnabar);border-radius:4px;color:#f3e9d8;font-family:var(--f-kai);font-size:11px;line-height:22px;text-align:center;box-shadow:0 1px 4px #8c2f2366}#leftRail{grid-area:left;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:16px 0}.rail-label{writing-mode:vertical-rl;font-size:11px;letter-spacing:.55em;color:var(--ink-faint);margin-bottom:6px}.brush-btn{position:relative;width:52px;padding:13px 0 11px;display:flex;flex-direction:column;align-items:center;gap:7px;background:var(--panel);border:1px solid var(--hairline);border-radius:26px;cursor:pointer;font-family:var(--f-body);color:var(--ink-soft);transition:all .35s cubic-bezier(.2,.7,.2,1);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.brush-btn .g{font-family:var(--f-kai);font-size:21px;line-height:1;color:var(--ink);transition:transform .35s}.brush-btn .t{writing-mode:vertical-rl;font-size:10px;letter-spacing:.28em;color:var(--ink-faint)}.brush-btn:hover{transform:translate(4px);border-color:#2b262066}.brush-btn.active{background:var(--ink);border-color:var(--ink);box-shadow:0 6px 18px #2b262059}.brush-btn.active .g{color:#f0e9d8;transform:scale(1.08)}.brush-btn.active .t{color:#f0e9d8a6}#rightRail{grid-area:right;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px;padding:16px 0}.pig{position:relative;width:30px;height:30px;border-radius:50%;cursor:pointer;border:1px solid rgba(43,38,32,.25);box-shadow:inset 0 2px 5px #ffffff40,inset 0 -3px 6px #00000038,0 2px 6px #3c32232e;transition:transform .3s cubic-bezier(.2,.7,.2,1)}.pig:hover{transform:scale(1.18)}.pig.active{transform:scale(1.12)}.pig.active:after{content:"";position:absolute;inset:-6px;border:1px solid rgba(43,38,32,.5);border-radius:50%}.pig .name{position:absolute;right:40px;top:50%;transform:translateY(-50%) translate(6px);writing-mode:vertical-rl;font-size:10px;letter-spacing:.3em;color:var(--ink-soft);background:var(--panel);border:1px solid var(--hairline);padding:7px 3px;border-radius:4px;opacity:0;pointer-events:none;transition:all .25s ease;white-space:nowrap}.pig:hover .name{opacity:1;transform:translateY(-50%) translate(0)}#bar{grid-area:bar;display:flex;align-items:center;justify-content:center;gap:26px;padding:0 20px 18px}.bar-group{display:flex;align-items:center;gap:12px;background:var(--panel);border:1px solid var(--hairline);border-radius:30px;padding:10px 20px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.bar-group .lbl{font-size:11px;letter-spacing:.25em;color:var(--ink-faint);white-space:nowrap}.ink-root input[type=range]{-webkit-appearance:none;appearance:none;width:120px;height:18px;background:transparent;cursor:pointer}.ink-root input[type=range]::-webkit-slider-runnable-track{height:4px;border-radius:2px;background:linear-gradient(90deg,#2b262026,#2b26208c)}.ink-root #inkRange::-webkit-slider-runnable-track{background:linear-gradient(90deg,#2b262014,#2b2620)}.ink-root input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:#f4eedd;border:1.5px solid var(--ink);margin-top:-6px;box-shadow:0 1px 4px #00000040;transition:transform .2s}.ink-root input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}.ink-root input[type=range]::-moz-range-track{height:4px;border-radius:2px;background:linear-gradient(90deg,#2b262026,#2b26208c)}.ink-root input[type=range]::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#f4eedd;border:1.5px solid var(--ink)}#inkMark{font-family:var(--f-kai);font-size:15px;width:1.2em;text-align:center;color:var(--ink)}.act{display:flex;flex-direction:column;align-items:center;gap:4px;background:none;border:none;cursor:pointer;color:var(--ink-soft);padding:4px 6px;transition:transform .3s cubic-bezier(.2,.7,.2,1)}.act .ico{width:42px;height:42px;display:grid;place-items:center;background:var(--panel);border:1px solid var(--hairline);border-radius:50%;font-family:var(--f-kai);font-size:19px;color:var(--ink);transition:all .3s;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.act .cap{font-size:10px;letter-spacing:.2em;color:var(--ink-faint)}.act:hover{transform:translateY(-3px)}.act:hover .ico{border-color:#2b262073;box-shadow:0 5px 14px #3c322333}.act.warn .ico{color:var(--cinnabar)}.act.warn.confirm .ico{background:var(--cinnabar);color:#f3e9d8;border-color:var(--cinnabar);animation:inkPulse .9s ease infinite}@keyframes inkPulse{50%{box-shadow:0 0 0 7px #a63a2b2e}}.act.prime .ico{background:var(--ink);color:#f0e9d8;border-color:var(--ink)}.sheet{position:fixed;left:50%;bottom:104px;transform:translate(-50%) translateY(16px);z-index:40;width:min(430px,calc(100vw - 32px));background:#f7f2e6f5;border:1px solid rgba(43,38,32,.22);box-shadow:var(--shadow-soft);padding:22px 24px 20px;opacity:0;pointer-events:none;transition:all .4s cubic-bezier(.2,.7,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sheet.open{opacity:1;pointer-events:auto;transform:translate(-50%) translateY(0)}.sheet:before{content:"";position:absolute;inset:6px;border:1px solid rgba(43,38,32,.14);pointer-events:none}.sheet h3{font-family:var(--f-kai);font-size:19px;font-weight:400;letter-spacing:.3em;margin-bottom:14px;display:flex;align-items:center;gap:10px}.sheet h3:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,rgba(43,38,32,.3),transparent)}.sheet textarea{width:100%;height:74px;resize:none;background:#fffcf4b3;border:1px solid var(--hairline);padding:10px 12px;font-family:var(--f-kai);font-size:19px;letter-spacing:.1em;color:var(--ink);outline:none;line-height:1.5}.sheet textarea:focus,.sheet input[type=text]:focus{border-color:#2b262080}.sheet input[type=text]{width:100%;background:#fffcf4b3;border:1px solid var(--hairline);padding:9px 12px;font-family:var(--f-kai);font-size:20px;letter-spacing:.25em;color:var(--cinnabar-deep);outline:none;text-align:center}.sheet .row{display:flex;align-items:center;gap:10px;margin-top:12px;flex-wrap:wrap}.sheet .row .lbl{font-size:11px;letter-spacing:.2em;color:var(--ink-faint)}.chip-set{display:flex;gap:6px}.chip{border:1px solid var(--hairline);background:none;padding:5px 11px;font-family:var(--f-body);font-size:12px;letter-spacing:.1em;color:var(--ink-soft);cursor:pointer;transition:all .25s}.chip:hover{border-color:#2b262073}.chip.active{background:var(--ink);color:#f0e9d8;border-color:var(--ink)}.chip.f-kai{font-family:var(--f-kai)}.chip.f-cao{font-family:var(--f-cao)}.chip.f-xing{font-family:var(--f-xing)}.sheet .row input[type=range]{width:90px}.sheet .foot{display:flex;justify-content:space-between;align-items:center;margin-top:16px}.link-btn{background:none;border:none;font-size:11px;letter-spacing:.15em;color:var(--ink-faint);cursor:pointer;border-bottom:1px dashed rgba(43,38,32,.3);padding-bottom:2px}.link-btn:hover{color:var(--ink)}.go-btn{background:var(--ink);color:#f0e9d8;border:none;font-family:var(--f-body);font-size:13px;letter-spacing:.35em;text-indent:.35em;padding:10px 26px;cursor:pointer;transition:all .3s}.go-btn:hover{box-shadow:0 6px 16px #2b262059;transform:translateY(-2px)}#sealSheet .go-btn{background:var(--cinnabar)}#sealSheet .go-btn:hover{box-shadow:0 6px 16px #a63a2b66}#sealPreview{width:78px;height:78px;flex:none}#sealSheet .preview-row{display:flex;gap:16px;align-items:center;margin-top:4px}#sealSheet .preview-row .side{flex:1}.lesson-panel{position:fixed;right:108px;bottom:100px;z-index:35;width:320px;max-height:calc(100% - 140px);overflow-y:auto;overscroll-behavior:contain;background:#f7f2e6f2;border:1px solid rgba(43,38,32,.22);box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.lesson-panel::-webkit-scrollbar{width:5px}.lesson-panel::-webkit-scrollbar-thumb{background:#2b262040;border-radius:3px}.lp-copybook{position:relative;margin-bottom:11px;border:1px solid rgba(43,38,32,.3);box-shadow:inset 0 0 18px #78643c1f;font-size:0}.lp-copybook canvas{width:100%;display:block}.lp-copybook-tag{position:absolute;top:6px;right:6px;font-family:var(--f-kai);font-size:10px;letter-spacing:.2em;text-indent:.1em;color:#f3e9d8;background:#2b2620a6;padding:2px 6px 1px;border-radius:2px}.lesson-panel:before{content:"";position:absolute;inset:5px;border:1px solid rgba(43,38,32,.12);pointer-events:none}.lp-head{display:flex;align-items:center;gap:9px;padding:11px 14px;cursor:pointer;-webkit-user-select:none;user-select:none}.lp-tag{background:var(--cinnabar);color:#f3e9d8;font-family:var(--f-kai);font-size:11px;letter-spacing:.15em;padding:3px 7px 2px;border-radius:3px}.lp-title{font-family:var(--f-kai);font-size:16px;letter-spacing:.12em}.lp-prog{font-size:10px;color:var(--ink-faint);letter-spacing:.12em}.lp-fold{margin-left:auto;font-size:10px;color:var(--ink-faint);border:1px solid var(--hairline);border-radius:3px;padding:2px 6px}.lp-body{padding:0 16px 14px}.lp-body h4{font-family:var(--f-kai);font-weight:400;font-size:15px;letter-spacing:.15em;margin-bottom:7px}.lp-body p{font-size:12px;line-height:1.95;color:var(--ink-soft);letter-spacing:.04em;margin-bottom:12px}.lp-acts{display:flex;align-items:center;gap:6px}.lp-spring{flex:1}.lp-acts button{border:1px solid var(--hairline);background:#fffcf4b3;font-size:11px;letter-spacing:.08em;color:var(--ink-soft);padding:6px 10px;transition:all .25s}.lp-acts button:hover:not(:disabled){color:var(--ink);border-color:#2b262073}.lp-acts button:disabled{opacity:.35;cursor:default}.lp-acts .lp-demo{background:var(--cinnabar);border-color:var(--cinnabar);color:#f3e9d8}.lp-acts .lp-demo:hover{box-shadow:0 4px 10px #a63a2b59;color:#f3e9d8}.lp-acts .lp-nav.primary{background:var(--ink);border-color:var(--ink);color:#f0e9d8}.lp-acts .lp-nav.primary:hover:not(:disabled){color:#f0e9d8;box-shadow:0 4px 10px #2b26204d}.lp-hint{margin-top:10px;font-size:10px;letter-spacing:.1em;color:var(--ink-faint)}html.compact .lesson-panel{inset:46px auto auto 8px;width:238px;max-height:calc(100% - 58px)}html.compact .lp-head{padding:8px 12px}html.compact .lp-title{font-size:14px}html.compact .lp-body{padding:0 12px 11px}html.compact .lp-body p{font-size:11px;line-height:1.8}html.compact .lp-copybook{margin-bottom:7px}.cp-figure{display:block;margin-bottom:10px;border:1px solid rgba(43,38,32,.3);background:#f4eedd;max-height:230px;overflow:hidden;text-align:center}.cp-figure img{max-width:100%;max-height:230px;object-fit:contain;display:inline-block;vertical-align:top}.cp-meta{font-family:var(--f-kai);font-size:14px;letter-spacing:.15em;margin-bottom:8px;display:flex;align-items:center;gap:8px}.cp-level{font-family:var(--f-body);font-size:10px;letter-spacing:.1em;padding:2px 7px 1px;border-radius:2px;color:#f3e9d8}.cp-level.lv-易{background:#5a7a52}.cp-level.lv-中{background:#8a6a36}.cp-level.lv-难{background:var(--cinnabar)}.cp-tip{border-left:2px solid rgba(166,58,43,.45);padding-left:9px;color:var(--ink-soft)}.cp-trace.on{background:var(--ink);border-color:var(--ink);color:#f0e9d8}.cp-op{width:110px}html.compact .cp-figure,html.compact .cp-figure img{max-height:150px}#placeHint{position:fixed;top:26px;left:50%;transform:translate(-50%) translateY(-8px);z-index:60;background:var(--ink);color:#f0e9d8;font-size:12px;letter-spacing:.3em;text-indent:.3em;padding:9px 22px;border-radius:20px;opacity:0;pointer-events:none;transition:all .35s ease}#placeHint.show{opacity:1;transform:translate(-50%) translateY(0)}#placeHint i{font-style:normal;opacity:.55;margin-left:1em;letter-spacing:.1em}.stamp-ripple{position:fixed;z-index:55;width:20px;height:20px;border:2px solid var(--cinnabar);border-radius:6px;pointer-events:none;transform:translate(-50%,-50%);animation:inkRipple .7s ease-out forwards}@keyframes inkRipple{0%{opacity:.9;scale:.6}to{opacity:0;scale:2.6}}#toast{position:fixed;bottom:110px;left:50%;transform:translate(-50%) translateY(8px);z-index:70;background:var(--panel);border:1px solid var(--hairline);color:var(--ink-soft);font-size:12px;letter-spacing:.25em;text-indent:.25em;padding:9px 22px;border-radius:18px;opacity:0;pointer-events:none;transition:all .35s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}#toast.show{opacity:1;transform:translate(-50%) translateY(0)}@media(max-width:860px){#app{grid-template-columns:74px 1fr 64px}.bar-group{padding:8px 12px;gap:8px}.ink-root input[type=range]{width:80px}#bar{gap:10px}#sideTitle{display:none}}#toolDrawer{display:contents}#drawerClose,#fabCluster{display:none}html.compact #app{display:block;height:100%}html.compact #stageWrap{position:absolute;inset:0;padding:0}html.compact #mount{width:100%;height:100%;padding:0;border:none;box-shadow:none;background:none;animation:none;opacity:1}html.compact #mount:before,html.compact #mount:after{display:none}html.compact #stage{width:100%;height:100%}html.compact #toolDrawer{display:flex;flex-direction:column;gap:11px;position:fixed;left:0;right:0;bottom:0;z-index:45;padding:8px 16px calc(12px + env(safe-area-inset-bottom,0px));background:#f7f2e6f5;border-top:1px solid rgba(43,38,32,.25);box-shadow:0 -10px 34px #3c322333;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transform:translateY(108%);transition:transform .38s cubic-bezier(.2,.7,.2,1)}.ink-root.tools-open #toolDrawer{transform:translateY(0)}html.compact #drawerClose{display:block;align-self:center;background:none;border:none;font-size:11px;letter-spacing:.3em;text-indent:.3em;color:var(--ink-faint);padding:4px 30px}html.compact .rail-label{display:none}html.compact #leftRail{flex-direction:row;justify-content:flex-start;gap:8px;padding:0;overflow-x:auto}html.compact .brush-btn{width:46px;flex:none;padding:8px 0 7px;gap:2px;border-radius:14px}html.compact .brush-btn .g{font-size:17px}html.compact .brush-btn .t{display:none}html.compact #rightRail{flex-direction:row;justify-content:flex-start;gap:11px;padding:2px 0;overflow-x:auto}html.compact .pig{width:27px;height:27px;flex:none}html.compact .pig .name{display:none}html.compact #bar{flex-wrap:wrap;gap:8px;padding:0;justify-content:flex-start}html.compact .bar-group{padding:6px 12px;gap:8px;border-radius:18px}html.compact .ink-root input[type=range],html.compact input[type=range]{width:88px}html.compact #inkMark{font-size:13px}html.compact .act{gap:0;padding:2px}html.compact .act .ico{width:36px;height:36px;font-size:16px}html.compact .act .cap{display:none}html.compact #fabCluster{display:flex;flex-direction:column;gap:10px;position:fixed;right:14px;bottom:calc(16px + env(safe-area-inset-bottom,0px));z-index:44;transition:opacity .3s}.ink-root.tools-open #fabCluster{opacity:0;pointer-events:none}html.compact #fabCluster button{width:47px;height:47px;border-radius:50%;background:var(--panel);border:1px solid rgba(43,38,32,.32);font-family:var(--f-kai);font-size:19px;color:var(--ink);box-shadow:0 4px 14px #3c322347;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}html.compact #fabCluster #fabTools{background:var(--ink);color:#f0e9d8;border-color:var(--ink)}html.compact #sideTitle{display:none}html.compact #edHeader{top:8px;left:10px}html.compact #edHeader .back{padding:6px 12px;font-size:11px}html.compact .sheet{bottom:76px;padding:14px 16px 12px}html.compact .sheet textarea{height:54px;font-size:16px}html.compact .sheet h3{font-size:16px;margin-bottom:9px}html.compact #placeHint{top:10px;font-size:11px;padding:7px 16px}html.compact #toast{bottom:80px}@media(pointer:coarse){#cursorRing{display:none!important}}:root{--paper: #ece4d2;--paper-deep: #e3d9c3;--silk: #d8cba9;--ink: #2b2620;--ink-soft: #5a5246;--ink-faint: #8a8071;--cinnabar: #a63a2b;--cinnabar-deep: #8c2f23;--hairline: rgba(43, 38, 32, .18);--panel: rgba(245, 240, 228, .82);--shadow-soft: 0 8px 40px rgba(60, 50, 35, .14), 0 2px 8px rgba(60, 50, 35, .08);--f-kai: "Ma Shan Zheng", "Kaiti SC", "STKaiti", serif;--f-cao: "Liu Jian Mao Cao", "Ma Shan Zheng", serif;--f-xing: "Zhi Mang Xing", "Ma Shan Zheng", serif;--f-body: "Noto Serif SC", "Songti SC", serif}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}html,body{overscroll-behavior:none;touch-action:manipulation;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}body{font-family:var(--f-body);color:var(--ink);background:var(--paper)}body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix type='saturate' values='0'/><feComponentTransfer><feFuncA type='linear' slope='0.07'/></feComponentTransfer></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>")}#root{position:relative;z-index:1}button{font-family:inherit;cursor:pointer}input,textarea{font-family:inherit}.login-wrap{min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px;padding:24px}.login-brand{display:flex;flex-direction:column;align-items:center;gap:12px}.login-brand .big{font-family:var(--f-kai);font-size:72px;line-height:1;letter-spacing:.1em}.login-brand .sub{font-size:12px;letter-spacing:.8em;text-indent:.8em;color:var(--ink-faint)}.login-card{width:min(380px,100%);background:#f7f2e6e6;border:1px solid var(--hairline);box-shadow:var(--shadow-soft);padding:30px 32px 26px;position:relative}.login-card:before{content:"";position:absolute;inset:7px;border:1px solid rgba(43,38,32,.12);pointer-events:none}.login-card h2{font-family:var(--f-kai);font-weight:400;font-size:20px;letter-spacing:.35em;margin-bottom:20px}.login-card label{display:block;font-size:11px;letter-spacing:.25em;color:var(--ink-faint);margin:14px 0 6px}.login-card input{width:100%;background:#fffcf4cc;border:1px solid var(--hairline);padding:10px 12px;font-size:15px;color:var(--ink);outline:none}.login-card input:focus{border-color:#2b262080}.login-error{margin-top:14px;font-size:12px;color:var(--cinnabar);letter-spacing:.1em}.login-actions{margin-top:22px;display:flex;align-items:center;justify-content:space-between}.btn-ink{background:var(--ink);color:#f0e9d8;border:none;font-size:13px;letter-spacing:.35em;text-indent:.35em;padding:11px 30px;transition:all .3s}.btn-ink:hover{box-shadow:0 6px 16px #2b262059;transform:translateY(-2px)}.btn-ink:disabled{opacity:.5;transform:none;box-shadow:none;cursor:default}.link-plain{background:none;border:none;font-size:12px;letter-spacing:.15em;color:var(--ink-faint);border-bottom:1px dashed rgba(43,38,32,.3);padding-bottom:2px}.link-plain:hover{color:var(--ink)}.dash{min-height:100%;display:flex;flex-direction:column;max-width:1180px;margin:0 auto;padding:0 28px 48px}.dash-head{display:flex;align-items:baseline;justify-content:space-between;padding:34px 0 10px;border-bottom:1px solid var(--hairline);margin-bottom:30px}.dash-brand{display:flex;align-items:center;gap:14px;font-family:var(--f-kai);font-size:26px;letter-spacing:.2em}.dash-brand .seal{width:30px;height:30px;background:var(--cinnabar);border-radius:5px;color:#f3e9d8;font-size:15px;display:grid;place-items:center;box-shadow:0 1px 5px #8c2f2366}.dash-brand .muted{font-family:var(--f-body);font-size:12px;letter-spacing:.4em;color:var(--ink-faint)}.dash-who{display:flex;align-items:center;gap:16px;font-size:13px;color:var(--ink-soft);letter-spacing:.1em}.scrolls{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:26px}.scroll-card{background:#f7f2e6d9;border:1px solid var(--hairline);box-shadow:0 3px 18px #3c32231a;transition:transform .3s cubic-bezier(.2,.7,.2,1),box-shadow .3s;display:flex;flex-direction:column}.scroll-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}.scroll-thumb{display:block;aspect-ratio:3 / 2;background:linear-gradient(160deg,#ffffff4d,#fff0 45%),#f4eedd;border-bottom:1px solid var(--hairline);overflow:hidden;position:relative;text-decoration:none}.scroll-thumb img{width:100%;height:100%;object-fit:cover;display:block}.dash-brand{text-decoration:none;color:var(--ink)}.card-badge{position:absolute;top:10px;left:10px;font-family:var(--f-kai);font-size:11px;letter-spacing:.15em;padding:3px 8px 2px;border-radius:3px}.card-badge.featured{background:var(--cinnabar);color:#f3e9d8;box-shadow:0 2px 6px #8c2f2366}.card-badge.public{background:#2b2620bf;color:#f0e9d8}.scroll-acts button:disabled{opacity:.4;cursor:default}.scroll-thumb .blank{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--f-kai);font-size:15px;letter-spacing:.4em;text-indent:.4em;color:#2b262040}.scroll-meta{padding:12px 14px;display:flex;align-items:center;justify-content:space-between;gap:8px}.scroll-title{font-family:var(--f-kai);font-size:17px;letter-spacing:.1em;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scroll-date{font-size:10px;color:var(--ink-faint);letter-spacing:.08em;margin-top:2px}.scroll-acts{display:flex;gap:4px;flex:none}.scroll-acts button{background:none;border:1px solid transparent;font-size:11px;color:var(--ink-faint);letter-spacing:.1em;padding:4px 7px;border-radius:4px;transition:all .25s}.scroll-acts button:hover{color:var(--ink);border-color:var(--hairline);background:#fffcf4cc}.scroll-acts button.danger:hover{color:var(--cinnabar)}.scroll-card.new{align-items:center;justify-content:center;min-height:200px;border-style:dashed;border-color:#2b26204d;background:transparent;box-shadow:none;gap:10px;font-family:var(--f-kai);font-size:17px;letter-spacing:.3em;text-indent:.3em;color:var(--ink-soft);border-width:1px;cursor:pointer}.scroll-card.new:hover{color:var(--ink);border-color:#2b26208c}.scroll-card.new .plus{width:44px;height:44px;border:1px solid currentColor;border-radius:50%;display:grid;place-items:center;font-size:22px;font-family:var(--f-body)}.dash-empty{grid-column:1 / -1;text-align:center;padding:30px 0 6px;color:var(--ink-faint);font-size:13px;letter-spacing:.3em}
