.calendar-modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.calendar-modal{background:#fff;border-radius:16px;flex-direction:column;width:100%;max-width:1200px;height:90vh;display:flex;position:relative;overflow:hidden;box-shadow:0 20px 40px #0003}.calendar-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.calendar-title-group{align-items:center;gap:12px;display:flex}.calendar-title{color:#1e293b;margin:0;font-size:1.25rem;font-weight:600}.calendar-year-nav{align-items:center;gap:16px;font-size:1.25rem;font-weight:600;display:flex}.calendar-btn-icon{cursor:pointer;color:#64748b;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:flex}.calendar-btn-icon:hover{color:#0f172a;background:#e2e8f0}@media (width>=769px){.mobile-only{display:none!important}}.calendar-banner{text-align:center;border-bottom:1px solid #e2e8f0;padding:12px 24px;font-size:.9rem;font-weight:500}.calendar-body{flex:1;display:flex;position:relative;overflow:hidden}.calendar-sidebar{background:#f8fafc;border-right:1px solid #e2e8f0;flex-direction:column;gap:16px;width:280px;padding:20px;display:flex;overflow-y:auto}.calendar-content{flex:1;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));align-content:start;gap:24px;padding:24px;display:grid;overflow-y:auto}.season-rainy-bg{background-color:#3b82f61a}.season-rainy-border{border-color:#3b82f6}.season-rainy-text{color:#3b82f6}.season-cool-bg{background-color:#10b9811a}.season-cool-border{border-color:#10b981}.season-cool-text{color:#10b981}.season-hot-bg{background-color:#ef44441a}.season-hot-border{border-color:#ef4444}.season-hot-text{color:#ef4444}.month-container{border:2px solid #0000;border-radius:12px;padding:16px;transition:opacity .3s}.month-container.season-rainy{background-color:#3b82f60d;border-color:#3b82f6}.month-container.season-cool-dry{background-color:#10b9810d;border-color:#10b981}.month-container.season-hot-dry{background-color:#ef44440d;border-color:#ef4444}.month-container.dimmed{opacity:.3}.month-title{margin:0 0 12px;font-size:1.1rem;font-weight:600}.month-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.day-header{text-align:center;color:#64748b;margin-bottom:4px;font-size:.75rem;font-weight:600}.day-cell{aspect-ratio:1;cursor:pointer;border-radius:6px;flex-direction:column;justify-content:flex-start;align-items:center;padding-top:4px;font-size:.85rem;transition:background .2s;display:flex;position:relative}.day-cell:hover{background:#0000000d}.day-cell.today{color:#fff;background:#1e293b;font-weight:600}.day-cell.today:hover{background:#0f172a}.day-dots{gap:2px;margin-top:auto;margin-bottom:4px;display:flex}.day-dot{background:#f59e0b;border-radius:50%;width:6px;height:6px}.day-harvest{color:#10b981;position:absolute;top:-4px;right:-4px}.season-filter-btn{cursor:pointer;text-align:left;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:space-between;align-items:center;width:100%;padding:12px;font-weight:600;transition:all .2s;display:flex}.season-filter-btn:hover{background:#f1f5f9}.season-filter-btn.active{border-width:2px}.season-crop-list{flex-direction:column;gap:8px;margin:0;padding:8px 0 8px 12px;font-size:.9rem;list-style:none;display:flex}.season-crop-item{color:#475569;justify-content:space-between;display:flex}.day-panel-overlay{z-index:10;background:#0006;justify-content:center;align-items:center;padding:20px;display:flex;position:absolute;inset:0}.day-panel{background:#fff;border-radius:12px;flex-direction:column;gap:16px;width:100%;max-width:400px;max-height:80vh;padding:24px;display:flex;overflow-y:auto;box-shadow:0 10px 25px #0003}.day-panel-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding-bottom:12px;display:flex}.day-panel-header h3{margin:0}.diary-entry{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;flex-direction:column;gap:8px;padding:12px;display:flex;position:relative}.diary-entry-delete{color:#ef4444;cursor:pointer;background:0 0;border:none;padding:4px;position:absolute;top:8px;right:8px}.harvest-estimate{color:#047857;background:#10b9811a;border-radius:6px;align-items:center;gap:8px;padding:8px 12px;font-size:.9rem;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:#334155;font-size:.9rem;font-weight:600}.form-control{border:1px solid #cbd5e1;border-radius:6px;padding:10px;font-size:.95rem}.export-btn{color:#fff;cursor:pointer;background:#1e293b;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;margin-top:auto;padding:12px;font-weight:600;display:flex}.export-btn:hover{background:#0f172a}@media (width<=768px){.calendar-body{flex-direction:column}.calendar-sidebar{border-bottom:1px solid #e2e8f0;border-right:none;width:100%;max-height:250px}.calendar-modal{border-radius:0;height:100vh}.calendar-modal-overlay{padding:0}}.navbar{height:56px;z-index:var(--z-sticky);background:#fff;border-bottom:1px solid #e8edf2;position:fixed;top:0;left:0;right:0}.navbar-inner{max-width:1080px;height:100%;padding:0 var(--space-6);justify-content:space-between;align-items:center;gap:var(--space-4);margin:0 auto;display:flex}.navbar-brand{align-items:center;gap:var(--space-2);flex-shrink:0;text-decoration:none;display:flex}.navbar-brand__avatar{border-radius:var(--radius-full);object-fit:cover;width:32px;height:32px;transition:border-color var(--transition-fast);border:2px solid #e8edf2}.navbar-brand:hover .navbar-brand__avatar{border-color:var(--color-blue-300)}.navbar-title{font-weight:600;font-size:var(--text-sm);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;max-width:120px;overflow:hidden}.navbar-center{flex:1;justify-content:center;display:flex}.navbar-progress{align-items:center;gap:var(--space-2);display:flex}.navbar-progress-track{border-radius:var(--radius-full);background:#e8edf2;width:100px;height:3px;overflow:hidden}.navbar-progress-fill{background:var(--color-blue-600);border-radius:var(--radius-full);height:100%;transition:width .3s}.navbar-progress-label{font-size:var(--text-xs);color:var(--color-text-muted);min-width:28px;font-weight:500}.navbar-actions{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}@media (width<=600px){.navbar-title,.navbar-progress{display:none}}.navbar-tutor-face{border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;width:38px;height:38px;padding:2px;display:flex;overflow:hidden}.navbar-tutor-face__img{border-radius:var(--radius-full);border:2px solid var(--color-blue-400);width:34px;height:34px;transition:all var(--transition-fast);background:var(--color-blue-600);flex-shrink:0;overflow:hidden;box-shadow:0 0 #0d8bf200}.navbar-tutor-face:hover .navbar-tutor-face__img{border-color:var(--color-blue-600);transform:scale(1.05);box-shadow:0 0 0 3px #0d8bf226}.navbar-tutor-face:active .navbar-tutor-face__img{transform:scale(.95)}.navbar-profile{margin-left:var(--space-1);position:relative}.navbar-profile__trigger{align-items:center;gap:var(--space-1);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;padding:3px;display:flex}.navbar-profile__trigger:hover{background:var(--color-bg-secondary)}.navbar-profile__avatar{border-radius:var(--radius-full);object-fit:cover;width:32px;height:32px;transition:border-color var(--transition-fast);border:2px solid #e8edf2}.navbar-profile__trigger:hover .navbar-profile__avatar{border-color:var(--color-blue-300)}.navbar-profile__chevron{color:var(--color-text-muted);transition:transform var(--transition-fast);flex-shrink:0}.navbar-profile__chevron--open{transform:rotate(180deg)}.navbar-dropdown{border-radius:var(--radius-xl);width:240px;box-shadow:var(--shadow-xl);padding:var(--space-2);z-index:var(--z-dropdown);background:#fff;border:1px solid #e8edf2;animation:.15s ease-out fadeInDown;position:absolute;top:calc(100% + 8px);right:0}.navbar-dropdown__header{align-items:center;gap:var(--space-3);padding:var(--space-3);display:flex}.navbar-dropdown__avatar{border-radius:var(--radius-full);object-fit:cover;border:2px solid #e8edf2;flex-shrink:0;width:40px;height:40px}.navbar-dropdown__info{flex-direction:column;min-width:0;display:flex}.navbar-dropdown__name{font-size:var(--text-sm);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.navbar-dropdown__badge{color:var(--color-gold-500);border-radius:var(--radius-full);background:#f59e0b1a;width:fit-content;margin-top:2px;padding:1px 6px;font-size:10px;font-weight:600;display:inline-block}.navbar-dropdown__email{font-size:var(--text-xs);color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.navbar-dropdown__divider{height:1px;margin:var(--space-1) var(--space-2);background:#e8edf2}.navbar-dropdown__item{align-items:center;gap:var(--space-3);width:100%;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text-secondary);cursor:pointer;font-family:var(--font-body);transition:all var(--transition-fast);background:0 0;border:none;display:flex}.navbar-dropdown__item:hover{background:var(--color-bg-secondary);color:var(--color-text-primary)}.navbar-dropdown__item--danger:hover{background:var(--color-danger-bg);color:var(--color-danger)}.tts-btn{border-radius:var(--radius-full);width:28px;height:28px;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.tts-btn:hover,.tts-btn--active{color:var(--color-blue-600);background:var(--color-blue-100)}.chat-panel{border-radius:var(--radius-xl);width:380px;max-width:calc(100vw - 32px);height:520px;max-height:calc(100vh - 100px);box-shadow:var(--shadow-xl);z-index:var(--z-chat);background:#fff;border:1px solid #e8edf2;flex-direction:column;display:flex;position:fixed;bottom:20px;right:20px;overflow:hidden}.chat-panel__header{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid #e8edf2;display:flex}.chat-avatar-img{border-radius:var(--radius-md);background:var(--color-blue-600);flex-shrink:0;width:32px;height:32px;overflow:hidden}.chat-msg__avatar-img{border-radius:var(--radius-sm);background:var(--color-blue-600);flex-shrink:0;width:24px;height:24px;overflow:hidden}.chat-msg__avatar-img--thinking{opacity:.6}.chat-panel__header-text{flex-direction:column;flex:1;display:flex}.chat-panel__header-text strong{font-size:var(--text-sm);color:var(--color-text-primary)}.chat-panel__header-text span{color:var(--color-text-muted);font-size:11px}.chat-panel__messages{padding:var(--space-3);gap:var(--space-3);flex-direction:column;flex:1;display:flex;overflow-y:auto}.chat-msg{gap:var(--space-2);align-items:flex-end;max-width:85%;display:flex}.chat-msg--user{flex-direction:row-reverse;align-self:flex-end}.chat-msg--bot{align-self:flex-start}.chat-msg__avatar{animation:none!important}.chat-msg__bubble{padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);font-size:var(--text-sm);line-height:1.5}.chat-msg--user .chat-msg__bubble{background:var(--color-blue-600);color:#fff;border-bottom-right-radius:var(--radius-sm)}.chat-msg--bot .chat-msg__bubble{background:var(--color-bg-secondary);color:var(--color-text-primary);border-bottom-left-radius:var(--radius-sm);position:relative}.chat-msg__tts-btn{float:right;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-full);transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;margin:0 0 4px 8px;padding:4px;display:flex}.chat-msg__tts-btn:hover{color:var(--color-blue-600);background:var(--color-blue-50)}.chat-msg__sources{margin-top:var(--space-2);padding-top:var(--space-2);gap:var(--space-1);border-top:1px solid #e8edf2;flex-direction:column;display:flex}.chat-msg__sources-label{color:var(--color-text-muted);font-size:11px}.chat-msg__source-pills{flex-wrap:wrap;gap:3px;display:flex}.chat-msg__source-pill{border-radius:var(--radius-full);background:var(--color-blue-100);color:var(--color-blue-600);border:1px solid var(--color-blue-200);white-space:nowrap;cursor:default;transition:background var(--transition-fast);align-items:center;gap:3px;padding:1px 6px;font-family:inherit;font-size:10px;display:inline-flex}.chat-msg__source-pill--link{cursor:pointer}.chat-msg__source-pill--link:hover{background:var(--color-blue-200)}.chat-msg__source-pill--link:active{transform:scale(.98)}.chat-msg__source-arrow{opacity:.6;font-size:10px}.chat-msg__typing{padding:var(--space-2) var(--space-4);gap:4px;display:flex}.chat-msg__typing span{border-radius:var(--radius-full);background:var(--color-blue-400);width:5px;height:5px;animation:1.4s ease-in-out infinite bounce}.chat-msg__typing span:nth-child(2){animation-delay:.2s}.chat-msg__typing span:nth-child(3){animation-delay:.4s}.chat-panel__input{gap:var(--space-2);padding:var(--space-3);border-top:1px solid #e8edf2;display:flex}.chat-panel__input input{padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);background:var(--color-bg-secondary);color:var(--color-text-primary);font-size:var(--text-sm);transition:border-color var(--transition-fast);border:1px solid #e8edf2;outline:none;flex:1}.chat-panel__input input:focus{border-color:var(--color-blue-400)}.chat-panel__input input::placeholder{color:var(--color-text-muted)}.chat-panel__mic{color:var(--color-text-muted);transition:all var(--transition-fast)}.chat-panel__mic:hover{color:var(--color-blue-600);background:var(--color-blue-50)}.chat-panel__mic--active{color:#fff;background:#ef4444;animation:2s infinite pulse-red}.chat-panel__mic--active:hover{color:#fff;background:#dc2626}@keyframes pulse-red{0%{box-shadow:0 0 #ef444466}70%{box-shadow:0 0 0 6px #ef444400}to{box-shadow:0 0 #ef444400}}.avatar-picker__overlay{z-index:200;-webkit-backdrop-filter:blur(6px);padding:var(--space-4);background:#1a233273;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.avatar-picker{border-radius:var(--radius-2xl);padding:var(--space-8);width:100%;max-width:440px;box-shadow:var(--shadow-xl);background:#fff;position:relative}.avatar-picker__header{text-align:center;margin-bottom:var(--space-6)}.avatar-picker__title{font-size:var(--text-xl);color:var(--color-text-primary);margin-bottom:var(--space-1);font-weight:700}.avatar-picker__subtitle{font-size:var(--text-sm);color:var(--color-text-muted)}.avatar-picker__close{top:var(--space-4);right:var(--space-4);border-radius:var(--radius-full);width:32px;height:32px;color:var(--color-text-muted);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex;position:absolute}.avatar-picker__close:hover{background:var(--color-bg-secondary);color:var(--color-text-primary)}.avatar-picker__grid{gap:var(--space-3);margin-bottom:var(--space-6);grid-template-columns:repeat(4,1fr);display:grid}.avatar-picker__item{align-items:center;gap:var(--space-2);padding:var(--space-2);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:2px solid #0000;flex-direction:column;display:flex}.avatar-picker__item:hover{background:var(--color-bg-secondary)}.avatar-picker__item--selected{border-color:var(--color-blue-500);background:var(--color-blue-100)}.avatar-picker__img-wrap{border-radius:var(--radius-full);background:var(--color-bg-secondary);width:64px;height:64px;transition:border-color var(--transition-fast);border:2px solid #e8edf2;position:relative;overflow:hidden}.avatar-picker__item--selected .avatar-picker__img-wrap{border-color:var(--color-blue-500)}.avatar-picker__img{object-fit:cover;width:100%;height:100%}.avatar-picker__check{background:var(--color-blue-600);color:#fff;border-radius:var(--radius-full);border:2px solid #fff;justify-content:center;align-items:center;width:22px;height:22px;display:flex;position:absolute;bottom:-2px;right:-2px}.avatar-picker__label{font-size:var(--text-xs);color:var(--color-text-secondary);transition:color var(--transition-fast);font-weight:500}.avatar-picker__item--selected .avatar-picker__label{color:var(--color-blue-600);font-weight:600}.avatar-picker__actions{justify-content:center;display:flex}.avatar-picker__confirm{min-width:200px}.avatar-picker__confirm:disabled{opacity:.5;cursor:not-allowed}@media (width<=480px){.avatar-picker{padding:var(--space-5)}.avatar-picker__img-wrap{width:52px;height:52px}.avatar-picker__grid{gap:var(--space-2)}}.greeter{z-index:100;cursor:default;background:linear-gradient(160deg,#0974d0 0%,#0d8bf2 35%,#2e9bf5 70%,#5cb3f7 100%);justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow:hidden}.greeter__blob{pointer-events:none;border-radius:50%;position:absolute}.greeter__blob--1{background:#ffffff0a;width:420px;height:420px;animation:10s ease-in-out infinite greeterFloat;top:-120px;right:-80px}.greeter__blob--2{background:#ffffff08;width:300px;height:300px;animation:12s ease-in-out infinite reverse greeterFloat;bottom:-60px;left:-40px}.greeter__content{width:100%;max-width:560px;padding:var(--space-6);align-items:center;gap:var(--space-6);text-align:center;z-index:1;flex-direction:column;display:flex}.greeter__face{width:200px;height:200px;box-shadow:none;background:0 0;border:none;flex-shrink:0;animation:5s ease-in-out infinite greeterFloat;position:relative;overflow:visible}.greeter__face img{object-fit:cover;width:100%;height:100%}.greeter__face--speaking{animation:5s ease-in-out infinite greeterFloat,1.8s ease-in-out infinite greeterGlow}.greeter__speech-waves{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff26;border-radius:12px;align-items:flex-end;gap:3px;padding:4px 10px;display:flex;position:absolute;bottom:-14px;left:50%;transform:translate(-50%)}.greeter__speech-waves span{border-radius:var(--radius-full);background:#fff;width:3px;animation:.6s ease-in-out infinite greeterWave;display:block}.greeter__speech-waves span:first-child{height:8px;animation-delay:0s}.greeter__speech-waves span:nth-child(2){height:14px;animation-delay:.15s}.greeter__speech-waves span:nth-child(3){height:10px;animation-delay:.3s}@keyframes greeterWave{0%,to{transform:scaleY(1)}50%{transform:scaleY(1.8)}}.greeter__text{color:#fff;max-width:500px;min-height:80px;font-size:1.15rem;line-height:1.7}.greeter__text p{margin:0}.greeter__cursor{opacity:.7;margin-left:2px;font-weight:300;animation:.7s step-end infinite greeterBlink;display:inline-block}.greeter__cursor--hidden{display:none}.greeter__skip-hint{margin-top:var(--space-3);font-size:var(--text-xs);color:#fff6;letter-spacing:.03em;display:block}.greeter__loading{padding:var(--space-8);justify-content:center;align-items:center;display:flex}.greeter__spinner{border:3px solid #fff3;border-top-color:#fff;border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.greeter__actions{align-items:center;gap:var(--space-3);flex-direction:column;width:100%;max-width:320px;display:flex}.greeter__btn{justify-content:center;align-items:center;gap:var(--space-2);width:100%;padding:14px var(--space-5);border-radius:var(--radius-lg);font-size:var(--text-base);font-weight:500;font-family:var(--font-body);cursor:pointer;border:none;transition:all .2s;display:flex}.greeter__btn:active{transform:scale(.97)}.greeter__btn--primary{color:#0d8bf2;background:#fffffff2;box-shadow:0 2px 12px #0000001a}.greeter__btn--primary:hover{background:#fff;transform:translateY(-1px);box-shadow:0 4px 20px #00000026}.greeter__btn--ghost{color:#ffffffe6;background:#ffffff1a;border:1px solid #fff3}.greeter__btn--ghost:hover{background:#ffffff2e;border-color:#ffffff59}.greeter__btn--lg{padding:16px var(--space-6);font-size:1.05rem}.greeter__lessons{width:100%;margin-top:var(--space-3)}.greeter__lessons-label{font-size:var(--text-xs);color:#ffffff80;margin-bottom:var(--space-2);text-transform:uppercase;letter-spacing:.04em;display:block}.greeter__lesson-list{gap:var(--space-1);flex-direction:column;display:flex}.greeter__lesson-card{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:#fff;cursor:pointer;font-family:var(--font-body);text-align:left;background:#ffffff14;border:1px solid #ffffff1a;transition:all .15s;display:flex}.greeter__lesson-card:hover{background:#ffffff26;border-color:#ffffff40}.greeter__lesson-icon{flex-shrink:0;font-size:1.1rem}.greeter__lesson-info{flex-direction:column;flex:1;min-width:0;display:flex}.greeter__lesson-ch{color:#ffffff73;text-transform:uppercase;letter-spacing:.04em;font-size:10px;font-weight:500}.greeter__lesson-title{font-size:var(--text-sm);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}@keyframes greeterFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes greeterTalk{0%{transform:scaleY(1)translateY(0)}to{transform:scaleY(1.06)translateY(-4px)}}@keyframes greeterGlow{0%,to{filter:drop-shadow(0 0 8px #fff3)}50%{filter:drop-shadow(0 0 20px #fff6)}}@keyframes greeterBlink{50%{opacity:0}}.greeter--interact{cursor:pointer}.greeter__start-pulse{margin-top:var(--space-8);font-size:var(--text-lg);color:#ffffffb3;font-weight:500;animation:1.5s infinite greeterBlink}@media (width<=600px){.greeter__face{width:150px;height:150px}.greeter__text{font-size:1rem;line-height:1.6}.greeter__actions{max-width:280px}.greeter__btn{padding:12px var(--space-4);font-size:var(--text-sm)}}.tutorial-overlay{z-index:999;pointer-events:auto;position:fixed;inset:0}.tutorial-backdrop{width:100%;height:100%;position:absolute;inset:0}.tutorial-tooltip{border-radius:var(--radius-xl);width:480px;padding:var(--space-5) var(--space-6);z-index:1000;background:#fff;position:fixed;box-shadow:0 12px 40px #0003}.tutorial-tooltip__layout{gap:var(--space-4);align-items:flex-start;display:flex}.tutorial-tooltip__avatar{background:var(--color-blue-500);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:120px;height:120px;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 12px #5cb3f74d}.tutorial-tooltip__avatar svg{width:80%;height:80%}.tutorial-floating-avatar{z-index:1000;pointer-events:none;position:fixed;bottom:60px;right:60px}.tutorial-floating-avatar__inner{background:var(--color-blue-500);border:4px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:140px;height:140px;display:flex;position:relative;overflow:hidden;box-shadow:0 12px 30px #5cb3f766}.tutorial-floating-avatar__inner svg{width:85%;height:85%}.tutorial-tooltip__content{flex:1}.tutorial-tooltip__header{margin-bottom:var(--space-2);justify-content:space-between;align-items:center;display:flex}.tutorial-tooltip__title{font-size:var(--text-xl);color:var(--color-text-primary);margin:0;font-weight:700}.tutorial-tooltip__close{border-radius:var(--radius-full);cursor:pointer;width:28px;height:28px;color:var(--color-text-muted);background:0 0;border:none;justify-content:center;align-items:center;transition:all .15s;display:flex}.tutorial-tooltip__close:hover{background:var(--color-bg-secondary);color:var(--color-text-primary)}.tutorial-tooltip__desc{font-size:var(--text-lg);color:var(--color-text-secondary);margin:0 0 var(--space-4);line-height:1.6}.tutorial-tooltip__footer{justify-content:space-between;align-items:center;display:flex}.tutorial-dots{gap:6px;display:flex}.tutorial-dot{background:#d0d8e0;border-radius:50%;width:7px;height:7px;transition:all .2s}.tutorial-dot--active{background:var(--color-blue-600);transform:scale(1.3)}.tutorial-dot--done{background:var(--color-blue-300)}.tutorial-tooltip__btn{align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);border-radius:var(--radius-lg);background:var(--color-blue-600);color:#fff;font-size:var(--text-sm);cursor:pointer;font-weight:500;font-family:var(--font-body);border:none;transition:background .15s;display:flex}.tutorial-tooltip__btn:hover{background:var(--color-blue-700)}.tutorial-tooltip__btn:active{transform:scale(.97)}@media (width<=480px){.tutorial-tooltip{width:calc(100vw - 32px);right:16px;left:16px!important}}.floating-ai-tutor{background:var(--color-blue-500);cursor:pointer;z-index:900;width:80px;height:80px;transition:transform var(--transition-fast), box-shadow var(--transition-fast);border:4px solid #fff;border-radius:50%;justify-content:center;align-items:center;padding:0;display:flex;position:fixed;bottom:40px;right:40px;overflow:hidden;box-shadow:0 10px 25px #5cb3f766}.floating-ai-tutor:hover{transform:translateY(-4px)scale(1.05);box-shadow:0 14px 30px #5cb3f780}.floating-ai-tutor:active{transform:translateY(0)scale(.95)}.floating-ai-tutor__img{width:100%;height:100%}.floating-ai-tutor__img svg{width:85%;height:85%}@media (width<=768px){.floating-ai-tutor{width:64px;height:64px;bottom:24px;right:24px}}.progress-bar{align-items:center;gap:var(--space-2);width:100%;display:flex}.progress-bar__track{border-radius:var(--radius-full);background:#e8edf2;flex:1;height:4px;overflow:hidden}.progress-bar--sm .progress-bar__track{height:3px}.progress-bar--lg .progress-bar__track{height:6px}.progress-bar__fill{border-radius:var(--radius-full);min-width:0;height:100%;transition:width .4s}.progress-bar__fill--green{background:var(--color-blue-600)}.progress-bar__fill--gold{background:var(--color-blue-500)}.progress-bar__fill--orange{background:var(--color-blue-400)}.progress-bar__label{font-size:var(--text-xs);color:var(--color-text-muted);text-align:right;min-width:32px;font-weight:500}.chapter-card{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);border-radius:var(--radius-xl);background:var(--color-bg-card);text-align:left;cursor:pointer;width:100%;transition:all var(--transition-fast);border:1px solid #e8edf2;display:flex}.chapter-card--unlocked:hover{border-color:var(--color-blue-300);background:var(--color-bg-card-hover)}.chapter-card--locked{opacity:.45;cursor:not-allowed}.chapter-card--complete{border-color:#10b98133}.chapter-card__icon{border-radius:var(--radius-lg);background:color-mix(in srgb, var(--ch-color) 12%, transparent);width:44px;height:44px;color:var(--ch-color);flex-shrink:0;justify-content:center;align-items:center;display:flex}.chapter-card__emoji{font-size:22px}.chapter-card--complete .chapter-card__icon{color:var(--color-success);background:#10b98114}.chapter-card__body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.chapter-card__number{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:500}.chapter-card__title{font-size:var(--text-base);color:var(--color-text-primary);font-weight:600;line-height:1.3}.chapter-card__desc{font-size:var(--text-sm);color:var(--color-text-secondary);-webkit-line-clamp:1;-webkit-box-orient:vertical;line-height:1.4;display:-webkit-box;overflow:hidden}.chapter-card__arrow{color:var(--color-text-muted);transition:color var(--transition-fast);flex-shrink:0}.chapter-card--unlocked:hover .chapter-card__arrow{color:var(--color-blue-600)}.home-page{padding-bottom:var(--space-16)}.progress-card{align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);border-radius:var(--radius-xl);background:var(--color-bg-card);border:1px solid #e8edf2;display:flex}.progress-card__label{font-size:var(--text-sm);color:var(--color-text-secondary);white-space:nowrap;font-weight:500}.chapters-section{padding-top:var(--space-6)}.section-title{font-size:var(--text-xl);margin-bottom:var(--space-4);color:var(--color-text-primary);font-weight:600}.chapters-list{gap:var(--space-2);flex-direction:column;display:flex}.chapter-map-page{padding-bottom:var(--space-16)}.chapter-map__header{padding:var(--space-6) 0 var(--space-5);margin-bottom:var(--space-6);border-bottom:1px solid #e8edf2}.chapter-map__back{margin-bottom:var(--space-3);text-decoration:none;display:inline-flex}.chapter-map__info{align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-3);display:flex}.chapter-map__icon{background:color-mix(in srgb, var(--ch-color) 12%, transparent);width:56px;height:56px;color:var(--ch-color);border-radius:var(--radius-lg);flex-shrink:0;justify-content:center;align-items:center;font-size:2.5rem;display:flex}.chapter-map__label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);font-weight:500}.chapter-map__title{font-size:var(--text-2xl);margin:2px 0}.chapter-map__desc{color:var(--color-text-secondary);font-size:var(--text-sm);max-width:500px}.lesson-path{flex-direction:column;max-width:580px;margin:0 auto;display:flex;position:relative}.lesson-node-wrapper{padding-left:32px;position:relative}.lesson-connector{border-radius:var(--radius-full);background:#e8edf2;width:2px;height:16px;position:absolute;top:-16px;left:51px}.lesson-connector--done{background:var(--color-blue-600)}.lesson-node{align-items:center;gap:var(--space-3);width:100%;padding:var(--space-4) var(--space-5);border-radius:var(--radius-xl);background:var(--color-bg-card);cursor:pointer;transition:all var(--transition-fast);text-align:left;margin-bottom:var(--space-1);border:1px solid #e8edf2;display:flex;position:relative}.lesson-node:hover:not(:disabled){border-color:var(--color-blue-300);background:var(--color-bg-card-hover)}.lesson-node--locked{opacity:.4;cursor:not-allowed}.lesson-node--current{border-color:var(--color-blue-400)}.lesson-node--done{border-color:#10b98133}.lesson-node--quiz{background:var(--color-bg-secondary)}.lesson-node__circle{border-radius:var(--radius-full);background:var(--color-blue-100);width:40px;height:40px;color:var(--color-blue-600);transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.lesson-node--current .lesson-node__circle{background:var(--color-blue-600);color:#fff}.lesson-node--done .lesson-node__circle{color:var(--color-success);background:#10b98114}.lesson-node--locked .lesson-node__circle{background:var(--color-bg-secondary);color:var(--color-text-muted)}.lesson-node__circle--quiz{color:var(--color-gold-500)!important;background:#f59e0b14!important}.lesson-node__info{flex:1;min-width:0}.lesson-node__number{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:500}.lesson-node__title{font-size:var(--text-base);color:var(--color-text-primary);margin:1px 0;font-weight:600}.lesson-node__desc{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:1.4}.lesson-node__pulse{border-radius:var(--radius-xl);border:1.5px solid var(--color-blue-400);pointer-events:none;animation:2.5s ease-in-out infinite pulseGlow;position:absolute;inset:-2px}@media (width<=600px){.lesson-node-wrapper{padding-left:0}.lesson-connector{left:24px}.lesson-node{padding:var(--space-3);gap:var(--space-2)}.lesson-node__circle{width:36px;height:36px}}.avatar{border-radius:var(--radius-lg);flex-shrink:0;position:relative;overflow:hidden}.avatar--sm{width:32px;height:32px}.avatar--md{width:48px;height:48px}.avatar--lg{width:64px;height:64px}.avatar--xl{width:96px;height:96px}.avatar__image{border-radius:var(--radius-lg);object-fit:cover;width:100%;height:100%}.avatar--speaking .avatar__image{box-shadow:0 0 0 2px var(--color-blue-600)}.avatar__speech-waves{align-items:center;gap:2px;display:flex;position:absolute;top:50%;right:-6px;transform:translateY(-50%)}.avatar__speech-waves span{background:var(--color-blue-600);border-radius:var(--radius-full);width:2px;animation:.8s ease-in-out infinite speechWave}.avatar__speech-waves span:first-child{height:6px;animation-delay:0s}.avatar__speech-waves span:nth-child(2){height:10px;animation-delay:.15s}.avatar__speech-waves span:nth-child(3){height:8px;animation-delay:.3s}@keyframes speechWave{0%,to{transform:scaleY(1)}50%{transform:scaleY(1.6)}}.narration-panel{background:var(--color-bg-card);border-radius:var(--radius-xl);border:1px solid #e8edf2;max-width:720px;margin:0 auto;overflow:hidden}.narration-header{align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid #e8edf2;flex-wrap:wrap;display:flex}.narration-header-text{flex:1;min-width:100px}.narration-header-text h4{font-size:var(--text-base);color:var(--color-text-primary);font-weight:600}.narration-subtitle{font-size:var(--text-xs);color:var(--color-text-muted)}.narration-actions{gap:var(--space-2);display:flex}.narration-content{padding:var(--space-5);gap:var(--space-2);flex-direction:column;max-height:460px;display:flex;overflow-y:auto}.narration-line{align-items:flex-start;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);transition:background var(--transition-fast);cursor:default;display:flex}.narration-line:hover{background:var(--color-bg-secondary)}.narration-line p{color:var(--color-text-primary);font-size:var(--text-sm);flex:1;line-height:1.7}.narration-line-tts{opacity:0;transition:opacity var(--transition-fast);margin-top:2px}.narration-line:hover .narration-line-tts{opacity:1}@keyframes speakingPulse{0%,to{box-shadow:0 0 #0d8bf233}50%{box-shadow:0 0 0 4px #0d8bf200}}.narration-line--speaking{border-left:2px solid var(--color-blue-600);border-radius:var(--radius-md);scroll-margin-top:80px;animation:1.5s ease-in-out infinite speakingPulse;background:var(--color-blue-100)!important}.narration-line--speaking p{color:var(--color-text-primary);font-weight:500}.narration-footer{padding:var(--space-4) var(--space-5);border-top:1px solid #e8edf2;justify-content:center;display:flex}@media (width<=600px){.narration-header{padding:var(--space-3)}.narration-content{padding:var(--space-3);max-height:360px}}@keyframes highlightPulse{0%{box-shadow:0 0 #0d8bf24d}50%{box-shadow:0 0 0 6px #0d8bf200}to{box-shadow:0 0 #0d8bf200}}.narration-line--highlight{border-left:2px solid var(--color-blue-500);border-radius:var(--radius-md);scroll-margin-top:80px;animation:1.8s ease-out .3s 2 highlightPulse;background:var(--color-blue-100)!important}.narration-line--highlight p{color:var(--color-text-primary)}.narration-highlight-banner{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);background:var(--color-blue-100);border-bottom:1px solid var(--color-blue-200);font-size:var(--text-xs);color:var(--color-blue-600);font-weight:500;display:flex}.video-player{border-radius:var(--radius-xl);background:var(--color-bg-card);margin:var(--space-3) 0;border:1px solid #e8edf2;overflow:hidden}.video-player__header{padding:var(--space-3) var(--space-4);border-bottom:1px solid #e8edf2;justify-content:space-between;align-items:center;display:flex}.video-player__title{font-size:var(--text-sm);color:var(--color-text-primary);font-weight:500}.video-player__container{background:#0a0a0a;width:100%;padding-top:56.25%;position:relative}.video-player__iframe{border:none;width:100%;height:100%;position:absolute;top:0;left:0}.video-player__footer{align-items:center;gap:var(--space-2);padding:var(--space-3);border-top:1px solid #e8edf2;flex-direction:column;display:flex}.video-player__tail-hint{font-size:var(--text-sm);color:var(--color-text-muted);text-align:center;margin:0}.video-player--placeholder{background:var(--color-bg-secondary);justify-content:center;align-items:center;min-height:280px;display:flex}.video-placeholder-inner{text-align:center;padding:var(--space-6);color:var(--color-text-muted);align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.video-placeholder-inner h4{color:var(--color-text-primary)}.video-placeholder-note{font-size:var(--text-sm);max-width:320px}.video-placeholder-actions{gap:var(--space-3);flex-wrap:wrap;justify-content:center;display:flex}.video-player--done{background:#10b9810a;border-color:#10b98126;justify-content:center;align-items:center;min-height:60px;display:flex}.video-done-badge{font-size:var(--text-base);color:var(--color-success);font-weight:500}.quiz-question{gap:var(--space-4);padding:var(--space-1) 0;flex-direction:column;display:flex}.quiz-question__text{align-items:flex-start;gap:var(--space-2);display:flex}.quiz-question__text p{font-size:var(--text-base);color:var(--color-text-primary);flex:1;font-weight:500;line-height:1.5}.mc-options{gap:var(--space-2);flex-direction:column;display:flex}.mc-option{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);background:var(--color-bg-card);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%;font-size:var(--text-sm);color:var(--color-text-primary);border:1.5px solid #e8edf2;display:flex}.mc-option:hover:not(:disabled){border-color:var(--color-blue-300);background:var(--color-bg-card-hover)}.mc-option--selected{border-color:var(--color-blue-500);background:var(--color-blue-100)}.mc-option--correct{border-color:var(--color-success)!important;background:#10b9810f!important}.mc-option--wrong{animation:.4s ease-in-out shake;border-color:var(--color-danger)!important;background:var(--color-danger-bg)!important}.mc-option__letter{border-radius:var(--radius-full);background:var(--color-bg-secondary);width:28px;height:28px;font-weight:600;font-size:var(--text-xs);color:var(--color-text-secondary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.mc-option--correct .mc-option__letter{background:var(--color-success);color:#fff}.mc-option--wrong .mc-option__letter{background:var(--color-danger);color:#fff}.mc-option--unknown{border-style:dashed}.mc-option__text{flex:1}.fill-blank__option--unknown{border-style:dashed;font-style:italic}.mc-icon{flex-shrink:0}.mc-icon--correct{color:var(--color-success)}.mc-icon--wrong{color:var(--color-danger)}.quiz-feedback{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-weight:500;font-size:var(--text-sm);display:flex}.quiz-feedback--correct{color:var(--color-success);background:#10b9810f;border:1px solid #10b98126}.quiz-feedback--wrong{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid #ef444426}.quiz-hint-btn{align-items:center;gap:var(--space-2);color:var(--color-text-muted);font-size:var(--text-sm);cursor:pointer;padding:var(--space-2);background:0 0;border:none;font-weight:500;display:inline-flex}.quiz-hint-btn:hover{color:var(--color-blue-600)}.quiz-hint{padding:var(--space-3) var(--space-4);background:var(--color-bg-secondary);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--text-sm);overflow:hidden}.drag-match{gap:var(--space-3);align-items:flex-start;display:flex}.drag-match__col{gap:var(--space-2);flex-direction:column;flex:1;display:flex}.drag-match__arrows{gap:var(--space-2);flex-direction:column;justify-content:center;align-items:center;padding-top:2px;display:flex}.drag-match__arrow{height:44px;color:var(--color-text-muted);opacity:.2;transition:all var(--transition-fast);align-items:center;display:flex}.drag-match__arrow--active{color:var(--color-success);opacity:1}.drag-match__item{padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);background:var(--color-bg-card);cursor:pointer;transition:all var(--transition-fast);font-size:var(--text-sm);color:var(--color-text-primary);align-items:center;gap:var(--space-2);text-align:left;border:1.5px solid #e8edf2;width:100%;min-height:44px;font-weight:500;display:flex}.drag-match__item--selected{border-color:var(--color-blue-500);background:var(--color-blue-100)}.drag-match__item--available{border-color:var(--color-blue-200);cursor:pointer}.drag-match__item--available:hover{border-color:var(--color-blue-400);background:var(--color-blue-100)}.drag-match__item--matched{border-color:var(--color-success);cursor:default;opacity:.7;background:#10b9810a}.drag-match__item--wrong{border-color:var(--color-danger);background:var(--color-danger-bg)}.fill-blank__sentence{font-size:var(--text-base);color:var(--color-text-primary);line-height:1.8}.fill-blank__slot{border-bottom:2px solid var(--color-blue-600);color:var(--color-blue-600);text-align:center;min-width:60px;transition:all var(--transition-fast);margin:0 3px;padding:1px 12px;font-weight:600;display:inline-block}.fill-blank__slot--correct{border-color:var(--color-success);color:var(--color-success);border-radius:var(--radius-sm);background:#10b9810a}.fill-blank__slot--wrong{border-color:var(--color-danger);color:var(--color-danger);background:var(--color-danger-bg);border-radius:var(--radius-sm)}.fill-blank__options{gap:var(--space-2);flex-wrap:wrap;display:flex}.fill-blank__option{padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);background:var(--color-bg-card);color:var(--color-text-primary);font-weight:500;font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);border:1.5px solid #e8edf2}.fill-blank__option:hover:not(:disabled){border-color:var(--color-blue-400);background:var(--color-blue-100)}.fill-blank__option--correct{border-color:var(--color-success)!important;color:var(--color-success)!important;background:#10b9810f!important}.fill-blank__option--wrong{border-color:var(--color-danger)!important;background:var(--color-danger-bg)!important;color:var(--color-danger)!important}.flashcard-header{align-items:center;gap:var(--space-3);display:flex}.flashcard-count{font-size:var(--text-sm);color:var(--color-text-muted);white-space:nowrap;font-weight:500}.flashcard-container{perspective:1200px;cursor:pointer;min-height:180px}.flashcard{padding:var(--space-6);border-radius:var(--radius-xl);text-align:center;justify-content:center;align-items:center;gap:var(--space-3);flex-direction:column;min-height:180px;display:flex}.flashcard--front{background:var(--color-bg-card);border:1.5px solid #e8edf2}.flashcard--back{background:var(--color-blue-100);border:1.5px solid var(--color-blue-200)}.flashcard__label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.flashcard__content{align-items:center;gap:var(--space-2);display:flex}.flashcard__content p{font-size:var(--text-lg);color:var(--color-text-primary);font-weight:500}.flashcard__tap-hint{align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--color-text-muted);display:flex}.flashcard-actions{gap:var(--space-3);justify-content:center;display:flex}.flashcard-btn{flex:1;max-width:180px}.flashcard-complete{text-align:center;padding:var(--space-6);align-items:center}.flashcard-complete h3{color:var(--color-success)}@media (width<=600px){.drag-match{flex-direction:column}.drag-match__arrows{gap:var(--space-2);flex-direction:row;transform:rotate(90deg)}.drag-match__arrow{height:auto}.flashcard-actions{flex-direction:column;align-items:center}}.quiz-engine{gap:var(--space-3);flex-direction:column;max-width:640px;margin:0 auto;display:flex}.quiz-engine__header{justify-content:space-between;align-items:center;display:flex}.quiz-engine__title{font-size:var(--text-lg);color:var(--color-text-primary);font-weight:600}.quiz-engine__duration{font-size:var(--text-sm);color:var(--color-text-muted)}.quiz-engine__section{font-size:var(--text-sm);color:var(--color-blue-600);margin:4px 0 0;font-weight:500}.quiz-engine__counter{font-size:var(--text-xs);color:var(--color-text-muted);text-align:center}.quiz-engine__body{min-height:280px}.quiz-results{text-align:center;align-items:center;gap:var(--space-4);max-width:440px;padding:var(--space-6);flex-direction:column;margin:0 auto;display:flex}.quiz-results__title{font-size:var(--text-2xl);color:var(--color-text-primary)}.quiz-results__score{flex-direction:column;align-items:center;display:flex}.quiz-results__number{font-size:var(--text-4xl);color:var(--color-blue-600);font-weight:700}.quiz-results__detail{color:var(--color-text-muted);font-size:var(--text-sm)}.quiz-results__stars{gap:var(--space-2);display:flex}.quiz-star--earned{color:var(--color-gold-500)}.quiz-star--empty{color:#d0d8e0}.quiz-results__xp{align-items:center;gap:var(--space-2);color:var(--color-blue-600);font-weight:600;font-size:var(--text-base);display:flex}.quiz-results__actions{gap:var(--space-3);flex-wrap:wrap;justify-content:center;display:flex}.lesson-page{min-height:calc(100vh - 56px)}.lesson-topbar{background:var(--color-bg-secondary);padding:var(--space-3) 0;margin-bottom:var(--space-5);border-bottom:1px solid #e8edf2}.lesson-topbar__inner{align-items:center;gap:var(--space-3);margin-bottom:var(--space-2);display:flex}.lesson-topbar__info{align-items:center;gap:var(--space-2);flex:1;display:flex}.lesson-topbar__chapter{font-size:var(--text-xs);background:var(--color-blue-100);border-radius:var(--radius-sm);color:var(--color-blue-600);padding:1px 6px;font-weight:500}.lesson-topbar__title{color:var(--color-text-primary);font-weight:500;font-size:var(--text-sm)}.lesson-steps{gap:var(--space-4);margin-bottom:var(--space-2);display:flex}.lesson-step{align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--color-text-muted);transition:color var(--transition-fast);font-weight:500;display:flex}.lesson-step--active{color:var(--color-blue-600)}.lesson-step--done{color:var(--color-success)}.lesson-content{padding-top:var(--space-3);padding-bottom:var(--space-16)}.lesson-video-section{gap:var(--space-3);flex-direction:column;display:flex}.lesson-video-counter{text-align:center;font-size:var(--text-sm);color:var(--color-text-muted);font-weight:500}.lesson-complete{text-align:center;align-items:center;gap:var(--space-4);padding:var(--space-12) var(--space-6);flex-direction:column;display:flex}.lesson-complete__icon{font-size:3rem}.lesson-complete h2{font-size:var(--text-2xl);color:var(--color-text-primary)}.lesson-complete p{color:var(--color-text-secondary)}.lesson-complete__actions{align-items:center;gap:var(--space-3);flex-direction:column;width:100%;max-width:360px;display:flex}@media (width<=600px){.lesson-steps{gap:var(--space-2)}.lesson-step span{display:none}}.assignment-panel{border-radius:var(--radius-2xl);padding:var(--space-8);box-shadow:var(--shadow-xl);background:#fff;border:1px solid #e8edf2;position:relative;overflow:hidden}.assignment-panel:before{content:"";background:linear-gradient(to right, var(--color-gold-400), var(--color-gold-600));height:6px;position:absolute;top:0;left:0;right:0}.assignment-panel__header{align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid #e8edf2;display:flex}.assignment-panel__icon{color:var(--color-gold-500)}.assignment-panel__title{font-size:var(--text-2xl);color:var(--color-text-primary);flex:1;margin:0}.assignment-panel__tts{flex-shrink:0}.assignment-panel__content{font-size:var(--text-lg);color:var(--color-text-primary);max-height:50vh;padding-right:var(--space-4);margin-bottom:var(--space-8);line-height:1.7;overflow-y:auto}.assignment-panel__content p{margin-bottom:var(--space-4)}.assignment-panel__content::-webkit-scrollbar{width:6px}.assignment-panel__content::-webkit-scrollbar-track{background:0 0}.assignment-panel__content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.assignment-panel__content::-webkit-scrollbar-thumb:hover{background:#94a3b8}.assignment-panel__footer{padding-top:var(--space-4);justify-content:center;align-items:center;display:flex}.assignment-panel__form{gap:var(--space-4);flex-direction:column;width:100%;max-width:400px;display:flex}.assignment-panel__input-wrapper{position:relative}.assignment-panel__input-wrapper .input-icon{color:var(--color-text-muted);position:absolute;top:50%;left:16px;transform:translateY(-50%)}.assignment-panel__input{border-radius:var(--radius-lg);width:100%;font-size:var(--text-base);text-transform:uppercase;border:2px solid #e8edf2;padding:14px 16px 14px 44px;font-family:monospace;transition:all .2s}.assignment-panel__input:focus{border-color:var(--color-gold-500);outline:none;box-shadow:0 0 0 4px #f59e0b1a}.assignment-panel__input.error{border-color:var(--color-red-500);animation:.4s ease-in-out shake}.assignment-panel__progress{text-align:center;font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-4);font-weight:500}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-3px)}80%{transform:translate(3px)}}.login-page{background:var(--color-bg-primary);min-height:100vh;padding:var(--space-4);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.login-page__bg{pointer-events:none;position:absolute;inset:0;overflow:hidden}.login-page__circle{opacity:.06;border-radius:50%;position:absolute}.login-page__circle--1{background:var(--color-blue-500);width:500px;height:500px;animation:8s ease-in-out infinite float;top:-120px;right:-100px}.login-page__circle--2{background:var(--color-green-500);width:350px;height:350px;animation:10s ease-in-out infinite reverse float;bottom:-80px;left:-60px}.login-page__circle--3{background:var(--color-gold-400);width:200px;height:200px;animation:12s ease-in-out infinite float;top:40%;left:15%}.login-card{z-index:1;border-radius:var(--radius-2xl);padding:var(--space-10) var(--space-8);text-align:center;width:100%;max-width:420px;box-shadow:var(--shadow-lg);background:#fff;border:1px solid #e8edf2;position:relative}.login-card__logo{margin-bottom:var(--space-5);justify-content:center;display:flex}.login-card__logo-img{border-radius:var(--radius-xl);object-fit:cover;width:72px;height:72px;box-shadow:var(--shadow-md)}.login-card__title{font-size:var(--text-2xl);color:var(--color-text-primary);margin-bottom:var(--space-2);font-weight:700;line-height:1.2}.login-card__subtitle{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-8);line-height:1.5}.login-card__error{background:var(--color-danger-bg);color:var(--color-danger);font-size:var(--text-sm);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);margin-bottom:var(--space-4);border:1px solid #ef44441a}.login-btn{justify-content:center;align-items:center;gap:var(--space-3);width:100%;padding:14px var(--space-5);border-radius:var(--radius-lg);font-size:var(--text-base);font-weight:500;font-family:var(--font-body);cursor:pointer;transition:all var(--transition-fast);border:none;display:flex}.login-btn:active{transform:scale(.98)}.login-btn--google{color:var(--color-text-primary);box-shadow:var(--shadow-sm);background:#fff;border:1.5px solid #d0d8e0}.login-btn--google:hover{box-shadow:var(--shadow-md);background:#f7f9fc;border-color:#b0b8c0}.login-btn--google:disabled{opacity:.6;cursor:not-allowed}.login-btn__google-icon{flex-shrink:0}.login-btn__spinner{border:2px solid #d0d8e0;border-top-color:var(--color-blue-600);border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}.login-card__divider{align-items:center;gap:var(--space-3);margin:var(--space-5) 0;display:flex}.login-card__divider:before,.login-card__divider:after{content:"";background:#e8edf2;flex:1;height:1px}.login-card__divider span{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.login-btn--guest{color:var(--color-text-secondary);background:0 0;border:1.5px solid #e8edf2}.login-btn--guest:hover{background:var(--color-bg-secondary);color:var(--color-text-primary);border-color:#d0d8e0}.login-card__disclaimer{margin-top:var(--space-4);font-size:var(--text-xs);color:var(--color-text-muted);line-height:1.5}@media (width<=480px){.login-card{padding:var(--space-6) var(--space-5)}.login-card__title{font-size:var(--text-xl)}}.da-page{min-height:100vh;padding:var(--space-6);background:var(--color-bg-secondary);justify-content:center;align-items:center;display:flex}.da-card{text-align:center;width:100%;max-width:500px;animation:.4s ease-out fadeInUp}.da-card--large{text-align:left;max-width:800px}.da-title{margin-bottom:var(--space-2);color:var(--color-text-primary)}.da-subtitle{color:var(--color-text-secondary);margin-bottom:var(--space-8);font-size:var(--text-sm)}.da-pin-group{justify-content:center;gap:var(--space-4);margin-bottom:var(--space-8);display:flex}.da-pin-input{width:50px;height:60px;font-size:var(--text-3xl);text-align:center;border:2px solid var(--color-blue-200);border-radius:var(--radius-md);transition:border-color var(--transition-fast);background:#fff}.da-pin-input:focus{border-color:var(--color-blue-500);outline:none}.da-form-section{padding:var(--space-6) 0;border-bottom:1px solid var(--color-blue-100)}.da-form-section:last-child{border-bottom:none}.da-section-title{font-size:var(--text-lg);margin-bottom:var(--space-4);color:var(--color-blue-600);border-left:4px solid var(--color-blue-500);padding-left:var(--space-3)}.da-field{margin-bottom:var(--space-6)}.da-field--error .da-input,.da-field--error .da-radio-option,.da-field--error.da-field .da-checkbox{border-color:var(--color-danger)}.da-field--error .da-label,.da-field--error .da-checkbox span{color:var(--color-danger)}.da-field-error{margin:var(--space-2) 0 0;font-size:var(--text-sm);color:var(--color-danger);font-weight:500}.da-label{margin-bottom:var(--space-2);color:var(--color-text-primary);font-weight:600;font-size:var(--text-sm);display:block}.da-input{width:100%;padding:var(--space-3);border:1.5px solid var(--color-blue-200);border-radius:var(--radius-md);font-size:var(--text-base);transition:border-color var(--transition-fast)}.da-input:focus{border-color:var(--color-blue-500);outline:none}.da-radio-group{gap:var(--space-2);flex-direction:column;display:flex}.da-radio-option{align-items:center;gap:var(--space-3);padding:var(--space-3);border:1px solid var(--color-blue-100);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);display:flex}.da-radio-option:hover{background:var(--color-blue-100)}.da-radio-option input{width:18px;height:18px}.da-checkbox{align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);cursor:pointer;display:flex}.da-checkbox input{width:20px;height:20px}.da-table-container{margin:var(--space-6) 0;border-radius:var(--radius-md);border:1px solid var(--color-blue-100);overflow-x:auto}.da-table{border-collapse:collapse;width:100%;font-size:var(--text-xs);text-align:left}.da-table th{background:var(--color-bg-secondary);padding:var(--space-3);border-bottom:2px solid var(--color-blue-100);white-space:nowrap}.da-table td{padding:var(--space-3);border-bottom:1px solid var(--color-blue-100);white-space:nowrap}.da-table tr:last-child td{border-bottom:none}.da-error{color:var(--color-danger);background:var(--color-danger-bg);padding:var(--space-3);border-radius:var(--radius-md);margin-bottom:var(--space-4);font-size:var(--text-sm)}@media (width<=600px){.da-page,.da-card{padding:var(--space-4)}}.app{flex-direction:column;min-height:100vh;display:flex}.app-main{flex:1;padding-top:56px}.app-loading{justify-content:center;align-items:center;gap:var(--space-4);min-height:60vh;color:var(--color-text-muted);font-size:var(--text-sm);flex-direction:column;display:flex}.app-loading__spinner{border:3px solid #e8edf2;border-top-color:var(--color-blue-600);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}:root{--color-bg-primary:#fff;--color-bg-secondary:#f7f9fc;--color-bg-card:#fff;--color-bg-card-hover:#f5f8fb;--color-bg-elevated:#f0f4f8;--color-bg-input:#f7f9fc;--color-blue-700:#0969c8;--color-blue-600:#0d8bf2;--color-blue-500:#2e9bf5;--color-blue-400:#5cb3f7;--color-blue-300:#8ecbfa;--color-blue-200:#c0e1fc;--color-blue-100:#e5f2fe;--color-green-500:#34d399;--color-green-400:#5eead4;--color-green-300:#a7f3d0;--color-green-200:#d1fae5;--color-gold-500:#f59e0b;--color-gold-400:#fbbf24;--color-gold-300:#fcd34d;--color-orange-500:#f97316;--color-orange-600:#ea580c;--color-brown-600:#78350f;--color-brown-500:#92400e;--color-brown-400:#b45309;--color-text-primary:#1a2332;--color-text-secondary:#5a6a7e;--color-text-muted:#9aa8b8;--color-text-accent:#0d8bf2;--color-danger:#ef4444;--color-danger-bg:#ef44440f;--color-success:#10b981;--color-success-bg:#10b9810f;--color-warning:#f59e0b;--gradient-primary:linear-gradient(135deg, #0d8bf2, #2e9bf5);--gradient-gold:linear-gradient(135deg, #f59e0b, #fbbf24);--gradient-hero:linear-gradient(180deg, #fff 0%, #f0f4f8 100%);--gradient-card:linear-gradient(145deg, #fff, #fafcfe);--gradient-glow:radial-gradient(circle at 50% 50%, #0d8bf20a, transparent 70%);--font-heading:"Inter", sans-serif;--font-body:"Inter", sans-serif;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--radius-sm:.25rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-2xl:1.25rem;--radius-full:9999px;--shadow-sm:0 1px 2px #0000000a;--shadow-md:0 2px 8px #0000000f;--shadow-lg:0 4px 16px #0000000f;--shadow-xl:0 8px 32px #00000014;--shadow-glow-green:none;--shadow-glow-blue:none;--shadow-glow-gold:none;--transition-fast:.15s ease;--transition-base:.2s ease;--transition-slow:.3s ease;--transition-spring:.3s ease;--z-base:1;--z-dropdown:10;--z-sticky:20;--z-modal:50;--z-chat:60;--z-toast:70}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text-primary);background:var(--color-bg-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--color-text-primary);font-weight:600;line-height:1.3}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}a{color:var(--color-blue-600);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-blue-700)}img{max-width:100%;height:auto;display:block}button{font-family:var(--font-body);cursor:pointer;font-size:var(--text-base);background:0 0;border:none;outline:none}.container{width:100%;max-width:1080px;padding:0 var(--space-6);margin:0 auto}.container-narrow{max-width:720px;padding:0 var(--space-6);margin:0 auto}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-lg);font-weight:500;font-size:var(--text-sm);transition:all var(--transition-fast);display:inline-flex;position:relative}.btn:active{transform:scale(.98)}.btn-primary{background:var(--color-blue-600);color:#fff}.btn-primary:hover{background:var(--color-blue-700)}.btn-gold{background:var(--color-gold-500);color:#fff}.btn-gold:hover{background:#e8920a}.btn-outline{border:1.5px solid var(--color-blue-300);color:var(--color-blue-600);background:0 0}.btn-outline:hover{background:var(--color-blue-100);border-color:var(--color-blue-400)}.btn-ghost{color:var(--color-text-secondary);background:0 0}.btn-ghost:hover{color:var(--color-text-primary);background:var(--color-bg-secondary)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--text-base)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-sm)}.btn-icon{border-radius:var(--radius-full);justify-content:center;align-items:center;width:36px;height:36px;padding:0;display:flex}.card{background:var(--color-bg-card);border-radius:var(--radius-xl);padding:var(--space-5);transition:border-color var(--transition-fast);border:1px solid #e8edf2}.card:hover{border-color:var(--color-blue-200)}.card-glass{-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-xl);padding:var(--space-5);background:#ffffffe6;border:1px solid #e8edf2}.badge{align-items:center;gap:var(--space-1);padding:2px var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:500;display:inline-flex}.badge-green{color:var(--color-success);background:#10b98114}.badge-gold{color:var(--color-gold-500);background:#f59e0b14}.badge-orange{color:var(--color-orange-500);background:#f9731614}.progress-track{border-radius:var(--radius-full);background:#e8edf2;width:100%;height:4px;overflow:hidden}.progress-fill{background:var(--color-blue-600);border-radius:var(--radius-full);height:100%;transition:width var(--transition-slow)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.03)}}@keyframes pulseGlow{0%,to{box-shadow:0 0 #0d8bf233}50%{box-shadow:0 0 0 8px #0d8bf200}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes spin{to{transform:rotate(360deg)}}.animate-fade-in{animation:.4s ease-out fadeIn}.animate-fade-in-up{animation:.4s ease-out fadeInUp}.animate-bounce{animation:2s ease-in-out infinite bounce}.animate-pulse{animation:2s ease-in-out infinite pulse}.animate-pulse-glow{animation:2s ease-in-out infinite pulseGlow}.animate-float{animation:4s ease-in-out infinite float}.animate-shake{animation:.4s ease-in-out shake}.animate-spin{animation:1s linear infinite spin}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#d0d8e0}::-webkit-scrollbar-thumb:hover{background:#b0b8c0}@media (width<=768px){h1{font-size:var(--text-2xl)}h2{font-size:var(--text-xl)}h3{font-size:var(--text-lg)}.container,.container-narrow{padding:0 var(--space-4)}}@media (width<=480px){h1{font-size:var(--text-xl)}h2{font-size:var(--text-lg)}}::selection{color:var(--color-text-primary);background:#0d8bf21f}
