:root{--primary:#4d8ee8;--primary-light:#6ba3ff;--primary-dark:#2a5cb5;--secondary:#7a4ced;--dark:#0f0f15;--darker:#08080d;--light:#f0f4f8;--gray:#252535;--light-gray:#3a3a4a;--transition:all .4s cubic-bezier(.175, .885, .32, 1.275)}*{box-sizing:border-box;scrollbar-width:none;margin:0;padding:0}body{background-color:var(--dark);color:var(--light);font-family:Poppins,sans-serif;line-height:1.6;overflow-x:hidden}.welcome-overlay{background-color:var(--darker);z-index:9999;opacity:1;justify-content:center;align-items:center;width:100%;height:100%;transition:opacity .8s ease-out;display:flex;position:fixed;top:0;left:0}.welcome-overlay.fade-out{opacity:0;pointer-events:none}.welcome-container{align-items:center;display:flex}.welcome-text{color:var(--primary);text-shadow:0 0 20px #5b9af4fe;font-family:JetBrains Mono,monospace;font-size:100px;font-weight:600}.cursor{color:var(--primary);margin-left:4px;font-size:80px;animation:.7s infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.sidebar{background-color:var(--darker);z-index:1000;border-right:1px solid #ffffff0d;flex-direction:column;width:280px;height:100vh;padding:2rem 1.5rem;transition:transform .4s;display:flex;position:fixed;top:0;left:0;transform:translate(0)}.sidebar.hidden{transform:translate(-100%)}.sidebar-header{border-bottom:1px solid var(--gray);align-items:center;margin-bottom:2.5rem;padding-bottom:1.5rem;display:flex}.sidebar-avatar{object-fit:cover;border:2px solid var(--primary);border-radius:50%;width:50px;height:50px;margin-right:15px;box-shadow:0 0 20px #456695}.sidebar-name{color:var(--light);font-size:1.1rem;font-weight:600}.sidebar-title{color:var(--primary);opacity:.8;font-size:.8rem}.nav-links{flex-direction:column;gap:.5rem;display:flex}.nav-link{color:var(--light);transition:var(--transition);border-radius:8px;align-items:center;padding:.8rem 1rem;text-decoration:none;display:flex;position:relative;overflow:hidden}.nav-link:before{content:"";background:var(--primary);width:3px;height:100%;transition:transform .3s;position:absolute;top:0;left:0;transform:scaleY(0)}.nav-link:hover:before{transform:scaleY(1)}.nav-link i{text-align:center;width:24px;margin-right:12px;font-size:1.1rem;transition:all .3s}.nav-link:hover i{color:var(--primary-light);transform:scale(1.2)rotate(5deg)}.nav-link:hover,.nav-link.active{color:var(--primary-light);background-color:#4d8ee81a;transform:translate(5px)}.nav-link.active{box-shadow:inset 3px 0 0 var(--primary);font-weight:500}.nav-link.active:before{transform:scaleY(1)}.mobile-menu-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--gray);color:var(--light);cursor:pointer;z-index:999;width:50px;height:50px;transition:var(--transition);background:#0f0f15cc;border-radius:50%;justify-content:center;align-items:center;font-size:1.2rem;display:none;position:fixed;top:20px;left:20px}.mobile-menu-btn:hover{background:var(--primary);color:var(--dark)}.mobile-nav{background-color:var(--darker);z-index:1000;border-top:1px solid var(--gray);width:100%;padding:12px 0;display:none;position:fixed;bottom:0;left:0;box-shadow:0 -5px 20px #0000004d}.mobile-nav-container{justify-content:space-around;display:flex}.mobile-nav a{color:var(--light);transition:var(--transition);cursor:pointer;border-radius:8px;flex-direction:column;align-items:center;padding:5px 10px;font-size:.7rem;text-decoration:none;display:flex}.mobile-nav a i{margin-bottom:5px;font-size:1.2rem}.mobile-nav a.active{color:var(--primary);background:#4d8ee81a}.main-container{width:calc(100% - 280px);max-width:100vw;margin-left:280px;transition:margin-left .4s;overflow-x:hidden}.home{flex-direction:column;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:4rem 3rem;display:flex}.home-content{grid-template-columns:1fr 1fr;align-items:center;gap:3rem;width:100%;max-width:1200px;margin:0 auto;display:grid}.profile-container{flex-direction:column;align-items:flex-start;animation:6s ease-in-out infinite float;display:flex}@keyframes float{0%,to{transform:translate(0)}50%{transform:translate(20px)}}.profile-img{object-fit:cover;border:8px solid var(--primary);width:380px;height:430px;transition:var(--transition);border-radius:20px;margin-bottom:2rem;box-shadow:0 20px 50px #4d8ee84d}.profile-img:hover{border-color:var(--primary-light);box-shadow:0 30px 70px #4d8ee880}.intro-text{background:radial-gradient(circle,#4d8ee826 0%,#0f0f1500 70%);width:100%;max-width:500px}.greeting{color:var(--primary);align-items:center;gap:10px;margin-bottom:.5rem;font-size:1.1rem;display:flex}.greeting:before{content:"";background:var(--primary);width:30px;height:2px;display:block}.name{margin:.5rem 0 1rem;font-size:3.5rem;font-weight:700;line-height:1.2}.title{color:var(--light);opacity:.9;margin-bottom:1.5rem;font-size:1.8rem;font-weight:600}.tagline{color:#f0f4f8cc;margin-bottom:2rem;font-size:1.1rem;line-height:1.7}.social-links{gap:1rem;margin-bottom:2rem;display:flex}.social-link{background:var(--gray);width:40px;height:40px;color:var(--light);transition:var(--transition);border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;text-decoration:none;display:flex;position:relative;overflow:hidden}.social-link:before{content:"";background:var(--primary);z-index:-1;border-radius:50%;width:100%;height:100%;transition:transform .4s;position:absolute;transform:scale(0)}.social-link:hover:before{transform:scale(1)}.social-link:hover{color:var(--dark);transform:translateY(-5px)rotate(360deg);box-shadow:0 8px 20px #4d8ee866}.skills-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--gray);background-color:#0a0a0fb3;border-radius:15px;max-width:1200px;margin:3rem auto;padding:2rem 0;overflow:hidden;box-shadow:0 20px 40px #0000004d}.skills-section h2{color:var(--primary);align-items:center;gap:10px;margin-bottom:1.5rem;padding:0 2rem;font-size:1.5rem;display:flex}.skills-section h2:before{content:"";background:var(--primary);flex-shrink:0;width:30px;height:2px;display:block}.marquee-wrapper{flex-direction:column;gap:.85rem;display:flex}.marquee-track{width:100%;position:relative;overflow:hidden}.marquee-track:before,.marquee-track:after{content:"";z-index:2;pointer-events:none;width:80px;position:absolute;top:0;bottom:0}.marquee-track:before{background:linear-gradient(90deg,#0a0a0fd9,#0000);left:0}.marquee-track:after{background:linear-gradient(270deg,#0a0a0fd9,#0000);right:0}.marquee-row{gap:.85rem;width:max-content;padding:.25rem 0;display:flex}.marquee-left{animation:28s linear infinite marqueeLeft}.marquee-right{animation:32s linear infinite marqueeRight}.marquee-track:hover .marquee-left,.marquee-track:hover .marquee-right{animation-play-state:paused}@keyframes marqueeLeft{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes marqueeRight{0%{transform:translate(-50%)}to{transform:translate(0)}}.skill-chip{color:#f0f4f8c7;white-space:nowrap;cursor:default;-webkit-user-select:none;user-select:none;background:#4d8ee814;border:1px solid #4d8ee833;border-radius:8px;align-items:center;gap:6px;padding:.55rem 1.1rem;font-size:.88rem;font-weight:500;transition:background .25s,color .25s,border-color .25s,transform .25s,box-shadow .25s;display:inline-flex}.skill-chip:hover{color:var(--primary-light);border-color:var(--primary);background:#4d8ee838;transform:translateY(-2px);box-shadow:0 6px 18px #4d8ee840}.achievements{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--gray);background-color:#0a0a0fb3;border-radius:15px;width:100%;max-width:1200px;padding:2.5rem;animation:.8s .3s both slideUp;box-shadow:0 20px 40px #0000004d}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.achievements h2{color:var(--primary);align-items:center;gap:10px;margin-bottom:1.5rem;font-size:1.5rem;display:flex}.achievements h2:before{content:"";background:var(--primary);flex-shrink:0;width:30px;height:2px;display:block}.achievement-item{transition:var(--transition);border-left:3px solid #0000;border-radius:8px;align-items:flex-start;margin:1.5rem 0;padding:1rem;display:flex;position:relative;overflow:hidden}.achievement-item:before{content:"";background:linear-gradient(90deg,#0000,#4d8ee80d,#0000);width:100%;height:100%;transition:left .6s;position:absolute;top:0;left:-100%}.achievement-item:hover:before{left:100%}.achievement-item:hover{border-left-color:var(--primary);background-color:#4d8ee814;transform:translate(10px)scale(1.01);box-shadow:0 5px 20px #4d8ee826}.achievement-icon{min-width:30px;color:var(--primary);flex-shrink:0;margin-top:3px;margin-right:15px;font-size:1.5rem;transition:all .3s}.achievement-item:hover .achievement-icon{color:var(--primary-light);transform:scale(1.2)rotate(10deg)}.achievement-content h3{color:var(--light);margin-bottom:.5rem;font-size:1.2rem}.achievement-content p{color:#f0f4f8b3;font-size:.95rem}.section-page{width:100%;max-width:100vw;min-height:100vh;padding:4rem 3rem;overflow-x:hidden}.section-header{max-width:1200px;margin:0 auto 3rem}.section-title{color:var(--light);margin-bottom:1rem;font-size:2.5rem;transition:all .3s;display:inline-block;position:relative}.section-title:after{content:"";background:linear-gradient(90deg, var(--primary), var(--secondary));border-radius:2px;width:60px;height:4px;transition:width .4s;position:absolute;bottom:-10px;left:0}.section-title:hover{color:var(--primary-light);transform:translate(5px)}.section-title:hover:after{width:100%}.section-subtitle{color:#f0f4f8b3;max-width:600px}.filter-buttons{flex-wrap:wrap;gap:10px;max-width:1200px;margin-bottom:2rem;margin-left:auto;margin-right:auto;display:flex}.filter-btn{background-color:var(--gray);color:var(--light);cursor:pointer;transition:var(--transition);border:none;border-radius:30px;padding:.6rem 1.2rem;font-family:Poppins,sans-serif;font-size:.9rem;position:relative;overflow:hidden}.filter-btn:after{content:"";background:linear-gradient(90deg,#0000,#fff3,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.filter-btn:hover:after{left:100%}.filter-btn.active,.filter-btn:hover{background-color:var(--primary);color:var(--dark);transform:translateY(-2px)scale(1.05);box-shadow:0 5px 15px #4d8ee866}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem;max-width:1200px;margin:0 auto;display:grid}.project-card{background-color:var(--darker);transition:var(--transition);border:1px solid var(--gray);border-radius:12px;flex-direction:column;display:flex;position:relative;overflow:hidden;box-shadow:0 10px 30px #0000004d}.project-card:before{content:"";background:linear-gradient(90deg, var(--primary), var(--secondary));height:3px;transition:transform .4s;position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.project-card:hover:before{transform:scaleX(1)}.project-card:hover{border-color:var(--primary);transform:translateY(-10px)scale(1.02);box-shadow:0 20px 50px #4d8ee84d}.project-cat-badge{text-transform:uppercase;letter-spacing:1px;color:var(--primary-light);background:#4d8ee826;border:1px solid #4d8ee84d;border-radius:20px;margin-bottom:.8rem;padding:3px 10px;font-size:.68rem;font-weight:600;display:inline-block}.project-content{flex-direction:column;flex-grow:1;padding:1.5rem;display:flex}.project-title{color:var(--light);margin-bottom:.8rem;font-size:1.4rem}.project-desc{color:#f0f4f8b3;flex-grow:1;margin-bottom:1.2rem;font-size:.95rem;line-height:1.6}.tech-stack{flex-wrap:wrap;gap:8px;margin-bottom:1.5rem;display:flex}.tech-item{color:var(--primary);background-color:#4d8ee81a;border:1px solid #0000;border-radius:20px;padding:.3rem .8rem;font-family:JetBrains Mono,monospace;font-size:.75rem;transition:all .3s}.tech-item:hover{color:var(--primary-light);border-color:var(--primary);background-color:#4d8ee840;transform:translateY(-3px)scale(1.1);box-shadow:0 5px 15px #4d8ee84d}.project-links{gap:12px;margin-top:auto;display:flex}.project-link{color:var(--light);transition:var(--transition);border-radius:6px;align-items:center;padding:.5rem 1.2rem;font-size:.9rem;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.project-link i{margin-right:8px;transition:transform .3s}.project-link:hover i{transform:scale(1.2)rotate(10deg)}.demo-link{background-color:var(--primary);color:var(--dark)}.demo-link:hover{background-color:var(--primary-light);transform:translateY(-3px)scale(1.05);box-shadow:0 8px 20px #4d8ee866}.code-link{background-color:var(--gray)}.code-link:hover{background-color:var(--light-gray);transform:translateY(-3px)scale(1.05);box-shadow:0 5px 15px #ffffff1a}.papers-list{flex-direction:column;gap:1.5rem;max-width:1200px;margin:0 auto;display:flex}.paper-card{background-color:var(--darker);border:1px solid var(--gray);transition:var(--transition);border-radius:12px;padding:2rem;position:relative}.paper-card:before{content:"";background:linear-gradient(180deg, var(--primary), var(--secondary));width:4px;height:0;transition:height .4s;position:absolute;top:0;left:0}.paper-card:hover:before{height:100%}.paper-card:hover{border-color:var(--primary);transform:translateY(-5px)translate(5px);box-shadow:0 10px 30px #4d8ee833}.paper-title{color:var(--light);margin-bottom:.8rem;font-size:1.5rem}.paper-authors{color:var(--primary);margin-bottom:1rem;font-size:.95rem;font-style:italic}.paper-abstract{color:#f0f4f8cc;margin-bottom:1.5rem;line-height:1.7}.paper-links{gap:12px;display:flex}.paper-link{color:var(--light);transition:var(--transition);background-color:var(--gray);border-radius:6px;align-items:center;padding:.5rem 1.2rem;font-size:.9rem;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.paper-link:before{content:"";background:var(--primary);width:0;height:3px;transition:width .4s;position:absolute;bottom:0;left:0}.paper-link:hover:before{width:100%}.paper-link:hover{background-color:var(--primary);color:var(--dark);transform:translateY(-3px)scale(1.05);box-shadow:0 8px 20px #4d8ee866}.notes-categories{flex-wrap:wrap;gap:10px;max-width:1200px;margin-bottom:2rem;margin-left:auto;margin-right:auto;display:flex}.category-btn{background-color:var(--gray);color:var(--light);cursor:pointer;transition:var(--transition);border:none;border-radius:30px;padding:.6rem 1.2rem;font-family:Poppins,sans-serif;font-size:.9rem}.category-btn.active,.category-btn:hover{background-color:var(--primary);color:var(--dark);transform:translateY(-2px)scale(1.05);box-shadow:0 5px 15px #4d8ee866}.notes-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;max-width:1200px;margin:0 auto;display:grid}.note-card{background-color:var(--darker);border:1px solid var(--gray);transition:var(--transition);border-radius:12px;flex-direction:column;padding:1.8rem;display:flex;position:relative}.note-card:after{content:"";background:linear-gradient(90deg, var(--primary), var(--secondary));height:3px;transition:transform .4s;position:absolute;bottom:0;left:0;right:0;transform:scaleX(0)}.note-card:hover:after{transform:scaleX(1)}.note-card:hover{border-color:var(--primary);transform:translateY(-8px)scale(1.02);box-shadow:0 15px 35px #4d8ee833}.note-category{color:var(--primary);background:#4d8ee81a;border-radius:4px;align-self:flex-start;margin-bottom:1rem;padding:.3rem .8rem;font-size:.75rem;display:inline-block}.note-title{color:var(--light);margin-bottom:.8rem;font-size:1.3rem}.note-desc{color:#f0f4f8b3;flex-grow:1;margin-bottom:1.5rem;font-size:.95rem;line-height:1.6}.note-link{color:var(--light);transition:var(--transition);background-color:var(--gray);border-radius:6px;align-self:flex-start;align-items:center;padding:.5rem 1.2rem;font-size:.9rem;text-decoration:none;display:inline-flex}.note-link:hover{background-color:var(--primary);color:var(--dark);transform:translateY(-3px)scale(1.05);box-shadow:0 8px 20px #4d8ee866}.footer{background-color:var(--darker);text-align:center;border-top:1px solid var(--gray);padding:2rem}.footer-text{color:#f0f4f8cc;font-size:.9rem}.loading-spinner{justify-content:center;align-items:center;min-height:200px;display:flex}.spinner{border:3px solid var(--gray);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.admin-login-page{background:var(--dark);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.admin-login-card{background:var(--darker);border:1px solid var(--gray);border-radius:16px;width:100%;max-width:420px;padding:2.5rem;box-shadow:0 20px 60px #00000080}.admin-login-card h1{text-align:center;color:var(--primary);margin-bottom:.5rem;font-size:1.8rem}.admin-login-card p{text-align:center;color:#f0f4f899;margin-bottom:2rem;font-size:.9rem}.form-group{margin-bottom:1.2rem}.form-group label{color:var(--light);margin-bottom:.4rem;font-size:.9rem;font-weight:500;display:block}.form-group input,.form-group textarea,.form-group select{background:var(--gray);border:1px solid var(--light-gray);width:100%;color:var(--light);border-radius:8px;outline:none;padding:.7rem 1rem;font-family:Poppins,sans-serif;font-size:.95rem;transition:border-color .3s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4d8ee826}.form-group textarea{resize:vertical;min-height:100px}.form-group select{cursor:pointer}.btn-primary{background:var(--primary);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:7px;padding:.55rem 1.2rem;font-family:Poppins,sans-serif;font-size:.88rem;font-weight:600;transition:background .2s,transform .2s,box-shadow .2s;display:inline-flex}.btn-primary:hover:not(:disabled){background:var(--primary-light);transform:translateY(-1px);box-shadow:0 6px 18px #4d8ee866}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-secondary{color:#f0f4f8bf;cursor:pointer;white-space:nowrap;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:8px;align-items:center;gap:7px;padding:.55rem 1.2rem;font-family:Poppins,sans-serif;font-size:.88rem;font-weight:500;transition:background .2s,color .2s,border-color .2s;display:inline-flex}.btn-secondary:hover:not(:disabled){color:var(--light);background:#ffffff1c;border-color:#ffffff38}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-danger{color:#fca5a5;cursor:pointer;white-space:nowrap;background:#ff6b6b24;border:1px solid #ff6b6b59;border-radius:8px;align-items:center;gap:7px;padding:.55rem 1.2rem;font-family:Poppins,sans-serif;font-size:.88rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-danger:hover:not(:disabled){background:#ff6b6b47}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn-primary-full{background:var(--primary);width:100%;color:var(--dark);cursor:pointer;transition:var(--transition);border:none;border-radius:8px;padding:.85rem;font-family:Poppins,sans-serif;font-size:1rem;font-weight:600}.btn-primary-full:hover{background:var(--primary-light);transform:translateY(-2px);box-shadow:0 8px 20px #4d8ee866}.btn-primary-full:disabled{opacity:.6;cursor:not-allowed;transform:none}.error-msg{color:#ff6b6b;text-align:center;margin-top:.4rem;margin-bottom:1rem;font-size:.85rem}.success-msg{color:#51cf66;text-align:center;margin-top:.4rem;font-size:.85rem}.admin-layout{background:var(--dark);min-height:100vh;display:flex}.admin-sidebar{background:var(--darker);border-right:1px solid var(--gray);z-index:100;flex-shrink:0;width:260px;height:100vh;padding:0;position:fixed;top:0;left:0;overflow-y:auto}.admin-sidebar-header{border-bottom:1px solid var(--gray);background:linear-gradient(135deg,#4d8ee833,#7a4ced1a);padding:1.5rem}.admin-sidebar-header h2{color:var(--primary);margin-bottom:.2rem;font-size:1.1rem}.admin-sidebar-header p{color:#f0f4f880;font-size:.75rem}.admin-nav{padding:1rem 0}.admin-nav-link{color:#f0f4f8b3;cursor:pointer;border-left:3px solid #0000;align-items:center;gap:10px;padding:.8rem 1.5rem;font-size:.9rem;text-decoration:none;transition:all .3s;display:flex}.admin-nav-link:hover,.admin-nav-link.active{color:var(--primary-light);border-left-color:var(--primary);background:#4d8ee81a}.admin-nav-link i{text-align:center;width:20px}.admin-content{flex:1;min-height:100vh;margin-left:260px;padding:2rem}.admin-topbar{border-bottom:1px solid var(--gray);justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;display:flex}.admin-topbar h1{color:var(--light);font-size:1.6rem}.btn-logout{color:#ff6b6b;cursor:pointer;background:#ff6b6b26;border:1px solid #ff6b6b4d;border-radius:8px;padding:.5rem 1.2rem;font-family:Poppins,sans-serif;font-size:.85rem;transition:all .3s}.btn-logout:hover{background:#ff6b6b4d}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1.2rem;margin-bottom:2rem;display:grid}.stat-card{background:var(--darker);border:1px solid var(--gray);text-align:center;border-radius:12px;padding:1.5rem;transition:all .3s;position:relative;overflow:hidden}.stat-card:before{content:"";background:linear-gradient(90deg, var(--primary), var(--secondary));height:3px;position:absolute;top:0;left:0;right:0}.stat-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:0 10px 30px #4d8ee833}.stat-card i{color:var(--primary);margin-bottom:.8rem;font-size:1.8rem;display:block}.stat-number{color:var(--light);margin-bottom:.3rem;font-size:2rem;font-weight:700}.stat-label{color:#f0f4f899;text-transform:uppercase;letter-spacing:1px;font-size:.8rem}.admin-section-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.admin-section-header h2{color:var(--light);font-size:1.3rem}.btn-add{background:var(--primary);color:var(--dark);cursor:pointer;transition:var(--transition);border:none;border-radius:8px;align-items:center;gap:6px;padding:.6rem 1.2rem;font-family:Poppins,sans-serif;font-size:.9rem;font-weight:600;display:flex}.btn-add:hover{background:var(--primary-light);transform:translateY(-2px);box-shadow:0 5px 15px #4d8ee866}.admin-table-wrapper{border:1px solid var(--gray);border-radius:12px;overflow-x:auto}.admin-table{border-collapse:collapse;width:100%}.admin-table th{text-align:left;color:var(--primary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--gray);background:#4d8ee81a;padding:1rem;font-size:.8rem;font-weight:600}.admin-table td{color:#f0f4f8d9;vertical-align:middle;border-bottom:1px solid #ffffff0a;padding:.9rem 1rem;font-size:.9rem}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:#4d8ee80d}.badge{border-radius:20px;padding:.2rem .7rem;font-size:.75rem;font-weight:600;display:inline-block}.badge-web{color:var(--primary);background:#4d8ee833}.badge-ml{color:#b388ff;background:#7a4ced33}.badge-agentic,.badge-visible{color:#51cf66;background:#51cf6633}.badge-hidden{color:#ff6b6b;background:#ff6b6b33}.table-actions{gap:8px;display:flex}.btn-edit,.btn-delete,.btn-toggle{cursor:pointer;border:none;border-radius:6px;padding:.35rem .8rem;font-family:Poppins,sans-serif;font-size:.8rem;font-weight:600;transition:all .3s}.btn-edit{color:var(--primary);background:#4d8ee826}.btn-edit:hover{background:var(--primary);color:var(--dark)}.btn-delete{color:#ff6b6b;background:#ff6b6b26}.btn-delete:hover{color:#fff;background:#ff6b6b}.btn-toggle{color:#f0f4f899;background:#ffffff14}.btn-toggle:hover{color:var(--light);background:#ffffff26}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;background:#000000b3;justify-content:center;align-items:center;width:100%;height:100%;padding:1rem;display:flex;position:fixed;top:0;left:0}.modal{background:var(--darker);border:1px solid var(--gray);border-radius:16px;width:100%;max-width:600px;max-height:90vh;padding:2rem;overflow-y:auto;box-shadow:0 25px 60px #0009}.modal h2{color:var(--primary);margin-bottom:1.5rem;font-size:1.3rem}.modal-actions{justify-content:flex-end;gap:10px;margin-top:1.5rem;display:flex}.btn-cancel{background:var(--gray);color:var(--light);cursor:pointer;border:none;border-radius:8px;padding:.7rem 1.4rem;font-family:Poppins,sans-serif;font-size:.9rem;transition:all .3s}.btn-cancel:hover{background:var(--light-gray)}.btn-save{background:var(--primary);color:var(--dark);cursor:pointer;transition:var(--transition);border:none;border-radius:8px;padding:.7rem 1.4rem;font-family:Poppins,sans-serif;font-size:.9rem;font-weight:600}.btn-save:hover{background:var(--primary-light);transform:translateY(-1px)}.btn-save:disabled{opacity:.6;cursor:not-allowed;transform:none}.checkbox-row{align-items:center;gap:8px;display:flex}.checkbox-row input[type=checkbox]{cursor:pointer;width:auto;accent-color:var(--primary)}.particle-canvas{pointer-events:none;z-index:0;width:100%;height:100%;position:fixed;top:0;left:0}.gradient-mesh{pointer-events:none;z-index:0;width:100%;height:100%;position:fixed;top:0;left:0;overflow:hidden}.blob{filter:blur(90px);opacity:.07;will-change:transform;border-radius:50%;position:absolute}.blob-1{background:var(--primary);width:650px;height:650px;animation:22s ease-in-out infinite blobMove1;top:-200px;left:-150px}.blob-2{background:var(--secondary);width:550px;height:550px;animation:28s ease-in-out infinite blobMove2;bottom:-120px;right:-120px}.blob-3{background:#ff6b6b;width:400px;height:400px;animation:19s ease-in-out infinite blobMove3;top:45%;left:45%;transform:translate(-50%,-50%)}@keyframes blobMove1{0%,to{transform:translate(0)scale(1)}33%{transform:translate(80px,60px)scale(1.12)}66%{transform:translate(40px,120px)scale(.92)}}@keyframes blobMove2{0%,to{transform:translate(0)scale(1)}33%{transform:translate(-90px,-60px)scale(1.15)}66%{transform:translate(-50px,-90px)scale(.9)}}@keyframes blobMove3{0%,to{transform:translate(-50%,-50%)scale(1)}50%{transform:translate(-50%,-50%)scale(1.4)}}.grain-overlay{pointer-events:none;z-index:1;opacity:.028;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:200px;width:100%;height:100%;position:fixed;top:0;left:0}.has-custom-cursor,.has-custom-cursor *{cursor:none!important}.cursor-dot{background:var(--primary);pointer-events:none;z-index:99999;opacity:0;will-change:left, top;border-radius:50%;width:8px;height:8px;transition:transform .2s,background .2s;position:fixed;transform:translate(-50%,-50%)}.cursor-ring{pointer-events:none;z-index:99998;opacity:0;will-change:left, top;border:1.5px solid #4d8ee8b3;border-radius:50%;width:32px;height:32px;transition:width .3s,height .3s,border-color .3s,background .3s;position:fixed;transform:translate(-50%,-50%)}.cursor-enlarged{background:#4d8ee814;border-color:var(--primary-light)!important;width:52px!important;height:52px!important}.scroll-progress{background:linear-gradient(90deg, var(--primary), var(--secondary), #ff922b);z-index:10001;border-radius:0 2px 2px 0;height:3px;transition:width 80ms linear;position:fixed;top:0;left:0;box-shadow:0 0 8px #4d8ee880}.page-wipe{background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);z-index:5000;pointer-events:none;clip-path:polygon(0 0,0 0,0 100%,0 100%);width:100%;height:100%;position:fixed;top:0;left:0}.page-wipe.wiping-in{animation:.38s cubic-bezier(.77,0,.18,1) forwards pageWipeIn}.page-wipe.wiping-out{animation:.38s cubic-bezier(.77,0,.18,1) forwards pageWipeOut}@keyframes pageWipeIn{0%{clip-path:polygon(0 0,0 0,0 100%,0 100%)}to{clip-path:polygon(0 0,100% 0,100% 100%,0 100%)}}@keyframes pageWipeOut{0%{clip-path:polygon(0 0,100% 0,100% 100%,0 100%)}to{clip-path:polygon(100% 0,100% 0,100% 100%,100% 100%)}}.reveal{opacity:0;transition:opacity .65s,transform .65s;transform:translateY(32px)}.reveal.visible{opacity:1;transform:translateY(0)}.name-glitch{display:inline-block;position:relative}.name-glitch:before,.name-glitch:after{content:attr(data-text);pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.name-glitch:before{color:#f09;clip-path:polygon(0 15%,100% 15%,100% 35%,0 35%);animation:5s step-end infinite glitch-before}.name-glitch:after{color:#0ff;clip-path:polygon(0 60%,100% 60%,100% 78%,0 78%);animation:5s step-end infinite glitch-after}@keyframes glitch-before{0%,88%,to{opacity:0;transform:translate(0)}89%{opacity:.85;transform:translate(-5px,2px)}91%{opacity:.85;transform:translate(5px,-2px)}93%{opacity:0;transform:translate(0)}95%{opacity:.6;transform:translate(-3px)}97%{opacity:0;transform:translate(0)}}@keyframes glitch-after{0%,88%,to{opacity:0;transform:translate(0)}90%{opacity:.85;transform:translate(5px,1px)}92%{opacity:.85;transform:translate(-4px,-1px)}94%{opacity:.5;transform:translate(3px)}96%{opacity:0;transform:translate(0)}}.typed-cursor{color:var(--primary);margin-left:2px;font-weight:300;animation:.7s step-end infinite blink;display:inline-block}.counters-row{flex-wrap:wrap;align-items:center;gap:1.5rem;margin:1.5rem 0;display:flex}.counter-item{text-align:center}.counter-number{color:var(--primary);font-family:JetBrains Mono,monospace;font-size:2rem;font-weight:700;line-height:1}.counter-number:after{content:"+";font-size:1.3rem}.counter-label{color:#f0f4f88c;text-transform:uppercase;letter-spacing:1.2px;margin-top:.3rem;font-size:.7rem}.counter-divider{background:#4d8ee84d;flex-shrink:0;width:1px;height:36px}.profile-img{will-change:transform;transition:transform .12s,box-shadow .12s!important}.sidebar-bottom{border-top:1px solid var(--gray);flex-direction:column;gap:.4rem;margin-top:auto;padding-top:1rem;display:flex}.cmd-hint-btn{border:1px solid var(--gray);color:#f0f4f873;cursor:pointer;text-align:left;background:0 0;border-radius:8px;align-items:center;gap:10px;width:100%;padding:.7rem 1rem;font-family:Poppins,sans-serif;font-size:.82rem;transition:all .3s;display:flex}.cmd-hint-btn:hover{color:var(--light);border-color:var(--primary);background:#4d8ee80f}.cmd-hint-btn i{font-size:.8rem}.cmd-hint-btn kbd{background:var(--gray);color:#f0f4f880;border-radius:4px;margin-left:auto;padding:1px 6px;font-family:monospace;font-size:.7rem}.theme-toggle{color:#f0f4f873;cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;width:100%;padding:.7rem 1rem;font-family:Poppins,sans-serif;font-size:.82rem;transition:all .3s;display:flex}.theme-toggle:hover{color:var(--light);background:#ffffff0d}.theme-toggle-track{background:var(--gray);border-radius:10px;flex-shrink:0;width:36px;height:20px;margin-left:auto;transition:background .3s;position:relative}.theme-toggle-track:after{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .3s;position:absolute;top:2px;left:2px}body.light-mode .theme-toggle-track{background:var(--primary)}body.light-mode .theme-toggle-track:after{transform:translate(16px)}.pcard{--cat-color:#4d8ee8;--mouse-x:50%;--mouse-y:50%;background:var(--darker);border:1px solid var(--gray);opacity:0;border-radius:16px;flex-direction:column;transition:transform .3s,box-shadow .3s,border-color .3s;display:flex;position:relative;overflow:hidden;transform:translateY(28px)}.pcard.visible{opacity:1;transition:opacity .55s,transform .55s,box-shadow .3s,border-color .3s;transform:translateY(0)}.pcard:hover{border-color:var(--cat-color);box-shadow:0 16px 48px #00000073, 0 0 0 1px var(--cat-color);transform:translateY(-5px)}.pcard:before{content:"";background:radial-gradient(320px circle at var(--mouse-x) var(--mouse-y), color-mix(in srgb, var(--cat-color) 12%, transparent), transparent 65%);opacity:0;pointer-events:none;z-index:0;border-radius:inherit;transition:opacity .35s;position:absolute;inset:0}.pcard:hover:before{opacity:1}.pcard-accent{background:linear-gradient(90deg, var(--cat-color), transparent);flex-shrink:0;height:3px}.pcard-body{z-index:1;flex-direction:column;flex:1;gap:.75rem;padding:1.4rem 1.4rem 1rem;display:flex;position:relative}.pcard-header{justify-content:space-between;align-items:center;display:flex}.pcard-badge{text-transform:uppercase;letter-spacing:.8px;border:1px solid;border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-size:.68rem;font-weight:600;display:inline-flex}.pcard-dots{gap:5px;display:flex}.pcard-dots span{background:var(--gray);border-radius:50%;width:8px;height:8px}.pcard-dots span:first-child{background:#ff5f57}.pcard-dots span:nth-child(2){background:#febc2e}.pcard-dots span:nth-child(3){background:#28c840}.pcard-title{color:var(--light);margin:0;font-size:1.15rem;font-weight:700;line-height:1.35}.pcard-desc{color:#f0f4f89e;-webkit-line-clamp:4;-webkit-box-orient:vertical;flex:1;margin:0;font-size:.88rem;line-height:1.65;display:-webkit-box;overflow:hidden}.pcard-tech{flex-wrap:wrap;gap:6px;margin-top:auto;display:flex}.pcard-chip{color:#f0f4f899;background:#ffffff0f;border:1px solid #ffffff14;border-radius:6px;padding:3px 9px;font-family:JetBrains Mono,monospace;font-size:.7rem;transition:background .2s,color .2s}.pcard:hover .pcard-chip{background:color-mix(in srgb, var(--cat-color) 14%, transparent);color:#f0f4f8d9;border-color:color-mix(in srgb, var(--cat-color) 30%, transparent)}.pcard-chip-more{color:#f0f4f859;background:#ffffff0a}.pcard-footer{z-index:1;border-top:1px solid #ffffff0f;gap:8px;padding:1rem 1.4rem 1.3rem;display:flex;position:relative}.pcard-btn{white-space:nowrap;border-radius:8px;align-items:center;gap:6px;padding:.45rem 1rem;font-family:Poppins,sans-serif;font-size:.8rem;font-weight:500;text-decoration:none;transition:all .25s;display:inline-flex}.pcard-btn-primary{background:var(--cat-color);color:#fff}.pcard-btn-primary:hover{filter:brightness(1.15);box-shadow:0 6px 20px color-mix(in srgb, var(--cat-color) 40%, transparent);transform:translateY(-1px)}.pcard-btn-ghost{color:#f0f4f8b3;background:#ffffff0f;border:1px solid #ffffff1a}.pcard-btn-ghost:hover{color:var(--light);background:#ffffff1f;border-color:#fff3}.spotlight-card{--mouse-x:50%;--mouse-y:50%}.note-card,.paper-card{--mouse-x:50%;--mouse-y:50%;position:relative}.note-card:after,.paper-card:after{content:"";background:radial-gradient(250px circle at var(--mouse-x) var(--mouse-y), #4d8ee81a, transparent 65%);opacity:0;pointer-events:none;z-index:0;border-radius:inherit;transition:opacity .4s;position:absolute;inset:0}.note-card:hover:after,.paper-card:hover:after{opacity:1}.cmd-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:20000;background:#000000a6;justify-content:center;align-items:flex-start;width:100%;height:100%;padding:15vh 1rem 0;display:flex;position:fixed;top:0;left:0}.cmd-palette{background:var(--darker);border:1px solid #4d8ee859;border-radius:16px;width:100%;max-width:560px;animation:.2s cubic-bezier(.16,1,.3,1) cmdIn;overflow:hidden;box-shadow:0 30px 70px #000000b3,0 0 0 1px #4d8ee81a}@keyframes cmdIn{0%{opacity:0;transform:scale(.95)translateY(-10px)}to{opacity:1;transform:scale(1)translateY(0)}}.cmd-search{border-bottom:1px solid var(--gray);align-items:center;gap:12px;padding:1rem 1.2rem;display:flex}.cmd-search-icon{color:#f0f4f859;flex-shrink:0;font-size:.9rem}.cmd-input{color:var(--light);background:0 0;border:none;outline:none;flex:1;font-family:Poppins,sans-serif;font-size:1rem}.cmd-input::placeholder{color:#f0f4f84d}.cmd-esc{background:var(--gray);color:#f0f4f873;cursor:pointer;border-radius:4px;flex-shrink:0;padding:2px 7px;font-family:monospace;font-size:.7rem}.cmd-results{scrollbar-width:thin;scrollbar-color:var(--gray) transparent;max-height:340px;padding:.5rem;overflow-y:auto}.cmd-item{cursor:pointer;color:#f0f4f8bf;border-radius:8px;align-items:center;gap:12px;padding:.75rem 1rem;font-size:.9rem;transition:background .12s;display:flex}.cmd-item i{text-align:center;color:#f0f4f859;flex-shrink:0;width:20px;font-size:1rem}.cmd-item-text{flex-direction:column;flex:1;gap:1px;display:flex}.cmd-item-label{color:var(--light);font-size:.88rem}.cmd-item-desc{color:#f0f4f866;font-size:.74rem}.cmd-item kbd{background:var(--gray);color:#f0f4f866;border-radius:4px;flex-shrink:0;padding:2px 6px;font-family:monospace;font-size:.7rem}.cmd-item-selected,.cmd-item:hover{background:#4d8ee826}.cmd-item-selected i,.cmd-item:hover i{color:var(--primary)}.cmd-item-selected .cmd-item-label,.cmd-item:hover .cmd-item-label{color:var(--primary-light)}.cmd-empty{color:#f0f4f859;flex-direction:column;align-items:center;gap:.5rem;padding:2rem;font-size:.9rem;display:flex}.cmd-empty i{font-size:1.5rem}.cmd-footer{border-top:1px solid var(--gray);color:#f0f4f84d;gap:1.2rem;padding:.75rem 1.2rem;font-size:.72rem;display:flex}.cmd-footer kbd{background:var(--gray);color:#f0f4f873;border-radius:3px;margin-right:4px;padding:2px 5px;font-family:monospace;font-size:.68rem}.toast-container{z-index:30000;pointer-events:none;flex-direction:column;gap:.6rem;display:flex;position:fixed;bottom:2rem;right:2rem}.toast{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid;border-radius:10px;align-items:center;gap:10px;max-width:320px;padding:.8rem 1.2rem;font-size:.88rem;font-weight:500;animation:.4s cubic-bezier(.16,1,.3,1) forwards toastIn;display:flex;box-shadow:0 8px 30px #00000080}.toast.toast-hide{animation:.3s forwards toastOut}.toast-info{color:#93c5fd;background:#4d8ee82e;border-color:#4d8ee866}.toast-success{color:#86efac;background:#51cf662e;border-color:#51cf6666}.toast-error{color:#fca5a5;background:#ff6b6b2e;border-color:#ff6b6b66}.toast-special{color:#c4b5fd;background:#7a4ced40;border-color:#7a4ced99;font-size:.95rem}@keyframes toastIn{0%{opacity:0;transform:translate(110%)}to{opacity:1;transform:translate(0)}}@keyframes toastOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(110%)}}body.light-mode{--dark:#f0f4f8;--darker:#e6edf6;--light:#1a1a2e;--gray:#c8d4e4;--light-gray:#9aaec0}body.light-mode .sidebar,body.light-mode .mobile-nav{border-color:var(--gray);background:#dce6f2}body.light-mode .card-front,body.light-mode .note-card,body.light-mode .paper-card,body.light-mode .stat-card,body.light-mode .admin-login-card,body.light-mode .admin-sidebar,body.light-mode .modal{background:#e6edf6}body.light-mode .skills-section,body.light-mode .achievements{background-color:#dce6f2cc}body.light-mode .welcome-overlay{background-color:#f0f4f8}body.light-mode .skill-box{background-color:#4d8ee81f}body.light-mode .particle-canvas{opacity:.4}@keyframes easterGlitch{0%,to{filter:none}8%{filter:hue-rotate(90deg)saturate(3)brightness(1.4)}16%{filter:invert(.08)hue-rotate(200deg)}24%{filter:none}32%{filter:hue-rotate(280deg)saturate(2.5)}40%{filter:none}48%{filter:hue-rotate(45deg)contrast(1.5)}56%{filter:none}}.easter-glitch{animation:1.6s easterGlitch}.projects-grid .project-card:first-child{transition-delay:0s}.projects-grid .project-card:nth-child(2){transition-delay:80ms}.projects-grid .project-card:nth-child(3){transition-delay:.16s}.projects-grid .project-card:nth-child(4){transition-delay:.24s}.projects-grid .project-card:nth-child(5){transition-delay:.32s}.projects-grid .project-card:nth-child(6){transition-delay:.4s}.projects-grid .project-card:nth-child(7){transition-delay:.48s}.projects-grid .project-card:nth-child(8){transition-delay:.56s}.projects-grid .project-card:nth-child(9){transition-delay:.64s}.projects-grid .project-card:nth-child(10){transition-delay:.72s}.projects-grid .project-card:nth-child(11){transition-delay:.8s}.projects-grid .project-card:nth-child(12){transition-delay:.88s}.chat-fab{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;cursor:pointer;z-index:9000;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.3rem;transition:transform .3s,box-shadow .3s;animation:2.5s ease-in-out infinite fabPulse;display:flex;position:fixed;bottom:2rem;right:2rem;box-shadow:0 6px 24px #4d8ee880}.chat-fab:hover{transform:scale(1.1);box-shadow:0 10px 32px #4d8ee8b3}.chat-fab.chat-fab-open{animation:none;transform:scale(1.05)}@keyframes fabPulse{0%,to{box-shadow:0 6px 24px #4d8ee880}50%{box-shadow:0 6px 32px #7a4cedb3}}.chat-fab-badge{color:#fff;background:#ff5f57;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.6rem;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px}.chat-window{background:var(--darker);z-index:8999;border:1px solid #4d8ee84d;border-radius:18px;flex-direction:column;width:380px;height:540px;transition:width .35s cubic-bezier(.16,1,.3,1),height .35s cubic-bezier(.16,1,.3,1),bottom .35s cubic-bezier(.16,1,.3,1),right .35s cubic-bezier(.16,1,.3,1);animation:.28s cubic-bezier(.16,1,.3,1) chatSlideUp;display:flex;position:fixed;bottom:5.5rem;right:2rem;overflow:hidden;box-shadow:0 24px 64px #0009,0 0 0 1px #4d8ee81a}.chat-window-expanded{border-radius:20px;width:min(820px,100vw - 3rem);height:min(680px,100vh - 7rem);bottom:5.5rem;right:2rem}@keyframes chatSlideUp{0%{opacity:0;transform:translateY(24px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.chat-header{background:#4d8ee814;border-bottom:1px solid #4d8ee826;flex-shrink:0;justify-content:space-between;align-items:center;padding:.9rem 1rem;display:flex}.chat-header-info{align-items:center;gap:10px;display:flex}.chat-avatar{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.95rem;display:flex}.chat-header-name{color:var(--light);font-size:.92rem;font-weight:600}.chat-header-status{color:#f0f4f873;align-items:center;gap:5px;font-size:.7rem;display:flex}.chat-status-dot{background:#51cf66;border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite statusPulse;box-shadow:0 0 6px #51cf66}@keyframes statusPulse{0%,to{opacity:1}50%{opacity:.4}}.chat-header-actions{gap:4px;display:flex}.chat-icon-btn{color:#f0f4f866;cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;font-family:Poppins,sans-serif;font-size:.8rem;transition:background .2s,color .2s;display:flex}.chat-icon-btn:hover{color:var(--light);background:#ffffff14}.chat-confirm{color:#f0f4f8cc;background:#ff6b6b1a;border-bottom:1px solid #ff6b6b33;flex-shrink:0;justify-content:space-between;align-items:center;gap:.5rem;padding:.7rem 1rem;font-size:.82rem;display:flex}.chat-confirm p{margin:0}.chat-confirm-btns{flex-shrink:0;gap:6px;display:flex}.chat-confirm-cancel,.chat-confirm-ok{cursor:pointer;border:none;border-radius:6px;padding:4px 12px;font-family:Poppins,sans-serif;font-size:.78rem;font-weight:500}.chat-confirm-cancel{color:#f0f4f8b3;background:#ffffff14}.chat-confirm-ok{color:#fff;background:#ff5f57}.chat-messages{scrollbar-width:thin;scrollbar-color:var(--gray) transparent;flex-direction:column;flex:1;gap:.75rem;padding:1rem;display:flex;overflow-y:auto}.chat-empty{color:#f0f4f840;text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.6rem;padding:2rem;font-size:.88rem;display:flex}.chat-empty i{font-size:2rem}.chat-msg{align-items:flex-end;gap:8px;display:flex}.chat-msg-user{flex-direction:row-reverse}.chat-msg-avatar{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.7rem;display:flex}.chat-bubble{word-break:break-word;border-radius:14px;max-width:82%;padding:.6rem .9rem;font-size:.85rem;line-height:1.55}.chat-msg-user .chat-bubble{background:linear-gradient(135deg, var(--primary), #3a7bd5);color:#fff;border-bottom-right-radius:4px}.chat-msg-bot .chat-bubble{color:#f0f4f8e6;background:#ffffff0f;border:1px solid #ffffff0f;border-bottom-left-radius:4px}.chat-bubble-error{background:#ff6b6b14!important;border-color:#ff6b6b4d!important}.chat-cursor{color:var(--primary);font-size:.9rem;animation:.7s step-end infinite blink}.chat-msg-content p{margin:0 0 .4rem}.chat-msg-content p:last-child{margin-bottom:0}.chat-msg-content strong{color:var(--primary-light)}.chat-msg-content em{color:#f0f4f8b3}.chat-msg-content code.md-code{color:var(--primary-light);background:#4d8ee826;border-radius:4px;padding:1px 5px;font-family:JetBrains Mono,monospace;font-size:.8em}.chat-msg-content pre.md-pre{background:#00000059;border:1px solid #ffffff14;border-radius:8px;margin:.5rem 0;padding:.7rem .9rem;font-family:JetBrains Mono,monospace;font-size:.8em;overflow-x:auto}.chat-msg-content ul.md-ul{margin:.3rem 0;padding-left:1.2rem}.chat-msg-content ul.md-ul li{margin-bottom:.2rem}.chat-msg-content h3,.chat-msg-content h4{color:var(--primary-light);margin:.4rem 0 .2rem}.chat-sources{border-top:1px solid #ffffff0f;margin-top:.5rem;padding-top:.4rem}.chat-sources-toggle{color:#f0f4f859;cursor:pointer;background:0 0;border:none;align-items:center;gap:5px;padding:0;font-family:Poppins,sans-serif;font-size:.72rem;transition:color .2s;display:flex}.chat-sources-toggle:hover{color:var(--primary-light)}.chat-sources-list{flex-direction:column;gap:.4rem;margin-top:.4rem;display:flex}.chat-source-item{background:#4d8ee812;border:1px solid #4d8ee826;border-radius:6px;padding:.4rem .6rem}.chat-source-label{color:var(--primary);margin-bottom:2px;font-size:.67rem;font-weight:600;display:block}.chat-source-preview{color:#f0f4f873;font-size:.72rem}.chat-typing-dots{gap:4px;padding:2px 0;display:flex}.chat-typing-dots span{background:#f0f4f866;border-radius:50%;width:7px;height:7px;animation:1.2s ease-in-out infinite dotBounce}.chat-typing-dots span:nth-child(2){animation-delay:.2s}.chat-typing-dots span:nth-child(3){animation-delay:.4s}@keyframes dotBounce{0%,80%,to{opacity:.4;transform:translateY(0)}40%{opacity:1;transform:translateY(-6px)}}.chat-input-row{background:#00000026;border-top:1px solid #ffffff0f;flex-shrink:0;align-items:flex-end;gap:8px;padding:.75rem .9rem;display:flex}.chat-input{color:var(--light);resize:none;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;outline:none;flex:1;max-height:100px;padding:.55rem .8rem;font-family:Poppins,sans-serif;font-size:.85rem;line-height:1.5;transition:border-color .2s}.chat-input:focus{border-color:#4d8ee880}.chat-input::placeholder{color:#f0f4f840}.chat-input:disabled{opacity:.5}.chat-send-btn{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;cursor:pointer;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.85rem;transition:opacity .2s,transform .2s;display:flex}.chat-send-btn:hover:not(:disabled){opacity:.88;transform:scale(1.05)}.chat-send-btn:disabled{opacity:.35;cursor:not-allowed}.chatbot-tabs{gap:8px;margin-bottom:1.5rem;display:flex}.chatbot-tab{background:var(--darker);border:1px solid var(--gray);color:#f0f4f88c;cursor:pointer;border-radius:8px;align-items:center;gap:8px;padding:.6rem 1.2rem;font-family:Poppins,sans-serif;font-size:.88rem;transition:all .25s;display:flex}.chatbot-tab.active,.chatbot-tab:hover{border-color:var(--primary);color:var(--primary-light);background:#4d8ee826}.chatbot-panel{flex-direction:column;gap:1rem;display:flex}.chatbot-add-grid{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}.chatbot-section-title{color:var(--primary-light);align-items:center;gap:8px;margin-bottom:1.2rem;font-size:1rem;font-weight:600;display:flex}.chatbot-count{background:var(--primary);color:#fff;border-radius:20px;margin-left:4px;padding:1px 7px;font-size:.7rem;font-weight:700}.chatbot-form{flex-direction:column;gap:1rem;display:flex}.chatbot-textarea{resize:vertical;min-height:150px}.chatbot-note{color:#f0f4f866;align-items:flex-start;gap:6px;margin:0;font-size:.78rem;display:flex}.chatbot-note i{color:var(--primary);flex-shrink:0;margin-top:2px}.chatbot-empty{text-align:center;color:#f0f4f84d;padding:2.5rem 1rem;font-size:.88rem}.chatbot-empty i{margin-bottom:.8rem;font-size:2rem;display:block}.pdf-drop-zone{text-align:center;cursor:pointer;color:#f0f4f866;border:2px dashed #4d8ee84d;border-radius:10px;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem;font-size:.85rem;transition:all .25s;display:flex}.pdf-drop-zone:hover{border-color:var(--primary);color:var(--primary-light);background:#4d8ee80d}.pdf-drop-zone i{font-size:1.5rem}.chatbot-config-form{flex-direction:column;gap:.5rem;display:flex}.chatbot-config-grid{grid-template-columns:1fr 1fr;gap:1.2rem;margin-bottom:.5rem;display:grid}.slider-row{align-items:center;gap:12px;margin-top:.4rem;display:flex}.slider-row input[type=range]{accent-color:var(--primary);flex:1}.slider-val{text-align:center;min-width:48px;color:var(--primary-light);background:#4d8ee81f;border-radius:6px;padding:2px 8px;font-size:.8rem;font-weight:600}.form-hint{color:#f0f4f859;margin-top:4px;font-size:.74rem;display:block}.form-required{color:#ff6b6b}.chunks-table-wrap{overflow-x:auto}.chunks-table{border-collapse:collapse;width:100%;font-size:.83rem}.chunks-table th{text-align:left;color:#f0f4f880;border-bottom:1px solid var(--gray);text-transform:uppercase;letter-spacing:.5px;padding:.6rem .8rem;font-size:.75rem;font-weight:600}.chunks-table td{vertical-align:middle;color:#f0f4f8bf;border-bottom:1px solid #ffffff0a;padding:.65rem .8rem}.chunks-table tr:last-child td{border-bottom:none}.chunks-table tr:hover td{background:#ffffff05}.chunk-id{color:#f0f4f866;font-family:JetBrains Mono,monospace;font-size:.75rem}.chunk-preview{color:#f0f4f899;max-width:300px}.chunk-date{white-space:nowrap;color:#f0f4f866;font-size:.78rem}.chunk-badge{white-space:nowrap;text-overflow:ellipsis;border-radius:12px;align-items:center;gap:5px;max-width:120px;padding:2px 8px;font-size:.72rem;font-weight:500;display:inline-flex;overflow:hidden}.chunk-badge-manual{color:#93c5fd;background:#4d8ee81f}.chunk-badge-pdf{color:#fca5a5;background:#ff6b6b1f}.btn-danger-sm{color:#ff6b6b;cursor:pointer;background:#ff6b6b1f;border:1px solid #ff6b6b4d;border-radius:6px;padding:4px 10px;font-family:Poppins,sans-serif;font-size:.78rem;transition:all .2s}.btn-danger-sm:hover{background:#ff6b6b40}.btn-secondary-sm{color:#f0f4f899;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:6px;padding:4px 10px;font-family:Poppins,sans-serif;font-size:.78rem;transition:all .2s}.admin-alert{border-radius:8px;align-items:center;gap:8px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.88rem;display:flex}.admin-alert-success{color:#86efac;background:#51cf661f;border:1px solid #51cf6640}.admin-alert-error{color:#fca5a5;background:#ff6b6b1f;border:1px solid #ff6b6b40}.apikeys-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.apikeys-header-info{color:#f0f4f880;align-items:flex-start;gap:12px;font-size:.82rem;line-height:1.5;display:flex}.apikeys-header-info>i{color:var(--primary);flex-shrink:0;margin-top:2px;font-size:1.1rem}.apikeys-note{margin:0}.apikeys-search-wrap{align-items:center;margin-bottom:1.25rem;display:flex;position:relative}.apikeys-search-icon{z-index:1;color:#f0f4f861;pointer-events:none;font-size:.82rem;position:absolute;left:14px}.apikeys-search{background:var(--gray);border:1px solid var(--light-gray);width:100%;color:var(--light);border-radius:10px;outline:none;padding:.65rem 2.6rem .65rem 2.5rem;font-family:Poppins,sans-serif;font-size:.9rem;transition:border-color .25s,box-shadow .25s}.apikeys-search::placeholder{color:#f0f4f84d}.apikeys-search:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4d8ee826}.apikeys-search-clear{cursor:pointer;color:#f0f4f859;background:0 0;border:none;border-radius:5px;justify-content:center;align-items:center;width:24px;height:24px;font-size:.78rem;transition:background .2s,color .2s;display:flex;position:absolute;right:10px}.apikeys-search-clear:hover{color:#f0f4f8d9;background:#ffffff1a}.apikey-form-card{margin-bottom:1.5rem}.apikey-form{flex-direction:column;gap:1rem;display:flex}.apikey-form-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.apikey-input{letter-spacing:.05em;font-family:JetBrains Mono,monospace}.apikey-form-actions{gap:10px;margin-top:.25rem;display:flex}.apikey-modal{width:100%;max-width:500px;padding:2rem}.apikey-modal-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.apikey-modal-header h2{color:var(--primary);align-items:center;gap:9px;margin:0;font-size:1.15rem;display:flex}.apikey-modal-close{color:#f0f4f899;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;font-size:.9rem;transition:background .2s,color .2s;display:flex}.apikey-modal-close:hover{color:#fca5a5;background:#ff6b6b33}.apikey-modal-actions{justify-content:flex-end;gap:10px;margin-top:1.5rem;display:flex}.apikeys-empty{text-align:center;color:#f0f4f84d;padding:3rem 1rem}.apikeys-empty i{color:#4d8ee84d;margin-bottom:1rem;font-size:2.5rem;display:block}.apikeys-empty p{margin:0;font-size:.9rem}.apikeys-list{flex-direction:column;gap:1rem;display:flex}.apikey-card{padding:1.2rem 1.4rem;transition:border-color .25s}.apikey-card:hover{border-color:#4d8ee859}.apikey-card-top{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.apikey-card-info{flex:1;min-width:0}.apikey-name{color:var(--light);align-items:center;gap:8px;margin-bottom:.25rem;font-size:1rem;font-weight:600;display:flex}.apikey-name i{color:var(--primary);font-size:.85rem}.apikey-desc{color:#f0f4f880;margin-bottom:.3rem;font-size:.82rem}.apikey-meta{color:#f0f4f84d;font-size:.72rem}.apikey-actions{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:6px;display:flex}.apikey-btn{cursor:pointer;white-space:nowrap;border:1px solid;border-radius:7px;align-items:center;gap:5px;padding:5px 12px;font-family:Poppins,sans-serif;font-size:.78rem;font-weight:500;transition:all .2s;display:inline-flex}.apikey-btn-reveal{color:var(--primary-light);background:#4d8ee81a;border-color:#4d8ee84d}.apikey-btn-reveal:hover{background:#4d8ee833}.apikey-btn-copy{color:#86efac;background:#51cf661a;border-color:#51cf664d}.apikey-btn-copy:hover,.apikey-btn-copy.copied{background:#51cf6638;border-color:#51cf6680}.apikey-btn-edit{color:#fbbf72;background:#ff922b1a;border-color:#ff922b4d}.apikey-btn-edit:hover{background:#ff922b33}.apikey-btn-danger{color:#fca5a5;background:#ff6b6b1a;border-color:#ff6b6b4d}.apikey-btn-danger:hover{background:#ff6b6b38}.apikey-btn-ghost{color:#f0f4f880;background:#ffffff0d;border-color:#ffffff1a}.apikey-btn:disabled{opacity:.5;cursor:not-allowed}.apikey-revealed{background:#0000004d;border:1px solid #4d8ee833;border-radius:8px;align-items:center;gap:10px;margin-top:.9rem;padding:.7rem 1rem;display:flex;overflow:hidden}.apikey-revealed-icon{color:#51cf66;flex-shrink:0;font-size:.85rem}.apikey-revealed-text{color:#a5f3a5;word-break:break-all;flex:1;min-width:0;font-family:JetBrains Mono,monospace;font-size:.78rem}.apikey-copy-inline{color:var(--primary-light);cursor:pointer;background:#4d8ee81f;border:1px solid #4d8ee840;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-family:Poppins,sans-serif;font-size:.8rem;transition:all .2s;display:flex}.apikey-copy-inline:hover{background:#4d8ee840}@media (width<=768px){.apikey-form-grid{grid-template-columns:1fr}.apikey-card-top{flex-direction:column;align-items:flex-start}.apikey-actions{width:100%}.chat-fab{width:48px;height:48px;font-size:1.1rem;bottom:5.5rem;right:1rem}.chat-window{border-radius:14px;width:calc(100vw - 1.5rem);bottom:9rem;right:.75rem}.chat-window-expanded{width:calc(100vw - 1.5rem);height:calc(100vh - 10.5rem)}.chat-expand-btn{display:none}}@media (width<=480px){.chatbot-add-grid,.chatbot-config-grid{grid-template-columns:1fr}}@media (width<=1200px){.home-content{grid-template-columns:1fr;gap:3rem}.profile-container{align-items:center}.intro-text{text-align:center;max-width:100%;margin:0 auto}.greeting,.social-links{justify-content:center}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (width<=992px){.name{font-size:2.8rem}.title{font-size:1.5rem}.profile-img{width:300px;height:330px}.home{padding:5rem 1.5rem}.section-page{padding:4rem 2rem}}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0)}.main-container{width:100%;margin-left:0}.mobile-menu-btn{display:none!important}.mobile-nav{display:block}.home,.section-page{padding:3rem 1.5rem 90px}.name{font-size:2.4rem}.section-title{font-size:2rem}.projects-grid,.notes-grid{grid-template-columns:1fr}.profile-img{width:280px;height:310px}.welcome-text,.cursor{font-size:1.8rem}.admin-layout{flex-direction:column}.admin-sidebar{width:100%;height:auto;position:relative}.admin-content{margin-left:0}.achievements{padding:1.5rem 1rem}.achievement-item{align-items:flex-start;margin:1rem 0;padding:.75rem .85rem}.achievement-item:hover{transform:none}.achievement-icon{min-width:24px;margin-right:10px;font-size:1.2rem}.achievement-content h3{margin-bottom:.3rem;font-size:1rem;line-height:1.35}.achievement-content p{font-size:.82rem;line-height:1.5}.marquee-track:before,.marquee-track:after{width:36px}.skill-chip{padding:.45rem .85rem;font-size:.8rem}.skills-section{margin:2rem auto;padding:1.5rem 0}.skills-section h2{margin-bottom:1rem;padding:0 1.2rem;font-size:1.2rem}}@media (width<=576px){.home{padding:2.5rem 1rem 80px}.profile-img{border:5px solid var(--primary);width:220px;height:260px}.name{font-size:1.8rem}.title{font-size:1.1rem}.section-page{padding:2.5rem 1rem 80px}.project-links{flex-direction:column}.project-link{justify-content:center;width:100%}.paper-links{flex-direction:column}.paper-link,.note-link{justify-content:center;width:100%}.achievements{padding:1.2rem .85rem}.achievement-content h3{font-size:.95rem}.achievement-content p{font-size:.8rem}.achievement-icon{font-size:1.1rem}.counters-row{justify-content:center;gap:.8rem}.counter-number{font-size:1.5rem}.counter-label{font-size:.62rem}.counter-divider{height:28px}.marquee-track:before,.marquee-track:after{width:24px}.skill-chip{padding:.4rem .7rem;font-size:.75rem}.marquee-row{gap:.6rem}}
