@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@400;500;600;700;800&display=swap";:root{--bg-main: #faf8f5;--surface: rgba(255, 255, 255, .7);--surface-solid: #ffffff;--border: rgba(230, 226, 216, .8);--text-main: #1c1917;--text-muted: #78716c;--primary: #d97706;--primary-hover: #b45309;--primary-light: rgba(217, 119, 6, .1);--primary-glow: rgba(217, 119, 6, .2);--success: #10b981;--success-bg: #d1fae5;--success-text: #065f46;--warning: #f59e0b;--warning-bg: #fef3c7;--warning-text: #92400e;--danger: #ef4444;--danger-bg: #fee2e2;--danger-text: #991b1b;--glass-border: rgba(255, 255, 255, .5);--shadow-sm: 0 4px 6px -1px rgba(0, 0, 0, .05), 0 2px 4px -1px rgba(0, 0, 0, .03);--shadow-md: 0 10px 15px -3px rgba(0, 0, 0, .05), 0 4px 6px -2px rgba(0, 0, 0, .025);--shadow-glow: 0 0 20px rgba(217, 119, 6, .15);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 24px}[data-theme=dark]{--bg-main: #0a0a0a;--surface: rgba(23, 23, 23, .7);--surface-solid: #171717;--border: rgba(64, 64, 64, .6);--text-main: #fafafa;--text-muted: #a3a3a3;--primary: #fbbf24;--primary-hover: #f59e0b;--primary-light: rgba(251, 191, 36, .15);--primary-glow: rgba(251, 191, 36, .3);--success: #34d399;--success-bg: rgba(5, 150, 105, .2);--success-text: #a7f3d0;--warning: #fbbf24;--warning-bg: rgba(217, 119, 6, .2);--warning-text: #fde68a;--danger: #f87171;--danger-bg: rgba(220, 38, 38, .2);--danger-text: #fecaca;--glass-border: rgba(255, 255, 255, .05);--shadow-sm: 0 4px 6px -1px rgba(0, 0, 0, .3), 0 2px 4px -1px rgba(0, 0, 0, .2);--shadow-md: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -2px rgba(0, 0, 0, .2);--shadow-glow: 0 0 20px rgba(251, 191, 36, .2)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,sans-serif;background-color:var(--bg-main);background-image:radial-gradient(circle at 15% 50%,var(--primary-glow),transparent 25%),radial-gradient(circle at 85% 30%,rgba(16,185,129,.05),transparent 25%);background-attachment:fixed;color:var(--text-main);line-height:1.6;transition:background-color .4s ease,color .4s ease;height:100dvh;overflow:hidden}h1,h2,h3,h4,h5,h6{font-family:Outfit,sans-serif;font-weight:700;letter-spacing:-.02em}.app{height:100dvh;display:flex;flex-direction:row;overflow:hidden;position:relative;padding-bottom:80px}@media(max-width:1024px){.app{flex-direction:column}}.floating-dock{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--surface);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);padding:12px 24px;border-radius:40px;display:flex;gap:16px;box-shadow:0 20px 40px #0003,inset 0 1px #ffffff1a;z-index:1000;align-items:center;max-width:calc(100% - 32px);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.floating-dock::-webkit-scrollbar{display:none}.nav-links{display:flex;gap:16px;align-items:center}.mobile-menu-toggle{display:none;background:var(--surface-solid);border:1px solid var(--border);border-radius:20px;color:var(--text-main);font-size:14px;font-weight:700;cursor:pointer;padding:10px 20px;transition:all .2s}.mobile-menu-toggle:hover{background:var(--primary);color:#000;border-color:var(--primary)}@media(max-width:1024px){.floating-dock{flex-direction:column;border-radius:24px;align-items:stretch;bottom:16px;padding:8px;max-width:250px;left:auto;right:16px;transform:none;overflow-x:hidden}.mobile-menu-toggle{display:block;text-align:center}.nav-links{display:none;flex-direction:column;gap:8px;margin-top:8px}.floating-dock.menu-open .nav-links{display:flex}.floating-dock .bottom-settings{display:none}.floating-dock.menu-open .bottom-settings{display:flex;justify-content:center;margin-top:8px}}.header-left{display:none}.header-left h1{font-size:24px;background:linear-gradient(135deg,var(--primary),#fb923c);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.subtitle{font-family:Outfit,sans-serif;font-size:13px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:1px}.header-nav{display:flex;flex-direction:row;gap:8px}.nav-btn{background:transparent;border:none;padding:10px 16px;border-radius:20px;cursor:pointer;font-size:14px;font-weight:600;color:var(--text-muted);text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;gap:8px;flex-shrink:0;white-space:nowrap}@media(max-width:1024px){.nav-btn{padding:8px 12px;font-size:13px}}.nav-btn:hover{color:var(--text-main);background:var(--surface-solid);transform:translateY(-2px)}.nav-btn.active{background:var(--primary-light);color:var(--primary);border-color:var(--primary-glow)}.bottom-settings{display:flex;gap:8px;border-left:1px solid var(--border);padding-left:16px;margin-left:8px}.theme-toggle-btn,.settings-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-solid);color:var(--text-main);cursor:pointer;transition:all .2s;padding:0;flex:1}.theme-toggle-btn:hover,.settings-btn:hover{background:var(--primary-light);color:var(--primary);border-color:var(--primary)}.settings-panel{background:var(--surface);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:24px;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.settings-inner{max-width:500px;margin:0 auto;display:flex;flex-direction:column;gap:12px}.settings-inner h3{font-size:16px;margin-bottom:8px;color:var(--text-main)}.settings-inner label{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.settings-inner select,.settings-inner input{padding:12px 16px;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:15px;font-family:inherit;background:var(--surface-solid);color:var(--text-main);transition:all .2s;outline:none}.settings-inner select:focus,.settings-inner input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.settings-hint{font-size:12px;color:var(--text-muted);margin-top:4px}.app-main{flex:1;padding:32px 48px;overflow-y:auto;height:100%;display:flex;flex-direction:column}.app-main::-webkit-scrollbar{width:8px}.app-main::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}@media(max-width:1024px){.app-main{padding:24px}}.stats-widget{position:fixed;top:24px;right:24px;z-index:1000;transition:all .3s cubic-bezier(.16,1,.3,1);overflow:hidden;box-shadow:0 10px 30px #0003}.stats-widget:not(.expanded){cursor:pointer;border-radius:40px}.stats-widget:not(.expanded):hover{transform:translateY(-2px);box-shadow:0 12px 36px #0000004d;border-color:var(--primary)}.stats-widget.expanded{border-radius:var(--radius-md);width:280px}.widget-collapsed{display:flex;align-items:center;gap:8px;padding:8px 16px}.widget-expanded{padding:20px;display:flex;flex-direction:column}.write-view{display:grid;grid-template-columns:320px 1fr;gap:32px;align-items:start}@media(max-width:1024px){.write-view{grid-template-columns:1fr}}@media(max-width:600px){.app-main{padding:16px 12px}.glass-card{padding:16px}.write-view{gap:16px}.writing-textarea{min-height:250px;padding:16px;font-size:15px}.btn{padding:10px 16px;font-size:14px;width:100%;justify-content:center}.editor-actions{flex-direction:column}.floating-dock{bottom:12px;padding:8px 12px;max-width:calc(100% - 24px)}.nav-btn{padding:6px 10px;font-size:12px}}.glass-card{background:var(--surface);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:24px;box-shadow:var(--shadow-md)}.topic-selector{display:flex;flex-direction:column;gap:16px}.task-section-title{font-family:Outfit,sans-serif;font-size:12px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:1px;margin:16px 0 8px;padding-bottom:4px;border-bottom:1px solid var(--border)}.task-section-title:first-child{margin-top:0}@keyframes pulse{0%{opacity:1}50%{opacity:.6}to{opacity:1}}.topic-list{display:flex;flex-direction:column;gap:6px}@media(max-width:600px){.topic-list{flex-direction:row;overflow-x:auto;padding-bottom:8px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.topic-list::-webkit-scrollbar{display:none}.topic-item{flex-shrink:0;white-space:nowrap}}.topic-item{padding:12px 16px;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;display:flex;justify-content:space-between;align-items:center;border:1px solid transparent;background:var(--surface-solid)}.topic-item:hover{transform:translate(4px);border-color:var(--border);box-shadow:var(--shadow-sm)}.topic-item.active{background:var(--primary-light);border-color:var(--primary);color:var(--primary);font-weight:600}.topic-delete{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;opacity:0;transition:all .2s;padding:4px 8px;border-radius:4px}.topic-item:hover .topic-delete{opacity:1}.topic-delete:hover{background:var(--danger-bg);color:var(--danger)}.add-topic-form{display:flex;flex-direction:column;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.add-topic-form input,.add-topic-form select{padding:10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;background:var(--surface-solid);color:var(--text-main);outline:none}.add-topic-form input:focus,.add-topic-form select:focus{border-color:var(--primary)}.editor-header{margin-bottom:24px}.editor-header h2{font-size:24px;margin-bottom:8px;color:var(--text-main)}.task-badge{display:inline-block;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;background:var(--primary-light);color:var(--primary);margin-bottom:12px}.topic-desc{font-size:15px;color:var(--text-muted);line-height:1.5}.accent-toolbar{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:12px}.accent-btn{width:36px;height:36px;border:1px solid var(--border);background:var(--surface-solid);color:var(--text-main);border-radius:6px;cursor:pointer;font-size:16px;font-weight:500;transition:all .15s;display:flex;align-items:center;justify-content:center}.accent-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary);transform:translateY(-2px)}.writing-textarea{width:100%;min-height:400px;padding:20px;border:2px solid var(--border);border-radius:var(--radius-sm);font-family:inherit;font-size:16px;line-height:1.8;background:var(--surface-solid);color:var(--text-main);resize:vertical;transition:all .2s}.writing-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-light)}.word-counter{text-align:right;font-size:13px;color:var(--text-muted);margin-top:8px;font-weight:500}.word-counter .count{font-weight:700;color:var(--text-main)}.word-counter .count.error{color:var(--danger)}.word-counter .count.success{color:var(--success)}.editor-actions{display:flex;gap:12px;margin-top:24px}.error-box{background:var(--danger-bg);color:var(--danger-text);padding:16px;border-radius:var(--radius-sm);font-size:14px;margin-top:16px;border:1px solid rgba(239,68,68,.3);font-weight:500}.btn{padding:12px 24px;border-radius:var(--radius-sm);border:none;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;font-family:Inter,sans-serif;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important;box-shadow:none!important}.btn-primary{background:linear-gradient(135deg,var(--primary),#f59e0b);color:#000;box-shadow:0 4px 12px var(--primary-glow)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px var(--primary-glow)}.btn-secondary{background:var(--surface-solid);color:var(--text-main);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){border-color:var(--text-muted);background:var(--bg-main)}.btn-small{padding:8px 16px;font-size:13px}.results-container{display:flex;flex-direction:column;gap:32px;animation:slideIn .5s cubic-bezier(.16,1,.3,1)}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.essay-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px}@media(max-width:1024px){.essay-grid{grid-template-columns:1fr}}.grade-header{display:flex;align-items:center;gap:24px;margin-bottom:24px}.grade-circle{width:100px;height:100px;border-radius:50%;flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:var(--shadow-md);position:relative}.grade-circle .val{font-size:36px;font-weight:800;font-family:Outfit,sans-serif;line-height:1}.grade-circle .max{font-size:14px;font-weight:600;opacity:.8;margin-top:-4px}.grade-circle.high{background:var(--success-bg);color:var(--success-text);border:2px solid var(--success)}.grade-circle.medium{background:var(--warning-bg);color:var(--warning-text);border:2px solid var(--warning)}.grade-circle.low{background:var(--danger-bg);color:var(--danger-text);border:2px solid var(--danger)}.grade-info h3{font-size:20px;color:var(--text-main);margin-bottom:4px}.grade-info p{font-size:15px;color:var(--text-muted);line-height:1.6}.criteria-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.criterion-card{background:var(--surface-solid);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;transition:transform .2s}.criterion-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.criterion-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.criterion-name{font-size:13px;font-weight:700;color:var(--text-main);text-transform:uppercase;letter-spacing:.5px}.criterion-score{font-size:18px;font-weight:800;font-family:Outfit,sans-serif}.score-bar{height:6px;background:var(--bg-main);border-radius:3px;margin-bottom:12px;overflow:hidden}.score-bar-fill{height:100%;border-radius:3px;transition:width 1s cubic-bezier(.4,0,.2,1)}.score-bar-fill.high{background:var(--success)}.score-bar-fill.medium{background:var(--warning)}.score-bar-fill.low{background:var(--danger)}.criterion-comment{font-size:13px;color:var(--text-muted);line-height:1.5}.mistakes-container{background:var(--surface-solid);padding:24px;border-radius:var(--radius-sm);border:1px solid var(--border);font-size:16px;line-height:2;color:var(--text-main);white-space:pre-wrap;margin:0}.corrected-container{background:color-mix(in srgb,var(--success) 10%,var(--surface-solid));padding:24px;border-radius:var(--radius-sm);border:1px solid color-mix(in srgb,var(--success) 30%,transparent);font-size:16px;line-height:2;color:var(--text-main);white-space:pre-wrap;margin:0}.mistake-inline{text-decoration:underline;text-decoration-color:var(--danger);text-decoration-style:wavy;text-decoration-thickness:2px;background:#ef44441a;color:var(--danger-text);border-radius:2px;padding:0 2px;cursor:pointer;transition:background .2s}.mistake-inline:hover{background:#ef444433}.grammarly-tooltip{position:absolute;transform:translate(-50%,-100%);background:var(--surface-solid);border:1px solid var(--border);box-shadow:var(--shadow-md);border-radius:var(--radius-sm);width:280px;z-index:1000;pointer-events:none;animation:tooltipFadeIn .2s cubic-bezier(.16,1,.3,1);overflow:hidden}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%,-90%)}to{opacity:1;transform:translate(-50%,-100%)}}.tooltip-correction{background:var(--danger-bg);padding:12px 16px;border-bottom:1px solid rgba(239,68,68,.2)}.tooltip-label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;color:var(--danger);margin-bottom:4px}.tooltip-corrected-text{font-size:16px;font-weight:600;color:var(--success)}.tooltip-reason{padding:12px 16px;font-size:13px;color:var(--text-main);line-height:1.5}.section-title{font-size:18px;margin-bottom:16px;color:var(--text-main);display:flex;align-items:center;gap:8px}.improvements-list,.grammar-list{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin:0;padding:0}.improvements-list li,.grammar-list li{padding:16px;border-radius:var(--radius-sm);font-size:14px;background:var(--surface-solid);border:1px solid var(--border);display:flex;flex-direction:column;gap:8px;transition:transform .2s;line-height:1.5}.improvements-list li:hover,.grammar-list li:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--primary-glow)}.improvements-list li{border-left:4px solid var(--primary)}.grammar-list li{border-left:4px solid var(--warning);background:var(--warning-bg);border:1px solid rgba(245,158,11,.3)}.grammar-concept-name{font-weight:800;color:var(--text-main);font-size:14px;text-transform:uppercase;letter-spacing:.5px}.grammar-reason{color:var(--text-muted);font-size:13px}.history-view{max-width:1000px;margin:0 auto}.history-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;margin-bottom:32px}.stat-card{background:var(--surface);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);padding:24px;border-radius:var(--radius-md);text-align:center;box-shadow:var(--shadow-sm)}.stat-number{font-size:36px;font-weight:800;font-family:Outfit,sans-serif;color:var(--primary);margin-bottom:4px}.stat-label{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.history-list{display:flex;flex-direction:column;gap:12px}.history-item{padding:20px;background:var(--surface-solid);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;display:flex;justify-content:space-between;align-items:center}.history-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary)}.history-item-left{display:flex;flex-direction:column;gap:6px}.history-item-title{font-size:16px;font-weight:600;color:var(--text-main)}.history-item-meta{font-size:13px;color:var(--text-muted);display:flex;align-items:center;gap:12px}.history-task-badge{background:var(--bg-main);padding:2px 8px;border-radius:4px;font-weight:600;font-size:11px}.history-item-score{font-size:24px;font-weight:800;font-family:Outfit,sans-serif;padding:8px 16px;border-radius:var(--radius-sm)}.history-item-score.high{color:var(--success-text);background:var(--success-bg)}.history-item-score.medium{color:var(--warning-text);background:var(--warning-bg)}.history-item-score.low{color:var(--danger-text);background:var(--danger-bg)}.delete-btn{background:var(--surface-solid);color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius-sm);width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;transition:all .2s;padding:0}.delete-btn:hover{background:var(--danger-bg);color:var(--danger-text);border-color:#ef44444d;transform:translateY(-2px)}.concept-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.concept-tag{padding:6px 12px;background:var(--warning-bg);border:1px solid rgba(245,158,11,.3);border-radius:20px;font-size:12px;font-weight:600;color:var(--warning-text)}.chat-panel{display:flex;flex-direction:column;height:100%;min-height:400px;max-height:500px}.chat-header{padding-bottom:12px;border-bottom:1px solid var(--border);margin-bottom:16px}.chat-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:12px;padding-right:8px}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.chat-bubble{padding:12px 16px;border-radius:var(--radius-sm);font-size:14px;max-width:85%;line-height:1.5}.chat-bubble.user{background:var(--surface-solid);color:var(--text-main);border:2px solid var(--border);align-self:flex-end;border-bottom-right-radius:4px;white-space:pre-wrap}.chat-bubble.assistant{background:var(--surface-solid);border:1px solid var(--border);align-self:flex-start;border-bottom-left-radius:4px}.chat-bubble.assistant p{margin:0 0 8px}.chat-bubble.assistant p:last-child{margin-bottom:0}.chat-bubble.assistant ul,.chat-bubble.assistant ol{margin:0 0 8px;padding-left:20px}.chat-bubble.assistant li{margin-bottom:4px}.chat-input-area{display:flex;gap:8px;margin-top:16px}.chat-input-area input{flex:1;padding:12px 16px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-solid);color:var(--text-main);font-size:14px;font-family:inherit}.chat-input-area input:focus{outline:none;border-color:var(--primary)}.chat-input-area button{background:var(--primary);color:#fff;border:none;padding:0 16px;border-radius:var(--radius-sm);cursor:pointer;font-weight:600;transition:transform .2s}.chat-input-area button:disabled{opacity:.5;cursor:not-allowed;transform:none}.chat-input-area button:not(:disabled):hover{transform:translateY(-2px)}.grading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;background:color-mix(in srgb,var(--surface-solid) 85%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-md);animation:overlayFadeIn .4s cubic-bezier(.16,1,.3,1)}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.grading-spinner{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center}.spinner-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:3px solid transparent;border-top-color:var(--primary);animation:spinnerRotate 1.2s cubic-bezier(.5,0,.5,1) infinite}.spinner-ring-2{top:6px;right:6px;bottom:6px;left:6px;border-top-color:transparent;border-right-color:var(--primary);opacity:.4;animation-direction:reverse;animation-duration:1.8s}@keyframes spinnerRotate{to{transform:rotate(360deg)}}.spinner-icon{font-size:28px;animation:spinnerPulse 2s ease-in-out infinite}@keyframes spinnerPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.15);opacity:.7}}.grading-text{font-family:Outfit,sans-serif;font-size:18px;font-weight:700;color:var(--text-main);letter-spacing:-.02em}.grading-subtext{font-size:14px;color:var(--text-muted);font-weight:500}.loading-dots span{animation:dotBlink 1.4s ease-in-out infinite;opacity:0}.loading-dots span:nth-child(1){animation-delay:0s}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes dotBlink{0%,80%,to{opacity:0}40%{opacity:1}}.vocabulary-layout{display:grid;grid-template-columns:minmax(350px,580px) 1fr;gap:24px;height:calc(100vh - 320px);min-height:400px}@media(max-width:900px){.vocabulary-layout{grid-template-columns:1fr;height:auto}.vocabulary-layout>div{min-height:400px}}.vocab-save-popup{position:absolute;transform:translate(-50%,-100%);z-index:2000;pointer-events:all}.vocab-save-popup button{background:var(--surface-solid);color:var(--text-main);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 16px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;box-shadow:var(--shadow-md);transition:all .2s cubic-bezier(.16,1,.3,1)}.vocab-save-popup button:hover{background:var(--primary);color:#000;border-color:var(--primary);transform:translateY(-2px);box-shadow:var(--shadow-glow)}.vocab-toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);background:var(--success-bg);color:var(--success-text);border:1px solid var(--success);border-radius:var(--radius-md);padding:12px 24px;font-size:14px;font-weight:600;z-index:9999;box-shadow:var(--shadow-md);animation:toastIn .3s ease,toastOut .3s ease 1.8s forwards;pointer-events:none}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes toastOut{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-10px)}}.flashcard-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}.flashcard-modal{background:var(--surface-solid);border:1px solid var(--border);border-radius:20px;padding:32px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px #0009;animation:fadeIn .25s ease}.flashcard{perspective:1200px;width:100%;min-height:260px;cursor:pointer}.flashcard-inner{position:relative;width:100%;min-height:260px;transition:transform .55s cubic-bezier(.4,.2,.2,1);transform-style:preserve-3d}.flashcard.flipped .flashcard-inner{transform:rotateY(180deg)}.flashcard-front,.flashcard-back{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;border-radius:16px;border:1px solid var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:28px 24px;background:var(--bg-main)}.flashcard-back{transform:rotateY(180deg);background:var(--surface);align-items:flex-start;justify-content:flex-start;overflow-y:auto}.fast-track-toggle{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:20px;border:1.5px solid #a3e635;background:transparent;color:#a3e635;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .2s;letter-spacing:.3px}.fast-track-toggle:hover,.fast-track-toggle.active{background:#a3e635;color:#0a0a0a;box-shadow:0 0 16px #a3e63559}.fast-track-panel{border:1.5px solid rgba(163,230,53,.4);border-radius:var(--radius);background:linear-gradient(135deg,#a3e6350a,#0000 60%);padding:20px;animation:fadeIn .25s ease}.fast-track-panel-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}.fast-track-panel-header h4{margin:0;font-size:15px;font-weight:800;background:linear-gradient(135deg,#a3e635,#4ade80);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:.3px}.fast-track-panel-header p{margin:0;font-size:12px;color:var(--text-muted)}.fast-track-ideas-textarea{width:100%;min-height:120px;resize:vertical;padding:14px 16px;background:var(--surface-solid);border:1.5px solid rgba(163,230,53,.3);border-radius:var(--radius-sm);color:var(--text-main);font-size:14px;font-family:inherit;line-height:1.6;outline:none;box-sizing:border-box;transition:border-color .2s}.fast-track-ideas-textarea:focus{border-color:#a3e635;box-shadow:0 0 0 3px #a3e6351a}.fast-track-ideas-textarea::placeholder{color:var(--text-muted);font-style:italic}.fast-track-generate-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,#a3e635,#4ade80);color:#0a0a0a;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:800;cursor:pointer;font-family:inherit;transition:all .2s;letter-spacing:.3px;box-shadow:0 4px 16px #a3e63540}.fast-track-generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #a3e63566}.fast-track-generate-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.fast-track-spinner{width:16px;height:16px;border:2px solid rgba(10,10,10,.3);border-top-color:#0a0a0a;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
