@import "https://fonts.googleapis.com/css2?family=Coiny&family=Nunito:wght@300;400;500;600;700;800&display=swap";:root{--pink:#ffe5ec;--pink-deep:#ff8fab;--yellow:#fff4d6;--yellow-deep:#f4c430;--green:#ddf4e7;--green-deep:#48bb78;--blue:#dceeff;--blue-deep:#4299e1;--purple:#fff0f5;--purple-deep:#e91e7b;--bg:#faf9fb;--surface:#fff;--surface-hover:#f8f7fa;--text:#2d3748;--text-secondary:#718096;--text-muted:#a0aec0;--border:#edf2f7;--border-light:#f7fafc;--accent:#e91e7b;--accent-light:#f472a8;--success:#38a169;--warning:#dd6b20;--danger:#e53e3e;--sidebar-w:260px;--topbar-h:64px;--radius:14px;--radius-sm:8px;--radius-lg:20px;--shadow-sm:0 2px 4px #00000005;--shadow:0 6px 18px #0000000a;--shadow-lg:0 10px 30px #0000000f;--shadow-glow:0 0 20px #e91e7b1f}*{box-sizing:border-box;margin:0;padding:0}button,input,select,textarea{font-family:inherit}body{background:var(--bg);color:var(--text);font-family:Nunito,-apple-system,sans-serif;font-weight:500;line-height:1.6;overflow-x:hidden}.app-layout{min-height:100vh;display:flex}.sidebar{display:none!important}.sidebar-logo{border-bottom:1px solid var(--border-light);align-items:center;gap:12px;padding:20px 24px;display:flex}.logo-icon{background:linear-gradient(135deg, var(--pink-deep), var(--purple-deep));color:#fff;border-radius:12px;justify-content:center;align-items:center;width:42px;height:42px;font-family:Coiny,cursive;font-size:20px;display:flex}.logo-text{background:linear-gradient(135deg, var(--pink-deep), var(--accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-family:Coiny,cursive;font-size:18px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px;display:flex;overflow-y:auto}.nav-item{border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:11px 16px;font-family:inherit;font-size:14px;font-weight:500;transition:all .2s;display:flex}.nav-item:hover{background:var(--surface-hover);color:var(--text)}.nav-item.active{color:var(--accent);background:linear-gradient(135deg,#e91e7b14,#f472a814);font-weight:600}.nav-item.active .nav-icon{color:var(--accent)}.nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:18px;display:flex}.sidebar-footer{border-top:1px solid var(--border-light);padding:16px}.user-profile{border-radius:var(--radius-sm);align-items:center;gap:12px;padding:8px;display:flex}.user-avatar{background:linear-gradient(135deg, var(--green-deep), var(--blue-deep));color:#fff;border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;font-size:16px;font-weight:700;display:flex}.user-info{flex-direction:column;display:flex}.user-name{font-size:13px;font-weight:600}.user-level{color:var(--text-muted);font-size:11px}.main-content{flex:1;max-width:100vw;min-height:100vh;margin-left:0;transition:margin-left .3s cubic-bezier(.4,0,.2,1);overflow-x:hidden}.topbar{height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--border-light);z-index:50;align-items:center;gap:clamp(6px,1.5vw,16px);padding:0 clamp(8px,2vw,28px);display:flex;position:sticky;top:0}.menu-toggle{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;width:36px;height:36px;color:var(--text-secondary);justify-content:center;align-items:center;transition:all .2s;display:flex}.menu-toggle:hover{background:var(--surface-hover);color:var(--accent);border-color:var(--accent-light)}@media (width>=769px){.app-layout.sidebar-collapsed .sidebar{transform:translate(-100%)}.app-layout.sidebar-collapsed .main-content{margin-left:0}}.search-box{background:var(--bg);border-radius:10px;flex:1;align-items:center;gap:8px;min-width:0;max-width:480px;padding:0 14px;display:flex}.search-box input{color:var(--text);background:0 0;border:none;outline:none;flex:1;padding:10px 0;font-family:inherit;font-size:14px}.search-icon{color:var(--text-muted);flex-shrink:0;font-size:16px}.topbar-actions{flex-shrink:0;align-items:center;gap:clamp(4px,1vw,12px);margin-left:auto;display:flex}.notif-btn{cursor:pointer;background:0 0;border:none;padding:6px;font-size:20px;position:relative}.notif-badge{background:var(--danger);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:10px;font-weight:700;display:flex;position:absolute;top:0;right:0}.page-content{padding:clamp(10px,3vw,28px);animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-title{color:var(--text);margin-bottom:4px;font-family:Coiny,cursive;font-size:clamp(18px,4vw,26px)}.page-subtitle{color:var(--text-secondary);margin-bottom:clamp(12px,3vw,24px);font-size:clamp(12px,2vw,14px)}.card{background:var(--surface);border-radius:var(--radius);border:2px solid #e2e8f0;padding:24px;transition:box-shadow .2s,transform .2s;box-shadow:0 8px 24px #959da51f,0 2px 8px #0000000a}.card:hover{box-shadow:0 12px 28px #00000017,0 3px 8px #0000000d}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{font-size:16px;font-weight:700}.card-badge{border-radius:20px;padding:4px 12px;font-size:11px;font-weight:600}.grid-2{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:20px;display:grid}.grid-auto{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;display:grid}.stat-card{border-radius:var(--radius);background:var(--surface);border:1px solid var(--border-light);align-items:center;gap:16px;padding:20px;transition:transform .2s;display:flex}.stat-card:hover{transform:translateY(-2px)}.stat-icon{border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;display:flex}.stat-value{font-size:24px;font-weight:800;line-height:1}.stat-label{color:var(--text-secondary);margin-top:2px;font-size:13px}.progress-bar{background:var(--border-light);border-radius:4px;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--accent), var(--accent-light));border-radius:4px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.btn{border-radius:var(--radius-sm);cursor:pointer;border:none;align-items:center;gap:8px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--accent), var(--accent-light));color:#fff;box-shadow:0 4px 12px #e91e7b4d}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #e91e7b66}.btn-secondary{background:var(--bg);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--surface-hover)}.btn-sm{padding:6px 14px;font-size:12px}.btn-lg{padding:14px 28px;font-size:16px}.tag{border-radius:20px;align-items:center;gap:4px;padding:4px 12px;font-size:12px;font-weight:600;display:inline-flex}.tag-pink{background:var(--pink);color:var(--pink-deep)}.tag-green{background:var(--green);color:var(--green-deep)}.tag-blue{background:var(--blue);color:var(--blue-deep)}.tag-yellow{background:var(--yellow);color:var(--yellow-deep)}.tag-purple{background:var(--purple);color:var(--purple-deep)}.quest-item{border-radius:var(--radius-sm);background:var(--bg);align-items:center;gap:14px;padding:14px 16px;transition:background .2s;display:flex}.quest-item:hover{background:var(--surface-hover)}.quest-icon{font-size:24px}.quest-info{flex:1}.quest-title{font-size:14px;font-weight:600}.quest-progress-text{color:var(--text-muted);font-size:12px}.quest-xp{color:var(--accent);font-size:13px;font-weight:700}.continue-item{border-radius:var(--radius-sm);background:var(--bg);cursor:pointer;align-items:center;gap:14px;padding:16px;transition:all .2s;display:flex}.continue-item:hover{background:var(--surface-hover);transform:translate(4px)}.continue-icon{font-size:28px}.continue-info{flex:1}.continue-title{font-size:14px;font-weight:600}.continue-sub{color:var(--text-muted);font-size:12px}.flashcard-container{perspective:1000px;cursor:pointer;width:100%;max-width:480px;height:320px;margin:0 auto}.flashcard{width:100%;height:100%;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.4,0,.2,1);position:relative}.flashcard.flipped{transform:rotateY(180deg)}.flashcard-front,.flashcard-back{backface-visibility:hidden;border-radius:var(--radius-lg);box-shadow:var(--shadow);flex-direction:column;justify-content:center;align-items:center;padding:32px;display:flex;position:absolute;inset:0}.flashcard-front{color:#fff;background:linear-gradient(135deg,#6c5ce7,#a29bfe)}.flashcard-back{background:var(--surface);border:2px solid var(--border-light);transform:rotateY(180deg)}.flashcard-word{margin-bottom:12px;font-family:Coiny,cursive;font-size:48px}.flashcard-pronunciation{opacity:.8;margin-bottom:8px;font-size:18px}.flashcard-type{background:#fff3;border-radius:20px;padding:4px 14px;font-size:13px}.flashcard-meaning{color:var(--accent);margin-bottom:16px;font-size:28px;font-weight:700}.flashcard-example{text-align:center;color:var(--text-secondary);font-size:14px;line-height:1.8}.hangul-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:10px;display:grid}.hangul-cell{aspect-ratio:1;background:var(--surface);border:2px solid var(--border-light);border-radius:var(--radius-sm);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:4px;transition:all .2s;display:flex}.hangul-cell:hover{border-color:var(--accent);box-shadow:var(--shadow-glow);transform:scale(1.08)}.hangul-cell.active{border-color:var(--accent);background:var(--purple)}.hangul-char{font-size:32px;font-weight:700}.hangul-rom{color:var(--text-muted);font-size:11px}.grammar-card{background:var(--surface);border-radius:var(--radius);cursor:pointer;border:2px solid #e2e8f0;padding:24px;transition:all .25s;box-shadow:0 8px 24px #959da51f,0 2px 8px #0000000a}.grammar-card:hover{border-color:var(--accent);box-shadow:0 10px 24px #00000014, 0 3px 6px #0000000a, var(--shadow-glow);transform:translateY(-3px)}.grammar-pattern{color:var(--accent);margin-bottom:6px;font-size:24px;font-weight:800}.grammar-name{margin-bottom:8px;font-size:15px;font-weight:600}.grammar-formula{color:var(--text-secondary);background:var(--bg);border-radius:var(--radius-sm);padding:8px 12px;font-size:13px}.exercise-box{background:var(--bg);border-radius:var(--radius);margin-top:16px;padding:24px}.exercise-question{margin-bottom:16px;font-size:18px;font-weight:600}.exercise-input{border:2px solid var(--border);border-radius:var(--radius-sm);outline:none;width:100%;padding:12px 16px;font-family:inherit;font-size:16px;transition:border-color .2s}.exercise-input:focus{border-color:var(--accent)}.exercise-input.correct{border-color:var(--success);background:#f0fff4}.exercise-input.wrong{border-color:var(--danger);background:#fff5f5}.exercise-hint{color:var(--text-muted);margin-top:8px;font-size:13px;font-style:italic}.ai-fab{background:linear-gradient(135deg, var(--accent), var(--pink-deep));cursor:pointer;z-index:200;color:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:24px;transition:transform .2s;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 20px #e91e7b66}.ai-fab:hover{transform:scale(1.1)}.ai-widget{background:var(--surface);border-radius:var(--radius-lg);width:360px;height:480px;box-shadow:var(--shadow-lg);z-index:200;opacity:0;pointer-events:none;flex-direction:column;transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;bottom:92px;right:24px;transform:scale(.9)}.ai-widget.open{opacity:1;pointer-events:all;transform:scale(1)}.ai-widget-header{border-bottom:1px solid var(--border-light);align-items:center;gap:10px;padding:16px 20px;font-weight:600;display:flex}.ai-avatar-small{background:linear-gradient(135deg, var(--accent), var(--pink-deep));border-radius:10px;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex}.ai-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;margin-left:auto;padding:4px;font-size:18px}.ai-chat-body{flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.ai-msg{border-radius:14px;max-width:85%;padding:12px 16px;font-size:14px;line-height:1.5}.ai-msg.bot{background:var(--bg);border-bottom-left-radius:4px;align-self:flex-start}.ai-msg.user{background:var(--accent);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}.ai-input-area{border-top:1px solid var(--border-light);gap:8px;padding:12px 16px;display:flex}.ai-input{border:1px solid var(--border);border-radius:10px;outline:none;flex:1;padding:10px 14px;font-family:inherit;font-size:14px}.ai-input:focus{border-color:var(--accent)}.ai-send{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:10px;width:40px;height:40px;font-size:18px;transition:background .2s}.ai-send:hover{background:var(--accent-light)}.tab-group{background:var(--bg);white-space:nowrap;scrollbar-width:none;border-radius:10px;gap:4px;margin-bottom:20px;padding:4px;display:flex;overflow-x:auto}.tab-group::-webkit-scrollbar{display:none}.tab-btn{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-radius:8px;flex-shrink:0;padding:8px 18px;font-family:inherit;font-size:13px;font-weight:500;transition:all .2s}.tab-btn.active{background:var(--surface);color:var(--accent);box-shadow:var(--shadow-sm);font-weight:600}.badge-item{border-radius:var(--radius-sm);background:var(--bg);text-align:center;flex-direction:column;align-items:center;gap:6px;padding:16px;display:flex}.badge-icon{font-size:32px}.badge-name{font-size:12px;font-weight:600}.profile-hero-card{border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--border-light);box-shadow:var(--shadow);position:relative;overflow:hidden}.profile-hero-bg{background:linear-gradient(135deg,#6c5ce7,#a29bfe,#ff6b9d,#ffa07a) 0 0/300% 300%;height:140px;animation:8s infinite profileGradient}@keyframes profileGradient{0%,to{background-position:0%}50%{background-position:100%}}.profile-hero-content{align-items:flex-start;gap:28px;margin-top:-50px;padding:0 32px 32px;display:flex}.profile-avatar-section{flex-direction:column;flex-shrink:0;align-items:center;gap:8px;display:flex}.profile-avatar-wrapper{cursor:pointer;border:4px solid var(--surface);border-radius:50%;width:120px;height:120px;transition:transform .3s;position:relative;overflow:hidden;box-shadow:0 4px 20px #0000001f}.profile-avatar-wrapper:hover{transform:scale(1.05)}.profile-avatar-wrapper:hover .profile-avatar-overlay{opacity:1}.profile-avatar-img{object-fit:cover;width:100%;height:100%;display:block}.profile-avatar-placeholder{background:linear-gradient(135deg, var(--accent), var(--pink-deep));color:#fff;justify-content:center;align-items:center;width:100%;height:100%;font-family:Coiny,cursive;font-size:48px;font-weight:800;display:flex}.profile-avatar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);color:#fff;opacity:0;background:#00000073;border-radius:50%;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:absolute;inset:0}.profile-avatar-spinner{border:3px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:28px;height:28px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.profile-status-dot{border:3px solid var(--surface);z-index:2;border-radius:50%;width:20px;height:20px;position:absolute;bottom:6px;right:6px}.profile-status-dot.online{background:#48bb78;animation:2s infinite statusPulse;box-shadow:0 0 8px #48bb7899}.profile-status-dot.offline{background:#a0aec0}@keyframes statusPulse{0%,to{box-shadow:0 0 4px #48bb7866}50%{box-shadow:0 0 12px #48bb78cc}}.profile-remove-avatar{border:1px solid var(--border);color:var(--danger);cursor:pointer;background:0 0;border-radius:6px;align-items:center;gap:4px;padding:4px 10px;font-family:inherit;font-size:11px;transition:all .2s;display:flex}.profile-remove-avatar:hover{background:#fff5f5;border-color:#fed7d7}.profile-hero-info{flex:1;padding-top:58px}.profile-name-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.profile-display-name{margin:0;font-family:Coiny,cursive;font-size:24px}.profile-status-badge{border-radius:20px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-weight:600;display:inline-flex}.profile-status-badge.online{color:#38a169;background:#f0fff4}.profile-status-badge.offline{color:#a0aec0;background:#f7fafc}.profile-status-pulse{border-radius:50%;width:8px;height:8px;display:inline-block}.profile-status-badge.online .profile-status-pulse{background:#48bb78;animation:2s infinite statusPulse}.profile-status-badge.offline .profile-status-pulse{background:#cbd5e0}.profile-email{color:var(--text-secondary);margin-top:4px;font-size:14px}.profile-joined{color:var(--text-muted);margin-top:4px;font-size:13px}.profile-quick-stats{flex-wrap:wrap;gap:12px;margin-top:16px;display:flex}.profile-stat-chip{background:var(--bg);border:1px solid var(--border-light);border-radius:12px;align-items:center;gap:10px;padding:10px 16px;transition:transform .2s;display:flex}.profile-stat-chip:hover{transform:translateY(-2px)}.profile-stat-icon{border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.profile-stat-value{font-size:16px;font-weight:800;line-height:1.2}.profile-stat-label{color:var(--text-muted);font-size:11px}.profile-section-card{animation:.3s fadeIn}.profile-form-grid{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.profile-field{flex-direction:column;gap:6px;display:flex}.profile-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:700}.profile-value{color:var(--text);padding:10px 0;font-size:15px;font-weight:500}.profile-msg{border-radius:var(--radius-sm);margin-bottom:16px;padding:10px 16px;font-size:13px;font-weight:600;animation:.3s fadeIn}.profile-msg.success{color:#38a169;background:#f0fff4;border:1px solid #c6f6d5}.profile-msg.error{color:#e53e3e;background:#fff5f5;border:1px solid #fed7d7}.profile-skills-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.profile-skill-card{background:var(--bg);border-radius:var(--radius);border:1px solid var(--border-light);padding:20px;transition:transform .2s,box-shadow .2s}.profile-skill-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.profile-skill-header{align-items:center;gap:10px;display:flex}.profile-skill-icon{font-size:24px}.profile-skill-name{flex:1;font-size:15px;font-weight:600}.profile-skill-score{font-size:20px;font-weight:800}.profile-badges-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;display:grid}.profile-badge-card{text-align:center;background:var(--bg);border-radius:var(--radius);border:1px solid var(--border-light);padding:24px 16px;transition:all .3s}.profile-badge-card:hover{box-shadow:var(--shadow-glow);border-color:var(--accent-light);transform:translateY(-4px)scale(1.02)}.profile-badge-icon{margin-bottom:8px;font-size:42px;animation:2s infinite badgeBounce}@keyframes badgeBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.profile-badge-name{margin-bottom:4px;font-size:14px;font-weight:700}.profile-badge-desc{color:var(--text-secondary);margin-bottom:6px;font-size:12px}.profile-badge-date{color:var(--text-muted);font-size:11px}.profile-security-item{background:var(--bg);border-radius:var(--radius);justify-content:space-between;align-items:center;gap:16px;padding:20px;display:flex}.profile-security-title{align-items:center;gap:8px;font-size:15px;font-weight:700;display:flex}.profile-security-desc{color:var(--text-secondary);margin-top:4px;font-size:13px}.profile-pw-form{background:var(--bg);border-radius:var(--radius);flex-direction:column;gap:16px;margin-top:20px;padding:24px;animation:.3s fadeIn;display:flex}.profile-loader{color:var(--text-muted);flex-direction:column;align-items:center;gap:16px;display:flex}.profile-loader-spinner{border:4px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.sr-layout{height:calc(100vh - var(--topbar-h));background:var(--bg);color:var(--text);display:flex;overflow:hidden}.sr-channels{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:230px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.sr-channels.sr-channels-collapsed{border-right:none;width:0;overflow:hidden}.sr-status-box{background:var(--bg);border:1px solid var(--border);border-radius:10px;margin:10px 8px 0;padding:8px 10px}.sr-status-input{width:100%;color:var(--text);background:0 0;border:none;outline:none;font-family:inherit;font-size:12px}.sr-status-input::placeholder{color:var(--text-muted)}.sr-channel-section{padding:12px 8px 4px}.sr-section-title{color:var(--text);text-transform:uppercase;letter-spacing:.5px;-webkit-user-select:none;user-select:none;padding:0 6px 6px;font-size:13px;font-weight:800}.sr-channel-btn{width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:10px;align-items:center;gap:8px;padding:8px 10px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s;display:flex}.sr-channel-btn:hover{background:var(--purple);color:var(--text)}.sr-channel-btn.active{background:var(--accent);color:#fff;font-weight:700}.sr-badge{background:var(--pink-deep);color:#fff;text-align:center;border-radius:10px;min-width:16px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:700}.sr-voice-users{padding:2px 0 4px 32px}.sr-voice-user{color:var(--text-secondary);align-items:center;gap:6px;padding:3px 8px;font-size:12px;display:flex}.sr-voice-controls{background:var(--green);border-top:1px solid var(--border);margin-top:auto;padding:10px 12px}.sr-vc-btn{background:var(--surface);width:32px;height:32px;color:var(--text);cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;font-size:14px;transition:all .2s;display:flex;box-shadow:0 1px 3px #00000014}.sr-vc-btn:hover{background:var(--accent);color:#fff}.sr-vc-btn.active,.sr-vc-leave{background:var(--pink-deep);color:#fff}.sr-vc-leave:hover{background:#e8607a}.sr-main{flex-direction:column;flex:1;min-width:0;display:flex}.sr-main-header{border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;align-items:center;gap:10px;padding:12px 16px;display:flex}.sr-join-btn{background:var(--green-deep);color:#fff;cursor:pointer;border:none;border-radius:12px;margin-left:auto;padding:8px 20px;font-family:inherit;font-size:13px;font-weight:700;transition:all .2s;box-shadow:0 2px 8px #48bb784d}.sr-join-btn:hover{background:#3a9d68;transform:translateY(-2px)}.sr-leave-btn{background:var(--pink-deep);color:#fff;cursor:pointer;border:none;border-radius:12px;margin-left:auto;padding:8px 20px;font-family:inherit;font-size:13px;font-weight:700;box-shadow:0 2px 8px #ff8fab4d}.sr-leave-btn:hover{background:#e8607a}.sr-chat-area{flex:1;padding:16px;overflow-y:auto}.sr-chat-area::-webkit-scrollbar{width:6px}.sr-chat-area::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.sr-message{border-radius:12px;gap:12px;padding:10px 8px;transition:background .15s;display:flex}.sr-message:hover{background:var(--surface)}.sr-msg-user{color:var(--accent);font-size:14px;font-weight:700}.sr-msg-time{color:var(--text-muted);font-size:11px}.sr-msg-text{color:var(--text);margin-top:2px;font-size:14px;line-height:1.5}.sr-chat-input-area{background:var(--surface);border:1px solid var(--border);border-radius:14px;gap:8px;margin:0 16px 16px;padding:12px 16px;display:flex;box-shadow:0 2px 8px #0000000a}.sr-chat-input{color:var(--text);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:14px}.sr-chat-input::placeholder{color:var(--text-muted)}.sr-send-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex}.sr-send-btn:hover{background:var(--accent-light);transform:scale(1.05)}.sr-send-btn:disabled{background:var(--border);cursor:default;color:var(--text-muted)}.sr-voice-grid{background:linear-gradient(135deg, var(--purple) 0%, var(--pink) 50%, var(--yellow) 100%);flex:1;justify-content:center;align-items:center;padding:24px;display:flex}.sr-voice-seats{flex-wrap:wrap;justify-content:center;align-items:center;gap:24px;max-width:650px;display:flex}.sr-seat{box-sizing:border-box;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffd9;border:2px solid #0000;border-radius:20px;flex-direction:column;justify-content:space-between;align-items:center;width:140px;height:190px;padding:16px 12px;transition:all .3s;display:flex;box-shadow:0 4px 20px #0000000f}.sr-seat:hover{background:#fff;transform:translateY(-6px);box-shadow:0 8px 30px #0000001a}.sr-seat-me{border-color:var(--accent);box-shadow:0 0 20px #e91e7b33}.sr-seat-name{color:var(--text);font-size:13px;font-weight:700}.sr-seat-wave{align-items:end;gap:3px;height:22px;display:flex}.sr-wave-bar{background:var(--accent);border-radius:2px;width:4px;animation:1s ease-in-out infinite srWave}.sr-wave-bar-live{background:linear-gradient(to top, var(--accent), var(--accent-light));border-radius:2px;width:4px;min-height:3px;transition:height 80ms ease-out}@keyframes srWave{0%,to{height:4px}50%{height:18px}}.sr-empty{text-align:center;color:var(--text-muted)}.sr-empty h3{color:var(--text);margin:12px 0 4px;font-family:Coiny,cursive;font-size:18px}.sr-empty p{margin-bottom:16px;font-size:14px}.sr-sidebar-right{background:var(--surface);border-left:1px solid var(--border);flex-shrink:0;width:240px;transition:transform .3s cubic-bezier(.4,0,.2,1);overflow-y:auto}.sr-right-sidebar-toggle-btn{background:var(--purple);border:1px solid var(--border);cursor:pointer;width:34px;height:34px;color:var(--text);border-radius:10px;justify-content:center;align-items:center;font-size:16px;transition:all .2s;display:none;box-shadow:0 1px 3px #00000014}.sr-right-sidebar-toggle-btn:hover{background:var(--accent);color:#fff}.sr-sidebar-right::-webkit-scrollbar{width:4px}.sr-sidebar-right::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.sr-right-section{border-bottom:1px solid var(--border);padding:14px}.sr-member-item{cursor:pointer;border-radius:10px;align-items:center;gap:10px;padding:6px 8px;transition:background .15s;display:flex}.sr-member-item:hover{background:var(--purple)}.sr-pomodoro{flex-direction:column;align-items:center;display:flex}.sr-pomodoro-ring{background:conic-gradient(var(--ring-color) var(--pct), var(--border) var(--pct));border-radius:50%;justify-content:center;align-items:center;width:120px;height:120px;display:flex;box-shadow:0 4px 15px #0000000f}.sr-pomodoro-inner{background:var(--surface);border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:100px;height:100px;display:flex}.sr-pomodoro-time{color:var(--text);font-variant-numeric:tabular-nums;font-size:26px;font-weight:800}.sr-pomodoro-label{color:var(--text-muted);letter-spacing:1px;font-size:10px;font-weight:700}.sr-btn{background:var(--purple);color:var(--text);cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;transition:all .2s;display:flex}.sr-btn:hover{background:var(--accent);color:#fff}.sr-btn-dim:hover{background:var(--pink);color:var(--text)}.sr-lofi{padding:0}.sr-lofi-track-item{cursor:pointer;text-align:left;width:100%;color:var(--text-secondary);background:0 0;border:1px solid #0000;border-radius:8px;align-items:center;gap:8px;padding:6px 10px;font-family:inherit;font-size:12px;transition:all .2s;display:flex}.sr-lofi-track-item:hover{background:var(--bg);color:var(--accent)}.sr-lofi-track-item.active{color:#7c3aed;background:#f3e8ff;border-color:#d8b4fe;font-weight:700}.sr-lofi-track-item.active:hover{background:#f3e8ff}.sr-clickable-user{cursor:pointer;transition:color .15s,-webkit-text-decoration .15s,text-decoration .15s}.sr-clickable-user:hover{text-decoration:underline;color:var(--accent)!important}.sr-profile-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background:#00000073;justify-content:center;align-items:center;animation:.2s srFadeIn;display:flex;position:fixed;inset:0}@keyframes srFadeIn{0%{opacity:0}to{opacity:1}}.sr-profile-popup{background:var(--surface);border-radius:20px;width:340px;max-width:90vw;animation:.25s srSlideUp;position:relative;overflow:hidden;box-shadow:0 20px 60px #00000040}@keyframes srSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.sr-profile-close{z-index:2;color:#fff;cursor:pointer;background:#0000004d;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;transition:background .15s;display:flex;position:absolute;top:10px;right:10px}.sr-profile-close:hover{background:#00000080}.sr-profile-banner{background:linear-gradient(135deg, var(--accent) 0%, var(--accent-light) 50%, var(--pink) 100%);height:80px}.sr-profile-avatar-wrap{justify-content:center;margin-top:-36px;display:flex;position:relative}.sr-profile-avatar-img{object-fit:cover;border:4px solid var(--surface);border-radius:50%;width:72px;height:72px;box-shadow:0 4px 12px #0000001f}.sr-profile-avatar-placeholder{background:linear-gradient(135deg, var(--accent), var(--accent-light));color:#fff;border:4px solid var(--surface);border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;font-size:28px;font-weight:800;display:flex;box-shadow:0 4px 12px #0000001f}.sr-profile-dot{border:3px solid var(--surface);background:#a0aec0;border-radius:50%;width:16px;height:16px;position:absolute;bottom:2px;right:calc(50% - 36px)}.sr-profile-dot.online{background:#48bb78}.sr-profile-stats{grid-template-columns:repeat(4,1fr);gap:8px;margin-top:12px;padding:12px 16px;display:grid}.sr-profile-stat{text-align:center;background:var(--bg);border-radius:12px;padding:8px 4px}.sr-profile-stat-val{color:var(--text);font-size:13px;font-weight:800}.sr-profile-stat-lbl{color:var(--text-muted);margin-top:2px;font-size:10px;font-weight:600}.sr-profile-full-btn{cursor:pointer;background:var(--accent);color:#fff;text-align:center;border:none;border-radius:12px;width:calc(100% - 32px);margin:12px 16px 16px;padding:10px;font-family:inherit;font-size:13px;font-weight:700;transition:all .2s;display:block}.sr-profile-full-btn:hover{background:var(--accent-light);transform:translateY(-1px)}.topik-level-selector{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:6px;display:flex}.topik-lvl-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:10px;padding:8px 18px;font-family:inherit;font-size:14px;font-weight:700;transition:all .2s}.topik-lvl-btn.active{background:var(--accent);color:#fff;box-shadow:0 4px 12px #764ba233}.topik-tabs{gap:8px;margin-bottom:20px;padding-bottom:6px;display:flex;overflow-x:auto}.topik-tab-btn{border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:12px;padding:10px 18px;font-family:inherit;font-size:14px;font-weight:700;transition:all .2s}.topik-tab-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.topik-sub-tabs{border-bottom:2px solid var(--border);gap:6px;padding-bottom:2px;display:flex}.topik-sub-tab-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-bottom:3px solid #0000;padding:8px 16px;font-family:inherit;font-size:14px;font-weight:700;transition:all .2s}.topik-sub-tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.topik-table{border-collapse:collapse;width:100%;margin-top:12px;font-size:14px}.topik-table th{background:var(--bg);color:var(--text-muted);font-weight:700}.topik-table tr.highlight-row{background:#ff6b9d0d}.vocab-flashcard{transform-style:preserve-3d;transition:transform .6s}.vocab-flashcard.flipped{transform:rotateY(180deg)}.topik-exam-room{background:var(--surface);border-radius:16px;box-shadow:0 10px 30px #0000000d}.topik-exam-bar{border-bottom:2px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:14px;display:flex}.topik-option-label{border:1px solid var(--border);border-radius:10px;padding:12px 16px;transition:background .15s}.topik-option-label:hover{background:var(--bg)}@media (width<=1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}.sr-channels{top:var(--topbar-h);z-index:100;background:var(--surface);transition:transform .3s cubic-bezier(.4,0,.2,1);position:fixed;bottom:0;left:0;transform:translate(-100%);box-shadow:10px 0 30px #00000026;width:240px!important}.sr-channels.sr-channels-mobile-open{transform:translate(0)}.sr-right-sidebar-toggle-btn{display:flex}.sr-sidebar-right{top:var(--topbar-h);z-index:100;background:var(--surface);border-left:1px solid var(--border);width:260px;position:fixed;bottom:0;right:0;transform:translate(100%);box-shadow:-10px 0 30px #00000026}.sr-sidebar-right.sr-sidebar-right-mobile-open{transform:translate(0)}}.topik-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.topik-level-selector{gap:8px;display:flex}.topik-lvl-btn{border:2px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;color:var(--text-secondary);white-space:nowrap;padding:clamp(8px,1.5vw,10px) clamp(12px,3vw,24px);font-family:inherit;font-size:clamp(11px,1.8vw,14px);font-weight:700;transition:all .2s}.topik-lvl-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.topik-tabs{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.topik-tab-btn{border:2px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;color:var(--text-secondary);white-space:nowrap;padding:clamp(6px,1.5vw,10px) clamp(10px,2.5vw,20px);font-family:inherit;font-size:clamp(10px,1.6vw,13px);font-weight:600;transition:all .2s}.topik-tab-btn.active{background:linear-gradient(135deg, var(--accent), var(--accent-light));color:#fff;border-color:var(--accent)}.topik-exam-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.topik-analytics-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}.topik-exp-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.topik-practice-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:10px;display:flex}.topik-practice-header h3{margin:0;font-size:16px}.topik-practice-skill-btns{gap:10px;display:flex}.topik-question-card{margin-bottom:16px;padding:clamp(12px,2.5vw,18px)}.topik-option-label{cursor:pointer;border-radius:10px;align-items:center;gap:clamp(8px,1.5vw,12px);padding:clamp(7px,1.5vw,10px) clamp(10px,2vw,16px);transition:all .2s;display:flex}.topik-option-number{-webkit-user-select:none;user-select:none;flex-shrink:0;font-size:clamp(16px,2.5vw,20px);line-height:1}.topik-option-text{color:var(--text);word-break:break-word;font-size:clamp(12px,1.8vw,14px)}.topik-result-stats{flex-wrap:wrap;justify-content:center;gap:20px;margin-bottom:24px;display:flex}.topik-result-card{background:var(--bg);border:1px solid var(--border);text-align:center;min-width:160px;padding:20px 16px}.topik-exam-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.topik-sub-tabs{flex-wrap:wrap;gap:8px;display:flex}.topik-sub-tab-btn{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;color:var(--text-secondary);white-space:nowrap;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:all .2s}.topik-sub-tab-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.topik-table{border-collapse:collapse;width:100%;font-size:14px}.topik-table th,.topik-table td{text-align:left;border-bottom:1px solid var(--border);padding:10px 12px}.topik-table th{background:var(--bg);color:var(--text-secondary);font-size:13px;font-weight:700}.table-responsive{-webkit-overflow-scrolling:touch;overflow-x:auto}.topik-section-header{padding:clamp(10px,2vw,16px) clamp(12px,2.5vw,20px)}.topik-compact-title{font-size:clamp(14px,2.5vw,18px);margin-bottom:4px!important}.topik-section-desc{color:var(--text-muted);margin-bottom:clamp(10px,2vw,16px);font-size:clamp(11px,1.6vw,13px)}@media (width<=1024px){.topik-exam-grid{grid-template-columns:1fr 1fr;gap:12px}.topik-analytics-grid,.topik-exp-grid{grid-template-columns:1fr}.topik-tabs{gap:6px}.topik-tab-btn{padding:8px 14px;font-size:12px}.topik-lvl-btn{padding:8px 16px;font-size:13px}}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.menu-toggle{display:block}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.ai-widget{width:calc(100vw - 32px);right:16px}.profile-hero-content{text-align:center;flex-direction:column;align-items:center}.profile-hero-info{padding-top:16px}.profile-name-row,.profile-quick-stats{justify-content:center}.profile-form-grid{grid-template-columns:1fr}.profile-security-item{text-align:center;flex-direction:column}.sr-layout{height:calc(100vh - var(--topbar-h))}.sr-voice-controls{padding:6px}.sr-vc-btn{width:28px;height:28px;font-size:12px}.sr-main-header{padding:8px 12px}.sr-chat-input-area{margin:0 8px 8px;padding:8px 12px}.topbar-widget,.topbar-widgets-wrapper,.topbar-user-name,.topbar-user-role{display:none!important}.search-box{display:none}.topik-header{flex-direction:column;align-items:stretch}.topik-header .page-title{text-align:center}.topik-level-selector{justify-content:center}.topik-lvl-btn{text-align:center;flex:1}.topik-tabs{grid-template-columns:1fr 1fr;gap:6px;display:grid}.topik-tab-btn{text-align:center;white-space:normal;line-height:1.3}.topik-exam-grid,.topik-analytics-grid,.topik-exp-grid{grid-template-columns:1fr}.topik-practice-header{flex-direction:column;align-items:stretch}.topik-practice-skill-btns{flex-direction:column}.topik-practice-skill-btns .btn{width:100%}.topik-result-stats{flex-direction:column;align-items:center}.topik-result-card{width:100%;min-width:unset}.topik-exam-bar{text-align:center;flex-direction:column;align-items:stretch}.topik-sub-tabs{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto}.topik-sub-tab-btn{flex-shrink:0}.topik-table{font-size:clamp(11px,2vw,13px)}}.vocab-animate{animation:.6s cubic-bezier(.34,1.56,.64,1) both vocabBounceIn}@keyframes vocabBounceIn{0%{opacity:0;transform:translateY(10px)scale(.9)}70%{transform:translateY(-2px)scale(1.02)}to{opacity:1;transform:translateY(0)scale(1)}}.flip-book{transform-style:preserve-3d;perspective:1000px;animation:.6s cubic-bezier(.4,0,.2,1) both flipBook}@keyframes flipBook{0%{opacity:1;transform:rotateY(0)}45%{opacity:.3;transform:rotateY(-90deg)}55%{opacity:.3;transform:rotateY(90deg)}to{opacity:1;transform:rotateY(0)}}.vocab-book-card{background:var(--surface);border-radius:var(--radius);cursor:pointer;border:2px solid #e2e8f0;align-items:center;gap:20px;padding:16px;transition:transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s cubic-bezier(.4,0,.2,1),border-color .25s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 8px 24px #959da51f,0 2px 8px #0000000a}.vocab-book-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 10px 24px #00000014,0 3px 6px #0000000a}.lesson-grid-item{background:var(--surface);text-align:center;cursor:pointer;border:2px solid #e2e8f0;border-radius:12px;padding:18px;transition:all .2s;box-shadow:0 8px 24px #959da51f,0 2px 8px #0000000a}.lesson-grid-item:hover{border-color:var(--accent);transform:scale(1.03);box-shadow:0 8px 20px #0000000f,0 2px 4px #00000008}@keyframes progress-bar-stripes{0%{background-position:1rem 0}to{background-position:0 0}}.progress-bar-animated-stripes{background-image:linear-gradient(45deg,#ffffff26 25%,#0000 25% 50%,#ffffff26 50% 75%,#0000 75%,#0000);background-size:1rem 1rem;animation:1s linear infinite progress-bar-stripes}.speaking-main-tabs{border-bottom:2px solid var(--border);gap:16px;margin-bottom:24px;display:flex}.main-tab-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:3px solid #0000;align-items:center;gap:8px;padding:12px 24px;font-family:inherit;font-size:16px;font-weight:800;transition:all .3s;display:flex}.main-tab-btn:hover{color:var(--accent)}.main-tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.jk-chat-container{border-radius:var(--radius-lg);height:calc(100vh - 210px);min-height:580px;box-shadow:var(--shadow-lg);background:linear-gradient(#f5eef6 0%,#eaddee 100%);border:2px solid #e2e8f0;flex-direction:column;display:flex;position:relative;overflow:hidden}.jk-chat-header{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10;background:#ffffffd9;border-bottom:1px solid #e2e8f0cc;justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.jk-header-profile{align-items:center;gap:12px;display:flex}.jk-header-avatar{border:2px solid var(--accent-light);object-fit:cover;width:44px;height:44px;box-shadow:var(--shadow-sm);border-radius:50%}.jk-header-info{flex-direction:column;gap:2px;display:flex}.jk-header-name{color:var(--text);align-items:center;gap:6px;font-size:15px;font-weight:800;display:flex}.jk-header-status{color:var(--text-secondary);align-items:center;gap:4px;font-size:11px;display:flex}.jk-status-dot{background-color:var(--success);border-radius:50%;width:6px;height:6px;animation:2s infinite jk-pulse-green;display:inline-block}@keyframes jk-pulse-green{0%{box-shadow:0 0 #38a169b3}70%{box-shadow:0 0 0 6px #38a16900}to{box-shadow:0 0 #38a16900}}.jk-chat-body{flex-direction:column;flex:1;gap:16px;padding:20px;display:flex;overflow-y:auto}.jk-msg-wrapper{gap:8px;max-width:80%;display:flex}.jk-msg-wrapper.jk{align-self:flex-start}.jk-msg-wrapper.user{justify-content:flex-end;align-self:flex-end;max-width:75%}.jk-bubble-avatar{object-fit:cover;width:36px;height:36px;box-shadow:var(--shadow-sm);border:1.5px solid #fff;border-radius:50%;flex-shrink:0}.jk-bubble-content-box{flex-direction:column;gap:4px;display:flex}.jk-bubble-sender-name{color:var(--text-secondary);margin-left:2px;font-size:11px;font-weight:700}.jk-msg-bubble{word-break:break-word;border-radius:18px;padding:12px 16px;font-size:14px;line-height:1.5;position:relative;box-shadow:0 2px 8px #00000008}.jk-msg-wrapper.jk .jk-msg-bubble{color:var(--text);background:#fff;border:1px solid #e2e8f099;border-top-left-radius:4px}.jk-msg-wrapper.user .jk-msg-bubble{background:linear-gradient(135deg, var(--accent), var(--pink-deep));color:#fff;text-align:left;border-top-right-radius:4px}.jk-msg-text-kr{margin-bottom:2px;font-size:15px;font-weight:700}.jk-msg-text-vi{opacity:.85;border-top:1px solid #0000000f;margin-top:4px;padding-top:4px;font-size:12px;font-style:italic}.jk-msg-wrapper.user .jk-msg-text-vi{border-top-color:#fff3}.jk-msg-time{color:var(--text-muted);flex-shrink:0;align-self:flex-end;margin-bottom:2px;font-size:10px}.jk-typing-indicator{width:fit-content;box-shadow:var(--shadow-sm);background:#fff;border:1px solid #e2e8f099;border-radius:4px 16px 16px;align-self:flex-start;align-items:center;gap:4px;margin-left:44px;padding:8px 14px;display:flex}.jk-typing-indicator span{background-color:var(--accent-light);border-radius:50%;width:6px;height:6px;animation:1.4s ease-in-out infinite both jk-typing;display:inline-block}.jk-typing-indicator span:first-child{animation-delay:-.32s}.jk-typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes jk-typing{0%,80%,to{opacity:.3;transform:scale(0)}40%{opacity:1;transform:scale(1)}}.jk-chat-suggestions-container{-webkit-backdrop-filter:blur(10px);background:#fff9;border-top:1px solid #e2e8f080}.jk-suggestions-header{cursor:pointer;-webkit-user-select:none;user-select:none;background:#8b5cf60a;border-bottom:1px solid #e2e8f04d;justify-content:space-between;align-items:center;padding:6px 16px;transition:all .2s;display:flex}.jk-suggestions-header:hover{background:#8b5cf614}.jk-suggestions-title{color:var(--accent);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:4px;font-size:11px;font-weight:800;display:flex}.jk-suggestions-toggle{color:var(--text-secondary);background:#e2e8f080;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:700;transition:all .2s}.jk-suggestions-header:hover .jk-suggestions-toggle{background:var(--purple);color:var(--accent)}.jk-chat-suggestions{flex-wrap:wrap;gap:10px;padding:12px 16px;display:flex}.jk-suggestion-chip{cursor:pointer;text-align:left;box-sizing:border-box;background:#fff;border:1.5px solid #8b5cf61f;border-radius:12px;flex-direction:column;flex:calc(33.333% - 10px);justify-content:center;align-items:flex-start;gap:3px;min-width:200px;max-width:100%;padding:10px 16px;line-height:1.35;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 2px 5px #00000005}.jk-suggestion-chip:hover{border-color:var(--accent);background:#8b5cf608;transform:translateY(-1px);box-shadow:0 4px 10px #8b5cf614}.jk-suggestion-kr{color:var(--accent);word-break:break-word;font-size:13px;font-weight:800}.jk-suggestion-roman{color:var(--text-secondary);opacity:.95;margin-top:1px;font-size:10.5px;font-style:italic;font-weight:600}.jk-suggestion-vi{color:var(--text-muted);opacity:.85;margin-top:1px;font-size:10px;font-weight:500}@media (width<=768px){.jk-chat-suggestions{gap:8px;padding:8px 12px}.jk-suggestion-chip{border-radius:10px;flex:100%;gap:2px;min-width:100%;max-width:100%;padding:10px 14px}.jk-suggestion-kr{font-size:12.5px;font-weight:700}.jk-suggestion-roman{font-size:10px}.jk-suggestion-vi{font-size:9.5px}}@media (width<=480px){.jk-chat-suggestions{gap:6px;padding:8px}.jk-suggestion-chip{border-radius:8px;flex:100%;gap:2px;min-width:100%;max-width:100%;padding:8px 12px}.jk-suggestion-kr{font-size:12px}.jk-suggestion-roman{font-size:9.5px}.jk-suggestion-vi{font-size:9px}}.jk-input-bar{border-top:1px solid var(--border);background:#fff;align-items:center;gap:8px;padding:12px 16px;display:flex}.jk-voice-btn{background:var(--bg);width:42px;height:42px;color:var(--text-secondary);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.jk-voice-btn:hover{background:var(--purple);color:var(--accent)}.jk-voice-btn.recording{background:var(--danger);color:#fff;animation:1.5s infinite jk-pulse-danger}@keyframes jk-pulse-danger{0%{box-shadow:0 0 #e53e3e66}70%{box-shadow:0 0 0 8px #e53e3e00}to{box-shadow:0 0 #e53e3e00}}.jk-chat-input{border:1px solid var(--border);background:var(--bg);border-radius:22px;outline:none;flex:1;padding:10px 18px;font-size:14px;transition:border-color .2s}.jk-chat-input:focus{border-color:var(--accent);background:#fff}.jk-send-btn{background:linear-gradient(135deg, var(--accent), var(--pink-deep));color:#fff;cursor:pointer;width:42px;height:42px;box-shadow:var(--shadow-sm);border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.jk-send-btn:hover:not(:disabled){transform:scale(1.05)}.jk-send-btn:disabled{background:var(--border);color:var(--text-muted);cursor:not-allowed;box-shadow:none}.jk-suggestion-wrapper{box-sizing:border-box;flex-direction:column;flex:calc(33.333% - 10px);gap:6px;min-width:200px;max-width:100%;display:flex}.jk-suggestion-chip{flex:1;width:100%!important}.jk-suggestion-practice-btn{color:var(--accent);cursor:pointer;box-sizing:border-box;background:#8b5cf60f;border:1.5px dashed #8b5cf64d;border-radius:10px;justify-content:center;align-items:center;gap:6px;width:100%;padding:6px 12px;font-size:11px;font-weight:700;transition:all .2s;display:inline-flex}.jk-suggestion-practice-btn:hover{background:var(--accent);color:#fff;border-style:solid;border-color:var(--accent)}.jk-practice-panel{background:#fff;border-top:1px solid #e2e8f080;flex-direction:column;gap:12px;padding:16px 20px;animation:.25s ease-out jk-slide-up;display:flex}@keyframes jk-slide-up{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.jk-practice-header{border-bottom:1px solid #e2e8f04d;justify-content:space-between;align-items:center;padding-bottom:8px;display:flex}.jk-practice-title{color:var(--accent);text-transform:uppercase;letter-spacing:.5px;font-size:11.5px;font-weight:800}.jk-practice-close-btn{color:var(--text-secondary);cursor:pointer;background:#e2e8f080;border:none;border-radius:8px;padding:2px 8px;font-size:11px;font-weight:700;transition:all .2s}.jk-practice-close-btn:hover{color:var(--danger);background:#e53e3e14}.jk-practice-body{text-align:center;flex-direction:column;align-items:center;gap:10px;display:flex}.jk-practice-text-kr{color:var(--text);word-break:break-word;font-size:20px;font-weight:800;line-height:1.4}.jk-practice-text-vi{color:var(--text-secondary);font-size:13px;font-style:italic}.jk-practice-text-roman{color:var(--accent);opacity:.95;margin-top:-4px;font-size:14px;font-style:italic;font-weight:600}.jk-practice-audio-btn{color:var(--accent);cursor:pointer;background:#8b5cf60d;border:1px solid #8b5cf626;border-radius:50%;justify-content:center;align-items:center;margin-left:6px;padding:6px;transition:all .2s;display:inline-flex}.jk-practice-audio-btn:hover:not(:disabled){background:var(--accent);color:#fff;border-color:var(--accent);transform:scale(1.08)}.jk-practice-audio-btn:active:not(:disabled){transform:scale(.95)}.jk-practice-audio-btn:disabled{opacity:.5;cursor:not-allowed}.jk-practice-status{justify-content:center;align-items:center;min-height:24px;display:flex}.jk-practice-score-box{color:var(--text-secondary);background:#8b5cf60d;border:1.5px solid #8b5cf626;border-radius:12px;padding:8px 24px;font-size:14px;font-weight:700}.jk-practice-controls{justify-content:center;gap:12px;margin-top:4px;display:flex}@media (width<=768px){.jk-suggestion-wrapper{flex:100%;min-width:100%;max-width:100%}.jk-practice-panel{gap:8px;padding:12px 14px}.jk-practice-text-kr{font-size:16px}.jk-practice-text-vi{font-size:12px}.jk-practice-text-roman{margin-top:-2px;font-size:12px}.jk-practice-audio-btn{padding:4px}}
