*{margin:0;padding:0;box-sizing:border-box}html,body{margin:0;padding:0;width:100%;height:100%;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}@media (max-width: 900px){html,body{height:auto!important;min-height:100%;overflow-y:auto!important;overflow-x:hidden;-webkit-overflow-scrolling:touch;touch-action:pan-y;position:static!important;-webkit-user-select:auto;user-select:auto}#app{min-height:100%;height:auto!important;overflow:visible!important;touch-action:pan-y}html.reading-mode,body.reading-mode{height:100%!important;min-height:100%!important;overflow:hidden!important;position:static!important}body.reading-mode #app{height:100%!important;min-height:100%!important;overflow:hidden!important}}input,textarea{-webkit-user-select:text;user-select:text}:root{--bg-background: #f7f4ef;--bg-card: #ffffff;--bg-secondary: #eee8df;--bg-secondary-hover: #e3dbcf;--bg-sidebar: #f3efe8;--bg-elevated: #ffffff;--bg-accent: rgba(47, 111, 126, .08);--bg-overlay: rgba(31, 35, 40, .35);--fg-strong: #111418;--fg-foreground: #1f2328;--fg-card-foreground: #1f2328;--fg-sidebar-foreground: #1f2328;--fg-subtle: #4b5057;--fg-muted-foreground: #6b6f76;--fg-inverse: #ffffff;--color-primary: #2f6f7e;--color-primary-hover: #265b66;--bg-primary: rgba(47, 111, 126, .14);--border-primary: rgba(47, 111, 126, .22);--border-color: #dfd7cc;--border-sidebar: #ded6cb;--border-hover: #cfc5b8;--border-subtle: #e9e1d6;--border-strong: #c8beaf;--border-focus: #2f6f7e;--color-success: #2f8f6f;--color-success-hover: #25785e;--color-destructive: #c84c4c;--color-destructive-hover: #b34343;--color-warning: #d39b36;--color-warning-hover: #b9852e;--bg-success: rgba(47, 143, 111, .12);--bg-warning: rgba(211, 155, 54, .12);--bg-destructive: rgba(200, 76, 76, .12);--shadow-sm: 0 1px 2px rgba(31, 35, 40, .08);--shadow-md: 0 8px 24px rgba(31, 35, 40, .12);--shadow-lg: 0 20px 50px rgba(31, 35, 40, .18);--ring-primary: 0 0 0 3px rgba(47, 111, 126, .18);--ring-success: 0 0 0 3px rgba(47, 143, 111, .18);--ring-danger: 0 0 0 3px rgba(200, 76, 76, .18);--motion-fast: .12s;--motion-base: .18s;--motion-slow: .28s;--ease-standard: cubic-bezier(.2, 0, 0, 1);--ease-emphasized: cubic-bezier(.2, 0, 0, 1);--primary-04: rgba(47, 111, 126, .04);--primary-05: rgba(47, 111, 126, .05);--primary-08: rgba(47, 111, 126, .08);--primary-10: rgba(47, 111, 126, .1);--primary-12: rgba(47, 111, 126, .12);--primary-14: var(--bg-primary);--primary-15: rgba(47, 111, 126, .15);--primary-16: rgba(47, 111, 126, .16);--primary-18: rgba(47, 111, 126, .18);--primary-20: rgba(47, 111, 126, .2);--primary-22: var(--border-primary);--primary-25: rgba(47, 111, 126, .25);--primary-30: rgba(47, 111, 126, .3);--primary-35: rgba(47, 111, 126, .35);--primary-40: rgba(47, 111, 126, .4);--primary-45: rgba(47, 111, 126, .45);--primary-50: rgba(47, 111, 126, .5);--success-05: rgba(47, 143, 111, .05);--success-08: rgba(47, 143, 111, .08);--success-10: rgba(47, 143, 111, .1);--success-12: var(--bg-success);--success-15: rgba(47, 143, 111, .15);--success-16: rgba(47, 143, 111, .16);--success-18: rgba(47, 143, 111, .18);--success-20: rgba(47, 143, 111, .2);--success-25: rgba(47, 143, 111, .25);--success-30: rgba(47, 143, 111, .3);--warning-12: var(--bg-warning);--warning-15: rgba(211, 155, 54, .15);--warning-20: rgba(211, 155, 54, .2);--warning-25: rgba(211, 155, 54, .25);--warning-30: rgba(211, 155, 54, .3);--danger-10: rgba(200, 76, 76, .1);--danger-12: var(--bg-destructive);--danger-15: rgba(200, 76, 76, .15);--danger-18: rgba(200, 76, 76, .18);--danger-20: rgba(200, 76, 76, .2);--danger-30: rgba(200, 76, 76, .3);--ink-04: rgba(31, 35, 40, .04);--ink-05: rgba(31, 35, 40, .05);--ink-06: rgba(31, 35, 40, .06);--ink-08: rgba(31, 35, 40, .08);--ink-10: rgba(31, 35, 40, .1);--ink-12: rgba(31, 35, 40, .12);--ink-15: rgba(31, 35, 40, .15);--ink-20: rgba(31, 35, 40, .2);--ink-25: rgba(31, 35, 40, .25);--ink-30: rgba(31, 35, 40, .3);--ink-35: rgba(31, 35, 40, .35);--ink-40: rgba(31, 35, 40, .4);--ink-50: rgba(31, 35, 40, .5);--ink-65: rgba(31, 35, 40, .65);--ink-70: rgba(31, 35, 40, .7);--ink-85: rgba(31, 35, 40, .85);--white-30: rgba(255, 255, 255, .3);--white-90: rgba(255, 255, 255, .9);--white-95: rgba(255, 255, 255, .95);--white-98: rgba(255, 255, 255, .98);--white-99: rgba(255, 255, 255, .99);--color-gold: #b8973b;--color-gold-light: #d4b064;--color-gold-dark: #96792e;--gold-10: rgba(184, 151, 59, .1);--gold-15: rgba(184, 151, 59, .15);--gold-20: rgba(184, 151, 59, .2);--gold-30: rgba(184, 151, 59, .3);--color-saffron: var(--color-primary);--color-saffron-light: var(--color-primary);--color-saffron-dark: var(--color-primary-hover);--color-earth: var(--fg-muted-foreground);--color-sand: var(--bg-secondary);--color-stone: var(--fg-foreground);--color-incense: var(--fg-muted-foreground);--color-paper: var(--bg-card);--color-shadow: rgba(31, 35, 40, .12);--color-jade: var(--color-success);--color-amber: var(--color-warning);--color-error: var(--color-destructive)}body{font-family:"Noto Serif SC",Geist,PingFang SC,Hiragino Sans GB,Microsoft YaHei,serif;font-size:17px;background:radial-gradient(1100px 800px at 12% -10%,var(--primary-05),transparent 60%),radial-gradient(900px 700px at 88% -15%,var(--success-05),transparent 55%),var(--bg-background);color:var(--fg-foreground);line-height:1.8;letter-spacing:.5px;position:relative}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(var(--ink-05) .6px,transparent .6px);background-size:26px 26px;opacity:.45;pointer-events:none;z-index:0}#app{width:100%;min-height:100vh;background:transparent;position:relative;z-index:1}.login-view{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px;position:relative}.login-view:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='40' cy='40' r='1.2' fill='%23b8973b' fill-opacity='0.06'/%3E%3Ccircle cx='40' cy='40' r='8' stroke='%23b8973b' stroke-opacity='0.03' fill='none' stroke-width='0.5'/%3E%3C/svg%3E");opacity:.7;pointer-events:none}.login-container{background-color:var(--bg-card);border-radius:16px;box-shadow:0 20px 60px var(--color-shadow),0 0 0 1px var(--border-primary);padding:48px 40px;width:100%;max-width:420px;position:relative;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);overflow:hidden}.login-container:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--color-gold-light),var(--color-gold),var(--color-primary),var(--color-gold),var(--color-gold-light))}.login-header{text-align:center;margin-bottom:36px;position:relative}.login-header:before{content:"";display:block;width:48px;height:48px;margin:0 auto 16px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' fill='none'%3E%3Cpath d='M32 12c0 0-8 10-8 22s8 18 8 18 8-6 8-18S32 12 32 12z' fill='%23b8973b' fill-opacity='0.15' stroke='%23b8973b' stroke-width='1.2'/%3E%3Cpath d='M32 12c-4 4-14 8-14 20s10 16 14 18' fill='none' stroke='%23b8973b' stroke-width='1' stroke-opacity='0.5'/%3E%3Cpath d='M32 12c4 4 14 8 14 20s-10 16-14 18' fill='none' stroke='%23b8973b' stroke-width='1' stroke-opacity='0.5'/%3E%3Cpath d='M32 12c-8 6-20 6-20 18s12 16 20 20' fill='none' stroke='%232f6f7e' stroke-width='0.8' stroke-opacity='0.35'/%3E%3Cpath d='M32 12c8 6 20 6 20 18s-12 16-20 20' fill='none' stroke='%232f6f7e' stroke-width='0.8' stroke-opacity='0.35'/%3E%3Ccircle cx='32' cy='36' r='3' fill='%23b8973b' fill-opacity='0.25'/%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;opacity:.85}.login-header h1{color:var(--fg-foreground);font-size:2.4em;margin-bottom:8px;font-weight:600;letter-spacing:8px;text-indent:8px}.login-header p{color:var(--fg-muted-foreground);font-size:.95em;font-weight:300}.login-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:10px}.form-group label{font-weight:500;color:var(--fg-foreground);font-size:.9em;letter-spacing:.5px}.form-group input{padding:14px 18px;border:2px solid var(--border-color);border-radius:10px;font-size:16px;transition:all .3s ease;background-color:var(--bg-card);color:var(--fg-foreground);font-family:inherit}.form-group input:focus{outline:none;border-color:var(--color-primary);background-color:var(--bg-card);box-shadow:0 0 0 4px var(--bg-primary)}.error-message{padding:14px 18px;background-color:var(--danger-10);color:var(--color-destructive);border-radius:10px;font-size:.9em;border:1px solid var(--danger-20)}.btn-login{width:100%;padding:16px;font-size:16px;margin-top:12px}.user-info{padding:10px 20px;background-color:var(--bg-primary);border-radius:24px;font-size:.9em;color:var(--fg-foreground);margin-right:10px;border:1px solid var(--border-primary)}.container{max-width:1400px;margin:0 auto;padding:20px;width:100%;box-sizing:border-box}.btn,.ui-button{padding:14px 26px;border:1px solid transparent;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:transform var(--motion-base) var(--ease-standard),box-shadow var(--motion-base) var(--ease-standard),background var(--motion-base) var(--ease-standard),border-color var(--motion-base) var(--ease-standard),color var(--motion-base) var(--ease-standard);min-width:120px;font-family:inherit;letter-spacing:.3px;position:relative;overflow:hidden;background:var(--bg-secondary);color:var(--fg-foreground);box-shadow:var(--shadow-sm)}.btn:before,.ui-button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:var(--white-30);transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn:active:before,.ui-button:active:before{width:300px;height:300px}.btn:hover,.ui-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn:active,.ui-button:active{transform:translateY(0)}.btn:disabled,.ui-button:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.btn-primary,.ui-button-primary{background:var(--color-primary);color:var(--fg-inverse);border-color:transparent;box-shadow:0 8px 20px var(--primary-20)}.btn-primary:hover:not(:disabled),.ui-button-primary:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:0 10px 24px var(--primary-25)}.btn-secondary,.ui-button-secondary{background:var(--bg-card);color:var(--fg-foreground);border-color:var(--border-color)}.btn-secondary:hover:not(:disabled),.ui-button-secondary:hover:not(:disabled){background:var(--bg-secondary-hover);border-color:var(--border-hover)}.btn-success,.ui-button-success{background:var(--color-success);color:var(--fg-inverse);border-color:transparent;box-shadow:0 8px 20px var(--success-20)}.btn-success:hover:not(:disabled),.ui-button-success:hover:not(:disabled){background:var(--color-success-hover)}.btn-danger,.ui-button-danger{background:var(--color-destructive);color:var(--fg-inverse);border-color:transparent;box-shadow:0 8px 20px var(--danger-20)}.btn-danger:hover:not(:disabled),.ui-button-danger:hover:not(:disabled){background:var(--color-destructive-hover)}.btn-ghost,.ui-button-ghost{background:transparent;border-color:var(--border-color);color:var(--fg-foreground);box-shadow:none}.btn-ghost:hover:not(:disabled),.ui-button-ghost:hover:not(:disabled){background:var(--bg-secondary)}.ui-input,.ui-textarea,.ui-select{width:100%;padding:12px 14px;border:1px solid var(--border-color);border-radius:10px;background:var(--bg-card);color:var(--fg-foreground);font-size:16px;font-family:inherit;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.ui-textarea{resize:vertical;min-height:96px}.ui-input:focus,.ui-textarea:focus,.ui-select:focus{outline:none;border-color:var(--border-focus);box-shadow:var(--ring-primary);background:var(--bg-card)}.ui-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;box-shadow:var(--shadow-sm);transition:transform var(--motion-base) var(--ease-standard),box-shadow var(--motion-base) var(--ease-standard),border-color var(--motion-base) var(--ease-standard)}.ui-panel{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;box-shadow:var(--shadow-md);transition:transform var(--motion-base) var(--ease-standard),box-shadow var(--motion-base) var(--ease-standard),border-color var(--motion-base) var(--ease-standard)}.ui-card.is-interactive,.ui-panel.is-interactive{cursor:pointer}.ui-card.is-interactive:hover,.ui-panel.is-interactive:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--border-hover)}.ui-card.is-interactive:active,.ui-panel.is-interactive:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.ui-divider{height:1px;background:var(--border-subtle);border:none}.ui-badge,.ui-tag{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:999px;font-size:13px;font-weight:600;background:var(--bg-secondary);color:var(--fg-subtle);border:1px solid var(--border-color)}.ui-badge-primary{background:var(--primary-10);color:var(--color-primary);border-color:var(--primary-20)}.ui-badge-success{background:var(--success-10);color:var(--color-success);border-color:var(--success-20)}.ui-badge-warning{background:var(--warning-12);color:var(--color-warning);border-color:var(--warning-20)}.ui-badge-danger{background:var(--danger-12);color:var(--color-destructive);border-color:var(--danger-20)}.ui-icon-button{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;border:1px solid var(--border-color);background:var(--white-95);color:var(--fg-foreground);cursor:pointer;transition:transform var(--motion-fast) var(--ease-standard),box-shadow var(--motion-fast) var(--ease-standard),background var(--motion-fast) var(--ease-standard),border-color var(--motion-fast) var(--ease-standard),color var(--motion-fast) var(--ease-standard);box-shadow:var(--shadow-sm)}.ui-icon-button:hover{background:var(--bg-card);border-color:var(--border-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.ui-icon-button:active{transform:translateY(0);box-shadow:var(--shadow-sm)}svg.icon{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;display:inline-block;vertical-align:middle;flex-shrink:0}.page-header{border-bottom:none;background:var(--bg-card);position:relative}.page-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--border-color) 15%,var(--gold-20) 50%,var(--border-color) 85%,transparent)}.page-header-inner{max-width:1200px;margin:0 auto;padding:20px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}.page-header-left{display:flex;align-items:center;gap:12px}.page-header-icon{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,var(--gold-15),var(--primary-10));color:var(--color-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.page-header-icon .icon{width:22px;height:22px}.page-header-text{display:flex;flex-direction:column;gap:3px}.page-header-title{margin:0;font-size:24px;font-weight:700;color:var(--fg-foreground);font-family:"Noto Serif SC",Geist,PingFang SC,serif;letter-spacing:4px}.page-header-subtitle{margin:0;font-size:13px;color:var(--fg-muted-foreground)}.page-header-tools{display:flex;align-items:center;gap:8px}.page-tool-btn{border:none;background:transparent;color:var(--fg-muted-foreground);font-size:14px;font-weight:500;padding:8px 12px;border-radius:8px;display:inline-flex;align-items:center;gap:6px;cursor:pointer;transition:background var(--motion-fast),color var(--motion-fast);white-space:nowrap;min-height:36px}.page-tool-btn:hover{background:var(--bg-accent);color:var(--fg-foreground)}.page-tool-btn .icon{width:16px;height:16px}.home-view{min-height:100vh}.home-content{padding:32px 24px;max-width:1200px;margin:0 auto}.header-actions{display:flex;gap:16px;align-items:center}.navigation-cards{display:flex;flex-direction:column;gap:8px}.nav-card{display:flex;align-items:center;gap:20px;padding:24px 28px;border:1px solid var(--border-color);border-radius:14px;background:var(--bg-card);text-align:left;cursor:pointer;transition:border-color .18s,box-shadow .18s,background .18s}.nav-card:hover{border-color:var(--primary-20);background:var(--bg-accent);box-shadow:var(--shadow-sm)}.nav-card.disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.nav-card-icon{width:54px;height:54px;border-radius:14px;background:var(--bg-secondary);color:var(--fg-muted-foreground);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .18s,color .18s}.nav-card-icon .icon{width:28px;height:28px}.nav-card:hover .nav-card-icon{background:linear-gradient(135deg,var(--gold-15),var(--primary-12));color:var(--color-primary)}.nav-card h2{font-size:19px;font-weight:600;margin:0 0 5px}.nav-card p{font-size:15px;color:var(--fg-muted-foreground);margin:0;line-height:1.5}.nav-card-info{flex:1;min-width:0}.nav-card-arrow{width:20px;height:20px;color:var(--fg-muted-foreground);flex-shrink:0}.file-editor-view{padding:20px}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:16px 24px;background:var(--bg-card);border-radius:14px;border:1px solid var(--border-color)}.file-editor-view .header .course-info{flex:1;order:0}.course-info{flex:1}.course-info h2{color:var(--color-stone);font-size:1.4em;margin-bottom:8px;font-weight:500}.lesson-info{display:flex;gap:16px;align-items:center;font-size:1em;color:var(--color-incense);font-weight:400}.lesson-counter{background:linear-gradient(135deg,var(--primary-12),var(--success-12));padding:6px 14px;border-radius:20px;font-size:.9em;font-weight:500;border:1px solid var(--primary-20)}.file-editor-view .header .progress-info{font-size:1em;color:var(--color-incense);font-weight:400;display:flex;gap:20px;align-items:center;order:1}.progress-info{font-size:1em;color:var(--color-incense);font-weight:400;display:flex;gap:20px;align-items:center}.progress-info .btn{margin-left:20px;font-size:.9em;padding:10px 20px}.file-status{padding:6px 14px;border-radius:20px;font-size:.9em;font-weight:500;transition:all .3s ease}.status-done{background:linear-gradient(135deg,var(--success-15),var(--success-25));color:var(--color-jade);border:1px solid var(--success-30)}.status-pending{background:linear-gradient(135deg,var(--warning-15),var(--warning-25));color:var(--color-amber);border:1px solid var(--warning-30)}.editor-container{display:grid;grid-template-columns:7fr 3fr;gap:24px;margin-bottom:24px;min-height:500px;height:calc(100vh - 280px);max-height:calc(100vh - 280px);overflow:visible}.image-panel{background:var(--color-paper);border-radius:14px;box-shadow:0 4px 16px var(--color-shadow);overflow:visible;display:flex;flex-direction:column;border:1px solid var(--primary-10);min-height:0}.text-panels{display:flex;flex-direction:row;gap:20px;height:100%;min-height:500px}.text-panel{background:var(--color-paper);border-radius:14px;box-shadow:0 4px 16px var(--color-shadow);overflow:hidden;display:flex;flex-direction:column;transition:all .3s ease;border:1px solid var(--primary-10)}.main-text-panel{flex:2;min-width:0;display:flex;flex-direction:column}.image-container{padding:24px;text-align:center;flex:1;min-height:0;max-height:calc(100% - 80px);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}#screenshot-image{max-width:100%;max-height:100%;border-radius:8px;box-shadow:0 4px 20px var(--ink-20)}.btn-copy-image{position:absolute;top:32px;right:32px;width:44px;height:44px;border-radius:12px;font-size:20px;border:1px solid var(--border-color);background:var(--white-95);color:var(--fg-foreground);box-shadow:var(--shadow-md);transition:transform var(--motion-base) var(--ease-standard),box-shadow var(--motion-base) var(--ease-standard),background var(--motion-base) var(--ease-standard),border-color var(--motion-base) var(--ease-standard),color var(--motion-base) var(--ease-standard)}.btn-copy-image:hover{transform:translateY(-2px);background:var(--bg-card);border-color:var(--border-hover);box-shadow:var(--shadow-lg)}.text-header{padding:14px 20px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0;display:flex;justify-content:space-between;align-items:center;min-height:56px}.text-toggle-controls{display:flex;align-items:center;gap:10px}.btn-sm{padding:10px 18px;font-size:.9em;min-width:auto}.text-header label{font-weight:600;color:var(--color-earth);font-size:1.1em;letter-spacing:.5px}#corrected-text-editor{width:100%;flex:1;padding:20px;border:none;resize:none;font-family:PingFang SC,Hiragino Sans GB,Microsoft YaHei,monospace;font-size:17px;line-height:1.9;outline:none;background:var(--color-paper);color:var(--color-stone);min-height:300px;height:calc(100% - 52px);max-height:calc(100% - 52px);overflow-y:auto}#corrected-text-editor:focus{background:var(--color-paper)}#corrected-text-editor::-webkit-scrollbar{width:8px}#corrected-text-editor::-webkit-scrollbar-track{background:var(--primary-05);border-radius:4px}#corrected-text-editor::-webkit-scrollbar-thumb{background:var(--primary-30);border-radius:4px}#corrected-text-editor::-webkit-scrollbar-thumb:hover{background:var(--primary-50)}.button-panel{display:flex;justify-content:center;gap:24px;padding:24px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:0}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--white-95);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000}.loading-spinner{width:60px;height:60px;border:5px solid var(--primary-20);border-top:5px solid var(--color-saffron);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:24px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-overlay p{color:var(--color-stone);font-size:1.2em;font-weight:500;letter-spacing:1px}.message{position:fixed;top:24px;right:24px;padding:16px 24px;border-radius:12px;color:var(--fg-inverse);font-weight:500;z-index:1001;transform:translate(120%);transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .4s ease;opacity:0;pointer-events:none;box-shadow:0 8px 24px var(--ink-20);max-width:400px}.message.show{transform:translate(0);opacity:1;pointer-events:auto}.message.success{background:linear-gradient(135deg,var(--color-jade),var(--color-success-hover))}.message.error{background:linear-gradient(135deg,var(--color-error),var(--color-destructive-hover))}.message.info{background:linear-gradient(135deg,var(--color-saffron),var(--color-saffron-dark))}.course-selection-view{padding:16px;min-height:100vh;display:flex;flex-direction:column}.course-selection-header{margin-bottom:16px;flex-shrink:0}.course-selection-header h1{color:var(--color-stone);font-size:1.6em;margin:0;font-weight:500;letter-spacing:1px}.course-list-container{background:var(--color-paper);border-radius:14px;box-shadow:0 4px 16px var(--color-shadow);overflow:hidden;flex:1;display:flex;flex-direction:column;border:1px solid var(--primary-10)}.course-list-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0}.course-list-header h2{color:var(--color-stone);font-size:1.2em;margin:0;font-weight:500}.course-stats{display:flex;gap:12px;font-size:.85em;color:var(--color-incense)}.course-stats span{background:var(--primary-08);padding:4px 10px;border-radius:12px;font-weight:500;border:1px solid var(--primary-15);line-height:1.3}.course-list{flex:1;overflow-y:auto;padding:8px}.course-list::-webkit-scrollbar{width:10px}.course-list::-webkit-scrollbar-track{background:var(--primary-05)}.course-list::-webkit-scrollbar-thumb{background:var(--primary-30);border-radius:5px}.course-item{display:flex;align-items:center;padding:16px 20px;border:2px solid var(--primary-12);border-radius:10px;margin-bottom:10px;cursor:pointer;transition:transform var(--motion-base) var(--ease-standard),box-shadow var(--motion-base) var(--ease-standard),border-color var(--motion-base) var(--ease-standard),background var(--motion-base) var(--ease-standard);background:var(--color-sand)}.course-item:hover{background:var(--bg-accent);border-color:var(--primary-20);box-shadow:var(--shadow-sm)}.course-item:last-child{margin-bottom:0}.course-info{flex:1;order:1}.course-name{font-size:1.1em;font-weight:600;color:var(--color-stone);margin:0;letter-spacing:.3px;line-height:1.4}.course-actions{display:flex;gap:12px;align-items:center;order:2}.btn-course{padding:10px 20px;font-size:.95em;min-width:100px;line-height:1.2}.lesson-selection-view{padding:16px;min-height:100vh;display:flex;flex-direction:column}.lesson-selection-header{margin-bottom:16px;flex-shrink:0;position:sticky;top:0;z-index:10}.lesson-selection-header h1{color:var(--color-stone);font-size:1.5em;margin:0;font-weight:500;letter-spacing:.5px}.header-actions{display:flex;gap:12px}.lesson-list-container{background:var(--color-paper);border-radius:14px;box-shadow:0 4px 16px var(--color-shadow);overflow:hidden;flex:1;display:flex;flex-direction:column;border:1px solid var(--success-10)}.lesson-list-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0}.lesson-list-header h2{color:var(--color-stone);font-size:1.2em;margin:0;font-weight:500}.lesson-stats{display:flex;gap:12px;font-size:.85em;color:var(--color-incense)}.lesson-stats span{background:var(--success-08);padding:4px 10px;border-radius:12px;font-weight:500;border:1px solid var(--success-15);line-height:1.3}.lesson-list{flex:1;overflow-y:auto;overflow-x:hidden;min-width:0;padding:4px}.lesson-list::-webkit-scrollbar{width:10px}.lesson-list::-webkit-scrollbar-track{background:var(--success-05)}.lesson-list::-webkit-scrollbar-thumb{background:var(--success-30);border-radius:5px}.lesson-item{display:flex;align-items:center;padding:14px 16px;border-bottom:1px solid var(--primary-08);cursor:pointer;transition:background var(--motion-base) var(--ease-standard),color var(--motion-base) var(--ease-standard),transform var(--motion-base) var(--ease-standard),box-shadow var(--motion-base) var(--ease-standard);position:relative;min-width:0;overflow:hidden;border-radius:8px;margin-bottom:4px}.lesson-item:hover{background:var(--bg-accent);border-color:var(--primary-20)}.lesson-item:last-child{border-bottom:none}.lesson-item.completed{background:var(--success-05);border:1px solid var(--success-20)}.lesson-item.completed:hover{background:var(--success-08)}.lesson-item.current{background:var(--primary-05);border:1px solid var(--primary-20)}.lesson-item.current:hover{background:var(--primary-08)}.lesson-info{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0;overflow:hidden}.lesson-name{font-size:1.05em;font-weight:600;color:var(--color-stone);margin:0;letter-spacing:.2px;line-height:1.4}.lesson-progress{font-size:.9em;color:var(--color-incense);display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-width:0}.lesson-status{display:flex;align-items:center;gap:8px;font-size:.9em;flex-shrink:0}.status-badge{padding:5px 10px;border-radius:12px;font-size:.82em;font-weight:600;letter-spacing:.2px;line-height:1.3}.status-completed{background:var(--bg-success);color:var(--color-success);border:1px solid var(--success-20)}.status-in-progress{background:var(--bg-warning);color:var(--color-warning);border:1px solid var(--warning-20)}.status-not-started{background:var(--bg-destructive);color:var(--color-destructive);border:1px solid var(--danger-20)}.progress-bar{width:100px;min-width:80px;max-width:150px;height:6px;background:var(--ink-15);border-radius:3px;overflow:hidden;flex-shrink:0}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-jade),var(--color-success-hover));transition:width .4s ease;border-radius:4px}.progress-fill.in-progress{background:linear-gradient(90deg,var(--color-amber),var(--color-warning-hover))}.progress-fill.not-started{background:linear-gradient(90deg,var(--color-error),var(--color-destructive-hover))}.lesson-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.btn-lesson{padding:8px 16px;font-size:.85em;min-width:80px;line-height:1.2}.btn-lesson:disabled{opacity:.4;cursor:not-allowed}.audio-player-container{padding:18px 24px;background:linear-gradient(135deg,var(--white-95),var(--white-98));-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid var(--primary-12);box-shadow:0 -2px 20px var(--ink-08);flex-shrink:0!important;min-height:80px!important;border-radius:0;position:relative;z-index:10;visibility:visible!important;display:flex!important;overflow:visible}.audio-player-row{display:flex;align-items:center;gap:14px}.btn-audio-play{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover));color:var(--fg-inverse);border:none;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px var(--primary-35),0 2px 8px var(--primary-20);transition:all .25s cubic-bezier(.4,0,.2,1);flex-shrink:0;position:relative;overflow:hidden}.btn-audio-play:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:var(--white-30);transform:translate(-50%,-50%);transition:width .3s ease,height .3s ease}.btn-audio-play:hover:before{width:100%;height:100%}.btn-audio-play:hover{transform:scale(1.05);box-shadow:0 6px 20px var(--primary-45),0 3px 10px var(--primary-25)}.btn-audio-play:active{transform:scale(.98);box-shadow:0 2px 12px var(--primary-30)}.audio-progress-container{flex:1;height:6px;background:var(--ink-12);border-radius:10px;position:relative;overflow:visible;cursor:pointer;transition:height .2s ease}.audio-progress-container:hover{height:8px}.audio-progress-track{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-success));border-radius:10px;transition:width .1s linear;box-shadow:0 0 8px var(--primary-40)}.audio-progress-simple{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:2}.audio-progress-simple::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--bg-card);border:2px solid var(--color-primary);box-shadow:0 2px 8px var(--primary-40);cursor:pointer;transition:all .2s ease}.audio-progress-simple::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 3px 12px var(--primary-50)}.audio-progress-simple::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--bg-card);border:2px solid var(--color-primary);box-shadow:0 2px 8px var(--primary-40);cursor:pointer;transition:all .2s ease}.audio-progress-simple::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 3px 12px var(--primary-50)}.audio-time-display{font-size:.875em;color:var(--ink-70);font-weight:500;white-space:nowrap;flex-shrink:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;letter-spacing:.3px}.audio-speed-control{flex-shrink:0;display:flex;align-items:center}.audio-speed-select{padding:6px 12px;border:1.5px solid var(--primary-20);border-radius:8px;background:var(--white-90);color:var(--ink-85);font-size:.85em;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);min-width:65px;outline:none;box-shadow:0 1px 3px var(--ink-05)}.audio-speed-select:hover{border-color:var(--primary-40);background:var(--bg-card);box-shadow:0 2px 6px var(--primary-15);transform:translateY(-1px)}.audio-speed-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--primary-15);background:var(--bg-card)}.floating-window{position:fixed;background:var(--color-paper);border-radius:14px;box-shadow:0 12px 48px var(--ink-25);z-index:1000;display:flex;flex-direction:column;min-width:400px;max-width:600px;max-height:80vh;border:2px solid var(--primary-20)}.window-header{padding:16px 20px;background:linear-gradient(135deg,var(--primary-08),var(--success-08));border-bottom:1px solid var(--primary-20);cursor:move;display:flex;justify-content:space-between;align-items:center;border-radius:12px 12px 0 0}.window-header h3{margin:0;color:var(--color-stone);font-size:1.1em;font-weight:500;letter-spacing:.5px}.window-controls{display:flex;gap:10px;align-items:center}.btn-close{background:none;border:none;font-size:28px;color:var(--color-incense);cursor:pointer;line-height:1;transition:all .2s ease;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%}.btn-close:hover{background:var(--danger-15);color:var(--color-error)}.window-body{flex:1;overflow:auto;padding:20px}.window-body textarea{width:100%;min-height:300px;padding:16px;border:2px solid var(--primary-15);border-radius:10px;font-family:PingFang SC,Hiragino Sans GB,Microsoft YaHei,monospace;font-size:14px;line-height:1.8;resize:vertical;background:var(--color-sand);color:var(--color-stone)}.window-body textarea::-webkit-scrollbar{width:8px}.window-body textarea::-webkit-scrollbar-track{background:var(--primary-05)}.window-body textarea::-webkit-scrollbar-thumb{background:var(--primary-30);border-radius:4px}.audio-index-window{min-width:450px}.audio-index-body{padding:0;max-height:500px}.audio-index-list{display:flex;flex-direction:column}.audio-index-item{padding:14px 20px;border-bottom:1px solid var(--primary-08);cursor:pointer;transition:all .2s ease}.audio-index-item:hover{background:var(--primary-05)}.audio-index-item.active{background:linear-gradient(135deg,var(--primary-12),var(--success-12));border-left:4px solid var(--color-saffron)}.audio-index-time{font-size:.85em;color:var(--color-incense);font-weight:500;margin-bottom:6px}.audio-index-text{font-size:.95em;color:var(--color-stone);line-height:1.6}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--ink-70);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000}.modal-content{background:var(--color-paper);border-radius:16px;box-shadow:0 20px 60px var(--ink-40);width:90%;max-width:500px;border:2px solid var(--primary-20)}.modal-header{padding:24px 28px;border-bottom:1px solid var(--primary-15);display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,var(--primary-05),var(--success-05));border-radius:14px 14px 0 0}.modal-header h3{margin:0;color:var(--color-stone);font-size:1.3em;font-weight:500;letter-spacing:1px}.modal-body{padding:28px}.modal-footer{padding:20px 28px;border-top:1px solid var(--primary-15);display:flex;justify-content:flex-end;gap:12px}.upload-status{margin-top:16px;padding:12px 16px;border-radius:10px;font-size:.9em}.upload-status.success{background:var(--success-12);color:var(--color-jade);border:1px solid var(--success-30)}.upload-status.error{background:var(--danger-12);color:var(--color-error);border:1px solid var(--danger-30)}.save-dialog{border:none;border-radius:16px;box-shadow:0 20px 60px var(--ink-40);padding:0;background:var(--color-paper);min-width:400px;border:2px solid var(--primary-20)}.save-dialog::backdrop{background:var(--ink-70);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.save-dialog-form{display:flex;flex-direction:column}.save-dialog-header{padding:24px 28px;border-bottom:1px solid var(--primary-15);background:linear-gradient(135deg,var(--primary-05),var(--success-05));border-radius:14px 14px 0 0}.save-dialog-title{margin:0;color:var(--color-stone);font-size:1.2em;font-weight:500;letter-spacing:.5px}.save-dialog-body{padding:28px}.save-dialog-message{margin:0;color:var(--color-incense);font-size:1em;line-height:1.7}.save-dialog-footer{padding:20px 28px;border-top:1px solid var(--primary-15);display:flex;justify-content:flex-end;gap:12px}.save-dialog-btn{min-width:100px}@media (min-width: 769px) and (max-width: 1200px){.audio-player-container{flex-shrink:0!important;min-height:80px!important;display:flex!important}.image-container{max-height:calc(100% - 80px)!important;min-height:0!important}.image-panel{display:flex;flex-direction:column;min-height:0;overflow:visible!important}.editor-container{overflow:visible!important}.audio-speed-select{padding:5px 8px;font-size:.8em;min-width:55px}.audio-player-container{background:linear-gradient(135deg,var(--white-95),var(--white-98));-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 -2px 20px var(--ink-08);visibility:visible!important;overflow:visible!important}}@media (max-width: 768px){.btn,button{min-height:44px;touch-action:manipulation}.header .btn,.header button{min-height:36px;padding:8px 14px;font-size:.85em}.course-list,.lesson-list{-webkit-overflow-scrolling:touch}.editor-container{grid-template-columns:1fr;grid-template-rows:auto 1fr;gap:16px;min-height:auto;height:auto;max-height:none;overflow:visible!important}.image-panel{order:1;max-height:65vh;overflow:visible!important}.image-container{padding:12px;min-height:0;max-height:calc(65vh - 50px)}#screenshot-image{max-height:60vh}.text-panels{order:2;flex-direction:column;gap:16px;height:auto;min-height:250px;max-height:35vh}.text-panel{min-height:250px;max-height:35vh}#corrected-text-editor{min-height:250px;font-size:16px;padding:16px}.button-panel{flex-direction:column;gap:12px;padding:16px;position:sticky;bottom:0;border-radius:0;border-top:1px solid var(--border-color);z-index:20}.btn{width:100%;padding:18px 20px;font-size:16px}.text-toggle-controls{gap:6px}.text-toggle-controls .btn-sm{padding:8px 12px;font-size:.82em;min-height:36px}.text-header{padding:12px 14px;min-height:52px}.file-editor-view{padding:12px}.header{flex-direction:column;gap:12px;padding:16px}.course-info h2{font-size:1.1em}.lesson-info{font-size:.85em;gap:8px;flex-wrap:wrap}.lesson-counter{padding:4px 10px;font-size:.85em}.progress-info{flex-direction:row;gap:8px;font-size:.85em;flex-wrap:wrap}.file-status{padding:4px 10px;font-size:.85em}.progress-info .btn{margin-left:auto;font-size:.85em;padding:8px 14px}.login-container{padding:36px 24px;margin:12px}.login-header h1{font-size:1.6em}.login-header:before{font-size:28px}.page-header-inner{padding:12px 16px;flex-wrap:wrap;gap:10px}.page-header-title{font-size:17px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.page-header-tools{width:100%;justify-content:flex-end;flex-wrap:wrap;gap:4px}.pass-toggle-group button{padding:6px 12px;font-size:14px}.home-content{padding:16px}.navigation-cards{gap:6px}.course-selection-view{padding:12px}.course-list-header{flex-direction:column;gap:12px;padding:16px}.course-list-header h2{font-size:1.2em}.course-stats{flex-direction:column;gap:8px;width:100%}.course-stats span{width:100%;text-align:center}.course-item{padding:16px;gap:12px}.course-name{font-size:1em;font-weight:600}.btn-course{padding:10px 18px;font-size:.9em}.lesson-selection-view{padding:8px}.lesson-list-header{flex-direction:column;gap:8px;padding:10px 12px}.lesson-list-header h2{font-size:1.1em;font-weight:600}.lesson-stats{flex-direction:row;gap:6px;width:100%;flex-wrap:wrap}.lesson-stats span{width:auto;text-align:center;padding:3px 8px;font-size:.8em}.lesson-item{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto auto;gap:6px;padding:10px 12px;margin-bottom:3px;align-items:start}.lesson-info{display:contents}.lesson-name{font-size:.95em;line-height:1.3;font-weight:600;grid-column:1 / -1;grid-row:1}.lesson-progress{font-size:.8em;gap:6px;display:flex;align-items:center;flex-wrap:nowrap;grid-column:1;grid-row:2}.progress-bar{height:5px;min-width:60px;flex:1;max-width:120px}.lesson-status{grid-column:2;grid-row:2;display:flex;align-items:center;gap:6px;margin-left:8px}.lesson-actions{grid-column:1 / -1;grid-row:3;width:100%;gap:6px}.status-badge{padding:5px 10px;font-size:.78em}.lesson-actions{order:3;width:100%;gap:6px}.btn-lesson{width:100%;padding:14px 12px;font-size:.95em}.audio-player-container{padding:14px 16px;flex-shrink:0!important;min-height:70px!important;display:flex!important}.btn-audio-play{width:46px;height:46px;font-size:16px}.audio-time-display{font-size:.82em}.audio-speed-select{padding:7px 10px;font-size:.82em;min-width:60px}.floating-window{top:auto!important;bottom:0!important;left:0!important;right:0!important;width:100%!important;min-width:0;max-width:100%;border-radius:16px 16px 0 0!important;max-height:70vh}.audio-index-window{min-width:auto}.window-header{padding:14px 16px}.window-body{padding:16px}.modal-content{width:95%;margin:12px}.modal-header{padding:18px 20px}.modal-header h3{font-size:1.1em}.modal-body{padding:20px}.modal-footer{padding:16px 20px;flex-direction:column}.modal-footer .btn{width:100%}.save-dialog{min-width:auto;width:90%;margin:12px}.save-dialog-footer{flex-direction:column}.save-dialog-btn{width:100%}.message{top:12px;right:12px;left:12px;max-width:none}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}.floating-window{position:fixed;height:600px;background-color:var(--bg-card);border-radius:8px;box-shadow:0 8px 32px var(--ink-30);display:flex;flex-direction:column;overflow:hidden;z-index:2000;border:1px solid var(--border-subtle);resize:both;min-width:300px;min-height:300px;max-width:80vw;max-height:80vh}.window-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);flex-shrink:0;cursor:move;-webkit-user-select:none;user-select:none}.window-header h3{margin:0;color:var(--fg-foreground);font-size:1.1em;font-weight:600}.window-controls{display:flex;align-items:center;gap:8px}.btn-close{background:var(--bg-secondary);border:1px solid var(--border-color);font-size:16px;color:var(--fg-muted-foreground);cursor:pointer;padding:4px;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;transition:background var(--motion-fast) var(--ease-standard),color var(--motion-fast) var(--ease-standard),border-color var(--motion-fast) var(--ease-standard),transform var(--motion-fast) var(--ease-standard)}.btn-close:hover{background:var(--bg-secondary-hover);color:var(--fg-foreground);border-color:var(--border-hover);transform:translateY(-1px)}.window-body{flex:1;padding:0;overflow:hidden;display:flex;flex-direction:column}#original-content-text{width:100%;height:100%;padding:15px;border:none;resize:none;font-family:Consolas,Monaco,Courier New,monospace;font-size:14px;line-height:1.5;outline:none;background-color:var(--bg-secondary);color:var(--fg-subtle);flex:1;box-sizing:border-box}.save-dialog{padding:0;border:none;border-radius:8px;box-shadow:0 4px 20px var(--ink-15);background:var(--bg-card);max-width:450px;width:90%;max-height:90vh;overflow:hidden}.save-dialog::backdrop{background-color:var(--ink-50);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.save-dialog-form{display:flex;flex-direction:column;height:100%}.save-dialog-header{padding:20px 24px 16px;border-bottom:1px solid var(--border-subtle);background:linear-gradient(to bottom,var(--bg-secondary),var(--bg-card))}.save-dialog-title{margin:0;font-size:18px;font-weight:600;color:var(--fg-foreground);line-height:1.4}.save-dialog-body{padding:20px 24px;flex:1;display:flex;align-items:center}.save-dialog-message{margin:0;font-size:15px;color:var(--fg-subtle);line-height:1.6;word-wrap:break-word}.save-dialog-footer{padding:16px 24px 20px;border-top:1px solid var(--border-subtle);display:flex;justify-content:flex-end;gap:10px;background-color:var(--bg-secondary)}.save-dialog-btn{min-width:80px;padding:8px 16px;font-size:14px;border-radius:4px;cursor:pointer;transition:all .2s ease;border:1px solid transparent}.save-dialog-btn:hover{transform:translateY(-1px);box-shadow:0 2px 4px var(--ink-10)}.save-dialog-btn:active{transform:translateY(0)}.save-dialog-btn:focus{outline:2px solid var(--color-primary);outline-offset:2px}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:var(--ink-50);display:flex;align-items:center;justify-content:center;z-index:1500}.modal-content{background-color:var(--bg-card);border-radius:8px;box-shadow:0 4px 20px var(--ink-15);max-width:500px;width:90%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-subtle)}.modal-header h3{margin:0;color:var(--fg-foreground);font-size:1.2em}.modal-body{padding:20px 24px;flex:1}.modal-footer{padding:16px 24px;border-top:1px solid var(--border-subtle);display:flex;justify-content:flex-end;gap:10px}.upload-status{margin-top:15px;padding:10px;border-radius:4px;font-size:14px}.upload-status.success{background-color:var(--bg-success);color:var(--color-success)}.upload-status.error{background-color:var(--bg-destructive);color:var(--color-destructive)}.upload-status.info{background-color:var(--primary-08);color:var(--color-primary)}.image-container{position:relative}.audio-player-container{background:var(--bg-card);border-top:1px solid var(--border-subtle);padding:8px 15px;margin-top:0}.audio-player-row{display:flex;align-items:center;gap:12px;width:100%}.btn-audio-play{background:var(--bg-card);border:1px solid var(--border-color);font-size:14px;cursor:pointer;padding:2px 6px;border-radius:8px;transition:background var(--motion-fast) var(--ease-standard),border-color var(--motion-fast) var(--ease-standard),transform var(--motion-fast) var(--ease-standard);display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;flex-shrink:0}.btn-audio-play:hover{background:var(--bg-secondary);border-color:var(--border-hover);transform:translateY(-1px)}.btn-audio-play:active{background-color:var(--ink-10)}.audio-time-display{font-size:12px;color:var(--fg-subtle);font-weight:500;text-align:right;font-family:Consolas,Monaco,Courier New,monospace;flex-shrink:0;white-space:nowrap;min-width:100px}.audio-progress-container{position:relative;flex:1;height:8px;background-color:var(--border-subtle);border-radius:4px;overflow:visible;cursor:pointer}.audio-progress-track{position:absolute;top:0;left:0;height:100%;background-color:var(--color-primary);border-radius:4px;transition:width .1s linear;z-index:1}.audio-progress-simple{position:absolute;top:0;left:0;width:100%;height:8px;border-radius:4px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;cursor:grab;z-index:2;margin:0;padding:0}.audio-progress-simple:active{cursor:grabbing}.audio-progress-simple::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--color-primary);cursor:grab;border:3px solid var(--bg-card);box-shadow:0 2px 6px var(--ink-30),0 0 0 4px var(--primary-20);transition:all .2s ease;margin-top:-5px}.audio-progress-simple::-webkit-slider-thumb:hover{background:var(--color-primary-hover);transform:scale(1.3);box-shadow:0 3px 8px var(--ink-40),0 0 0 5px var(--primary-30)}.audio-progress-simple::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.2)}.audio-progress-simple::-webkit-slider-runnable-track{height:8px;border-radius:4px;background:transparent}.audio-progress-simple::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--color-primary);cursor:grab;border:3px solid var(--bg-card);box-shadow:0 2px 6px var(--ink-30),0 0 0 4px var(--primary-20);transition:all .2s ease}.audio-progress-simple::-moz-range-thumb:hover{background:var(--color-primary-hover);transform:scale(1.3);box-shadow:0 3px 8px var(--ink-40),0 0 0 5px var(--primary-30)}.audio-progress-simple::-moz-range-thumb:active{cursor:grabbing;transform:scale(1.2)}.audio-progress-simple::-moz-range-track{height:8px;border-radius:4px;background:transparent}.btn-copy-image{position:absolute;top:10px;right:10px;padding:6px;background-color:var(--white-95);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--ink-10);border-radius:6px;font-size:18px;line-height:1;color:var(--fg-foreground);cursor:pointer;transition:all .2s ease;z-index:10;box-shadow:0 2px 8px var(--ink-15);width:32px;height:32px;display:flex;align-items:center;justify-content:center}.btn-copy-image:hover{background-color:var(--bg-card);transform:translateY(-2px);box-shadow:0 4px 12px var(--ink-20)}.btn-copy-image:active{transform:translateY(0)}.audio-index-window{max-height:70vh}.audio-index-body{overflow-y:auto;padding:0}.audio-index-list{padding:10px}.audio-index-item{padding:12px;margin-bottom:8px;border-radius:6px;border:1px solid var(--border-subtle);background-color:var(--bg-card);cursor:pointer;transition:all .2s ease}.audio-index-item:hover{background-color:var(--bg-secondary);border-color:var(--color-primary);transform:translate(3px)}.audio-index-item.active{background-color:var(--primary-08);border-color:var(--color-primary);box-shadow:0 2px 4px var(--primary-20)}.audio-index-time{font-size:13px;color:var(--fg-muted-foreground);font-weight:600;margin-bottom:6px;font-family:Consolas,Monaco,Courier New,monospace}.audio-index-text{font-size:15px;color:var(--fg-foreground);line-height:1.6;word-break:break-word}@media (max-width: 768px){.audio-player-container{padding:6px 12px;min-height:50px!important;background:linear-gradient(135deg,var(--white-98),var(--white-99));box-shadow:0 -1px 12px var(--ink-06)}.audio-player-row{gap:8px}.btn-audio-play{font-size:16px;width:40px;min-width:40px;height:40px;padding:0;box-shadow:0 2px 8px var(--primary-30),0 1px 4px var(--primary-20)}.btn-audio-play:hover{transform:scale(1.05);box-shadow:0 3px 10px var(--primary-40),0 1px 5px var(--primary-25)}.audio-time-display{font-size:13px;min-width:80px;color:var(--ink-65)}.audio-speed-select{padding:6px 8px;font-size:13px;min-width:56px;border-width:1px;box-shadow:0 1px 2px var(--ink-04)}.audio-speed-select:hover{transform:none}.audio-progress-container{height:4px;background:var(--ink-15)}.audio-progress-container:hover{height:5px}.audio-progress-track{box-shadow:0 0 6px var(--primary-35)}.audio-progress-simple{height:4px}.audio-progress-simple::-webkit-slider-thumb{width:14px;height:14px;border-width:2px;margin-top:-5px;box-shadow:0 2px 6px var(--primary-40)}.audio-progress-simple::-webkit-slider-thumb:active{transform:scale(1.15)}.audio-progress-simple::-moz-range-thumb{width:14px;height:14px;border-width:2px;box-shadow:0 2px 6px var(--primary-40)}.audio-progress-simple::-moz-range-thumb:active{transform:scale(1.15)}.btn-copy-image{top:8px;right:8px;padding:5px;font-size:16px;width:28px;height:28px}.audio-index-window{width:95vw!important;max-width:95vw!important;height:60vh;max-height:60vh;left:2.5vw!important;top:20vh!important}.audio-index-item{padding:12px 14px}.audio-index-time{font-size:13px}.audio-index-text{font-size:15px}}pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}/*!
  Theme: GitHub
  Description: Light theme as seen on github.com
  Author: github.com
  Maintainer: @Hirse
  Updated: 2021-05-15

  Outdated base version: https://github.com/primer/github-syntax-light
  Current colors taken from GitHub's CSS
*/.hljs{color:#24292e;background:#fff}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#d73a49}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#6f42c1}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id,.hljs-variable{color:#005cc5}.hljs-meta .hljs-string,.hljs-regexp,.hljs-string{color:#032f62}.hljs-built_in,.hljs-symbol{color:#e36209}.hljs-code,.hljs-comment,.hljs-formula{color:#6a737d}.hljs-name,.hljs-quote,.hljs-selector-pseudo,.hljs-selector-tag{color:#22863a}.hljs-subst{color:#24292e}.hljs-section{color:#005cc5;font-weight:700}.hljs-bullet{color:#735c0f}.hljs-emphasis{color:#24292e;font-style:italic}.hljs-strong{color:#24292e;font-weight:700}.hljs-addition{color:#22863a;background-color:#f0fff4}.hljs-deletion{color:#b31d28;background-color:#ffeef0}
