.header-spacer[data-v-0db3ba26]{width:40px}.course-header-section[data-v-fd90b393]{margin-bottom:20px;text-align:left}.course-title[data-v-fd90b393]{font-size:32px;font-weight:700;color:var(--text-primary);margin-bottom:15px}.back-link[data-v-fd90b393]{display:inline-block;color:var(--accent);text-decoration:none;font-size:14px;transition:opacity .3s ease;margin-bottom:15px}.back-link[data-v-fd90b393]:hover{opacity:.8}.pagination[data-v-fd90b393]{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:15px;background:#f8fafc;border-radius:8px}.dark-theme .pagination[data-v-fd90b393]{background:#1e293b}.pagination-bottom[data-v-fd90b393]{margin-top:30px;margin-bottom:0}.pagination-btn[data-v-fd90b393]{padding:8px 16px;background:var(--accent);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:opacity .3s ease,transform .2s ease}.pagination-btn[data-v-fd90b393]:hover:not(:disabled){opacity:.9;transform:translateY(-2px)}.pagination-btn[data-v-fd90b393]:disabled{opacity:.5;cursor:not-allowed}.page-info[data-v-fd90b393]{font-size:14px;color:var(--text-primary);font-weight:500}.course-content[data-v-fd90b393]{line-height:1.8;color:var(--text-primary)}.lesson-content h2[data-v-fd90b393]{font-size:28px;font-weight:700;color:var(--text-primary);margin-top:30px;margin-bottom:20px}.lesson-content h3[data-v-fd90b393]{font-size:22px;font-weight:600;color:var(--text-primary);margin-top:25px;margin-bottom:15px}.lesson-content p[data-v-fd90b393]{margin-bottom:15px;font-size:16px}.lesson-content ul[data-v-fd90b393],.lesson-content ol[data-v-fd90b393]{margin-bottom:15px;padding-left:30px}.lesson-content li[data-v-fd90b393]{margin-bottom:8px;font-size:16px}.lesson-content code[data-v-fd90b393]{background:#f1f5f9;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-size:14px;color:#e11d48}.dark-theme .lesson-content code[data-v-fd90b393]{background:#334155;color:#f87171}.lesson-content pre[data-v-fd90b393]{background:#f8fafc;padding:15px;border-radius:8px;overflow-x:auto;margin-bottom:20px;border-left:4px solid var(--accent)}.dark-theme .lesson-content pre[data-v-fd90b393]{background:#1e293b}.lesson-content pre code[data-v-fd90b393]{background:transparent;padding:0;color:var(--text-primary);font-size:14px}.dark-theme .lesson-content pre code[data-v-fd90b393]{color:#f7fafc}.lesson-content a[data-v-fd90b393]{color:var(--accent);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .3s ease}.lesson-content a[data-v-fd90b393]:hover{border-bottom-color:var(--accent)}.note[data-v-fd90b393]{background:#fef3c7;padding:15px;border-radius:8px;border-left:4px solid #f59e0b;margin:20px 0}.dark-theme .note[data-v-fd90b393]{background:#451a03;border-left-color:#f59e0b}.dom-diagram[data-v-fd90b393]{margin:25px 0;text-align:center}.dom-image[data-v-fd90b393]{max-width:100%;height:auto;border-radius:8px;box-shadow:0 4px 6px #0000001a}@media (max-width: 640px){.course-title[data-v-fd90b393]{font-size:24px}.pagination[data-v-fd90b393]{flex-direction:column;gap:10px}.lesson-content h2[data-v-fd90b393]{font-size:24px}.lesson-content h3[data-v-fd90b393]{font-size:20px}.lesson-content pre[data-v-fd90b393]{font-size:12px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Titillium Web,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:300;background:linear-gradient(135deg,#1e1b4b,#312e81,#1e1b4b);height:100vh;color:#333;overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}.dark-theme body{background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a)}#app{height:100vh;display:flex;align-items:center;justify-content:center;padding:0;overflow:hidden;width:100%}:root{--bg-primary: #ffffff;--bg-secondary: #2d3748;--text-primary: #1a202c;--text-secondary: #ffffff;--accent: #f97316;--accent-hover: #ea580c;--shadow: 0 20px 50px rgba(0, 0, 0, .15);--shadow-hover: 0 25px 60px rgba(0, 0, 0, .2)}.dark-theme{--bg-primary: #1a202c;--bg-secondary: #2d3748;--text-primary: #f7fafc;--text-secondary: #ffffff;--shadow: 0 20px 50px rgba(0, 0, 0, .3)}.container{display:flex;gap:0;align-items:stretch;justify-content:flex-start;width:100%;max-width:100%;height:100vh;position:relative;flex-direction:row;margin:0;padding:0}.main-card-wrapper{flex:0 0 auto;width:100px;min-width:100px;height:100vh;display:flex;flex-direction:column}.card{background:#f8f9fa;border-radius:0;box-shadow:2px 0 10px #0000001a;padding:0;margin-bottom:0;transition:all .4s cubic-bezier(.4,0,.2,1);overflow:visible;position:relative;display:flex;flex-direction:column;height:100%;border-right:1px solid rgba(0,0,0,.08)}.dark-theme .card{background:#0f1419;border-right-color:#ffffff1a}.card:hover{box-shadow:4px 0 20px #00000026}.side-panel{flex:1;background:var(--bg-primary);border-radius:0;box-shadow:none;padding:50px;overflow-y:auto;transition:all .4s cubic-bezier(.4,0,.2,1);height:100vh}.side-panel::-webkit-scrollbar{width:10px}.side-panel::-webkit-scrollbar-track{background:transparent;border-radius:10px}.side-panel::-webkit-scrollbar-thumb{background:#0003;border-radius:10px;border:2px solid transparent;background-clip:content-box}.side-panel::-webkit-scrollbar-thumb:hover{background:#0000004d;background-clip:content-box}.dark-theme .side-panel::-webkit-scrollbar-thumb{background:#ffffff40;background-clip:content-box}.dark-theme .side-panel::-webkit-scrollbar-thumb:hover{background:#ffffff59;background-clip:content-box}.welcome-screen{animation:fadeIn .8s cubic-bezier(.4,0,.2,1);max-width:1000px;width:100%}.welcome-name{font-size:48px;font-weight:900;color:var(--text-primary);margin-bottom:15px;letter-spacing:-1px;line-height:1.1}.welcome-subtitle{font-size:20px;font-weight:300;color:var(--text-primary);opacity:.7;margin-bottom:50px;padding-bottom:30px;border-bottom:2px solid rgba(0,0,0,.1)}.dark-theme .welcome-subtitle{border-bottom-color:#ffffff1a}.welcome-content{display:flex;flex-direction:column;gap:40px}.welcome-section h3{font-size:24px;font-weight:900;color:var(--text-primary);margin-bottom:20px;display:flex;align-items:center;gap:10px}.welcome-section h3:before{content:"";width:4px;height:24px;background:var(--accent);border-radius:2px}.welcome-section>p{font-size:16px;font-weight:300;color:var(--text-primary);line-height:1.8;opacity:.9}.skills-highlight{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:25px;margin-top:20px}.skill-item{display:flex;gap:20px;background:#f8fafc;padding:25px;border-radius:15px;border-left:4px solid var(--accent);transition:all .3s ease}.skill-item:hover{transform:translate(5px);box-shadow:0 4px 12px #00000014}.dark-theme .skill-item{background:#1e293b}.skill-icon{font-size:32px;flex-shrink:0;line-height:1;color:var(--accent)}.inline-icon{display:inline-block;vertical-align:middle;margin-right:8px;color:var(--accent)}.panel-title-icon{display:inline-flex;align-items:center;margin-right:10px;color:var(--accent)}.skill-item h4{font-size:17px;font-weight:900;color:var(--text-primary);margin-bottom:8px}.skill-item p{font-size:14px;font-weight:300;color:var(--text-primary);opacity:.85;line-height:1.6;margin:0}.welcome-cta{text-align:center;padding:30px;background:linear-gradient(135deg,#f973161a,#f973160d);border-radius:15px;margin-top:20px}.welcome-cta p{font-size:16px;font-weight:400;color:var(--text-primary);margin:0}.header{position:fixed;top:20px;right:30px;z-index:1000;display:flex;gap:15px;align-items:center}.theme-toggle{background:var(--bg-primary);border:none;cursor:pointer;padding:12px;border-radius:50%;transition:all .3s cubic-bezier(.4,0,.2,1);color:var(--text-primary);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00000026}.theme-toggle:hover{background-color:var(--accent);color:#fff;transform:scale(1.1) rotate(20deg);box-shadow:0 6px 20px #f9731666}.theme-toggle:active{transform:scale(.95) rotate(20deg)}.icon{width:22px;height:22px;fill:currentColor}.profile{text-align:center;padding:30px 15px 20px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:20px}.profile-image{width:60px;height:60px;border-radius:50%;object-fit:cover;margin:0;border:4px solid #3b82f6;box-shadow:0 10px 30px #3b82f64d;transition:all .3s ease;cursor:pointer}.profile-image:hover{transform:scale(1.1);box-shadow:0 15px 40px #3b82f666;border-color:var(--accent)}.profile-name{font-size:0;font-weight:900;color:var(--text-primary);margin:0;writing-mode:vertical-rl;text-orientation:mixed;letter-spacing:3px;cursor:pointer;transition:all .3s ease}.profile-name:hover{color:var(--accent);transform:scale(1.05)}.profile-name:before{content:"FYN";font-size:22px;font-weight:900}.profile-title{display:none}.dark-theme .profile{background:var(--bg-primary)}.social-links{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:15px;margin-bottom:20px}.social-link{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;background-color:#1a202c;transition:all .3s cubic-bezier(.4,0,.2,1);text-decoration:none;color:#fff;box-shadow:0 4px 12px #0000001a}.social-link:hover{background-color:var(--accent);color:#fff;transform:scale(1.15);box-shadow:0 8px 20px #f9731666}.social-link:active{transform:scale(1.05)}.dark-theme .social-link{background-color:#2d3748;color:#f7fafc}.dark-theme .social-link svg{color:#f7fafc;stroke:#f7fafc}.social-link svg{color:inherit;stroke:currentColor;fill:none}.social-link{color:#fff}.dark-theme .social-link svg{color:#f7fafc!important;stroke:#f7fafc!important}.nav-buttons{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:12px;margin-bottom:0;padding-bottom:20px}.nav-btn{background:transparent;color:var(--text-primary);border:2px solid rgba(0,0,0,.1);width:35px;height:35px;border-radius:50%;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;position:relative;padding:0}.nav-btn svg{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:inherit;stroke:currentColor}.nav-btn-text{position:absolute;left:calc(100% + 12px);top:50%;transform:translateY(-50%) translate(-10px);white-space:nowrap;opacity:0;transition:all .3s cubic-bezier(.4,0,.2,1);font-size:14px;font-weight:600;color:var(--text-primary);pointer-events:none;z-index:1000;background:var(--bg-primary);padding:6px 14px;border-radius:8px;box-shadow:0 4px 12px #0003;border:1px solid rgba(0,0,0,.1)}.dark-theme .nav-btn-text{border-color:#ffffff1a;background:#1e293b;color:#f7fafc}.nav-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:scale(1.15);box-shadow:0 8px 20px #f9731666}.nav-btn:hover .nav-btn-text{opacity:1;transform:translateY(-50%) translate(0);color:var(--text-primary)}.nav-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);transform:scale(1.05)}.nav-btn:active{transform:scale(1.05)}.dark-theme .nav-btn{border-color:#fff3;color:#f7fafc}.dark-theme .nav-btn svg{color:#f7fafc!important;stroke:#f7fafc!important}.btn-primary{background:var(--accent);color:#fff;border:none;padding:12px 40px;border-radius:50px;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-block;text-decoration:none;font-size:15px;letter-spacing:.3px;box-shadow:0 6px 16px #f973164d;position:relative;z-index:2;margin-bottom:15px}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-3px);box-shadow:0 10px 24px #f9731673}.btn-primary:active{transform:translateY(-1px);box-shadow:0 4px 12px #f9731659}.description{font-size:15px;line-height:1.7;text-align:center;font-weight:300;letter-spacing:.2px}.side-panel-content{animation:slideInRight .4s cubic-bezier(.4,0,.2,1);max-width:1200px;width:100%}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}.panel-title{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:25px;text-align:left;letter-spacing:-.5px;display:flex;align-items:center;justify-content:space-between;gap:12px}.panel-title-left{display:flex;align-items:center;gap:12px}.panel-title-right{font-size:18px;font-weight:300;opacity:.5;letter-spacing:0;white-space:nowrap}.panel-title-icon{display:inline-flex;align-items:center;flex-shrink:0}.section-item{background:#f8fafc;padding:20px;border-radius:15px;margin-bottom:15px;border-left:4px solid var(--accent);transition:all .3s ease;width:100%;box-sizing:border-box}.section-item:hover{transform:translate(5px);box-shadow:0 4px 12px #00000014}.dark-theme .section-item{background:#1e293b}.section-item h4{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:8px;display:flex;align-items:center;gap:8px}.section-item h4 .inline-icon{flex-shrink:0}.section-item p{font-size:14px;color:var(--text-primary);opacity:.85;line-height:1.6;margin:6px 0;font-weight:300}.section-item strong{color:var(--accent);font-weight:700}.course-item{cursor:pointer;position:relative;border-left:4px solid var(--accent)}.course-item:hover{transform:translate(8px);box-shadow:0 6px 16px #f9731633;background:linear-gradient(135deg,#fff7ed,#f8fafc)}.dark-theme .course-item:hover{background:linear-gradient(135deg,#451a03,#1e293b)}.course-link{color:var(--accent)!important;font-weight:600!important;margin-top:10px!important;opacity:1!important}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-top:10px}.project-card{background:#f8fafc;padding:24px;border-radius:15px;border-left:4px solid var(--accent);transition:all .3s ease;text-decoration:none;color:inherit;display:block;box-sizing:border-box}.project-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0000001f;border-left-color:var(--accent)}.dark-theme .project-card{background:#1e293b}.dark-theme .project-card:hover{box-shadow:0 8px 20px #0000004d}.project-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.project-header h4{font-size:20px;font-weight:700;color:var(--text-primary);margin:0;flex:1}.project-status{display:flex;align-items:center;gap:6px;margin-left:12px}.status-dot{width:12px;height:12px;border-radius:50%;display:inline-block;flex-shrink:0}.status-production .status-dot{background-color:#10b981;box-shadow:0 0 0 3px #10b98133}.status-development .status-dot{background-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b33}.project-url{font-size:14px;color:var(--accent);font-weight:600;margin:8px 0 12px;opacity:.9}.project-description{font-size:14px;color:var(--text-primary);opacity:.8;line-height:1.6;margin:0;font-weight:300}@media (max-width: 768px){.sidebar{width:280px;max-width:90vw;padding:25px 20px 50px}.sidebar-header{margin-bottom:25px;padding-bottom:15px}.sidebar-title{font-size:20px}.menu-link{padding:14px 18px;font-size:15px}.projects-grid{grid-template-columns:1fr;gap:15px}.project-card{padding:20px}.project-header h4{font-size:18px}}@media (max-width: 480px){.sidebar{width:100vw;max-width:100vw;padding:20px 15px 60px}.sidebar-header{margin-bottom:20px;padding-bottom:12px}.menu-link{padding:12px 16px;font-size:14px}}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:15px;margin-top:10px;width:100%}.skill-category{background:#f8fafc;padding:15px;border-radius:12px;border-left:4px solid var(--accent);width:100%;box-sizing:border-box}.dark-theme .skill-category{background:#1e293b}.skill-category h5{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:10px}.skill-category p{font-size:13px;color:var(--text-primary);opacity:.8;line-height:1.5;font-weight:300}.sidebar{position:fixed;top:0;left:-320px;width:320px;max-width:85vw;height:100vh;max-height:100vh;background:var(--bg-primary);box-shadow:4px 0 30px #0003;transition:left .4s cubic-bezier(.4,0,.2,1);z-index:1000;padding:30px 25px 40px;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;box-sizing:border-box}.dark-theme .sidebar{background:var(--bg-primary)}.sidebar.open{left:0}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-thumb{background:var(--accent);border-radius:10px}.sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid #e5e7eb}.dark-theme .sidebar-header{border-bottom-color:#ffffff1a}.sidebar-title{font-size:22px;font-weight:900;color:var(--text-primary);letter-spacing:-.3px}.close-btn{background:transparent;border:none;cursor:pointer;padding:8px;border-radius:10px;transition:all .3s cubic-bezier(.4,0,.2,1);color:var(--text-primary);display:flex;align-items:center;justify-content:center}.close-btn:hover{background-color:#f973161a;color:var(--accent);transform:rotate(90deg)}.close-btn svg{color:inherit;stroke:currentColor}.dark-theme .close-btn{color:#f7fafc}.dark-theme .close-btn svg{color:#f7fafc;stroke:#f7fafc}.close-btn:active{transform:rotate(90deg) scale(.9)}.sidebar nav{flex:1;display:flex;flex-direction:column;min-height:0;overflow-y:auto}.menu-list{list-style:none;margin:0;padding:0;flex:1;display:flex;flex-direction:column;min-height:0}.menu-item{margin-bottom:10px;flex-shrink:0}.menu-item:last-child{margin-bottom:0}.menu-link{display:flex;align-items:center;padding:16px 20px;color:var(--text-primary);text-decoration:none;border-radius:12px;transition:all .3s cubic-bezier(.4,0,.2,1);font-weight:600;font-size:16px;position:relative;overflow:hidden}.menu-link:before{content:"";position:absolute;left:0;top:0;height:100%;width:4px;background:var(--accent);transform:scaleY(0);transition:transform .3s ease}.menu-link:hover{background-color:#f973161a;color:var(--accent);transform:translate(8px);padding-left:24px}.menu-link:hover:before{transform:scaleY(1)}.menu-link:active{transform:translate(6px)}.menu-link svg{color:inherit;stroke:currentColor;flex-shrink:0;margin-right:12px}.dark-theme .menu-link{color:#f7fafc}.dark-theme .menu-link svg{color:#f7fafc;stroke:#f7fafc}.dark-theme .sidebar svg{color:#f7fafc;stroke:#f7fafc}.dark-theme .sidebar .social-link svg,.dark-theme .sidebar .close-btn svg,.dark-theme .sidebar .menu-link svg{color:#f7fafc!important;stroke:#f7fafc!important}.dark-theme .nav-btn svg{color:#f7fafc;stroke:#f7fafc}.nav-btn svg{color:inherit;stroke:currentColor}.overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:999;opacity:0;visibility:hidden;transition:all .3s ease}.overlay.show{opacity:1;visibility:visible}@media (max-width: 1024px) and (min-width: 641px){.container{flex-direction:column;gap:20px;width:95%;max-height:95vh;overflow-y:auto}.main-card-wrapper{flex:none;width:100%;max-width:480px;max-height:none}.side-panel{flex:none;width:100%;max-width:480px;height:auto;min-height:400px}}@media (max-width: 640px){.container{width:100%;height:100vh;padding:0;gap:0;flex-direction:row}.main-card-wrapper{flex:0 0 auto;width:80px;min-width:80px;height:100vh;max-height:100vh}.card{border-radius:0;height:100vh}.header{top:15px;right:15px}.theme-toggle{padding:10px}.icon{width:20px;height:20px}.profile{padding:20px 10px;display:flex;flex-direction:column;align-items:center;gap:15px}.profile-image{width:60px;height:60px;border-width:3px}.profile-name{font-size:16px;writing-mode:vertical-rl;text-orientation:mixed;letter-spacing:2px;margin-bottom:0}.profile-name:before{content:"FYN"}.profile-name{font-size:0}.profile-name:before{font-size:18px;font-weight:900}.profile-title{display:none}.social-links{flex-direction:column;gap:12px;margin-bottom:15px}.social-link{width:30px;height:30px}.nav-buttons{flex-direction:column;gap:10px;margin-bottom:0}.nav-btn{width:35px;height:35px}.nav-btn span{font-size:16px}.side-panel{flex:1;max-width:none;width:calc(100% - 80px);height:100vh;padding:30px 20px;border-radius:0}.panel-title{font-size:24px;margin-bottom:20px}.panel-title-icon{width:24px;height:24px}.section-item{padding:15px;margin-bottom:12px}.section-item h4{font-size:16px}.section-item p{font-size:13px}.skills-grid{grid-template-columns:1fr}.panel-title-right{display:none}.welcome-name{font-size:32px}.welcome-subtitle{font-size:16px;margin-bottom:30px}.welcome-section h3{font-size:20px}.skills-highlight{grid-template-columns:1fr}.skill-item{padding:20px}.skill-icon{font-size:28px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .8s cubic-bezier(.4,0,.2,1)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}*:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:4px}.card,.social-link,.btn-primary,.menu-link{will-change:transform}html{scroll-behavior:smooth}
