:root{--primary:#2B3FBF;--primary-hover:#1f2d8a;--accent:#F5C518;--accent-hover:#e0b415;--bg:#F8F8F8;--surface:#FFFFFF;--text:#1A1A2E;--text-muted:#6b7280;--success:#22C55E;--success-bg:#dcfce7;--error:#ef4444;--error-bg:#fee2e2;--locked:#9CA3AF;--locked-bg:#f3f4f6;--sidebar-bg:#1A1A2E;--sidebar-text:#FFFFFF;--border:#f3f4f6;--font-family:var(--font-inter,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif)}*{box-sizing:border-box;margin:0;padding:0}body,html{height:100%;font-family:var(--font-family)}.app-layout{display:flex;flex:1 1;min-height:100vh}.sidebar{background-color:var(--sidebar-bg);color:var(--sidebar-text);width:16rem;display:flex;flex-direction:column;flex-shrink:0;padding:1.5rem;height:100vh;position:-webkit-sticky;position:sticky;top:0}.main-content{flex:1 1;overflow-y:auto;padding:2rem;background-color:var(--bg);height:100vh}.mobile-nav-toggle{display:none;position:fixed;top:1rem;left:1rem;z-index:1001;width:44px;height:44px;border-radius:.5rem;background:var(--sidebar-bg);color:var(--sidebar-text);border:none;cursor:pointer;align-items:center;justify-content:center;padding:0}.mobile-nav-toggle svg{width:1.5rem;height:1.5rem;stroke:currentColor;stroke-width:2;fill:none}.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:999;opacity:0;transition:opacity .3s}.sidebar-overlay.active{opacity:1}@media (max-width:768px){body{height:auto;overflow:auto}.app-layout,body{display:block}.mobile-nav-toggle{display:flex}.sidebar-overlay{display:block}.sidebar{position:fixed;top:0;left:0;bottom:0;width:280px;z-index:1000;transform:translateX(-100%);transition:transform .3s ease-in-out;padding-top:5rem}.sidebar.open{transform:translateX(0)}.sidebar .user-switcher{margin-top:2rem}.main-content{padding:4rem 1rem 1rem;min-height:100vh}.grid-2{gap:1rem}.grid-2,.grid-3{grid-template-columns:1fr}.grid-4{grid-template-columns:repeat(2,1fr)}.roadmap-tree{margin-left:0;padding-left:1.5rem}.roadmap-cluster{margin-bottom:2rem}.section-title{font-size:1.25rem;margin-bottom:1.5rem}.section-subtitle{font-size:1.1rem;margin-bottom:1rem;color:var(--text)}.card{padding:1rem}.quiz-result-large{padding:2rem 1rem}.quiz-result-large .score{font-size:3.5rem}}.sidebar-header{margin-bottom:2.5rem}.sidebar-header h1{font-size:.875rem;font-weight:700;letter-spacing:-.025em;color:var(--surface);margin-bottom:0}.sidebar-header p{font-size:.625rem;color:var(--sidebar-text);opacity:.6;text-transform:uppercase;font-weight:400}.user-switcher{margin-top:auto;padding:1rem;background-color:rgba(255,255,255,.05);border-radius:.5rem}.user-switcher label{display:block;font-size:.625rem;color:rgba(255,255,255,.4);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.user-switcher select{width:100%;background:transparent;border:none;color:var(--surface);padding:0;border-radius:4px;font-family:var(--font-family);font-size:.75rem;font-weight:700;outline:none;cursor:pointer}.user-switcher select option{color:var(--text);background:var(--surface)}.sidebar-nav{flex:1 1;display:flex;flex-direction:column;gap:.5rem}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;color:var(--sidebar-text);opacity:.6;text-decoration:none;font-size:.875rem;font-weight:600;border-radius:4px;transition:all .2s}.nav-item:hover{opacity:1}.nav-item.active{background-color:var(--accent);color:var(--text);opacity:1}.card{background-color:var(--surface);border-radius:.75rem;padding:1.5rem;box-shadow:0 1px 2px 0 rgba(0,0,0,.05);margin-bottom:2rem;border:1px solid var(--border)}h2.section-title{font-size:1.5rem;margin-bottom:2rem;color:var(--text);font-weight:700}h3{font-size:1.25rem;margin-bottom:.5rem;font-weight:700}p{line-height:1.5;color:var(--text-muted);margin-bottom:1rem}.btn,p{font-size:.875rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.5rem;border-radius:.5rem;cursor:pointer;font-weight:700;text-decoration:none;transition:all .2s;border:none;font-family:var(--font-family);box-shadow:0 1px 2px 0 rgba(0,0,0,.05)}.btn-primary{background-color:var(--accent);color:var(--text)}.btn-primary:hover{filter:brightness(.95)}.btn-primary:active{transform:scale(.95)}.btn-secondary{background-color:transparent;border:1px solid var(--primary);color:var(--primary);box-shadow:none;font-weight:600}.btn-secondary:hover{background-color:#eff6ff}.btn.locked,.btn:disabled{cursor:not-allowed;background-color:var(--locked-bg);color:var(--locked);border:1px solid var(--border);box-shadow:none}.login-layout{min-height:100vh;background-color:var(--bg)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,var(--sidebar-bg) 0,#2d2d4a 100%)}.login-container{width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:2rem;font-weight:700;color:var(--surface);margin-bottom:.5rem}.login-header p{font-size:1rem;color:rgba(255,255,255,.7)}.login-form{background:var(--surface);padding:2rem;border-radius:.75rem;box-shadow:0 8px 30px rgba(0,0,0,.2)}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--text);margin-bottom:.5rem}.form-group input{width:100%;padding:.75rem 1rem;font-size:1rem;border:1px solid var(--border);border-radius:.5rem;background:var(--bg);color:var(--text);transition:border-color .2s,box-shadow .2s}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(43,63,191,.1)}.form-group input::placeholder{color:var(--text-muted)}.login-btn{width:100%;padding:.875rem;font-size:1rem;margin-top:.5rem}.login-error{background:var(--error-bg);color:var(--error);padding:.75rem 1rem;border-radius:.5rem;font-size:.875rem;margin-bottom:1rem;text-align:center}.login-demo{margin-top:1.5rem;text-align:center}.login-demo>p{font-size:.75rem;color:rgba(255,255,255,.5);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.demo-accounts{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem}.demo-accounts span{font-size:.7rem;color:rgba(255,255,255,.6);background:rgba(255,255,255,.1);padding:.25rem .5rem;border-radius:.25rem}@media (max-width:480px){.login-page{padding:1.5rem}.login-header h1{font-size:1.75rem}.login-form{padding:1.5rem}}.status-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:.25rem;font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.status-completed{color:var(--success);background-color:var(--surface);border:1px solid var(--border)}.status-available{color:var(--primary);background-color:#eff6ff}.status-locked{color:var(--locked);background-color:var(--locked-bg)}.progress-container{margin:1rem 0}.progress-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:.5rem;font-size:.75rem;font-weight:400}.progress-bar-bg{background-color:#e5e7eb;border-radius:3px;height:6px;width:100%;overflow:hidden}.progress-bar-fill{background-color:var(--success);height:100%;border-radius:3px;transition:width .5s ease-out}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:1.5rem;gap:1.5rem;margin-bottom:2rem}.grid-3{grid-template-columns:repeat(3,1fr);grid-gap:1rem}.grid-3,.grid-4{display:grid;gap:1rem}.grid-4{grid-template-columns:repeat(4,1fr);grid-gap:1rem}.roadmap-tree{margin-left:1rem;border-left:2px solid var(--border);padding-left:2rem;padding-top:.5rem}.roadmap-cluster{position:relative;margin-bottom:3rem}.cluster-marker{position:absolute;left:-2rem;top:0;transform:translateX(-50%);width:24px;height:24px;border-radius:50%;background:var(--locked-bg);border:4px solid var(--surface);box-shadow:0 4px 6px -1px rgba(0,0,0,.1);transition:background .3s}.roadmap-cluster.completed .cluster-marker{background:var(--success);border-color:var(--surface)}.roadmap-cluster.available .cluster-marker{background:var(--surface);border-color:var(--accent)}.cluster-header{margin-bottom:1.25rem;display:flex;align-items:center;gap:1rem}.cluster-header h3{font-size:.875rem;font-weight:700;margin:0}.roadmap-course-card{background:var(--surface);border:1px solid var(--border);padding:1.25rem;border-radius:.75rem;margin-bottom:1rem;cursor:pointer;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 2px 0 rgba(0,0,0,.05)}.roadmap-course-card:hover:not(.locked){transform:translateY(-2px);box-shadow:0 4px 6px -1px rgba(0,0,0,.05);border-color:var(--primary)}.roadmap-course-card.locked{opacity:.6;cursor:not-allowed;background-color:var(--locked-bg);box-shadow:none}.course-info h4{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:.25rem}.course-info p{font-size:.75rem;margin:0}.course-use-case{color:var(--text-muted)!important;font-size:.7rem!important;font-style:italic;margin-top:.25rem!important}.lesson-list{display:flex;flex-direction:column}.list-item{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;border-bottom:1px solid var(--border);background:var(--surface)}.list-item:first-child{border-top-left-radius:.75rem;border-top-right-radius:.75rem}.list-item:last-child{border-bottom:none;border-bottom-left-radius:.75rem;border-bottom-right-radius:.75rem}.list-item-content{display:flex;align-items:center;gap:1rem}.list-item-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--locked-bg);color:var(--locked)}.list-item.completed .list-item-icon{background:var(--success-bg);color:var(--success)}.list-item.available .list-item-icon{background:#eff6ff;color:var(--primary)}.list-item.locked{opacity:.6;background-color:var(--locked-bg)}.lesson-content{font-size:1rem;line-height:1.8;color:var(--text);padding:2rem}.lesson-content p{color:var(--text);margin-bottom:1.5rem}.markdown-content h1,.markdown-content h2,.markdown-content h3{margin-top:2rem;margin-bottom:1rem;color:var(--text)}.markdown-content h1{font-size:1.75rem}.markdown-content h2{font-size:1.5rem}.markdown-content h3{font-size:1.25rem}.markdown-content p{margin-bottom:1.25rem}.markdown-content ol,.markdown-content ul{margin-bottom:1.25rem;padding-left:1.5rem}.markdown-content li{margin-bottom:.5rem}.markdown-content code{background:var(--bg);padding:.2rem .4rem;border-radius:.25rem;font-family:monospace;font-size:.9rem}.markdown-content pre{background:var(--bg);padding:1rem;border-radius:.5rem;overflow-x:auto;margin-bottom:1.25rem}.markdown-content pre code{background:none;padding:0}.markdown-content strong{font-weight:600}.markdown-content a{color:var(--primary)}.lesson-materials{margin-top:2rem;padding:1.5rem;background:var(--bg);border-radius:.5rem;border:1px solid var(--border)}.lesson-materials h4{font-size:.875rem;font-weight:600;color:var(--text);margin-bottom:1rem}.materials-list{display:flex;flex-direction:column;gap:.75rem}.material-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:.5rem;text-decoration:none;color:var(--text);font-size:.875rem;transition:all .2s ease}.material-item:hover{border-color:var(--primary);background:#eff6ff}.material-item .icon{width:1.25rem;height:1.25rem;color:var(--primary)}.quiz-question{margin-bottom:2.5rem}.quiz-question p{font-weight:700;color:var(--text);margin-bottom:1rem;font-size:1rem}.quiz-options{display:flex;flex-direction:column;gap:.75rem}.quiz-option{display:flex;align-items:center;gap:.75rem;padding:1.25rem;border:1px solid var(--border);border-radius:.5rem;cursor:pointer;transition:all .2s;background:var(--surface)}.quiz-option:hover{background-color:var(--bg);border-color:var(--primary)}.quiz-option input[type=radio]{width:1.15rem;height:1.15rem;accent-color:var(--primary)}.quiz-result-large{text-align:center;padding:4rem 2rem}.quiz-result-large .score{font-size:5rem;font-weight:800;margin-bottom:1rem;line-height:1}.quiz-result-large.pass .score{color:var(--success)}.quiz-result-large.fail .score{color:var(--error)}.icon{width:1.25rem;height:1.25rem;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.flex-between{display:flex;justify-content:space-between;align-items:center}.loading-bar-container{position:fixed;top:0;left:0;right:0;height:3px;background:var(--bg);z-index:9999}.loading-bar{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));animation:loading-indeterminate 1.5s ease-in-out infinite;width:30%;border-radius:0 2px 2px 0}@keyframes loading-indeterminate{0%{transform:translateX(-100%);width:30%}50%{width:50%}to{transform:translateX(400%);width:30%}}.loading-spinner{display:flex;justify-content:center;align-items:center;min-height:200px}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,#e5e7eb 25%,#f3f4f6 50%,#e5e7eb 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:.5rem}.roadmap-skeleton{margin-left:1rem;border-left:2px solid var(--border);padding-left:2rem}.skeleton-cluster{margin-bottom:3rem}.skeleton-cluster-header{height:24px;width:200px;margin-bottom:1.25rem}.skeleton-courses{display:flex;flex-direction:column;gap:1rem}.skeleton-course-card{height:80px;width:100%}.course-skeleton{padding:1rem}.skeleton-course-header{height:32px;width:300px;margin-bottom:1.5rem}.skeleton-lessons{display:flex;flex-direction:column}.skeleton-lesson-item{height:72px;width:100%;margin-bottom:1rem}.dashboard-skeleton{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));grid-gap:1.5rem;gap:1.5rem}.skeleton-card{background:var(--surface);border:1px solid var(--border);border-radius:.75rem}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:1.5rem;gap:1.5rem;margin-bottom:2rem}.admin-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:.75rem;padding:1.5rem;display:flex;align-items:center;gap:1rem}.admin-stat-icon{width:48px;height:48px;border-radius:.5rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-stat-icon svg{width:24px;height:24px}.admin-stat-icon.blue{background:#eff6ff;color:var(--primary)}.admin-stat-icon.green{background:var(--success-bg);color:var(--success)}.admin-stat-icon.yellow{background:#fef9c3;color:var(--accent)}.admin-stat-icon.purple{background:#f3e8ff;color:#9333ea}.admin-stat-value{font-size:1.75rem;font-weight:800;color:var(--text);line-height:1;margin-bottom:.25rem}.admin-stat-label{font-size:.75rem;color:var(--text-muted);font-weight:500}.admin-charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));grid-gap:1.5rem;gap:1.5rem;margin-bottom:2rem}.admin-chart-card{background:var(--surface);border:1px solid var(--border);border-radius:.75rem;padding:1.5rem}.admin-chart-title{font-size:.875rem;font-weight:700;color:var(--text);margin-bottom:1.5rem}.progress-chart-item{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.progress-chart-label{width:80px;font-size:.75rem;color:var(--text-muted);flex-shrink:0}.progress-chart-bar-container{flex:1 1;height:24px;background:var(--bg);border-radius:4px;overflow:hidden}.progress-chart-bar{height:100%;border-radius:4px;display:flex;align-items:center;justify-content:flex-end;padding-right:.5rem}.progress-chart-bar.completed{background:var(--success)}.progress-chart-bar.completed span{font-size:.625rem;font-weight:700;color:white}.donut-chart-container{display:flex;align-items:center;gap:2rem}.donut-chart{width:120px;height:120px;border-radius:50%;position:relative;flex-shrink:0}.donut-chart-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80px;height:80px;background:var(--surface);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:800;color:var(--text)}.donut-legend{display:flex;flex-direction:column;gap:.75rem}.donut-legend-item{display:flex;align-items:center;gap:.5rem;font-size:.75rem}.donut-legend-dot{width:10px;height:10px;border-radius:2px}.donut-legend-dot.completed{background:var(--success)}.donut-legend-dot.available{background:var(--primary)}.donut-legend-dot.locked{background:var(--locked)}.admin-table{width:100%;border-collapse:collapse}.admin-table th{text-align:left;font-size:.625rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;padding:.75rem 1rem}.admin-table td,.admin-table th{border-bottom:1px solid var(--border)}.admin-table td{padding:1rem;font-size:.875rem;color:var(--text)}.admin-table tr:hover td{background:var(--bg)}.score-badge{display:inline-flex;align-items:center;justify-content:center;min-width:40px;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:700}.score-badge.pass{background:var(--success-bg);color:var(--success)}.score-badge.fail{background:var(--error-bg);color:var(--error)}.admin-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border)}.content-section{margin:.5rem 0}.content-toggle{font-size:.875rem!important}.content-submenu{margin-left:1.5rem;border-left:1px solid rgba(255,255,255,.1);padding-left:.5rem}.content-submenu .sub-item{font-size:.8rem!important;opacity:.7}.content-submenu .sub-item.active,.content-submenu .sub-item:hover{opacity:1}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/ba9851c3c22cd980-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/21350d82a1f187e9-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/c5fe6dc8356a8c31-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/19cfc7226ec3afaa-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/df0a9ae256c0569c-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/8e9860b6e62d6359-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Inter Fallback;src:local("Arial");ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.00%;size-adjust:107.12%}.__className_f367f3{font-family:Inter,Inter Fallback;font-style:normal}.__variable_f367f3{--font-inter:"Inter","Inter Fallback"}