:root{--font-sans: Inter, "Microsoft YaHei", "PingFang SC", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--color-background-primary: rgba(30, 28, 37, .74);--color-background-secondary: rgba(22, 20, 28, .72);--color-background-tertiary: rgba(46, 42, 56, .6);--color-border-secondary: rgba(212, 177, 94, .22);--color-border-tertiary: rgba(255, 255, 255, .08);--color-text-primary: #f4efe3;--color-text-secondary: rgba(244, 239, 227, .68);--color-text-tertiary: rgba(244, 239, 227, .42);--color-accent: #d4b15e;--color-accent-strong: #b8902f;--color-accent-soft: rgba(212, 177, 94, .1);--color-accent-glow: rgba(212, 177, 94, .3);--gradient-ink: linear-gradient(160deg, #1a1820 0%, #2a2533 100%);--gradient-accent: linear-gradient(135deg, #f0d68a 0%, #d4b15e 45%, #b8902f 100%);--shadow-soft: 0 36px 90px rgba(0, 0, 0, .6);--shadow-card: 0 18px 44px rgba(0, 0, 0, .5), 0 2px 6px rgba(0, 0, 0, .35);--shadow-hover: 0 26px 60px rgba(212, 177, 94, .2);--hairline: inset 0 1px 0 rgba(255, 255, 255, .06)}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{background:radial-gradient(1100px 560px at 12% -8%,rgba(212,177,94,.12),transparent 58%),radial-gradient(900px 520px at 102% 0%,rgba(120,92,36,.14),transparent 55%),radial-gradient(700px 700px at 50% 120%,rgba(40,36,52,.6),transparent 60%),linear-gradient(180deg,#0d0c11,#131119,#0e0d12);background-attachment:fixed;color:var(--color-text-primary);font-family:var(--font-sans);letter-spacing:.01em;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button,input,select,textarea{font:inherit}input,select,textarea{color:var(--color-text-primary);background-color:#ffffff0a}input::placeholder,textarea::placeholder{color:var(--color-text-tertiary)}option{color:#1a1206;background:#fff}.app-error{max-width:720px;margin:48px auto;padding:24px;border:1px solid #f09595;border-radius:12px;background:#fcebeb;color:#791f1f;font-family:var(--font-sans)}.app-error pre{white-space:pre-wrap}#root{width:100%}.page-shell{display:flex;min-height:100vh;width:100%;padding:18px;gap:18px}.sidebar-shell{width:280px;padding:18px 14px;overflow-y:auto;max-height:calc(100vh - 36px);background:linear-gradient(180deg,#201d28d1,#14121aa8);backdrop-filter:blur(22px) saturate(1.2);-webkit-backdrop-filter:blur(22px) saturate(1.2);border:1px solid rgba(212,177,94,.16);border-radius:24px;box-shadow:var(--shadow-card),var(--hairline)}.main-shell{flex:1;min-width:0;display:flex;flex-direction:column;background:linear-gradient(180deg,#1e1b25cc,#121018a3);backdrop-filter:blur(20px) saturate(1.2);-webkit-backdrop-filter:blur(20px) saturate(1.2);border:1px solid rgba(212,177,94,.16);border-radius:24px;box-shadow:var(--shadow-soft),var(--hairline);overflow:hidden}.topbar-shell{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(212,177,94,.14);position:sticky;top:0;background:#100e16b8;backdrop-filter:blur(16px) saturate(1.2);-webkit-backdrop-filter:blur(16px) saturate(1.2);z-index:10}.content-shell{flex:1;padding:28px;overflow:auto}.panel-card{background:var(--color-background-primary);border:1px solid var(--color-border-tertiary);border-radius:20px;box-shadow:var(--shadow-card)}.subtle-card{background:var(--color-background-secondary);border:1px solid var(--color-border-tertiary);border-radius:18px}.chip-tabs{display:flex;gap:8px;margin-bottom:18px;padding:6px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:18px;overflow-x:auto}.chip-tab{padding:10px 14px;border-radius:14px;border:none;font-size:12px;font-weight:600;cursor:pointer;background:transparent;color:var(--color-text-tertiary);white-space:nowrap}.chip-tab.is-active{background:var(--gradient-accent);color:#1a1206;box-shadow:0 8px 20px #d4b15e47}.lesson-layout{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(280px,.75fr);gap:18px;align-items:start}.lesson-main,.lesson-side{display:grid;gap:16px}.section-stack{display:grid;gap:14px}.section-card{padding:18px;border-radius:20px;background:linear-gradient(180deg,#221f2ac7,#18161ea3);border:1px solid rgba(212,177,94,.14);box-shadow:var(--shadow-card),var(--hairline)}.support-grid{display:grid;gap:10px}.support-tile{text-align:left;padding:16px;border-radius:18px;border:1px solid rgba(212,177,94,.14);background:linear-gradient(180deg,#221f2ac7,#16141ca3);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.support-tile:hover{transform:translateY(-2px);border-color:#d4b15e66;box-shadow:var(--shadow-hover)}.metric-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.home-hero{position:relative;overflow:hidden;border-radius:32px;padding:32px;margin-bottom:18px;background:radial-gradient(120% 140% at 88% -10%,rgba(83,74,183,.55),transparent 52%),linear-gradient(150deg,#15131d,#211c33 55%,#2c2647);color:#fff;box-shadow:var(--shadow-soft)}.home-hero:before{content:"";position:absolute;inset:-24% auto auto 58%;width:280px;height:280px;border-radius:999px;background:radial-gradient(circle,rgba(124,112,235,.45),transparent 64%);filter:blur(6px);pointer-events:none}.home-hero:after{content:"";position:absolute;inset:auto -10% -40% auto;width:320px;height:320px;border-radius:999px;background:radial-gradient(circle,rgba(83,74,183,.3),transparent 68%);pointer-events:none}.motion-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:#ffffff14;color:#ffffffe0;font-size:12px;backdrop-filter:blur(10px)}.motion-dot{width:8px;height:8px;border-radius:50%;background:#f3f3f3;box-shadow:0 0 #ffffff8c;animation:pulseDot 1.8s infinite}.motion-bars{display:inline-flex;align-items:end;gap:3px;height:14px}.motion-bars span{width:3px;border-radius:999px;background:#ffffffdb;animation:musicBars 1.1s infinite ease-in-out}.motion-bars span:nth-child(1){height:7px;animation-delay:0s}.motion-bars span:nth-child(2){height:12px;animation-delay:.18s}.motion-bars span:nth-child(3){height:9px;animation-delay:.32s}.chapter-panel{margin-bottom:16px;padding:24px;border-radius:24px;background:linear-gradient(180deg,#201d28bd,#14121a99);border:1px solid rgba(212,177,94,.14);box-shadow:var(--shadow-card),var(--hairline)}.lesson-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:14px;margin-top:16px}.lesson-grid-modern{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:14px;margin-top:18px}.lesson-card-modern{position:relative;overflow:hidden;text-align:left;border-radius:20px;border:1px solid rgba(212,177,94,.14);background:linear-gradient(180deg,#24202cd1,#16141cb3);padding:20px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;box-shadow:0 10px 28px #0006,var(--hairline)}.lesson-card-modern:hover{transform:translateY(-3px);border-color:#534ab766;box-shadow:var(--shadow-hover)}.lesson-card-modern:after{content:"";position:absolute;right:-28px;bottom:-28px;width:120px;height:120px;border-radius:999px;background:radial-gradient(circle,rgba(83,74,183,.16),transparent 68%);pointer-events:none;transition:opacity .2s ease}.lesson-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:12px}.lesson-tile{position:relative;overflow:hidden;text-align:left;border-radius:20px;border:1px solid rgba(212,177,94,.14);background:linear-gradient(180deg,#24202cd1,#16141cb3);padding:20px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;box-shadow:0 10px 28px #0006,var(--hairline)}.lesson-tile:hover{transform:translateY(-3px);border-color:#534ab766;box-shadow:var(--shadow-hover)}.lesson-tile:after{content:"";position:absolute;right:-28px;bottom:-28px;width:120px;height:120px;border-radius:999px;background:radial-gradient(circle,rgba(83,74,183,.16),transparent 68%);pointer-events:none}.lesson-kicker{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:8px}.lesson-no{font-size:12px;font-weight:700;color:var(--color-accent);letter-spacing:.08em}.lesson-status{font-size:11px;color:var(--color-text-tertiary)}.lesson-cta{display:inline-flex;align-items:center;gap:8px;margin-top:14px;font-size:12px;font-weight:600;color:var(--color-accent)}.lesson-media-grid{display:grid;gap:16px}.media-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}.media-kicker{font-size:11px;font-weight:700;color:var(--color-text-tertiary);letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px}.media-title{font-size:20px;font-weight:700;color:var(--color-text-primary)}.media-subtitle{font-size:12px;color:var(--color-text-secondary);line-height:1.7}.media-metrics{display:flex;gap:8px;flex-wrap:wrap}.media-metrics span{padding:8px 12px;border-radius:999px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);font-size:11px;color:var(--color-text-secondary)}.video-shell{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(300px,.95fr);gap:14px}.video-stage{position:relative;min-height:280px;padding:24px;border-radius:24px;background:radial-gradient(circle at top right,rgba(255,255,255,.12),transparent 28%),linear-gradient(160deg,#0a0a0afa,#2a2a2af2);color:#fff;overflow:hidden;box-shadow:var(--shadow-card)}.video-stage:after{content:"";position:absolute;right:-50px;bottom:-50px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.12),transparent 70%)}.video-overlay{display:flex;gap:8px;flex-wrap:wrap;position:relative;z-index:1}.video-chip{padding:7px 11px;border-radius:999px;background:#ffffff14;border:1px solid rgba(255,255,255,.14);font-size:11px;color:#ffffffd6}.video-lesson-no{margin-top:22px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#ffffff9e;position:relative;z-index:1}.video-stage h3{margin:10px 0;font-size:30px;line-height:1.15;position:relative;z-index:1}.video-stage p{margin:0;max-width:520px;font-size:14px;line-height:1.9;color:#ffffffc2;position:relative;z-index:1}.video-stage-meta{position:absolute;left:24px;right:24px;bottom:24px;display:grid;gap:6px;padding:14px 16px;border-radius:18px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(8px);z-index:1}.video-stage-meta strong{font-size:12px}.video-stage-meta span{font-size:12px;color:#ffffffb8;line-height:1.7}.video-script-card{padding:18px;border-radius:22px;background:linear-gradient(180deg,#221f2ad1,#16141cb3);border:1px solid rgba(212,177,94,.14)}.video-script-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.video-controls{display:flex;gap:8px;flex-wrap:wrap}.media-button{padding:8px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;color:var(--color-text-primary);cursor:pointer;transition:border-color .2s ease,background .2s ease}.media-button:hover{border-color:#d4b15e73;background:#d4b15e14}.media-button.is-primary{background:var(--gradient-accent);color:#1a1206;border-color:transparent;font-weight:600;box-shadow:0 8px 20px #d4b15e47}.video-progress{height:8px;border-radius:999px;overflow:hidden;background:#ffffff1a;margin-bottom:12px}.video-progress-bar{height:100%;border-radius:999px;background:var(--gradient-accent);box-shadow:0 0 12px #d4b15e66;transition:width .25s ease}.video-script-body{padding:14px 15px;border-radius:16px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);font-size:13px;color:var(--color-text-secondary);line-height:1.85;margin-bottom:12px}.video-segment-list{display:grid;gap:8px}.video-segment-item{text-align:left;display:grid;gap:4px;padding:12px 14px;border-radius:16px;border:1px solid rgba(212,177,94,.14);background:#ffffff0d;cursor:pointer}.video-segment-item span{font-size:11px;color:var(--color-text-tertiary)}.video-segment-item strong{font-size:13px;color:var(--color-text-primary)}.video-segment-item.is-active{background:var(--gradient-accent);border-color:#e6c878}.video-segment-item.is-active span,.video-segment-item.is-active strong{color:#1a1206}.ppt-shell{display:grid;gap:12px}.ppt-slide{padding:22px;border-radius:24px;background:linear-gradient(180deg,#221f2ad1,#16141cb3);border:1px solid rgba(212,177,94,.14);min-height:360px;box-shadow:var(--shadow-card),var(--hairline)}.ppt-kicker{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;margin-bottom:12px;font-size:11px;color:var(--color-text-tertiary)}.ppt-slide h3{margin:0 0 14px;font-size:30px;line-height:1.16;color:var(--color-text-primary)}.ppt-slide ul{margin:0;padding-left:20px;display:grid;gap:10px;color:var(--color-text-secondary);line-height:1.9;font-size:14px}.ppt-note{margin-top:18px;padding-top:14px;border-top:1px solid var(--color-border-tertiary);display:grid;gap:6px;font-size:12px;color:var(--color-text-secondary);line-height:1.8}.ppt-toolbar{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}.ppt-thumb-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px}.ppt-thumb{text-align:left;display:grid;gap:6px;padding:14px;border-radius:16px;border:1px solid rgba(212,177,94,.14);background:#ffffff0d;cursor:pointer}.ppt-thumb strong{font-size:13px;color:var(--color-text-primary);line-height:1.6}.ppt-thumb span{font-size:11px;color:var(--color-text-secondary);line-height:1.7}.ppt-thumb-no{display:inline-flex;width:34px;height:24px;align-items:center;justify-content:center;border-radius:999px;background:#d4b15e29;color:var(--color-accent);font-weight:700}.ppt-thumb.is-active{background:var(--gradient-accent);border-color:#e6c878}.ppt-thumb.is-active strong,.ppt-thumb.is-active span{color:#1a1206}.ppt-thumb.is-active .ppt-thumb-no{background:#1a12062e;color:#1a1206}.lesson-video-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:14px}.lesson-video-frame{padding:14px;border-radius:22px;background:linear-gradient(180deg,#221f2ad1,#16141cb3);border:1px solid rgba(212,177,94,.14)}.lesson-video-player{width:100%;display:block;border-radius:18px;background:#0d0d0d;border:1px solid rgba(17,17,17,.14);min-height:320px}@media(max-width:980px){.lesson-layout,.video-shell,.lesson-video-grid{grid-template-columns:1fr}}@media(max-width:860px){.page-shell{padding:0;gap:0}.main-shell{border-radius:0;border-left:none;border-right:none;min-height:100vh}.topbar-shell{padding:12px 14px;gap:10px;align-items:flex-start;flex-direction:column}.content-shell{padding:14px}.home-hero,.chapter-panel{padding:20px;border-radius:20px}.section-card,.subtle-card,.panel-card{border-radius:16px}.metric-grid{grid-template-columns:1fr}}@keyframes pulseDot{0%{box-shadow:0 0 #ffffff85;opacity:.9}70%{box-shadow:0 0 0 10px #fff0;opacity:1}to{box-shadow:0 0 #fff0;opacity:.9}}@keyframes musicBars{0%,to{transform:scaleY(.5);opacity:.55}50%{transform:scaleY(1);opacity:1}}.kmap-canvas{position:relative;border-radius:22px;background:radial-gradient(circle at 50% 44%,rgba(212,177,94,.12),transparent 50%),linear-gradient(180deg,#18161ee6,#100e16eb);border:1px solid rgba(212,177,94,.16);box-shadow:var(--hairline);overflow-x:auto}.kmap-link{fill:none;stroke-linecap:round;stroke-dasharray:1;stroke-dashoffset:1;animation:kmapDraw .9s cubic-bezier(.65,0,.35,1) forwards}.kmap-link.is-flow{stroke-dasharray:.05 .07;stroke-dashoffset:0;animation:kmapFlow 2.6s linear infinite}@keyframes kmapDraw{to{stroke-dashoffset:0}}@keyframes kmapFlow{to{stroke-dashoffset:-.6}}.kmap-anchor-dot{transform-box:fill-box;transform-origin:center;animation:kmapPulse 2.2s ease-in-out infinite}@keyframes kmapPulse{0%,to{opacity:.45;transform:scale(.85)}50%{opacity:1;transform:scale(1.15)}}.kmap-center{position:relative;animation:kmapFloat 6s ease-in-out infinite}.kmap-center:before{content:"";position:absolute;inset:-34px;border-radius:999px;background:radial-gradient(circle,rgba(212,177,94,.32),transparent 68%);z-index:-1;pointer-events:none}@keyframes kmapFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.kmap-node{transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,background .2s ease;backdrop-filter:blur(12px);animation:kmapNodeIn .55s ease both}.kmap-node:hover{transform:translateY(-3px)}@keyframes kmapNodeIn{0%{opacity:0}to{opacity:1}}.kmap-seg{display:inline-flex;gap:4px;padding:4px;border-radius:999px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08)}.kmap-seg button{padding:6px 14px;border:none;border-radius:999px;background:transparent;color:var(--color-text-secondary);font-size:12px;font-weight:600;cursor:pointer;transition:background .18s ease,color .18s ease,box-shadow .18s ease}.kmap-seg button.is-active{background:var(--gradient-accent);color:#1a1206;box-shadow:0 6px 16px #d4b15e40}.kmap-outline{margin-top:14px;display:grid;gap:2px}.kmap-branch{position:relative;padding-left:20px}.kmap-branch:before{content:"";position:absolute;left:7px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,#d4b15e59,#d4b15e14)}.kmap-branch:last-child:before{bottom:auto;height:24px}.kmap-branch-head{position:relative;width:100%;display:flex;align-items:center;gap:10px;padding:11px 12px;margin-bottom:6px;border-radius:14px;border:1px solid rgba(212,177,94,.14);background:linear-gradient(180deg,#26222ee6,#18161ecc);color:var(--color-text-primary);cursor:pointer;text-align:left;transition:border-color .18s ease,transform .12s ease,box-shadow .18s ease}.kmap-branch-head:hover{border-color:#d4b15e66;transform:translate(2px);box-shadow:0 8px 22px #00000059}.kmap-branch-head:before{content:"";position:absolute;left:-13px;top:50%;width:13px;height:2px;background:#d4b15e59}.kmap-chevron{color:var(--color-accent);font-size:10px;width:12px;flex-shrink:0;transition:transform .2s ease}.kmap-chevron.is-open{transform:rotate(90deg)}.kmap-badge{width:24px;height:24px;flex-shrink:0;border-radius:8px;background:linear-gradient(135deg,#f0d68a,#b8902f);color:#1a1206;font-size:12px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 4px 10px #d4b15e4d}.kmap-branch-title{font-size:13px;font-weight:700}.kmap-branch-body,.kmap-branch-peek{margin:0 0 10px 32px;animation:kmapBodyIn .28s ease both}.kmap-branch-body{padding:12px 14px;border-radius:12px;background:#ffffff0a;border-left:2px solid rgba(212,177,94,.4)}.kmap-branch-body p{margin:0;font-size:12px;line-height:1.85;color:var(--color-text-secondary)}.kmap-branch-peek{font-size:12px;line-height:1.7;color:var(--color-text-tertiary);padding:0 4px}.kmap-jump{margin-top:10px;padding:5px 12px;border-radius:999px;border:1px solid rgba(212,177,94,.3);background:#d4b15e14;color:var(--color-accent);font-size:11px;font-weight:600;cursor:pointer;transition:background .18s ease}.kmap-jump:hover{background:#d4b15e29}@keyframes kmapBodyIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
