:root{--primary-color:#405084;--secondary-color:#f49221;--accent-color:#64b2ac;--success-color:#2ecc71;--warning-color:#f39c12;--error-color:#e74c3c;--bg-primary:#121212;--bg-secondary:#1a1a1a;--bg-tertiary:#2a2a2a;--text-primary:#fff;--text-secondary:#b1b1b1;--text-muted:#6c757d;--border-color:#333;--hover-bg:#2a2a2a;--font-family:"Inter","Segoe UI",Tahoma,Geneva,Verdana,sans-serif;--font-family-heading:"Chakra Petch","Inter",sans-serif;--border-radius:8px;--border-radius-lg:12px;--border-radius-xl:16px;--shadow-sm:0 1px 3px #0000001f;--shadow-md:0 4px 6px #0000001a;--shadow-lg:0 10px 25px #00000026;--shadow-xl:0 20px 40px #0003}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#121212;background-color:var(--bg-primary);color:#b1b1b1;color:var(--text-secondary);font-family:Inter,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-family:var(--font-family);line-height:1.6}h1,h2,h3,h4,h5,h6{color:#fff;color:var(--text-primary);font-family:Chakra Petch,Inter,sans-serif;font-family:var(--font-family-heading);font-weight:600;line-height:1.3}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}p{color:#b1b1b1;color:var(--text-secondary);margin-bottom:1rem}.app-container{display:flex;flex-direction:column;min-height:100vh}.app-header{background-color:#1a1a1a;background-color:var(--bg-secondary);border-bottom:1px solid #333;border-bottom:1px solid var(--border-color);height:80px;justify-content:space-between;padding:1.25rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.app-header,.header-left{align-items:center;display:flex}.header-left{gap:1rem}.header-right{align-items:center;display:flex;gap:1rem}.sidebar-toggle{background:none;border:none;border-radius:8px;border-radius:var(--border-radius);color:#b1b1b1;color:var(--text-secondary);cursor:pointer;font-size:1.25rem;padding:.5rem;transition:all .2s ease}.sidebar-toggle:hover{background-color:#2a2a2a;background-color:var(--hover-bg);color:#fff;color:var(--text-primary)}.logo h1{font-size:1.75rem;font-weight:900;margin:0}.PES{color:#f49221;color:var(--secondary-color)}.PES,.to{font-family:Caveat,cursive}.to{color:#405084;color:var(--primary-color)}.app-layout{display:flex;flex:1 1;position:relative}.main-content{flex:1 1;min-height:calc(100vh - 80px);overflow-x:hidden;padding:0;transition:margin-left .3s ease}.main-content.sidebar-open{margin-left:0}.greeting-container{background:linear-gradient(135deg,#1a1a1a,#121212);background:linear-gradient(135deg,var(--bg-secondary),var(--bg-primary));border-bottom:1px solid #333;border-bottom:1px solid var(--border-color);padding:3rem 2rem;text-align:center}.greeting-heading{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#405084,#f49221);background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;background-clip:text;font-size:3rem;font-weight:700;margin-bottom:.75rem}.greeting-subtitle{color:#b1b1b1;color:var(--text-secondary);font-size:1.25rem;margin:0}.lofi-button{background:linear-gradient(135deg,#f49221,#ff8c42);background:linear-gradient(135deg,var(--secondary-color),#ff8c42);border:none;border-radius:8px;border-radius:var(--border-radius);box-shadow:0 1px 3px #0000001f;box-shadow:var(--shadow-sm);color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:.75rem 1.25rem;transition:all .3s ease}.lofi-button:hover{background:linear-gradient(135deg,#ff8c42,#f49221);background:linear-gradient(135deg,#ff8c42,var(--secondary-color));box-shadow:0 4px 6px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.lofi-button:active{transform:translateY(0)}@media (max-width:768px){.app-header{height:70px;padding:1rem}.header-left{gap:.75rem}.logo h1{font-size:1.5rem}.greeting-container{padding:2rem 1rem}.greeting-heading{font-size:2.25rem}.greeting-subtitle{font-size:1.125rem}.main-content{min-height:calc(100vh - 70px)}}@media (min-width:769px){.main-content.sidebar-open{margin-left:280px}}audio{display:none}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .6s ease-out forwards}button:focus-visible,input:focus-visible{outline:2px solid #405084;outline:2px solid var(--primary-color);outline-offset:2px}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:1rem}.mb-4{margin-bottom:1.5rem}.mb-5{margin-bottom:2rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:1rem}.mt-4{margin-top:1.5rem}.mt-5{margin-top:2rem}.subject-page{margin:0 auto;max-width:900px;min-height:calc(100vh - 80px);padding:2rem}.subject-header{background:linear-gradient(135deg,var(--bg-secondary),var(--bg-tertiary));border:1px solid var(--border-color);border-radius:var(--border-radius-xl);margin-bottom:3rem;padding:2rem;text-align:center}.subject-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;background-clip:text;font-family:var(--font-family-heading);font-size:2.5rem;font-weight:700;margin-bottom:1rem}.subject-description{font-size:1.125rem;line-height:1.6;margin:0 auto;max-width:600px}.units-container{display:flex;flex-direction:column;gap:1.5rem}.unit-container{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);overflow:hidden;transition:all .3s ease}.unit-container:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md)}.unit-header{cursor:pointer;padding:1.5rem;transition:background-color .2s ease;-webkit-user-select:none;user-select:none}.unit-header:hover{background-color:var(--hover-bg)}.unit-header-content{align-items:center;display:flex;gap:1rem;justify-content:space-between}.unit-info{flex:1 1}.unit-title{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.unit-progress{align-items:center;display:flex;gap:1rem}.progress-text{color:var(--text-secondary);font-size:.875rem;min-width:150px}.progress-bar-mini{background-color:var(--bg-primary);border-radius:3px;flex:1 1;height:6px;max-width:150px;overflow:hidden}.progress-fill-mini{background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));border-radius:3px;height:100%;transition:width .3s ease}.unit-controls{gap:1rem}.completion-indicator,.unit-controls{align-items:center;display:flex}.completion-icon{color:var(--text-secondary);font-size:1.25rem;transition:color .3s ease}.completion-icon.completed{color:var(--success-color)}.expand-icon{color:var(--text-secondary);font-size:1rem;transition:transform .3s ease,color .3s ease}.unit-header:hover .expand-icon{color:var(--primary-color)}.unit-content{max-height:0;overflow:hidden;transition:max-height .3s ease}.unit-content.expanded{max-height:2000px}.select-all-container{background-color:var(--bg-tertiary);border-bottom:1px solid var(--border-color);padding:1.5rem}.select-all-label{align-items:center;color:var(--text-primary);cursor:pointer;display:flex;font-weight:600;gap:.75rem;-webkit-user-select:none;user-select:none}.topics-list{padding:1rem 1.5rem 1.5rem}.topic-item{margin-bottom:.75rem}.topic-label{align-items:flex-start;border-radius:var(--border-radius);cursor:pointer;display:flex;gap:.75rem;padding:.875rem;transition:all .2s ease;-webkit-user-select:none;user-select:none}.topic-label:hover{background-color:var(--hover-bg)}.select-all-checkbox,.topic-checkbox{display:none}.checkbox-custom{border:2px solid var(--border-color);border-radius:4px;flex-shrink:0;height:20px;margin-top:2px;position:relative;transition:all .2s ease;width:20px}.select-all-checkbox:checked+.checkbox-custom,.topic-checkbox:checked+.checkbox-custom{background-color:var(--primary-color);border-color:var(--primary-color)}.select-all-checkbox:indeterminate+.checkbox-custom,.topic-checkbox:indeterminate+.checkbox-custom{background-color:var(--secondary-color);border-color:var(--secondary-color)}.select-all-checkbox:checked+.checkbox-custom:after,.topic-checkbox:checked+.checkbox-custom:after{color:#fff;content:"✓";font-size:12px;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.select-all-checkbox:indeterminate+.checkbox-custom:after,.topic-checkbox:indeterminate+.checkbox-custom:after{color:#fff;content:"−";font-size:14px;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.topic-text{color:var(--text-secondary);flex:1 1;font-size:.95rem;line-height:1.5;transition:all .3s ease}.topic-text.completed{color:var(--text-muted);opacity:.7;text-decoration:line-through}.select-all-text{font-size:.9rem}.select-all-text,.topic-label:hover .topic-text{color:var(--text-primary)}.topic-label:hover .checkbox-custom{border-color:var(--primary-color)}@media (max-width:768px){.subject-page{padding:1rem}.subject-header{margin-bottom:2rem;padding:1.5rem}.subject-title{font-size:2rem}.subject-description{font-size:1rem}.unit-header{padding:1.25rem}.unit-header-content{align-items:flex-start;flex-direction:column;gap:.75rem}.unit-controls{align-self:flex-end}.unit-progress{width:100%}.progress-bar-mini{max-width:none}.unit-title{font-size:1.125rem}.select-all-container,.topics-list{padding:1rem}.topic-label{padding:.75rem}}@media (prefers-reduced-motion:no-preference){.unit-content{transition:max-height .4s cubic-bezier(.4,0,.2,1)}}.sidebar-overlay{background-color:#00000080;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:998}.sidebar{background-color:var(--bg-secondary);border-right:1px solid var(--border-color);box-shadow:2px 0 10px #0000001a;height:calc(100vh - 80px);left:0;overflow-y:auto;position:fixed;top:80px;transform:translateX(-100%);transition:transform .3s ease-in-out;width:280px;z-index:999}.sidebar-open{transform:translateX(0)}.sidebar-content{height:100%;padding:1.5rem 0}.sidebar-header{margin-bottom:1.5rem;padding:0 1.5rem}.home-button{align-items:center;background:#0000;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.75rem;padding:.875rem 1rem;transition:all .2s ease;width:100%}.home-button:hover{background-color:var(--hover-bg);color:var(--text-primary)}.home-button.active{background-color:var(--primary-color);color:#fff}.sidebar-nav{flex:1 1}.nav-section{margin-bottom:1rem}.nav-header{align-items:center;background:#0000;border:none;color:var(--text-primary);cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.75rem;padding:.875rem 1.5rem;transition:all .2s ease;width:100%}.nav-header:hover{background-color:var(--hover-bg)}.nav-subheader{align-items:center;background:#0000;border:none;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.75rem;padding:.75rem 1.5rem .75rem 2.5rem;transition:all .2s ease;width:100%}.nav-subheader:hover{background-color:var(--hover-bg);color:var(--text-primary)}.nav-subsection,.subjects-list{margin-left:1rem}.subjects-list{border-left:2px solid var(--border-color);padding-left:1rem}.subject-item{align-items:center;background:#0000;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.75rem;margin:.25rem 0;padding:.75rem 1rem;transition:all .2s ease;width:100%}.subject-item:hover{background-color:var(--hover-bg);color:var(--text-primary);transform:translateX(4px)}.subject-item.active{background-color:var(--primary-color);color:#fff;font-weight:600}.subject-item.active .subject-icon{color:#fff}.chevron-icon{color:var(--text-secondary);font-size:.75rem;transition:transform .2s ease}.branch-icon{color:var(--secondary-color);font-size:.9rem}.subject-icon{color:var(--accent-color);font-size:.875rem}.subject-name{font-weight:500}@media (max-width:768px){.sidebar-overlay{display:block}.sidebar{height:calc(100vh - 70px);top:70px;width:280px}.sidebar-open{transform:translateX(0)}}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:var(--bg-secondary)}.sidebar::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.dashboard{margin:0 auto;max-width:1200px;padding:2rem}.dashboard-header{margin-bottom:3rem;text-align:center}.dashboard-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;background-clip:text;color:var(--text-primary);font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.dashboard-header p{color:var(--text-secondary);font-size:1.125rem;font-weight:400}.stats-overview{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:3rem}.stat-card{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;display:flex;gap:1rem;padding:1.5rem;transition:all .3s ease}.stat-card:hover{border-color:var(--primary-color);box-shadow:0 8px 25px #0000001a;transform:translateY(-2px)}.stat-icon{border-radius:10px;font-size:2rem;padding:.75rem}.stat-icon.completed{background-color:#2ecc711a;color:#2ecc71}.stat-icon.in-progress{background-color:#f39c121a;color:#f39c12}.stat-icon.total{background-color:#3498db1a;color:#3498db}.stat-content h3{color:var(--text-primary);font-size:2rem;font-weight:700;line-height:1;margin:0}.stat-content p{color:var(--text-secondary);font-size:.875rem;font-weight:500;margin:.25rem 0 0}.subjects-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.subject-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;cursor:pointer;overflow:hidden;padding:1.5rem;position:relative;transition:all .3s ease}.subject-card:before{background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));content:"";height:4px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.subject-card:hover{border-color:var(--primary-color);box-shadow:0 12px 40px #00000026;transform:translateY(-4px)}.subject-card:hover:before{transform:scaleX(1)}.subject-header{align-items:flex-start;display:flex;gap:1rem;margin-bottom:1rem}.subject-icon-container{align-items:center;border-radius:12px;display:flex;height:60px;justify-content:center;min-width:60px;padding:.75rem}.subject-icon{color:#fff;font-size:1.5rem}.subject-title h3{color:var(--text-primary);font-size:1.25rem;font-weight:700;margin:0 0 .25rem}.subject-title p{color:var(--text-secondary);font-size:.875rem;font-weight:500;line-height:1.4;margin:0}.subject-description{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin-bottom:1.5rem}.progress-section{margin-bottom:1.5rem}.progress-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.progress-header span:first-child{color:var(--text-secondary);font-size:.875rem;font-weight:600}.progress-percentage{color:var(--text-primary);font-size:.875rem;font-weight:700}.progress-bar{background-color:var(--bg-primary);border-radius:4px;height:8px;overflow:hidden}.progress-fill{border-radius:4px;height:100%;position:relative;transition:width .3s ease}.progress-fill:after{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#fff3,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.subject-footer{display:flex;justify-content:flex-end}.continue-btn{align-items:center;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.75rem 1.25rem;transition:all .3s ease}.continue-btn:hover{box-shadow:0 4px 15px #4050844d;transform:translateY(-1px)}.continue-btn:active{transform:translateY(0)}@media (max-width:768px){.dashboard{padding:1rem}.dashboard-header h1{font-size:2rem}.stats-overview,.subjects-grid{gap:1rem;grid-template-columns:1fr}.subject-card{padding:1.25rem}.subject-header{align-items:center;flex-direction:column;gap:.75rem;text-align:center}.subject-title h3{font-size:1.125rem}}
/*# sourceMappingURL=main.6521b25c.css.map*/