:root{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #e2e8f0;--text-primary: #1e293b;--text-secondary: #475569;--text-muted: #64748b;--primary: #6366f1;--primary-light: #818cf8;--primary-dark: #4f46e5;--accent: #0891b2;--accent-light: #06b6d4;--gradient-primary: linear-gradient(135deg, #6366f1 0%, #06b6d4 100%);--gradient-hero: linear-gradient(135deg, #667eea 0%, #764ba2 50%, #6366f1 100%);--border-color: #cbd5e1;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .08);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .12), 0 2px 4px -2px rgb(0 0 0 / .08);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .15), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .15), 0 8px 10px -6px rgb(0 0 0 / .1);--glass-bg: rgba(255, 255, 255, .85);--glass-border: rgba(255, 255, 255, .5);--card-bg: #ffffff;--card-border: #e2e8f0;--card-shadow: 0 4px 6px -1px rgb(0 0 0 / .08);--section-padding: 6rem;--container-max: 1200px;--font-primary: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--transition-fast: .15s ease;--transition-base: .3s ease;--transition-slow: .5s ease;--radius-sm: .375rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-full: 9999px}[data-theme=dark]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #64748b;--primary: #818cf8;--primary-light: #a5b4fc;--primary-dark: #6366f1;--accent: #22d3ee;--accent-light: #67e8f9;--border-color: #334155;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .3);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .4), 0 2px 4px -2px rgb(0 0 0 / .3);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .4), 0 4px 6px -4px rgb(0 0 0 / .3);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .4), 0 8px 10px -6px rgb(0 0 0 / .3);--glass-bg: rgba(30, 41, 59, .8);--glass-border: rgba(51, 65, 85, .5);--card-bg: #1e293b;--card-border: #334155;--card-shadow: 0 4px 6px -1px rgb(0 0 0 / .3)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-primary);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow-x:hidden;transition:background-color var(--transition-base),color var(--transition-base)}a{color:var(--primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-light)}img{max-width:100%;height:auto;display:block}ul,ol{list-style:none}button{font-family:inherit;cursor:pointer;border:none;background:none}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;color:var(--text-primary)}h1{font-size:clamp(2.5rem,5vw,4rem)}h2{font-size:clamp(2rem,4vw,3rem)}h3{font-size:clamp(1.5rem,3vw,2rem)}h4{font-size:clamp(1.25rem,2vw,1.5rem)}p{color:var(--text-secondary);font-size:1.1rem}.text-gradient{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.container{max-width:var(--container-max);margin:0 auto;padding:0 1.5rem}section{padding:var(--section-padding) 0}.section-header{text-align:center;margin-bottom:4rem}.section-header h2{margin-bottom:1rem}.section-header p{max-width:600px;margin:0 auto}.section-title{text-align:center;margin-bottom:1rem}.section-subtitle{text-align:center;color:var(--text-muted);margin-bottom:3rem}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1rem 0;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);transition:all var(--transition-base)}.navbar.scrolled{padding:.75rem 0;box-shadow:var(--shadow-md)}.navbar .container{display:flex;justify-content:space-between;align-items:center}.logo a,.navbar a.nav-logo{font-size:1.5rem;font-weight:800;display:flex;align-items:center;color:var(--text-primary)}.logo-text{color:var(--text-primary)}.logo-accent{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav-menu{display:flex;align-items:center;gap:2rem}.nav-link{color:var(--text-secondary);font-weight:500;position:relative;padding:.5rem 0}.nav-link:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--gradient-primary);transition:width var(--transition-base)}.nav-link:hover,.nav-link.active{color:var(--primary)}.nav-link:hover:after,.nav-link.active:after{width:100%}.nav-actions{display:flex;align-items:center;gap:1rem}.theme-toggle{width:44px;height:44px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);color:var(--text-primary);transition:all var(--transition-fast)}.theme-toggle:hover{background:var(--primary);color:#fff}.theme-toggle svg{width:20px;height:20px}.nav-toggle{display:none;flex-direction:column;gap:5px;width:30px;height:24px;justify-content:center}.nav-toggle span{display:block;width:100%;height:2px;background:var(--text-primary);transition:all var(--transition-fast)}@media(max-width:768px){.nav-toggle{display:flex}.nav-menu{position:fixed;top:72px;left:0;right:0;background:var(--bg-secondary);flex-direction:column;padding:2rem;gap:1.5rem;transform:translateY(-100%);opacity:0;visibility:hidden;transition:all var(--transition-base);border-bottom:1px solid var(--border-color)}.nav-menu.active{transform:translateY(0);opacity:1;visibility:visible}}.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding-top:80px}.hero-bg{position:absolute;inset:0;background:var(--gradient-hero);opacity:.05;z-index:-2}.hero-particles{position:absolute;inset:0;z-index:-1;overflow:hidden}.hero-particle{position:absolute;width:300px;height:300px;border-radius:50%;filter:blur(80px);opacity:.4;animation:float 20s infinite ease-in-out}.hero-particle:nth-child(1){background:var(--primary);top:10%;left:10%;animation-delay:0s}.hero-particle:nth-child(2){background:var(--accent);top:60%;right:10%;animation-delay:-5s}.hero-particle:nth-child(3){background:#a855f7;bottom:10%;left:30%;animation-delay:-10s}.hero-content{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}.hero-greeting{display:inline-block;font-size:1.25rem;color:var(--primary);font-weight:600;margin-bottom:1rem}.hero-name{margin-bottom:1rem}.hero-title{font-size:1.5rem;color:var(--text-secondary);margin-bottom:1.5rem}.hero-title span,.typing-text{color:var(--accent)}.typing-cursor{color:var(--accent);animation:blink 1s infinite;margin-left:2px}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.hero-description{font-size:1.125rem;margin-bottom:2rem;max-width:500px}.hero-buttons{display:flex;gap:1rem;flex-wrap:wrap}.hero-socials{display:flex;gap:1rem;margin-top:2.5rem}.social-link{width:48px;height:48px;border-radius:var(--radius-full);background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all var(--transition-fast)}.social-link:hover{background:var(--primary);color:#fff;transform:translateY(-3px)}.social-link svg{width:22px;height:22px}.hero-image{display:flex;justify-content:center;animation:fadeInUp 1s ease .3s backwards}.hero-avatar{position:relative;width:380px;height:380px}.hero-avatar img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-xl);border:4px solid var(--bg-secondary);box-shadow:var(--shadow-xl)}.hero-avatar:before{content:"";position:absolute;inset:-8px;border-radius:calc(var(--radius-xl) + 8px);background:var(--gradient-primary);z-index:-1;opacity:.8}.hero-stats{position:absolute;bottom:-30px;left:50%;transform:translate(-50%);display:flex;gap:1rem;background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:1rem 1.5rem;border-radius:var(--radius-lg);border:1px solid var(--glass-border);box-shadow:var(--shadow-lg)}.stat-item{text-align:center;padding:0 1rem;border-right:1px solid var(--border-color)}.stat-item:last-child{border-right:none}.stat-number{font-size:1.5rem;font-weight:800;color:var(--primary)}.stat-label{font-size:.875rem;color:var(--text-muted)}@media(max-width:968px){.hero-content{grid-template-columns:1fr;text-align:center}.hero-description{margin:0 auto 2rem}.hero-buttons,.hero-socials{justify-content:center}.hero-avatar{width:280px;height:280px}}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.75rem;font-size:1rem;font-weight:600;border-radius:var(--radius-md);transition:all var(--transition-fast)}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 14px #6366f166}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f180;color:#fff}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.btn svg{width:18px;height:18px}.about{background:var(--bg-secondary)}.about-content{display:grid;grid-template-columns:1fr 1.5fr;gap:4rem;align-items:center}.about-image{position:relative}.about-image img{border-radius:var(--radius-xl);box-shadow:var(--shadow-xl)}.about-badge{position:absolute;bottom:-20px;right:-20px;background:var(--gradient-primary);color:#fff;padding:1.25rem 1.5rem;border-radius:var(--radius-lg);font-weight:700;font-size:1.25rem;box-shadow:var(--shadow-lg)}.about-text h3{margin-bottom:1.5rem}.about-text p{margin-bottom:1rem}.about-highlights{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:2rem}.highlight-item{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius-md)}.highlight-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--primary);color:#fff;border-radius:var(--radius-sm)}.highlight-icon svg{width:20px;height:20px}.highlight-text{font-weight:600;color:var(--text-primary)}@media(max-width:968px){.about-content{grid-template-columns:1fr;text-align:center}.about-highlights{justify-content:center}}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}.skill-category{background:var(--bg-secondary);padding:2rem;border-radius:var(--radius-lg);border:1px solid var(--border-color);transition:all var(--transition-base)}.skill-category:hover{transform:translateY(-5px);box-shadow:var(--shadow-xl);border-color:var(--primary)}.skill-category-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.skill-icon{width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);color:#fff;border-radius:var(--radius-md)}.skill-icon svg{width:26px;height:26px}.skill-icon.blue{background:linear-gradient(135deg,#3b82f6,#60a5fa)}.skill-icon.pink{background:linear-gradient(135deg,#ec4899,#f472b6)}.skill-category h4{font-size:1.25rem}.skill-tags{display:flex;flex-wrap:wrap;gap:.5rem}.skill-tag{padding:.5rem 1rem;background:var(--bg-tertiary);color:var(--text-secondary);border-radius:var(--radius-full);font-size:.875rem;font-weight:500;transition:all var(--transition-fast)}.skill-tag:hover{background:var(--primary);color:#fff}.project-filters{display:flex;justify-content:center;gap:.75rem;margin-bottom:3rem;flex-wrap:wrap}.projects-filter{display:flex;justify-content:center;gap:1rem;margin-bottom:3rem;flex-wrap:wrap}.filter-btn{padding:.625rem 1.25rem;background:var(--bg-tertiary);color:var(--text-secondary);border-radius:var(--radius-full);font-weight:500;transition:all var(--transition-fast)}.filter-btn:hover,.filter-btn.active{background:var(--primary);color:#fff}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem}.project-card{background:var(--bg-secondary);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-color);transition:all var(--transition-base)}.project-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:var(--primary)}.project-image{position:relative;height:220px;overflow:hidden}.project-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.project-card:hover .project-image img{transform:scale(1.1)}.project-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);opacity:0;display:flex;align-items:flex-end;justify-content:center;padding:1.5rem;gap:1rem;transition:opacity var(--transition-base)}.project-card:hover .project-overlay{opacity:1}.project-link{width:44px;height:44px;border-radius:var(--radius-full);background:#fff;display:flex;align-items:center;justify-content:center;color:var(--text-primary);transition:all var(--transition-fast)}.project-link:hover{background:var(--primary);color:#fff}.project-link svg{width:20px;height:20px}.project-content{padding:1.5rem}.project-category{display:inline-block;padding:.25rem .75rem;background:var(--primary);color:#fff;font-size:.75rem;font-weight:600;border-radius:var(--radius-full);margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.5px}.project-card h3{font-size:1.25rem;margin-bottom:.75rem}.project-card p{font-size:.95rem;color:var(--text-muted);margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-tech{display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag{padding:.25rem .75rem;background:var(--bg-tertiary);color:var(--text-secondary);font-size:.8rem;border-radius:var(--radius-sm);font-family:var(--font-mono)}.project-details-link{display:inline-block;margin-top:1rem;color:var(--primary);font-weight:600;transition:all var(--transition-fast)}.project-details-link:hover{color:var(--accent)}.project-github-link{display:inline-flex;align-items:center;gap:.35rem;margin-left:1rem;margin-top:1rem;color:var(--text-secondary);font-weight:600;font-size:.9rem;transition:all var(--transition-fast)}.project-github-link:hover{color:var(--primary)}.project-github-link svg{width:18px;height:18px}.projects-footer{display:flex;justify-content:flex-end;margin-top:3rem}.see-all-btn{display:inline-flex;align-items:center;gap:.5rem}.projects-page{padding-top:120px;min-height:100vh}.back-home{margin-top:3rem;text-align:center}.timeline{position:relative;max-width:900px;margin:0 auto}.timeline:before{content:"";position:absolute;left:50%;transform:translate(-50%);width:2px;height:100%;background:var(--border-color)}.timeline-item{display:flex;justify-content:flex-end;padding-right:calc(50% + 30px);position:relative;margin-bottom:3rem}.timeline-item:nth-child(odd){justify-content:flex-start;padding-right:0;padding-left:calc(50% + 30px)}.timeline-dot{position:absolute;left:50%;transform:translate(-50%);width:20px;height:20px;background:var(--gradient-primary);border-radius:50%;border:4px solid var(--bg-primary);z-index:1}.timeline-content{background:var(--bg-secondary);padding:1.5rem;border-radius:var(--radius-lg);border:1px solid var(--border-color);max-width:400px;transition:all var(--transition-base)}.timeline-content:hover{border-color:var(--primary);box-shadow:var(--shadow-lg)}.timeline-date{display:inline-block;padding:.25rem .75rem;background:var(--primary);color:#fff;font-size:.875rem;font-weight:600;border-radius:var(--radius-sm);margin-bottom:1rem}.timeline-content h4{margin-bottom:.5rem}.timeline-company{color:var(--accent);font-weight:600;margin-bottom:.75rem}.timeline-content p{font-size:.95rem;color:var(--text-muted)}@media(max-width:768px){.timeline:before{left:10px}.timeline-item,.timeline-item:nth-child(odd){padding-left:50px;padding-right:0;justify-content:flex-start}.timeline-dot{left:10px}.timeline-content{max-width:100%}}.publications-list{display:flex;flex-direction:column;gap:1.5rem;max-width:900px;margin:0 auto}.publication-card{background:var(--bg-secondary);padding:1.5rem 2rem;border-radius:var(--radius-lg);border:1px solid var(--border-color);display:flex;gap:1.5rem;transition:all var(--transition-base)}.publication-card:hover{border-color:var(--primary);box-shadow:var(--shadow-lg)}.publication-type{writing-mode:vertical-rl;text-orientation:mixed;padding:.5rem;background:var(--gradient-primary);color:#fff;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.publication-info{flex:1}.publication-info h4{margin-bottom:.5rem;font-size:1.1rem}.publication-authors{color:var(--text-muted);font-size:.95rem;margin-bottom:.5rem}.publication-venue{color:var(--accent);font-weight:600;font-size:.95rem;margin-bottom:1rem}.publication-links{display:flex;gap:.75rem}.pub-link{padding:.375rem .875rem;background:var(--bg-tertiary);color:var(--text-secondary);font-size:.85rem;font-weight:500;border-radius:var(--radius-sm);display:flex;align-items:center;gap:.375rem;transition:all var(--transition-fast)}.pub-link:hover{background:var(--primary);color:#fff}.pub-link svg{width:16px;height:16px}@media(max-width:600px){.publication-card{flex-direction:column}.publication-type{writing-mode:horizontal-tb;text-orientation:initial;align-self:flex-start}}.blog-list{display:flex;flex-direction:column;gap:1.5rem;max-width:800px;margin:0 auto}.blog-card{display:flex;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden;transition:all var(--transition-base)}.blog-card:hover{border-color:var(--primary);box-shadow:var(--shadow-lg);transform:translateY(-3px)}.blog-date-badge{background:var(--gradient-primary);color:#fff;padding:1rem .75rem;display:flex;align-items:center;justify-content:center;min-width:70px}.blog-date-badge span{writing-mode:vertical-rl;text-orientation:mixed;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px}.blog-content{padding:1.5rem;flex:1}.blog-content h3{font-size:1.1rem;margin-bottom:.5rem;color:var(--text-primary)}.blog-description{color:var(--accent);font-size:.9rem}.blog-footer{display:flex;justify-content:center;margin-top:2rem}@media(max-width:600px){.blog-date-badge span{writing-mode:horizontal-tb;text-orientation:initial}}.news-grid{display:flex;flex-direction:column;gap:1.5rem;max-width:900px;margin:0 auto}.news-item{background:var(--bg-secondary);padding:1.5rem 2rem;border-radius:var(--radius-lg);border:1px solid var(--border-color);display:grid;grid-template-columns:120px 1fr;gap:2rem;transition:all var(--transition-base)}.news-item:hover{border-color:var(--primary);box-shadow:var(--shadow-lg)}.news-item.expanded{grid-template-columns:1fr}.news-date{color:var(--text-muted);font-size:.9rem;font-weight:500}.news-content h4{font-size:1.1rem;margin-bottom:.75rem;display:flex;align-items:flex-start;gap:.5rem;flex-wrap:wrap}.news-icon{font-size:1.2rem}.news-summary{color:var(--text-muted);font-size:.95rem;margin-bottom:.75rem}.news-description{color:var(--text-secondary);font-size:.95rem;line-height:1.7;margin-bottom:1rem}.news-image{margin:1rem 0;border-radius:var(--radius-md);overflow:hidden}.news-image img{width:100%;max-width:400px;height:auto;border-radius:var(--radius-md)}.read-more-btn{background:none;border:none;color:var(--accent);font-weight:600;cursor:pointer;padding:0;font-size:.9rem;transition:all var(--transition-fast)}.news-footer{display:flex;justify-content:center;margin-top:2rem}.news-page{padding-top:120px;min-height:100vh}.news-page .news-grid{max-width:1000px}.news-full-item{display:flex;flex-direction:column;margin-bottom:2rem;padding:2rem;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.news-full-image{margin-bottom:1.5rem}.news-full-image img{width:100%;max-height:400px;object-fit:contain;border-radius:var(--radius-md);background:var(--bg-tertiary)}.news-full-content h3{color:var(--accent);font-size:1.3rem;margin-bottom:1rem}.news-full-content p{color:var(--text-secondary);line-height:1.7;margin-bottom:1rem}.news-full-date{display:inline-block;padding:.5rem 1rem;background:var(--primary);color:#fff;font-size:.85rem;font-weight:500;border-radius:var(--radius-full)}@media(max-width:768px){.news-item{grid-template-columns:1fr;gap:.5rem}.news-full-item,.news-full-item:nth-child(2n){grid-template-columns:1fr}.news-full-item:nth-child(2n) .news-full-image{order:0}}.contact{background:var(--bg-secondary)}.contact-content{display:grid;grid-template-columns:1fr 1.5fr;gap:4rem}.contact-info h3{margin-bottom:1.5rem}.contact-info p{margin-bottom:2rem}.contact-details{display:flex;flex-direction:column;gap:1.5rem}.contact-item{display:flex;align-items:center;gap:1rem}.contact-icon{width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);color:#fff;border-radius:var(--radius-md)}.contact-icon svg{width:24px;height:24px}.contact-text span{display:block;font-size:.875rem;color:var(--text-muted)}.contact-text a,.contact-text p{font-weight:600;color:var(--text-primary);font-size:1rem;margin:0}.contact-form{background:var(--bg-primary);padding:2.5rem;border-radius:var(--radius-xl);border:1px solid var(--border-color)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.form-group input,.form-group textarea{width:100%;padding:.875rem 1rem;font-family:var(--font-primary);font-size:1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);transition:all var(--transition-fast)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.form-group textarea{min-height:150px;resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:768px){.contact-content,.form-row{grid-template-columns:1fr}}.footer{padding:3rem 0;border-top:1px solid var(--border-color)}.footer-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem}.footer-logo{font-size:1.25rem;font-weight:800;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.footer-text{color:var(--text-muted);font-size:.95rem}.footer-socials a{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);color:var(--text-secondary);border-radius:var(--radius-full);transition:all var(--transition-fast)}.footer-socials a:hover{background:var(--primary);color:#fff}.footer-socials svg{width:18px;height:18px}@media(max-width:600px){.footer-content{flex-direction:column;text-align:center}}.fade-in{opacity:1;transform:translateY(0);animation:fadeInUp .6s ease forwards}.page-header{padding:10rem 0 4rem;text-align:center;background:var(--bg-secondary);position:relative;overflow:hidden}.page-header:before{content:"";position:absolute;inset:0;background:var(--gradient-hero);opacity:.03}.page-header h1{margin-bottom:1rem}.page-header p{max-width:600px;margin:0 auto}.back-to-top{position:fixed;bottom:2rem;right:2rem;width:50px;height:50px;background:var(--gradient-primary);color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(20px);transition:all var(--transition-base);z-index:999}.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}.back-to-top:hover{transform:scale(1.1);color:#fff}.back-to-top svg{width:24px;height:24px}.news{background:var(--bg-secondary)}.news-grid{display:flex;flex-direction:column;gap:1rem;max-width:800px;margin:0 auto}.news-item{display:flex;gap:1.5rem;padding:1.5rem;background:var(--bg-primary);border-radius:var(--radius-lg);border:1px solid var(--border-color);transition:all var(--transition-base)}.news-item:hover{border-color:var(--primary);box-shadow:var(--shadow-md)}.news-date{flex-shrink:0;width:100px;font-size:.875rem;font-weight:600;color:var(--primary)}.news-content{flex:1}.news-icon{font-size:1.25rem;margin-right:.5rem}.news-content h4{font-size:1rem;margin-bottom:.5rem;color:var(--text-primary)}.news-content p{font-size:.9rem;color:var(--text-secondary);line-height:1.5}.news-summary{margin-bottom:.5rem}.news-expanded{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-color)}.news-expanded p{font-size:.9rem;color:var(--text-secondary)}.read-more-btn{margin-top:.75rem;padding:0;background:none;border:none;color:var(--accent);font-size:.875rem;font-weight:600;cursor:pointer;transition:color var(--transition-fast)}.read-more-btn:hover{color:var(--primary)}@media(max-width:768px){.news-item{flex-direction:column;gap:.5rem}.news-date{width:auto}}.page-header{text-align:center}.page-header h1{margin-bottom:.5rem}.page-header p{color:var(--text-secondary)}.news-full-grid{display:flex;flex-direction:column;gap:2rem;max-width:900px;margin:0 auto}.news-full-item{display:flex;flex-direction:column;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden;transition:all var(--transition-base)}.news-full-item:hover{box-shadow:var(--shadow-lg);border-color:var(--primary)}.news-full-image{width:100%;max-height:400px;overflow:hidden}.news-full-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.news-full-item:hover .news-full-image img{transform:scale(1.02)}.news-full-content{padding:2rem}.news-full-date{display:inline-block;padding:.375rem .75rem;background:var(--primary);color:#fff;font-size:.8rem;font-weight:600;border-radius:var(--radius-full);margin-bottom:1rem}.news-full-content h2{font-size:1.5rem;margin-bottom:1rem;color:var(--text-primary)}.news-full-content p{font-size:1rem;color:var(--text-secondary);line-height:1.7;margin-bottom:.75rem}.news-full-content p:last-child{margin-bottom:0}@media(max-width:768px){.news-full-content{padding:1.5rem}.news-full-content h2{font-size:1.25rem}}.back-link{display:inline-block;color:var(--primary);font-weight:500;margin-bottom:2rem;transition:color var(--transition-fast)}.back-link:hover{color:var(--accent)}.project-detail-header{margin-bottom:2rem}.project-detail-header .project-category{display:inline-block;padding:.375rem .75rem;background:var(--primary);color:#fff;font-size:.8rem;font-weight:600;border-radius:var(--radius-full);margin-bottom:1rem}.project-detail-header h1{margin-bottom:1rem}.project-detail-header .project-tech{display:flex;flex-wrap:wrap;gap:.5rem}.project-detail-image{width:100%;max-height:500px;overflow:hidden;border-radius:var(--radius-lg);margin-bottom:2rem}.project-detail-image img{width:100%;height:100%;object-fit:cover}.project-detail-content{max-width:800px}.project-detail-content h2{margin-bottom:1rem;font-size:1.75rem}.project-detail-content h3{margin-top:2rem;margin-bottom:.75rem;font-size:1.25rem;color:var(--primary)}.project-detail-content p{margin-bottom:1rem;line-height:1.8}.project-detail-content ul{margin-bottom:1rem;padding-left:1.5rem}.project-detail-content li{margin-bottom:.5rem;color:var(--text-secondary);line-height:1.6}.project-detail-content li::marker{color:var(--primary)}.project-links{margin-top:2rem;display:flex;gap:1rem;flex-wrap:wrap}.project-view-link{display:inline-block;margin-top:1rem;color:var(--accent);font-size:.875rem;font-weight:600;transition:color var(--transition-fast)}.project-view-link:hover{color:var(--primary)}.text-center{text-align:center}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.footer{background:var(--bg-secondary);padding:2rem 0;border-top:1px solid var(--border-color)}.footer-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.footer-brand{font-size:1.2rem;font-weight:700}.footer-content p{color:var(--text-muted);font-size:.9rem;margin:0}.footer-socials{display:flex;gap:1rem}.footer-socials a{width:40px;height:40px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all var(--transition-fast)}.footer-socials a:hover{background:var(--primary);color:#fff;transform:translateY(-3px)}.footer-socials svg{width:20px;height:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.btn-block{width:100%;justify-content:center}@media(max-width:768px){.footer-content{flex-direction:column;text-align:center}.form-row{grid-template-columns:1fr}}.fade-in{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}.fade-in.visible{opacity:1;transform:translateY(0)}.fade-in:nth-child(1){transition-delay:0s}.fade-in:nth-child(2){transition-delay:.1s}.fade-in:nth-child(3){transition-delay:.15s}.fade-in:nth-child(4){transition-delay:.2s}.fade-in:nth-child(5){transition-delay:.25s}.fade-in:nth-child(6){transition-delay:.3s}.fade-in:nth-child(7){transition-delay:.35s}.fade-in:nth-child(8){transition-delay:.4s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translate(0) scale(1)}25%{transform:translate(30px,-30px) scale(1.1)}50%{transform:translate(-20px,20px) scale(.9)}75%{transform:translate(20px,10px) scale(1.05)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.hero-text{animation:fadeInUp 1s ease}.hero-image{animation:fadeInUp 1s ease .3s backwards}.hero-gradient{position:absolute;inset:0;background:var(--gradient-hero);opacity:.05;z-index:-2}.hero-pattern{position:absolute;inset:0;z-index:-1;overflow:hidden}.hero-pattern:before,.hero-pattern:after{content:"";position:absolute;width:300px;height:300px;border-radius:50%;filter:blur(80px);opacity:.4;animation:float 20s infinite ease-in-out}.hero-pattern:before{background:var(--primary);top:10%;left:10%;animation-delay:0s}.hero-pattern:after{background:var(--accent);bottom:20%;right:10%;animation-delay:-10s}section{position:relative}.skill-category,.project-card,.news-item,.news-full-item,.timeline-content,.publication-card{transition:all var(--transition-base)}.skill-category:hover,.project-card:hover,.news-item:hover,.news-full-item:hover{transform:translateY(-5px);box-shadow:var(--shadow-xl)}a{transition:color var(--transition-fast)}.btn{transition:all var(--transition-fast)}.btn:hover{transform:translateY(-2px)}.social-link{transition:all var(--transition-fast)}.social-link:hover{transform:translateY(-3px) scale(1.1)}[data-theme=light] .navbar{background:#ffffffe6;border-bottom:1px solid rgba(0,0,0,.05)}[data-theme=light] .skill-category,[data-theme=light] .project-card,[data-theme=light] .blog-card,[data-theme=light] .news-item,[data-theme=light] .timeline-content,[data-theme=light] .publication-card{background:var(--card-bg);border:1px solid var(--card-border);box-shadow:var(--card-shadow)}[data-theme=light] .hero-stats{background:#ffffffe6;border:1px solid rgba(0,0,0,.05);box-shadow:0 10px 25px #0000000d}[data-theme=light] .skill-tag,[data-theme=light] .tech-tag,[data-theme=light] .pub-link,[data-theme=light] .social-link{background:#f1f5f9;color:#475569}[data-theme=light] .skill-tag:hover,[data-theme=light] .tech-tag:hover,[data-theme=light] .pub-link:hover,[data-theme=light] .social-link:hover{background:var(--primary);color:#fff}[data-theme=light] .project-overlay{background:linear-gradient(to top,rgba(0,0,0,.7),transparent)}[data-theme=light] .project-overlay .project-link{color:#0f172a;background:#fff}[data-theme=light] .project-overlay .project-link:hover{background:var(--primary);color:#fff}
