@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.layout-container{min-height:100vh;display:flex}.sidebar{background-color:var(--color-surface);border-right:1px solid var(--color-border);z-index:100;flex-direction:column;width:280px;padding:2rem 1.5rem;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-top{justify-content:space-between;align-items:center;display:flex}.logo-container{color:var(--color-primary);align-items:center;gap:.75rem;margin-bottom:3rem;font-size:1.25rem;font-weight:700;display:flex}.nav-links{flex-direction:column;gap:.5rem;display:flex}.nav-item{border-radius:var(--radius-md);color:var(--color-text-muted);transition:all var(--transition-fast);align-items:center;gap:.75rem;padding:.75rem 1rem;font-weight:500;display:flex}.nav-item:hover{background-color:var(--color-bg);color:var(--color-text)}.nav-item.active{background-color:var(--color-primary-light);color:#fff;background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));box-shadow:var(--shadow-md)}.main-content{flex:1;max-width:1200px;margin-left:280px;padding:2rem 3rem}.hamburger{color:var(--color-text);cursor:pointer;background:0 0;border:none;padding:.25rem;display:none}.sidebar-overlay{display:none}@media (width<=768px){.hamburger{justify-content:center;align-items:center;display:flex}.sidebar{border-right:none;border-bottom:1px solid var(--color-border);z-index:100;flex-direction:column;width:100%;padding:.75rem 1rem;position:fixed;inset:0 0 auto}.sidebar-top{justify-content:space-between;align-items:center;width:100%;display:flex}.logo-container{margin-bottom:0}.nav-links{flex-direction:column;width:100%;padding-top:1rem;display:none}.sidebar.open{bottom:0}.sidebar.open .nav-links{display:flex}.sidebar-overlay{z-index:99;background:#00000080;display:block;position:fixed;inset:0}.main-content{margin-left:0;padding:5rem 1.25rem 1.5rem}}@media (width<=480px){.main-content{padding:4.5rem 1rem 1rem}}.ai-chat-container{z-index:100;flex-direction:column;align-items:flex-end;display:flex;position:fixed;bottom:2rem;right:2rem}.chat-bubble-btn{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--color-primary), var(--color-secondary));color:#fff;width:60px;height:60px;box-shadow:var(--shadow-lg), var(--shadow-glow);transition:all var(--transition-normal);justify-content:center;align-items:center;display:flex}.chat-bubble-btn:hover{transform:scale(1.05)}.chat-window{background-color:var(--color-surface);border-radius:var(--radius-lg);width:450px;height:650px;box-shadow:var(--shadow-lg);border:1px solid var(--color-border);transform-origin:100% 100%;flex-direction:column;margin-bottom:1rem;animation:.3s forwards scaleUp;display:flex;overflow:hidden}@media (width<=520px){.chat-window{z-index:200;border-radius:0;width:100%;height:100%;margin-bottom:0;animation:none;position:fixed;inset:0}.ai-chat-container{bottom:0;right:0}.chat-bubble-btn{width:52px;height:52px;margin:1rem}}@keyframes scaleUp{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.chat-header{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));color:#fff;justify-content:space-between;align-items:center;padding:1rem;font-weight:600;display:flex}.close-btn{color:#fff;opacity:.8;transition:opacity var(--transition-fast)}.close-btn:hover{opacity:1}.chat-messages{background-color:var(--color-bg);flex-direction:column;flex:1;gap:1rem;padding:1rem;display:flex;overflow-y:auto}.message{border-radius:var(--radius-lg);max-width:80%;padding:.75rem 1rem;font-size:1rem;line-height:1.5}.message.user{background-color:var(--color-primary);color:#fff;border-bottom-right-radius:.25rem;align-self:flex-end}.message.ai{max-width:100%;color:var(--color-text);border:none;border-bottom:1px solid var(--color-border);background-color:#0000;border-radius:0;align-self:stretch;padding:.75rem 0 1.25rem}.chat-input-area{background-color:var(--color-surface);border-top:1px solid var(--color-border);gap:.5rem;padding:1rem;display:flex}.chat-input{border:1px solid var(--color-border);border-radius:var(--radius-full);transition:border-color var(--transition-fast);outline:none;flex:1;padding:.75rem 1rem;font-family:inherit}.chat-input:focus{border-color:var(--color-primary)}.send-btn{border-radius:var(--radius-full);background-color:var(--color-primary);color:#fff;width:40px;height:40px;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.send-btn:hover:not(:disabled){background-color:var(--color-primary-dark)}.send-btn:disabled{opacity:.5;cursor:not-allowed}.typing-indicator{color:var(--color-text-muted);align-self:flex-start;padding:0 1rem;font-size:.8rem}.message h1,.message h2,.message h3{color:inherit;margin-top:.5rem;margin-bottom:.25rem;font-weight:600}.message h3{font-size:1rem}.message blockquote{border-left:2px solid var(--color-primary);background-color:#9333ea0d;border-radius:2px;margin:.5rem 0;padding:.25rem .5rem;font-style:italic}.message li{margin-bottom:.2rem;margin-left:1rem;list-style-type:disc}.message hr{border:0;border-top:1px solid var(--color-border);margin:.75rem 0}.message strong{color:var(--color-primary-dark);font-weight:700}.message.user strong{color:#fff}.home-container{flex-direction:column;gap:2rem;display:flex}@media (width<=480px){.home-container{gap:1.25rem}}.welcome-card{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-dark));border-radius:var(--radius-lg);color:#fff;box-shadow:var(--shadow-lg);padding:3rem 2rem;position:relative;overflow:hidden}.welcome-content{z-index:2;max-width:600px;position:relative}.welcome-title{margin-bottom:1rem;font-size:2.5rem;font-weight:700}@media (width<=768px){.welcome-title{font-size:1.75rem}.welcome-card{padding:2rem 1.5rem}.welcome-subtitle{font-size:1rem}}@media (width<=480px){.welcome-title{font-size:1.5rem}.welcome-card{border-radius:var(--radius-md);padding:1.5rem 1.25rem}.welcome-subtitle{margin-bottom:1.5rem;font-size:.9rem}}.welcome-subtitle{opacity:.9;margin-bottom:2rem;font-size:1.1rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;display:grid}@media (width<=480px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem}.stat-card{padding:1rem}.stat-icon{width:40px;height:40px}.stat-icon svg{width:18px;height:18px}.stat-info h3{font-size:1.15rem}}.stat-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:transform var(--transition-normal);align-items:center;gap:1rem;padding:1.5rem;display:flex}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}.stat-icon{border-radius:var(--radius-full);background-color:var(--color-primary-light);color:#fff;justify-content:center;align-items:center;width:50px;height:50px;display:flex}.stat-icon.success{background-color:var(--color-success)}.stat-info h3{color:var(--color-text);font-size:1.5rem}.stat-info p{color:var(--color-text-muted);font-size:.9rem}.dashboard-units{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem}.dashboard-units-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.dashboard-units-header h2{color:var(--color-text);font-size:1.25rem}.view-all-link{color:var(--color-primary);transition:gap var(--transition-fast);align-items:center;gap:.25rem;font-size:.9rem;font-weight:600;text-decoration:none;display:flex}.view-all-link:hover{gap:.5rem}.dashboard-units-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;display:grid}@media (width<=480px){.dashboard-units-grid{grid-template-columns:1fr;gap:.75rem}.dashboard-units-header h2{font-size:1.05rem}}.dashboard-unit-card{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-normal);flex-direction:column;padding:1.25rem;display:flex}.dashboard-unit-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary-light);transform:translateY(-3px)}.dashboard-unit-card .unit-number{background-color:var(--color-surface);color:var(--color-primary);border-radius:var(--radius-full);width:fit-content;margin-bottom:.75rem;padding:.2rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.dashboard-unit-card h3{color:var(--color-text);margin-bottom:.4rem;font-size:1.05rem}.dashboard-unit-card p{color:var(--color-text-muted);flex:1;margin-bottom:.75rem;font-size:.85rem}.dashboard-unit-card .exercise-count{color:var(--color-text-muted);align-items:center;gap:.25rem;font-size:.8rem;display:flex}.units-header{margin-bottom:2rem}.units-header h1{color:var(--color-text);margin-bottom:.5rem;font-size:2rem}.units-header p{color:var(--color-text-muted)}.units-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;display:grid}@media (width<=480px){.units-header h1{font-size:1.5rem}.units-grid{grid-template-columns:1fr;gap:1rem}.unit-card{padding:1.25rem}}.unit-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-normal);flex-direction:column;padding:1.5rem;display:flex}.unit-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary-light);transform:translateY(-4px)}.unit-number{background-color:var(--color-bg);color:var(--color-primary);border-radius:var(--radius-full);width:fit-content;margin-bottom:1rem;padding:.25rem .75rem;font-size:.8rem;font-weight:600;display:inline-block}.unit-card h2{color:var(--color-text);margin-bottom:.5rem;font-size:1.25rem}.unit-card p{color:var(--color-text-muted);flex:1;margin-bottom:1.5rem;font-size:.9rem}.unit-footer{justify-content:space-between;align-items:center;margin-top:auto;display:flex}.start-btn{color:var(--color-primary);transition:gap var(--transition-fast);align-items:center;gap:.5rem;font-weight:600;display:flex}.unit-card:hover .start-btn{gap:.75rem}.exercises-container{flex-direction:column;gap:2rem;display:flex}.exercise-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:2rem}@media (width<=480px){.exercise-card{border-radius:var(--radius-md);padding:1.25rem}.exercise-question{font-size:1rem}.option-btn{padding:.75rem 1rem;font-size:.9rem}.blank-input{width:100px;font-size:1rem}}.exercise-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.exercise-number{color:var(--color-primary);font-size:1.1rem;font-weight:600}.exercise-question{color:var(--color-text);margin-bottom:1.5rem;font-size:1.1rem;line-height:1.6}.options-grid{flex-direction:column;gap:.75rem;display:flex}.option-btn{border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface);color:var(--color-text);text-align:left;transition:all var(--transition-fast);padding:1rem 1.5rem;font-size:1rem}.option-btn:hover:not(:disabled){border-color:var(--color-primary);background-color:var(--color-bg)}.option-btn.selected{border-color:var(--color-primary);background-color:var(--color-primary-light);color:#fff}.option-btn.correct{border-color:var(--color-success);background-color:var(--color-success-bg);color:var(--color-success)}.option-btn.incorrect{border-color:var(--color-error);background-color:var(--color-error-bg);color:var(--color-error)}.blank-input{border:none;border-bottom:2px solid var(--color-border);color:var(--color-primary);text-align:center;width:150px;transition:border-color var(--transition-fast);background:0 0;outline:none;padding:.25rem .5rem;font-family:inherit;font-size:1.1rem;font-weight:600}.blank-input:focus{border-color:var(--color-primary)}.blank-input.correct{border-color:var(--color-success);color:var(--color-success)}.blank-input.incorrect{border-color:var(--color-error);color:var(--color-error)}.feedback-section{border-radius:var(--radius-md);margin-top:1.5rem;padding:1rem;animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.feedback-section.correct{background-color:var(--color-success-bg);border:1px solid var(--color-success);color:var(--color-success)}.feedback-section.incorrect{background-color:var(--color-error-bg);border:1px solid var(--color-error);color:var(--color-error)}.feedback-header{align-items:center;gap:.5rem;margin-bottom:.5rem;font-weight:600;display:flex}.check-btn-container{justify-content:flex-end;margin-top:1.5rem;display:flex}.unit-reader-container{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);height:750px;box-shadow:var(--shadow-sm);flex-direction:column;display:flex;overflow:hidden}@media (width<=768px){.unit-reader-container{height:500px;max-height:60vh}.unit-reader-workspace{padding:1rem}}@media (width<=480px){.unit-reader-container{height:400px;max-height:50vh}.unit-reader-header{padding:.75rem 1rem;font-size:1rem}}.unit-reader-header{background:linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 100%);color:#fff;align-items:center;gap:.5rem;padding:1rem 1.5rem;font-size:1.1rem;font-weight:600;display:flex}.unit-reader-header .sparkle-icon{animation:2s infinite pulse-sparkle}.unit-reader-workspace{background-color:var(--color-bg);flex-direction:column;flex:1;gap:1.5rem;padding:1.5rem;display:flex;overflow-y:auto}.reader-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:transform var(--transition-fast), box-shadow var(--transition-fast);flex-shrink:0;overflow:hidden}.reader-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.reader-card .card-header{border-bottom:1px solid var(--color-border);background-color:#00000003;align-items:center;gap:.6rem;padding:1rem 1.25rem;display:flex}@media (prefers-color-scheme:dark){.reader-card .card-header{background-color:#ffffff03}}.reader-card .card-header h4{color:var(--color-text);margin:0;font-size:1.05rem;font-weight:600}.reader-card .card-body{padding:1.25rem}.explanation-card{border-left:4px solid var(--color-primary)}.explanation-card .card-header svg{color:var(--color-primary)}.comparison-card{border-left:4px solid var(--color-secondary)}.comparison-card .card-header svg{color:var(--color-secondary)}.quiz-card{border-left:4px solid var(--color-success)}.quiz-card .card-header svg{color:var(--color-success)}.explanation-card .card-body p{color:var(--color-text);margin-bottom:.75rem}.explanation-card .card-body p:last-child{margin-bottom:0}.explanation-card .card-body strong{color:var(--color-primary-dark);font-weight:700}.explanation-card .card-body ul,.explanation-card .card-body ol{margin-bottom:.75rem;padding-left:1.25rem}.explanation-card .card-body li{color:var(--color-text);margin-bottom:.25rem}.explanation-card .card-body blockquote{border-left:3px solid var(--color-primary);background-color:#6366f10d;border-radius:2px;margin:.75rem 0;padding:.5rem 1rem;font-style:italic}.comparison-grid{grid-template-columns:1fr;gap:1rem;padding:1.25rem;display:grid}@media (width>=640px){.comparison-grid{grid-template-columns:1fr 1fr}}.comparison-column{border-radius:var(--radius-md);background-color:var(--color-bg);border:1px solid var(--color-border);padding:1rem}.comparison-column h5{margin-bottom:.75rem;font-size:1rem;font-weight:600}.comparison-column.left-col{border-top:3px solid var(--color-primary)}.comparison-column.left-col h5{color:var(--color-primary)}.comparison-column.right-col{border-top:3px solid var(--color-secondary)}.comparison-column.right-col h5{color:var(--color-secondary)}.comparison-column ul{padding-left:1.25rem}.comparison-column li{margin-bottom:.35rem;font-size:.95rem}.examples-container-block{flex-shrink:0;margin-top:.5rem}.examples-container-block .section-title{color:var(--color-text);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.1rem;font-weight:600;display:flex}.examples-container-block .section-title svg{color:var(--color-secondary)}.examples-grid{flex-direction:column;gap:1rem;display:flex}.example-item-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:transform var(--transition-fast);padding:1.25rem}.example-item-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.example-badge{text-transform:uppercase;letter-spacing:.05em;color:var(--color-secondary);border-radius:var(--radius-full);background-color:#ec48991a;margin-bottom:.75rem;padding:.25rem .5rem;font-size:.7rem;font-weight:700;display:inline-block}.example-sentence{color:var(--color-text);border-left:2px solid var(--color-border);margin-bottom:.5rem;padding-left:.75rem;font-size:1.05rem;font-style:italic;font-weight:500;line-height:1.5}.example-desc{color:var(--color-text-muted);font-size:.9rem;line-height:1.5}.quiz-question{color:var(--color-text);margin-bottom:1.25rem;font-size:1.05rem;font-weight:600;line-height:1.5}.quiz-options-list{flex-direction:column;gap:.75rem;margin-bottom:1.25rem;display:flex}.quiz-opt-btn{text-align:left;border-radius:var(--radius-md);border:1.5px solid var(--color-border);background-color:var(--color-surface);width:100%;color:var(--color-text);transition:all var(--transition-fast);cursor:pointer;padding:.85rem 1.25rem;font-size:.95rem;font-weight:500}.quiz-opt-btn:hover:not(:disabled){background-color:var(--color-bg);border-color:var(--color-text-muted)}.quiz-opt-btn.selected{border-color:var(--color-primary);color:var(--color-primary);background-color:#6366f10d}.quiz-opt-btn.correct{border-color:var(--color-success);background-color:var(--color-success-bg);color:var(--color-success)}@media (prefers-color-scheme:dark){.quiz-opt-btn.correct{color:#34d399}}.quiz-opt-btn.incorrect{border-color:var(--color-error);background-color:var(--color-error-bg);color:var(--color-error)}@media (prefers-color-scheme:dark){.quiz-opt-btn.incorrect{color:#f87171}}.quiz-opt-btn:disabled{cursor:not-allowed}.quiz-action-area{justify-content:flex-end;display:flex}.quiz-btn{border-radius:var(--radius-full);border:none;padding:.6rem 1.25rem;font-size:.95rem}.quiz-btn:disabled{opacity:.5;cursor:not-allowed}.quiz-feedback{border-radius:var(--radius-md);border:1px solid #0000;margin-top:1.25rem;padding:1.25rem}.quiz-feedback.correct{background-color:var(--color-success-bg);color:var(--color-text);border-color:#10b98133}.quiz-feedback.incorrect{background-color:var(--color-error-bg);color:var(--color-text);border-color:#ef444433}.feedback-header{margin-bottom:.5rem;font-size:1.05rem}.quiz-feedback.correct .feedback-header{color:var(--color-success)}@media (prefers-color-scheme:dark){.quiz-feedback.correct .feedback-header{color:#34d399}}.quiz-feedback.incorrect .feedback-header{color:var(--color-error)}@media (prefers-color-scheme:dark){.quiz-feedback.incorrect .feedback-header{color:#f87171}}.feedback-desc{font-size:.95rem;line-height:1.5}.correct-answer-reveal{color:var(--color-success);margin-top:.5rem;font-size:.95rem;font-weight:600}@media (prefers-color-scheme:dark){.correct-answer-reveal{color:#34d399}}.reader-loading-skeleton{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);flex-direction:column;flex-shrink:0;gap:1.25rem;padding:1.5rem;display:flex}.skeleton-loader-line.progress{background:linear-gradient(90deg, var(--color-border) 25%, var(--color-primary-light) 50%, var(--color-border) 75%);border-radius:var(--radius-full);background-size:200% 100%;height:4px;animation:1.5s infinite loading-animation}.loading-status{color:var(--color-text-muted);align-items:center;gap:.5rem;font-size:.9rem;display:flex}.spinner{border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:18px;height:18px;animation:1s linear infinite spin}.raw-stream-preview{background-color:var(--color-bg);border-radius:var(--radius-md);border:1px dashed var(--color-border);padding:1rem}.preview-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.75rem;font-weight:700;display:block}.raw-stream-preview p{color:var(--color-text-muted);white-space:pre-wrap;margin:0;font-family:monospace;font-size:.85rem;line-height:1.5}.unit-reader-input-area{background-color:var(--color-surface);border-top:1px solid var(--color-border);gap:.5rem;padding:1rem;display:flex}.unit-reader-input{border-radius:var(--radius-md);border:1px solid var(--color-border);background-color:var(--color-bg);color:var(--color-text);transition:border-color var(--transition-fast);flex:1;padding:.75rem 1rem;font-size:.95rem}.unit-reader-input:focus{border-color:var(--color-primary);outline:none}.unit-reader-send-btn{border-radius:var(--radius-md);background-color:var(--color-primary);color:#fff;width:42px;height:42px;transition:all var(--transition-fast);cursor:pointer;border:none;justify-content:center;align-items:center;display:flex}.unit-reader-send-btn:hover:not(:disabled){background-color:var(--color-primary-dark);transform:translateY(-1px)}.unit-reader-send-btn:disabled{opacity:.5;cursor:not-allowed}@keyframes pulse-sparkle{0%{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}to{opacity:.8;transform:scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes loading-animation{0%{background-position:200% 0}to{background-position:-200% 0}}.streaming-indicator{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);box-shadow:var(--shadow-sm);align-self:flex-start;align-items:center;gap:.5rem;margin-top:.5rem;padding:.75rem 1.25rem;font-size:.85rem;display:flex}.mini-spinner{border-width:1.5px;width:14px;height:14px}.typing-blinker{color:var(--color-primary);margin-left:2px;font-weight:700;animation:1s step-end infinite blink;display:inline-block}@keyframes blink{0%,to{color:#0000}50%{color:var(--color-primary)}}.playground-container{flex-direction:column;max-width:1100px;height:calc(100vh - 4rem);margin:0 auto;display:flex}@media (width<=768px){.playground-container{height:auto;min-height:calc(100dvh - 5rem)}}.playground-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.playground-header h1{color:var(--color-text);align-items:center;gap:.75rem;font-size:1.75rem;font-weight:700;display:flex}.playground-header p{color:var(--color-text-muted);font-size:.95rem}@media (width<=480px){.playground-header h1{font-size:1.25rem}.playground-header p{font-size:.85rem}}.glow-icon{color:var(--color-primary);filter:drop-shadow(0 0 8px #6366f180);animation:2s ease-in-out infinite pulse-glow}@keyframes pulse-glow{0%,to{filter:drop-shadow(0 0 4px #6366f14d)}50%{filter:drop-shadow(0 0 12px #6366f1b3)}}.playground-workspace{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);flex:1;min-height:500px;display:flex;overflow:hidden}@media (width<=768px){.playground-workspace{border-radius:var(--radius-md);min-height:400px}}.chat-area{flex-direction:column;flex:1;display:flex;position:relative}.messages-list{flex-direction:column;flex:1;gap:1.5rem;padding:2rem;display:flex;overflow-y:auto}@media (width<=480px){.messages-list{gap:1rem;padding:1rem}}.chat-bubble-container{gap:1rem;max-width:85%;display:flex}.chat-bubble-container.user{flex-direction:row-reverse;align-self:flex-end}.chat-bubble-container.ai{align-self:flex-start}.avatar{background:var(--color-bg);border:1px solid var(--color-border);width:36px;height:36px;box-shadow:var(--shadow-sm);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.25rem;display:flex}.chat-bubble-container.user .avatar{background:linear-gradient(135deg, var(--color-secondary), #db2777);color:#fff;border:none}.chat-bubble-content{flex-direction:column;flex:1;gap:.75rem;display:flex}.chat-bubble{box-shadow:var(--shadow-sm);border-radius:1.25rem;padding:1rem 1.25rem;font-size:.95rem;line-height:1.5}.chat-bubble-container.user .chat-bubble{background-color:var(--color-primary);color:#fff;border-top-right-radius:.25rem}.chat-bubble-container.ai .chat-bubble{background-color:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border);border-top-left-radius:.25rem}.chat-bubble p{margin-bottom:.75rem}.chat-bubble p:last-child{margin-bottom:0}.chat-bubble ul,.chat-bubble ol{margin-bottom:.75rem;margin-left:1.25rem}.chat-bubble blockquote{border-left:4px solid var(--color-primary-light);color:var(--color-text-muted);margin:.75rem 0;padding-left:.75rem}.stream-loader{color:var(--color-text-muted);align-items:center;gap:.75rem;margin-top:.5rem;font-size:.85rem;display:flex}.loader-dots{gap:3px;display:flex}.loader-dots span{background-color:var(--color-primary);border-radius:50%;width:6px;height:6px;animation:1.4s ease-in-out infinite both dot-pulse}.loader-dots span:nth-child(2){animation-delay:.2s}.loader-dots span:nth-child(3){animation-delay:.4s}@keyframes dot-pulse{0%,80%,to{opacity:.3;transform:scale(0)}40%{opacity:1;transform:scale(1)}}.saving-widget{color:var(--color-primary);align-items:center;gap:.5rem;margin-top:.75rem;font-size:.85rem;font-weight:500;display:flex}.spin-icon{animation:1.5s linear infinite spin}.widget-card{border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-md);flex-direction:column;margin-top:.5rem;display:flex;overflow:hidden}.widget-card-header{background-color:var(--color-bg);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:.75rem 1.25rem;display:flex}.widget-title{color:var(--color-text);align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;display:flex}.widget-tabs{background-color:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);gap:.25rem;padding:.25rem;display:flex}.widget-tabs .tab-btn{border-radius:calc(var(--radius-md) - 2px);color:var(--color-text-muted);transition:all var(--transition-fast);align-items:center;gap:.35rem;padding:.35rem .75rem;font-size:.8rem;font-weight:500;display:flex}.widget-tabs .tab-btn:hover{color:var(--color-text);background-color:var(--color-bg)}.widget-tabs .tab-btn.active{color:var(--color-primary);background-color:var(--color-bg);box-shadow:var(--shadow-sm)}.widget-card-body{background-color:var(--color-surface);min-height:200px;padding:1.5rem}@media (width<=480px){.widget-card-body{padding:1rem!important}}.code-display{color:#e2e8f0;border-radius:var(--radius-md);background-color:#0f172a;max-height:400px;margin:0;padding:1rem;font-family:Courier New,Courier,monospace;font-size:.85rem;overflow-x:auto}.chat-controls{border-top:1px solid var(--color-border);background-color:var(--color-surface);padding:1.5rem 2rem}@media (width<=480px){.chat-controls{padding:1rem}.suggestion-btn{gap:.75rem;padding:.75rem}.suggestion-btn .sug-icon{font-size:1.25rem}.suggestion-btn .sug-text{font-size:.85rem}.sug-desc{font-size:.75rem}}.sample-selector-header{color:var(--color-text);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.9rem;font-weight:600;display:flex}.suggestions-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.suggestion-btn{border:1px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-bg);text-align:left;transition:all var(--transition-fast);align-items:flex-start;gap:1rem;padding:1rem;display:flex}.suggestion-btn:hover:not(:disabled){border-color:var(--color-primary);background-color:var(--color-surface);box-shadow:var(--shadow-md);transform:translateY(-2px)}.suggestion-btn:disabled{opacity:.6;cursor:not-allowed}.suggestion-btn .sug-icon{margin-top:.1rem;font-size:1.75rem;line-height:1}.sug-info{flex-direction:column;gap:.25rem;display:flex}.suggestion-btn .sug-text{color:var(--color-text);font-size:.95rem;font-weight:600}.sug-desc{color:var(--color-text-muted);font-size:.8rem;line-height:1.4}@media (width<=768px){.suggestions-grid{grid-template-columns:1fr}.chat-bubble-container{max-width:95%}.chat-bubble-container .avatar{display:none}}@media (width<=480px){.chat-bubble-container{gap:0;max-width:100%}.chat-bubble-container .avatar{width:28px;height:28px;font-size:.9rem}.chat-bubble{border-radius:1rem;padding:.75rem 1rem;font-size:.9rem}.custom-input-area{flex-direction:column}.active-widget-header{padding:.75rem 1rem}.active-widget-body{padding:1rem!important}}.ai-log-details{margin-bottom:.5rem;display:block}.ai-log-summary{color:var(--color-text-muted);cursor:pointer;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);-webkit-user-select:none;user-select:none;transition:all var(--transition-fast);box-shadow:var(--shadow-sm);outline:none;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.85rem;font-weight:500;display:inline-flex}.ai-log-summary:hover{background-color:var(--color-surface);color:var(--color-text);border-color:var(--color-primary-light)}.ai-log-details[open] .ai-log-summary{background-color:var(--color-surface);border-bottom:none;border-bottom-right-radius:0;border-bottom-left-radius:0}.ai-log-details .chat-bubble{border-top-right-radius:var(--radius-md);border-bottom-left-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md);border:1px solid var(--color-border);background-color:var(--color-surface);margin-top:0;border-top-left-radius:0!important}.widget-skeleton-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:500px;box-shadow:var(--shadow-md);flex-direction:column;gap:1.25rem;padding:1.5rem;display:flex}.skeleton-header{align-items:center;gap:.75rem;display:flex}.skeleton-avatar{background-color:var(--color-border);border-radius:50%;width:32px;height:32px}.skeleton-title{border-radius:var(--radius-md);background-color:var(--color-border);width:150px;height:18px}.skeleton-body{flex-direction:column;gap:.75rem;display:flex}.skeleton-line{border-radius:var(--radius-md);background-color:var(--color-border);height:12px}.skeleton-line.long{width:90%}.skeleton-line.medium{width:75%}.skeleton-line.short{width:40%}.skeleton-button-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;margin-top:.75rem;display:grid}.skeleton-btn{border-radius:var(--radius-full);background-color:var(--color-border);height:36px}.pulse{animation:1.5s ease-in-out infinite skeleton-pulse}@keyframes skeleton-pulse{0%{opacity:.6}50%{opacity:.3}to{opacity:.6}}.active-widget-view{background-color:var(--color-surface);flex-direction:column;width:100%;height:100%;display:flex}.active-widget-header{border-bottom:1px solid var(--color-border);background-color:var(--color-bg);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.5rem;display:flex}.back-chat-btn{color:var(--color-primary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast);background:0 0;border:none;align-items:center;gap:.5rem;padding:.4rem .8rem;font-size:.9rem;font-weight:600;display:inline-flex}.back-chat-btn:hover{background-color:var(--color-surface);color:var(--color-primary-dark)}.unit-detail-container{max-width:1400px;margin:0 auto}.unit-header{margin-bottom:2rem}.back-link{color:var(--color-text-muted);transition:color var(--transition-fast);align-items:center;gap:.5rem;margin-bottom:1rem;font-weight:500;display:inline-flex}.back-link:hover{color:var(--color-primary)}.unit-header h1{color:var(--color-text);margin-bottom:.5rem;font-size:2.5rem}.unit-header p{color:var(--color-text-muted);font-size:1.1rem}@media (width<=768px){.unit-header h1{font-size:1.5rem}.unit-header p{font-size:.95rem}}.tabs{border-bottom:1px solid var(--color-border);gap:1rem;margin-bottom:2rem;display:flex}.tab-btn{color:var(--color-text-muted);transition:all var(--transition-fast);border-bottom:3px solid #0000;padding:1rem 2rem;font-size:1rem;font-weight:600}@media (width<=768px){.tabs{-webkit-overflow-scrolling:touch;gap:0;overflow-x:auto}.tab-btn{white-space:nowrap;flex-shrink:0;padding:.75rem 1rem;font-size:.85rem}}@media (width<=480px){.tab-btn{padding:.6rem .75rem;font-size:.8rem}}.tab-btn:hover{color:var(--color-text)}.tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.theory-content{background-color:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:2rem;line-height:1.8}@media (width<=480px){.theory-content{border-radius:var(--radius-md);padding:1rem}}.theory-content h2{color:var(--color-text);margin-top:2rem;margin-bottom:1rem;font-size:1.5rem}.theory-content h2:first-child{margin-top:0}.theory-content p{color:var(--color-text);margin-bottom:1rem}.theory-content ul{color:var(--color-text);margin-bottom:1.5rem;padding-left:1.5rem}.theory-content li{margin-bottom:.5rem}.unit-detail-layout{margin-bottom:2.5rem}.unit-content-pane{min-width:0}.unit-board-section{border-top:1px solid var(--color-border);margin-top:2.5rem;padding-top:2.5rem}.vocab-container{max-width:1100px}.vocab-header{margin-bottom:1.5rem}.vocab-header h1{color:var(--color-text);align-items:center;gap:.75rem;margin-bottom:.5rem;font-size:2rem;display:flex}.vocab-header p{color:var(--color-text-muted)}.vocab-search{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:border-color var(--transition-fast);align-items:center;gap:.75rem;margin-bottom:2rem;padding:.75rem 1rem;display:flex}.vocab-search:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #6366f11a}.vocab-search input{color:var(--color-text);font-size:1rem;font-family:var(--font-sans);background:0 0;border:none;outline:none;flex:1}.vocab-search input::placeholder{color:var(--color-text-muted)}.vocab-sections{flex-direction:column;gap:.75rem;display:flex}.vocab-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:border-color var(--transition-fast);overflow:hidden}.vocab-section:hover,.vocab-section.open{border-color:var(--color-primary-light)}.vocab-section-header{cursor:pointer;width:100%;color:var(--color-text);text-align:left;transition:background var(--transition-fast);background:0 0;border:none;justify-content:space-between;align-items:center;padding:1rem 1.25rem;font-size:1rem;display:flex}.vocab-section-header:hover{background:var(--color-bg)}.vocab-section-title{align-items:center;gap:.5rem;display:flex}.vocab-section-title span:first-child{color:var(--color-primary)}.vocab-count{color:var(--color-text-muted);background:var(--color-bg);border-radius:var(--radius-full);padding:.2rem .6rem;font-size:.8rem}.vocab-section-body{border-top:1px solid var(--color-border);padding:0 1.25rem 1.25rem}.vocab-section.open .vocab-section-body{animation:.2s slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.vocab-table-wrapper{margin-top:1rem;overflow-x:auto}.vocab-table{border-collapse:collapse;width:100%;font-size:.9rem}.vocab-table th{text-align:left;background:var(--color-bg);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--color-border);padding:.75rem 1rem;font-size:.8rem;font-weight:600}.vocab-table th:first-child{border-radius:var(--radius-md) 0 0 0}.vocab-table th:last-child{border-radius:0 var(--radius-md) 0 0}.vocab-table td{border-bottom:1px solid var(--color-border);vertical-align:top;padding:.75rem 1rem;line-height:1.5}.vocab-table tr:last-child td{border-bottom:none}.vocab-table tr:hover td{background:var(--color-bg)}.vocab-word{white-space:nowrap;color:var(--color-primary)}.vocab-pos{background:var(--color-primary-light);color:#fff;border-radius:var(--radius-full);padding:.15rem .5rem;font-size:.75rem;font-weight:600;display:inline-block}.vocab-example{color:var(--color-text-muted);font-size:.85rem}.vocab-synonyms{color:var(--color-text);line-height:1.6}.linking-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-top:1rem;display:grid}.linking-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem}.linking-category{color:var(--color-primary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem;font-size:.85rem;font-weight:600}.linking-list{margin:0;padding:0;list-style:none}.linking-list li{color:var(--color-text);border-bottom:1px dashed var(--color-border);padding:.35rem 0;font-size:.9rem}.linking-list li:last-child{border-bottom:none}.vocab-empty{text-align:center;color:var(--color-text-muted);padding:3rem}@media (width<=768px){.vocab-table{font-size:.8rem}.vocab-table th,.vocab-table td{padding:.5rem}.vocab-word{white-space:normal}.linking-grid{grid-template-columns:1fr}}@media (width<=480px){.vocab-header h1{font-size:1.5rem}.vocab-search{padding:.6rem .75rem}.vocab-section-header{padding:.75rem 1rem;font-size:.9rem}.vocab-section-body{padding:0 1rem 1rem}.vocab-table th,.vocab-table td{padding:.4rem .5rem;font-size:.75rem}}:root{--color-primary:#6366f1;--color-primary-dark:#4f46e5;--color-primary-light:#818cf8;--color-secondary:#ec4899;--color-bg:#f8fafc;--color-surface:#fff;--color-text:#0f172a;--color-text-muted:#64748b;--color-success:#10b981;--color-success-bg:#d1fae5;--color-error:#ef4444;--color-error-bg:#fee2e2;--color-border:#e2e8f0;--font-sans:"Inter", sans-serif;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--shadow-glow:0 0 15px #6366f14d;--radius-md:.5rem;--radius-lg:1rem;--radius-full:9999px;--transition-fast:.15s ease;--transition-normal:.3s ease}@media (prefers-color-scheme:dark){:root{--color-bg:#0f172a;--color-surface:#1e293b;--color-text:#f8fafc;--color-text-muted:#94a3b8;--color-border:#334155;--color-success-bg:#064e3b;--color-error-bg:#7f1d1d}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--transition-normal), color var(--transition-normal);line-height:1.6}a{color:var(--color-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-dark)}button{cursor:pointer;background:0 0;border:none;font-family:inherit}.glass-panel{-webkit-backdrop-filter:blur(10px);background:#ffffffb3;border:1px solid #ffffff2e}@media (prefers-color-scheme:dark){.glass-panel{background:#1e293bb3;border:1px solid #ffffff0d}}.btn-primary{background-color:var(--color-primary);color:#fff;border-radius:var(--radius-full);transition:all var(--transition-fast);box-shadow:var(--shadow-sm);padding:.75rem 1.5rem;font-weight:600}.btn-primary:hover{background-color:var(--color-primary-dark);box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-full);transition:all var(--transition-fast);background-color:#0000;padding:.75rem 1.5rem;font-weight:600}.btn-secondary:hover{background-color:var(--color-surface);border-color:var(--color-text-muted)}button.limited{opacity:.6;background-color:var(--color-text-muted)!important;cursor:not-allowed!important}.rate-limit-badge{color:var(--color-text-muted);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);white-space:nowrap;align-items:center;gap:.35rem;padding:.2rem .5rem;font-size:.75rem;display:inline-flex}@supports (padding:env(safe-area-inset-bottom)){body{padding-bottom:env(safe-area-inset-bottom)}}@media (width<=480px){:root{--radius-lg:.75rem;--radius-md:.4rem}}
