@import "https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700;800;900&display=swap";
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-blue-50:#eff6ff;--color-blue-600:#155dfc;--color-blue-700:#1447e6;--color-indigo-100:#e0e7ff;--color-gray-500:#6a7282;--color-gray-800:#1e2939;--color-white:#fff;--spacing:.25rem;--container-md:28rem;--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-5xl:3rem;--text-5xl--line-height:1;--font-weight-medium:500;--font-weight-bold:700;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--ease-in-out:cubic-bezier(.4, 0, .2, 1);--animate-spin:spin 1s linear infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}@supports (color:lab(0% 0 0)){:root,:host{--color-blue-50:lab(96.492% -1.14644 -5.11479);--color-blue-600:lab(44.0605% 29.0279 -86.0352);--color-blue-700:lab(36.9089% 35.0961 -85.6872);--color-indigo-100:lab(91.6577% 1.04591 -12.7199);--color-gray-500:lab(47.7841% -.393182 -10.0268);--color-gray-800:lab(16.1051% -1.18239 -11.7533)}}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.min-h-screen{min-height:100vh}.w-full{width:100%}.max-w-md{max-width:var(--container-md)}.flex-shrink{flex-shrink:1}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-spin{animation:var(--animate-spin)}.resize{resize:both}.items-center{align-items:center}.justify-center{justify-content:center}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-lg{border-radius:var(--radius-lg)}.border{border-style:var(--tw-border-style);border-width:1px}.bg-\[\#FF6B6B\]{background-color:#ff6b6b}.bg-blue-600{background-color:var(--color-blue-600)}.bg-white{background-color:var(--color-white)}.bg-gradient-to-br{--tw-gradient-position:to bottom right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-blue-50{--tw-gradient-from:var(--color-blue-50);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-indigo-100{--tw-gradient-to:var(--color-indigo-100);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.p-4{padding:calc(var(--spacing) * 4)}.p-8{padding:calc(var(--spacing) * 8)}.px-6{padding-inline:calc(var(--spacing) * 6)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.text-center{text-align:center}.text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.text-gray-500{color:var(--color-gray-500)}.text-gray-800{color:var(--color-gray-800)}.text-white{color:var(--color-white)}.uppercase{text-transform:uppercase}.italic{font-style:italic}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}@media (hover:hover){.hover\:bg-blue-700:hover{background-color:var(--color-blue-700)}}}:root{--primary:#6c5ce7;--primary-light:#a29bfe;--primary-dark:#5545d4;--accent-pink:#fd79a8;--accent-orange:#fdcb6e;--accent-green:#00b894;--accent-blue:#74b9ff;--accent-red:#ff7675;--bg-main:#f8f9fe;--bg-card:#fff;--bg-dark:#1a1a2e;--bg-dark-card:#16213e;--text-primary:#2d3436;--text-secondary:#636e72;--text-light:#b2bec3;--text-dark-mode:#dfe6e9;--border:#e8ecf4;--shadow-sm:0 2px 8px #6c5ce714;--shadow-md:0 4px 20px #6c5ce71f;--shadow-lg:0 8px 40px #6c5ce729;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-xl:28px;--glass-bg:#ffffffb3;--glass-border:#ffffff4d;--glass-blur:20px}[data-color-scheme=dark]{--bg-main:#1a1a2e;--bg-card:#16213e;--text-primary:#dfe6e9;--text-secondary:#b2bec3;--text-light:#636e72;--border:#2d3748;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 20px #0006;--shadow-lg:0 8px 40px #00000080;--glass-bg:#16213ecc;--glass-border:#2d374880}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg-main);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-family:Nunito,sans-serif}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.gradient-primary{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%)}.gradient-warm{background:linear-gradient(135deg, var(--accent-orange) 0%, var(--accent-pink) 100%)}.gradient-cool{background:linear-gradient(135deg, var(--accent-blue) 0%, var(--accent-green) 100%)}.gradient-hero{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.btn{border-radius:var(--radius-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:1rem;font-weight:700;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-flex}.btn:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn:active{transform:translateY(0)}.btn-primary{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%);color:#fff}.btn-success{background:linear-gradient(135deg, var(--accent-green) 0%, #55efc4 100%);color:#fff}.btn-danger{background:linear-gradient(135deg, var(--accent-red) 0%, var(--accent-pink) 100%);color:#fff}.btn-large{border-radius:var(--radius-lg);padding:16px 40px;font-size:1.15rem}.record-btn{background:linear-gradient(135deg, var(--accent-red) 0%, var(--accent-pink) 100%);cursor:pointer;border:4px solid #fff;border-radius:50%;width:80px;height:80px;transition:all .3s;position:relative;box-shadow:0 0 #fd79a866}.record-btn.recording{animation:1.5s infinite pulse-record}@keyframes pulse-record{0%{box-shadow:0 0 #fd79a899}70%{box-shadow:0 0 0 20px #fd79a800}to{box-shadow:0 0 #fd79a800}}.score-badge{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.1rem;font-weight:900;display:inline-flex}.score-badge.excellent{background:linear-gradient(135deg, var(--accent-green), #55efc4)}.score-badge.good{background:linear-gradient(135deg, var(--accent-blue), #a29bfe)}.score-badge.average{background:linear-gradient(135deg, var(--accent-orange), #ffeaa7);color:#2d3436}.score-badge.poor{background:linear-gradient(135deg, var(--accent-red), var(--accent-pink))}.star-earned{animation:.6s cubic-bezier(.175,.885,.32,1.275) star-pop;display:inline-block}@keyframes star-pop{0%{opacity:0;transform:scale(0)rotate(-45deg)}60%{transform:scale(1.3)rotate(10deg)}to{opacity:1;transform:scale(1)rotate(0)}}.audio-bars{align-items:flex-end;gap:3px;height:40px;display:flex}.audio-bar{background:var(--primary);border-radius:2px;width:4px;transition:height .1s;animation:.5s ease-in-out infinite alternate audio-bounce}.audio-bar:first-child{animation-delay:0s}.audio-bar:nth-child(2){animation-delay:.1s}.audio-bar:nth-child(3){animation-delay:.2s}.audio-bar:nth-child(4){animation-delay:.3s}.audio-bar:nth-child(5){animation-delay:.15s}.audio-bar:nth-child(6){animation-delay:.25s}.audio-bar:nth-child(7){animation-delay:50ms}@keyframes audio-bounce{0%{height:8px}to{height:36px}}@keyframes confetti-fall{0%{opacity:1;transform:translateY(-100vh)rotate(0)}to{opacity:0;transform:translateY(100vh)rotate(720deg)}}.confetti-piece{z-index:9999;width:10px;height:10px;animation:3s linear forwards confetti-fall;position:fixed;top:-10px}.sidebar{border-right:1px solid var(--border);z-index:50;background:#fff;width:260px;min-height:100vh;padding:24px 16px;transition:transform .3s;position:fixed;top:0;left:0}.sidebar-link{border-radius:var(--radius-md);color:var(--text-secondary);align-items:center;gap:12px;margin-bottom:4px;padding:12px 16px;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.sidebar-link:hover,.sidebar-link.active{color:var(--primary);background:linear-gradient(135deg,#6c5ce714,#a29bfe14)}.main-content{min-height:100vh;margin-left:260px;padding:32px}.responsive-grid-4{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.responsive-grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.responsive-grid-2{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.responsive-2col{grid-template-columns:1fr 340px;gap:24px;display:grid}.responsive-2col-equal{grid-template-columns:1fr 1fr;gap:24px;display:grid}.mobile-menu-btn{display:none}@media (max-width:1024px){.sidebar{width:220px}.main-content{margin-left:220px;padding:24px}.responsive-grid-4{grid-template-columns:repeat(2,1fr)}.responsive-2col,.responsive-2col-equal{grid-template-columns:1fr}}@media (max-width:768px){.sidebar{z-index:1000;width:260px;height:100vh;transition:transform .3s;position:fixed;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay{z-index:999;background:#0006;position:fixed;inset:0}.mobile-menu-btn{display:flex}.main-content{margin-left:0;padding:16px}.responsive-grid-4,.responsive-grid-3{grid-template-columns:repeat(2,1fr)}.responsive-2col,.responsive-2col-equal{grid-template-columns:1fr}.record-btn{width:64px;height:64px}.responsive-table{display:block}.responsive-table .table-header{display:none}.responsive-table .table-row{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;flex-direction:column;margin-bottom:8px;padding:12px;display:flex}.responsive-table .table-cell{padding:4px 0}.responsive-table .table-cell:before{content:attr(data-label);color:var(--text-secondary);margin-right:8px;font-size:.8rem;font-weight:700}.modal-content{margin:8px;border-radius:16px!important;max-width:100%!important;max-height:85vh!important;padding:20px!important}}@media (max-width:480px){.main-content{padding:12px}.responsive-grid-4,.responsive-grid-3,.responsive-grid-2{grid-template-columns:1fr}.record-btn{width:56px;height:56px}h1{font-size:1.3rem!important}h2{font-size:1.15rem!important}.btn,button{min-height:44px}.input-field{min-height:44px;padding:12px 14px}}@media (max-width:375px){.main-content{padding:8px}.record-btn{width:52px;height:52px}}.spinner{border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.word-wrong{color:var(--accent-red);border-bottom:2px solid var(--accent-red);background:#ff767533;border-radius:4px;padding:2px 4px;font-weight:700}.word-missed{color:#e17055;border-bottom:2px dashed var(--accent-orange);background:#fdcb6e33;border-radius:4px;padding:2px 4px;font-weight:700}.word-correct{color:var(--accent-green);font-weight:600}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--primary-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}.input-field{border:1.5px solid var(--border);width:100%;color:var(--text-primary);background:#fff;border-radius:12px;outline:none;padding:12px 16px;font-family:Nunito,sans-serif;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.input-field:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6c5ce71a}select.input-field{appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 12px center;background-repeat:no-repeat;background-size:20px;padding-right:40px}button:disabled{opacity:.6;cursor:not-allowed}button:disabled:hover{box-shadow:none;transform:none}[data-theme=student]{--primary:#0ea5e9;--primary-light:#38bdf8;--primary-dark:#0284c7;--accent-coral:#ff6b6b;--accent-coral-dark:#ee5253;--accent-yellow:#ffd93d;--accent-yellow-dark:#ffc300;--accent-mint:#6bcb77;--accent-mint-dark:#4caf50;--accent-lavender:#c77dff;--accent-lavender-dark:#9d4edd;--accent-peach:#ffb347;--bg-main:#ebf8ff;--bg-gradient-start:#dbeafe;--bg-gradient-end:#ede9fe;--bg-card:#fff;--bg-nav:#fff;--text-primary:#1e3a5f;--text-secondary:#4a6fa5;--text-light:#93c5fd;--border:#bfdbfe;--shadow-sm:0 4px 12px #0ea5e91f;--shadow-md:0 8px 24px #0ea5e92e;--shadow-lg:0 16px 48px #0ea5e938;--shadow-card:0 6px 20px #00000014;--shadow-nav:0 -4px 20px #0ea5e91f;--radius-sm:12px;--radius-md:18px;--radius-lg:24px;--radius-xl:32px;--radius-pill:9999px;--font-size-base:18px;--font-size-sm:15px;--font-size-lg:20px;--font-size-xl:26px;--font-size-2xl:32px;--font-size-hero:40px;--star-color:#ffd93d;--nav-height:80px;--record-btn-size:128px}html[data-theme=student]{font-size:18px}[data-theme=student] h1{font-size:36px;font-weight:900;line-height:1.15}[data-theme=student] h2{font-size:26px;font-weight:900}[data-theme=student] h3{font-size:22px;font-weight:800}[data-theme=student] p,[data-theme=student] span,[data-theme=student] label{font-weight:700}.student-bottom-nav{z-index:100;background:#fff;border-top:2px solid #bfdbfe;justify-content:space-around;align-items:center;height:80px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #0ea5e91f}.student-nav-tab{cursor:pointer;background:0 0;border:none;border-radius:16px;flex-direction:column;flex:1;align-items:center;gap:4px;margin:4px;padding:8px 0;transition:all .2s;display:flex}.student-nav-tab .nav-icon{border-radius:16px;justify-content:center;align-items:center;width:52px;height:52px;font-size:24px;transition:all .2s;display:flex}.student-nav-tab.active .nav-icon{background:linear-gradient(135deg,#0ea5e9,#38bdf8);box-shadow:0 4px 12px #0ea5e959}.student-nav-tab .nav-label{color:#93c5fd;font-family:Nunito,sans-serif;font-size:11px;font-weight:800}.student-nav-tab.active .nav-label{color:#0ea5e9}[data-theme=student] .record-btn{cursor:pointer;background:linear-gradient(135deg,#ff6b6b 0%,#ffb347 100%);border:6px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:128px;height:128px;transition:all .3s;display:flex;box-shadow:0 8px 32px #ff6b6b73}[data-theme=student] .record-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 12px 40px #ff6b6b8c}[data-theme=student] .record-btn.recording{animation:1.2s infinite student-pulse}@keyframes student-pulse{0%{box-shadow:0 0 #ff6b6bb3,0 8px 32px #ff6b6b73}70%{box-shadow:0 0 0 24px #ff6b6b00,0 8px 32px #ff6b6b73}to{box-shadow:0 0 #ff6b6b00,0 8px 32px #ff6b6b73}}.student-task-card{cursor:pointer;background:#fff;border:2px solid #bfdbfe;border-radius:24px;align-items:center;gap:16px;padding:20px;transition:all .25s;display:flex;box-shadow:0 6px 20px #00000014}.student-task-card:hover{border-color:#0ea5e9;transform:translateY(-3px);box-shadow:0 10px 28px #0ea5e933}@keyframes mascot-bounce{0%,to{transform:translateY(0)rotate(-3deg)}50%{transform:translateY(-8px)rotate(3deg)}}@keyframes mascot-idle{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.student-mascot{filter:drop-shadow(0 4px 8px #0ea5e94d);animation:2.5s ease-in-out infinite mascot-bounce;display:inline-block}.star-rating{justify-content:center;align-items:center;gap:6px;display:flex}.star-rating .star{font-size:32px;transition:all .3s}@keyframes confetti-pop{0%{opacity:1;transform:translateY(0)rotate(0)scale(1)}to{opacity:0;transform:translateY(-80px)rotate(360deg)scale(0)}}.student-main{background:linear-gradient(160deg,#dbeafe 0%,#ede9fe 100%);min-height:100vh;padding-bottom:96px}[data-theme=teacher]{--primary:#0d9488;--primary-light:#14b8a6;--primary-dark:#0f766e;--primary-accent:#f59e0b;--bg-main:#f0fdfa;--bg-card:#fff;--bg-sidebar:#0d9488;--bg-sidebar-hover:#ffffff26;--bg-sidebar-active:#ffffff38;--bg-accent-subtle:#fef3c7;--text-primary:#134e4a;--text-secondary:#4a5568;--text-light:#94a3b8;--text-on-sidebar:#ffffffe0;--text-on-sidebar-active:#fff;--border:#ccfbf1;--border-neutral:#e2e8f0;--shadow-sm:0 2px 8px #0d948814;--shadow-md:0 4px 20px #0d948824;--shadow-lg:0 8px 40px #0d94882e;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-xl:28px;--font-size-base:15px}html[data-theme=teacher]{font-size:15px}[data-theme=teacher] .sidebar{background:linear-gradient(#0d9488 0%,#0f766e 100%);border-right:none;box-shadow:4px 0 20px #0d948826}[data-theme=teacher] .sidebar-link{color:#ffffffd1;border-radius:10px;padding:11px 14px;font-size:14px;transition:all .2s}[data-theme=teacher] .sidebar-link:hover{color:#fff;background:#ffffff1f}[data-theme=teacher] .sidebar-link.active{color:#fff;background:#fff3;font-weight:800;box-shadow:0 2px 8px #0000001a}[data-theme=teacher] .main-content{background:#f0fdfa}[data-theme=teacher] .stat-card{background:#fff;border:1px solid #ccfbf1;border-radius:16px;box-shadow:0 2px 8px #0d948814}.teacher-badge-amber{color:#78350f;background:linear-gradient(135deg,#f59e0b,#fcd34d);border-radius:20px;padding:4px 12px;font-size:12px;font-weight:800}.teacher-badge-teal{color:#fff;background:linear-gradient(135deg,#0d9488,#14b8a6);border-radius:20px;padding:4px 12px;font-size:12px;font-weight:800}[data-theme=teacher] .toast-success{background:linear-gradient(135deg,#0d9488,#14b8a6)}[data-theme=admin]{--primary:#1e3a5f;--primary-light:#2d5986;--primary-dark:#122640;--primary-accent:#3b82f6;--bg-main:#f0f4f8;--bg-card:#fff;--bg-sidebar:#1e3a5f;--bg-sidebar-hover:#2d5986;--text-primary:#1a2332;--text-secondary:#4a5568;--text-light:#a0aec0;--text-on-sidebar:#cbd5e0;--text-on-sidebar-active:#fff;--border:#e2e8f0;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 6px #00000012, 0 2px 4px #0000000a;--shadow-lg:0 10px 15px #00000014, 0 4px 6px #0000000a;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--font-size-base:14px;--status-success:#10b981;--status-warning:#f59e0b;--status-danger:#ef4444;--status-info:#3b82f6}html[data-theme=admin]{font-size:14px}[data-theme=admin] .sidebar{background:#1e3a5f;border-right:none;width:230px;box-shadow:4px 0 16px #0000001f}[data-theme=admin] .main-content{background:#f0f4f8;margin-left:230px}[data-theme=admin] .sidebar-link{color:#cbd5e0;border-radius:6px;padding:10px 12px;font-size:13px;font-weight:600}[data-theme=admin] .sidebar-link:hover,[data-theme=admin] .sidebar-link.active{color:#fff;background:#2d5986}.admin-sidebar-section{letter-spacing:1.2px;text-transform:uppercase;color:#ffffff4d;padding:14px 12px 4px;font-size:10px;font-weight:800}[data-theme=admin] .stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:14px;padding:18px 20px;display:flex;box-shadow:0 1px 3px #00000014}[data-theme=admin] .stat-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}[data-theme=admin] .nav-item{color:#cbd5e0;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:10px;width:100%;margin-bottom:2px;padding:10px 12px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s;display:flex}[data-theme=admin] .nav-item:hover{color:#fff;background:#2d5986}[data-theme=admin] .nav-item.active{color:#fff;background:#2d5986;font-weight:700}[data-theme=admin] .nav-item-danger{color:#ffffff80}[data-theme=admin] .nav-item-danger:hover{color:#fca5a5;background:#ef444426}[data-theme=admin] .sidebar-label{letter-spacing:1.2px;text-transform:uppercase;color:#ffffff4d;padding:14px 12px 4px;font-size:10px;font-weight:800;display:block}.badge{border-radius:20px;padding:3px 10px;font-size:.72rem;font-weight:800;display:inline-block}.badge-admin{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.badge-teacher{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0}.badge-student{color:#c2410c;background:#fff7ed;border:1px solid #fed7aa}.badge-parent{color:#7e22ce;background:#fdf4ff;border:1px solid #e9d5ff}.grid-2col{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.grid-2col-lg{grid-template-columns:repeat(2,1fr);gap:24px;display:grid}.grid-2col-sm{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}@media (max-width:768px){.grid-2col,.grid-2col-lg,.grid-2col-sm{grid-template-columns:1fr!important}.table-scroll-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}.stat-card{padding:14px!important}.modal-wide{width:calc(100vw - 32px)!important;max-width:100%!important}.analytics-grid{grid-template-columns:1fr!important}}@media (max-width:480px){.grid-2col,.grid-2col-lg,.grid-2col-sm{grid-template-columns:1fr!important;gap:10px!important}.bottom-nav{padding-bottom:max(16px, env(safe-area-inset-bottom))}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
