@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Noto+Sans+SC:wght@400;500;700&display=swap";@layer components;@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--radius-xs:.125rem;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--shadow-xs:0 1px 2px 0 #0000000d;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{.visible{visibility:visible}.static{position:static}.block{display:block}.contents{display:contents}.hidden{display:none}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}}:root{--brand-primary:#2f6fe8;--brand-hover:#1a5fd5;--brand-active:#0e52c7;--brand-light:#ebf2ff;--brand-lighter:#f4f8ff;--teal:#00bfb3;--teal-light:#e6faf9;--success:#27ae7a;--success-light:#e7f7f0;--warning:#f7a230;--warning-light:#fff5e6;--gray-50:#f8f9fa;--gray-100:#f2f3f5;--gray-200:#e4e6eb;--gray-300:#d0d3da;--gray-400:#9ea4b0;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--text-primary:#1f2329;--text-secondary:#646a73;--text-tertiary:#9ea4b0;--text-inverse:#fff;--bg-body:#f2f3f5;--bg-card:#fff;--bg-subtle:#f8f9fa;--bg-overlay:#0000000a;--border-default:#e4e6eb;--border-light:#f0f1f3;--border-focus:#2f6fe8;--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 16px #00000014, 0 1px 4px #0000000a;--shadow-lg:0 8px 32px #0000001a, 0 2px 8px #0000000f;--radius-xs:4px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-full:9999px;--page-max-width:960px;--page-padding:20px;--card-padding:28px;--font-sans:"Plus Jakarta Sans", "Noto Sans SC", -apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", sans-serif;--font-zh:"Noto Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif}*,:before,:after{box-sizing:border-box}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:15px}body{font-family:var(--font-sans);color:var(--text-primary);background-color:#eaf0fb;background-image:radial-gradient(at 15% 40%,#2f6fe821,#0000 55%),radial-gradient(at 85% 15%,#00bfb31a,#0000 50%),radial-gradient(at 70% 85%,#6a96f51a,#0000 50%),radial-gradient(at 40% 70%,#2f6fe80f,#0000 45%);min-height:100vh;line-height:1.7}body:before{content:"";pointer-events:none;z-index:0;background-image:radial-gradient(circle,#2f6fe81a 1px,#0000 1px);background-size:28px 28px;position:fixed;inset:0}.site-header,.page-main{z-index:1;position:relative}.site-header{z-index:50;-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-default);box-shadow:var(--shadow-xs);background:#eaf0fbe0;position:sticky;top:0}.header-inner{max-width:var(--page-max-width);padding:0 var(--page-padding);justify-content:space-between;align-items:center;gap:12px;height:56px;margin:0 auto;display:flex}.brand{color:var(--text-primary);flex-shrink:0;align-items:center;gap:9px;text-decoration:none;display:flex}.brand-icon{border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--brand-primary) 0%,#6b96f5 100%);color:#fff;letter-spacing:.5px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:11px;font-weight:800;display:flex}.brand-name{color:var(--text-primary);letter-spacing:-.2px;font-size:15px;font-weight:700}.header-right{align-items:center;gap:8px;display:flex}.header-date{color:var(--text-secondary);font-size:13px;font-weight:500}.today-badge{background:var(--success-light);color:var(--success);border-radius:var(--radius-full);border:1px solid #27ae7a33;align-items:center;gap:4px;padding:3px 9px;font-size:12px;font-weight:600;display:inline-flex}.page-main{max-width:var(--page-max-width);padding:24px var(--page-padding) 80px;margin:0 auto}@media(min-width:768px){:root{--page-padding:32px;--card-padding:36px}}.notice-bar{background:var(--warning-light);border-radius:var(--radius-md);color:#9e6800;border:1px solid #f7a23040;align-items:center;gap:8px;margin-bottom:20px;padding:11px 16px;font-size:13.5px;font-weight:500;display:flex}.notice-bar-icon{flex-shrink:0;font-size:15px}.card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-default);box-shadow:var(--shadow-sm);overflow:hidden}.card-padding{padding:var(--card-padding)}.lesson-header{margin-bottom:24px}.lesson-date-row{align-items:center;gap:10px;margin-bottom:12px;display:flex}.lesson-date-tag{background:var(--brand-light);color:var(--brand-primary);border-radius:var(--radius-full);letter-spacing:.3px;border:1px solid #2f6fe833;align-items:center;gap:6px;padding:4px 12px;font-size:12.5px;font-weight:600;display:inline-flex}.lesson-date-tag.is-today{background:var(--success-light);color:var(--success);border-color:#27ae7a33}.lesson-title{color:var(--text-primary);letter-spacing:-.5px;font-size:24px;font-weight:800;line-height:1.3}.article-body{margin-bottom:20px}.article-body p{color:var(--text-primary);letter-spacing:.03em;word-spacing:.08em;margin-bottom:28px;font-size:20px;line-height:2.6;line-height:2.6!important}.link-toggle-row{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;display:flex}.anno-btn{border-radius:var(--radius-full);cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none;border:1px solid #0000;align-items:center;gap:4px;padding:4px 11px;font-size:12px;font-weight:600;transition:background .15s,opacity .15s;display:inline-flex}.anno-btn.btn-link{background:var(--brand-lighter);color:var(--brand-primary);border-color:#2f6fe847}.anno-btn.btn-link:hover{background:var(--brand-light)}.anno-btn.btn-stress{color:#c2620b;background:#fff4e8;border-color:#c2620b47}.anno-btn.btn-stress:hover{background:#ffe8cc}.anno-btn.btn-tone{color:var(--success);background:#f0fbf5;border-color:#27ae7a47}.anno-btn.btn-tone:hover{background:var(--success-light)}.anno-btn.is-off{opacity:.45;background:var(--gray-100);color:var(--text-tertiary);border-color:var(--border-default)}.linked-words{color:var(--brand-primary);border-bottom:1.5px solid #2f6fe86b;border-radius:0 0 3px 3px;padding-bottom:1px}body.hide-linking .linked-words{color:inherit;border-bottom:none;padding-bottom:0}.word-nuclear{color:#c2620b;font-weight:700;position:relative}.word-nuclear:before{content:"ˈ";color:#c2620b;opacity:.9;pointer-events:none;font-size:13px;font-style:normal;font-weight:400;line-height:1;position:absolute;top:-16px;left:0}.word-func{color:var(--text-tertiary)}body.hide-stress .word-nuclear{color:inherit;font-weight:inherit}body.hide-stress .word-nuclear:before{display:none}body.hide-stress .word-func{color:inherit}.tone-fall{color:#d94f4f;vertical-align:-2px;opacity:.85;margin-left:2px;font-size:16px;font-style:normal;display:inline-block}.tone-rise{color:var(--success);vertical-align:-2px;opacity:.85;margin-left:2px;font-size:16px;font-style:normal;display:inline-block}.pause-minor{color:var(--text-tertiary);vertical-align:1px;opacity:.7;-webkit-user-select:none;user-select:none;margin:0 4px;font-size:15px;font-style:normal;display:inline-block}.pause-clause{color:#2f6fe88c;vertical-align:-1px;-webkit-user-select:none;user-select:none;margin:0 5px;font-size:14px;font-style:normal;display:inline-block}body.hide-intonation .tone-fall,body.hide-intonation .tone-rise,body.hide-intonation .pause-minor,body.hide-intonation .pause-clause{display:none}.article-body p:last-child{margin-bottom:0}.source-link{background:var(--brand-lighter);color:var(--brand-primary);border-radius:var(--radius-full);border:1px solid #2f6fe82e;align-items:center;gap:5px;margin-top:4px;margin-bottom:24px;padding:6px 14px;font-size:13px;font-weight:600;text-decoration:none;transition:background .15s,transform .15s;display:inline-flex}.source-link:hover{background:var(--brand-light);transform:translateY(-1px)}.section-block{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-default);box-shadow:var(--shadow-xs);margin-bottom:12px;transition:box-shadow .2s;overflow:hidden}.section-block:hover{box-shadow:var(--shadow-sm)}.section-header{cursor:pointer;text-align:left;width:100%;color:var(--text-primary);-webkit-user-select:none;user-select:none;background:0 0;border:none;justify-content:space-between;align-items:center;gap:12px;min-height:52px;padding:14px 18px;transition:background .15s;display:flex}.section-header:hover{background:var(--bg-overlay)}.section-header-left{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.section-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex}.section-icon.vocab-icon{background:#ebf5ff}.section-icon.expr-icon{background:#f0fbf0}.section-icon.qa-icon{background:#fff6e8}.section-title{color:var(--text-primary);font-size:15px;font-weight:700}.section-count{color:var(--text-tertiary);background:var(--gray-100);border-radius:var(--radius-full);padding:2px 7px;font-size:12px;font-weight:600}.section-chevron{border-radius:var(--radius-full);background:var(--gray-100);width:20px;height:20px;color:var(--text-secondary);flex-shrink:0;justify-content:center;align-items:center;font-size:10px;transition:transform .25s,background .15s;display:flex}[data-collapsed=false] .section-chevron{background:var(--brand-light);color:var(--brand-primary);transform:rotate(180deg)}.section-body{transition:grid-template-rows .28s cubic-bezier(.4,0,.2,1);display:grid}.section-body-inner{overflow:hidden}.section-content{border-top:1px solid var(--border-light);padding:4px 18px 18px}.vocab-entry{border-radius:var(--radius-md);background:var(--bg-subtle);border:1px solid var(--border-light);margin-bottom:10px;padding:12px 14px;transition:border-color .15s,box-shadow .15s;position:relative}.vocab-entry:last-child{margin-bottom:0}.vocab-entry:hover{border-color:#2f6fe840;box-shadow:0 2px 8px #2f6fe80f}.vocab-entry:before{content:"";background:var(--brand-primary);opacity:.5;border-radius:0 2px 2px 0;width:3px;position:absolute;top:12px;bottom:12px;left:0}.vocab-word-row{flex-wrap:wrap;align-items:baseline;gap:6px;margin-bottom:5px;display:flex}.vocab-word{color:var(--text-primary);letter-spacing:-.2px;font-size:16px;font-weight:700}.vocab-pos{border-radius:var(--radius-full);background:var(--brand-light);color:var(--brand-primary);text-transform:lowercase;letter-spacing:.2px;align-items:center;padding:1px 7px;font-size:11px;font-weight:600;display:inline-flex}.vocab-zh{color:var(--text-secondary);font-size:13px;font-family:var(--font-zh)}.vocab-def{color:var(--text-secondary);margin-bottom:4px;font-size:13.5px;line-height:1.6}.vocab-quote{color:var(--text-tertiary);border-left:2px solid var(--gray-300);margin-top:6px;padding-left:10px;font-size:12.5px;font-style:italic;line-height:1.6}.expr-entry{border-radius:var(--radius-md);background:var(--bg-subtle);border:1px solid var(--border-light);margin-bottom:10px;padding:12px 14px;transition:border-color .15s}.expr-entry:last-child{margin-bottom:0}.expr-entry:hover{border-color:#00bfb34d}.expr-phrase-row{flex-wrap:wrap;align-items:baseline;gap:6px;margin-bottom:5px;display:flex}.expr-phrase{color:var(--teal);letter-spacing:-.2px;font-size:15px;font-weight:700}.expr-zh{color:var(--text-secondary);font-size:13px;font-family:var(--font-zh)}.expr-explanation{color:var(--text-secondary);margin-bottom:6px;font-size:13.5px;line-height:1.6}.expr-examples{margin:0;padding:0;list-style:none}.expr-examples li{color:var(--text-secondary);border-radius:var(--radius-xs);background:#00bfb30a;gap:8px;margin-bottom:3px;padding:4px 8px;font-size:12.5px;line-height:1.6;display:flex}.expr-examples li:before{content:"›";color:var(--teal);flex-shrink:0;margin-top:1px;font-weight:700}.qa-block{border-radius:var(--radius-md);border:1px solid var(--border-light);margin-bottom:12px;overflow:hidden}.qa-block:last-child{margin-bottom:0}.qa-question{color:var(--text-primary);background:var(--bg-subtle);gap:8px;padding:11px 14px;font-size:14px;font-weight:600;line-height:1.6;display:flex}.qa-question-num{border-radius:var(--radius-full);background:var(--warning-light);width:20px;height:20px;color:var(--warning);flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;font-size:11px;font-weight:700;display:flex}.qa-answer{background:var(--bg-card);border-top:1px solid var(--border-light);padding:10px 14px}.qa-answer-en{color:var(--text-primary);margin-bottom:4px;font-size:13.5px;line-height:1.7}.qa-answer-zh{color:var(--text-secondary);font-size:12.5px;line-height:1.6;font-family:var(--font-zh)}.reveal-btn{border:none;border-top:1px dashed var(--border-default);cursor:pointer;width:100%;color:var(--brand-primary);background:0 0;justify-content:center;align-items:center;gap:5px;min-height:40px;padding:9px 14px;font-size:13px;font-weight:600;transition:background .15s,color .15s;display:flex}.reveal-btn:hover{background:var(--brand-lighter)}.section-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.8px;align-items:center;gap:8px;margin-top:32px;margin-bottom:12px;font-size:12.5px;font-weight:700;display:flex}.section-label:after{content:"";background:var(--border-default);flex:1;height:1px}.recent-list{flex-direction:column;gap:8px;display:flex}.recent-item{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-default);color:var(--text-primary);align-items:center;gap:12px;padding:12px 16px;text-decoration:none;transition:border-color .15s,box-shadow .15s,transform .15s;display:flex}.recent-item:hover{border-color:#2f6fe84d;transform:translateY(-1px);box-shadow:0 2px 8px #2f6fe814}.recent-date{color:var(--brand-primary);background:var(--brand-light);border-radius:var(--radius-sm);font-variant-numeric:tabular-nums;text-align:center;flex-shrink:0;min-width:80px;padding:3px 8px;font-size:12px;font-weight:700}.recent-preview{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:13px;overflow:hidden}.recent-arrow{color:var(--text-tertiary);flex-shrink:0;font-size:14px;transition:transform .15s,color .15s}.recent-item:hover .recent-arrow{color:var(--brand-primary);transform:translate(3px)}.back-link{color:var(--text-secondary);align-items:center;gap:5px;margin-bottom:20px;padding:5px 0;font-size:13px;font-weight:600;text-decoration:none;transition:color .15s;display:inline-flex}.back-link:hover{color:var(--brand-primary)}.empty-state{text-align:center;color:var(--text-tertiary);padding:64px 24px}.empty-state-icon{opacity:.6;margin-bottom:16px;font-size:48px}.empty-state-title{color:var(--text-secondary);margin-bottom:8px;font-size:18px;font-weight:700}.empty-state-desc{color:var(--text-tertiary);font-size:14px}.divider{background:var(--border-light);height:1px;margin:20px 0}.hidden{display:none!important}.selection-tooltip{z-index:200;background:var(--gray-900);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);padding:0;display:none;position:absolute}.selection-tooltip.visible{display:flex}.selection-tooltip-btn{color:#fff;cursor:pointer;border-radius:var(--radius-sm);white-space:nowrap;background:0 0;border:none;align-items:center;gap:4px;padding:6px 12px;font-size:12.5px;font-weight:600;transition:background .15s;display:flex}.selection-tooltip-btn:hover{background:#ffffff1f}.ai-fab{z-index:100;background:linear-gradient(135deg,var(--brand-primary) 0%,#6b96f5 100%);color:#fff;border-radius:var(--radius-full);cursor:pointer;-webkit-user-select:none;user-select:none;border:none;align-items:center;gap:6px;padding:12px 18px;font-size:14px;font-weight:700;transition:transform .2s,box-shadow .2s;display:flex;position:fixed;bottom:28px;right:20px;box-shadow:0 4px 20px #2f6fe873}.ai-fab:hover{transform:translateY(-2px);box-shadow:0 6px 28px #2f6fe88c}.ai-fab:active{transform:translateY(0)}.ai-fab-icon{font-size:16px;line-height:1}.ai-fab-label{letter-spacing:.5px}.ai-overlay{z-index:110;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000040;display:none;position:fixed;inset:0}.ai-overlay.open{display:block}.ai-panel{z-index:120;background:var(--bg-card);border-radius:var(--radius-xl) var(--radius-xl) 0 0;flex-direction:column;max-height:80vh;transition:transform .32s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;bottom:0;left:0;right:0;transform:translateY(100%);box-shadow:0 -8px 40px #00000026}.ai-panel.open{transform:translateY(0)}@media(min-width:640px){.ai-panel{border-radius:var(--radius-xl);opacity:0;width:380px;max-height:580px;transition:transform .25s cubic-bezier(.4,0,.2,1),opacity .25s;bottom:80px;left:auto;right:20px;transform:translateY(20px)}.ai-panel.open{opacity:1;transform:translateY(0)}}.ai-panel-header{border-bottom:1px solid var(--border-light);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 18px 12px;display:flex}.ai-panel-title{color:var(--text-primary);align-items:center;gap:8px;font-size:15px;font-weight:700;display:flex}.ai-panel-icon{border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--brand-primary) 0%,#6b96f5 100%);color:#fff;justify-content:center;align-items:center;width:26px;height:26px;font-size:12px;display:flex}.ai-panel-close{border-radius:var(--radius-full);background:var(--gray-100);cursor:pointer;width:28px;height:28px;color:var(--text-secondary);border:none;justify-content:center;align-items:center;font-size:13px;transition:background .15s;display:flex}.ai-panel-close:hover{background:var(--gray-200)}.ai-tabs{border-bottom:1px solid var(--border-light);flex-shrink:0;gap:4px;padding:8px 14px;display:flex}.ai-tab{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;flex:1;padding:7px 8px;font-size:12.5px;font-weight:600;transition:background .15s,color .15s}.ai-tab:hover{background:var(--bg-overlay)}.ai-tab.active{background:var(--brand-lighter);color:var(--brand-primary)}.ai-tab-content{flex-direction:column;flex:1;display:none;overflow:hidden}.ai-tab-content.active{display:flex}.ai-messages{flex-direction:column;flex:1;gap:10px;padding:12px 14px;display:flex;overflow-y:auto}.ai-message{display:flex}.ai-message-user{justify-content:flex-end}.ai-message-bot{justify-content:flex-start}.ai-message-bubble{border-radius:var(--radius-md);white-space:pre-wrap;word-break:break-word;max-width:82%;padding:9px 13px;font-size:13.5px;line-height:1.65}.ai-message-user .ai-message-bubble{background:var(--brand-primary);color:#fff;border-radius:var(--radius-md) var(--radius-md) 4px var(--radius-md)}.ai-message-bot .ai-message-bubble{background:var(--gray-100);color:var(--text-primary);border-radius:var(--radius-md) var(--radius-md) var(--radius-md) 4px}.ai-thinking{align-items:center;gap:4px;display:flex;padding:12px 16px!important}.ai-thinking span{background:var(--gray-400);border-radius:50%;width:6px;height:6px;animation:1.2s infinite ai-bounce}.ai-thinking span:nth-child(2){animation-delay:.2s}.ai-thinking span:nth-child(3){animation-delay:.4s}@keyframes ai-bounce{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-5px)}}.ai-input-row{border-top:1px solid var(--border-light);flex-shrink:0;align-items:flex-end;gap:8px;padding:10px 14px 14px;display:flex}.ai-input{border:1px solid var(--border-default);border-radius:var(--radius-md);font-size:13.5px;font-family:var(--font-sans);resize:none;color:var(--text-primary);background:var(--bg-subtle);flex:1;min-height:42px;max-height:100px;padding:9px 12px;line-height:1.5;transition:border-color .15s}.ai-input:focus{border-color:var(--border-focus);background:#fff;outline:none}.ai-send-btn{border-radius:var(--radius-full);background:var(--brand-primary);color:#fff;cursor:pointer;border:none;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;font-weight:700;transition:background .15s,transform .15s;display:flex}.ai-send-btn:hover:not(:disabled){background:var(--brand-hover);transform:scale(1.05)}.ai-send-btn:disabled{opacity:.5;cursor:not-allowed}.ai-analyze-hint{color:var(--text-tertiary);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:32px 20px;font-size:14px;line-height:1.7;display:flex}.ai-analyze-hint-icon{opacity:.5;font-size:32px}.ai-analyze-result{flex-direction:column;flex:1;gap:10px;padding:14px 16px;display:flex;overflow-y:auto}.ai-analyze-selection{color:var(--brand-primary);background:var(--brand-lighter);border-radius:var(--radius-sm);border-left:3px solid var(--brand-primary);padding:8px 12px;font-size:14px;font-weight:700}.ai-analyze-content{color:var(--text-primary);white-space:pre-wrap;font-size:13.5px;line-height:1.75}.ai-loading{flex:1;justify-content:center;align-items:center;gap:6px;padding:40px;display:flex}.ai-loading-dot{background:var(--brand-primary);opacity:.35;border-radius:50%;width:8px;height:8px;animation:1.2s infinite ai-bounce}.ai-loading-dot:nth-child(2){animation-delay:.2s}.ai-loading-dot:nth-child(3){animation-delay:.4s}.ai-practice-idle{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:32px 20px;display:flex}.ai-practice-desc{color:var(--text-secondary);text-align:center;font-size:14px;line-height:1.6}.ai-practice-gen-btn{background:linear-gradient(135deg,var(--brand-primary) 0%,#6b96f5 100%);color:#fff;border-radius:var(--radius-full);cursor:pointer;border:none;padding:10px 24px;font-size:14px;font-weight:700;transition:opacity .15s,transform .15s}.ai-practice-gen-btn:hover{opacity:.9;transform:translateY(-1px)}.ai-practice-active{flex-direction:column;flex:1;gap:12px;padding:14px 16px;display:flex;overflow-y:auto}.ai-practice-prompt{color:var(--text-primary);background:var(--warning-light);border-radius:var(--radius-md);border:1px solid #f7a23040;padding:12px 14px;font-size:14px;font-weight:600;line-height:1.65}.ai-practice-input{border:1px solid var(--border-default);border-radius:var(--radius-md);width:100%;font-size:13.5px;font-family:var(--font-sans);resize:none;color:var(--text-primary);background:var(--bg-subtle);min-height:90px;padding:10px 12px;line-height:1.6;transition:border-color .15s}.ai-practice-input:focus{border-color:var(--border-focus);background:#fff;outline:none}.ai-practice-actions{gap:8px;display:flex}.ai-practice-submit-btn{background:var(--brand-primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;flex:1;padding:9px 14px;font-size:13.5px;font-weight:700;transition:background .15s}.ai-practice-submit-btn:hover:not(:disabled){background:var(--brand-hover)}.ai-practice-submit-btn:disabled{opacity:.5;cursor:not-allowed}.ai-practice-reset-btn{background:var(--gray-100);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;border:none;padding:9px 14px;font-size:13px;font-weight:600;transition:background .15s}.ai-practice-reset-btn:hover{background:var(--gray-200)}.ai-practice-feedback{color:var(--text-primary);background:var(--teal-light);border-radius:var(--radius-md);white-space:pre-wrap;border:1px solid #00bfb333;padding:12px 14px;font-size:13.5px;line-height:1.75}.article-audio-bar{margin-bottom:12px}.audio-btn{border-radius:var(--radius-sm);background:var(--bg-subtle);border:1px solid var(--border-default);cursor:pointer;color:var(--text-secondary);align-items:center;gap:4px;padding:4px 10px;font-size:13px;line-height:1;transition:background .15s,color .15s;display:inline-flex}.audio-btn:hover{background:var(--gray-200);color:var(--text-primary)}.audio-icon{padding:2px 6px;font-size:14px}.vocab-ipa{color:var(--text-tertiary);margin-left:2px;font-family:Courier New,Courier,monospace;font-size:13px}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
