@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/inter-latin-ext.woff2) format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/inter-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/inter-latin-ext.woff2) format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/inter-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/space-grotesk-latin-ext.woff2) format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/space-grotesk-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/space-grotesk-latin-ext.woff2) format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/space-grotesk-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--bg: #0f172a;--surface: #1e293b;--primary: #38bdf8;--primary-hover: #0ea5e9;--accent-violet: #a78bfa;--accent-gradient: linear-gradient(135deg, var(--primary), var(--accent-violet));--text: #e2e8f0;--heading: #f8fafc;--muted: #94a3b8;--border: #334155;--glass-bg: rgba(30, 41, 59, .6);--glass-border: rgba(148, 163, 184, .12);--radius: 12px;--transition: .3s ease;--max-width: 1100px}[data-theme=light]{--bg: #f8fafc;--surface: #ffffff;--primary: #0284c7;--primary-hover: #0369a1;--accent-violet: #7c3aed;--accent-gradient: linear-gradient(135deg, var(--primary), var(--accent-violet));--text: #334155;--heading: #0f172a;--muted: #64748b;--border: #e2e8f0;--glass-bg: rgba(255, 255, 255, .7);--glass-border: rgba(148, 163, 184, .2)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:80px}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg);color:var(--text);line-height:1.6;font-size:16px}body:after{content:"";position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9999;opacity:.02;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}a{color:var(--primary);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--primary-hover)}img{max-width:100%;display:block}ul{list-style:none}.skip-to-content{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;z-index:9999;background:var(--primary);color:var(--bg);padding:.75rem 1.5rem;font-weight:700;font-size:.9rem;border-radius:0 0 var(--radius) 0;text-decoration:none}.skip-to-content:focus{position:fixed;left:0;top:0;width:auto;height:auto;overflow:visible}h1,h2,h3,h4{font-family:Space Grotesk,Inter,sans-serif;color:var(--heading);font-weight:700;line-height:1.2}h2{font-size:2rem}h3{font-size:1.25rem}strong{color:var(--heading)}.container{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}section{padding:7rem 0}.section-title{margin-bottom:3rem;position:relative;display:inline-block}.section-title:after{content:"";position:absolute;bottom:-10px;left:0;width:60px;height:3px;background:var(--accent-gradient);border-radius:2px}.glass-card{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius);transition:all .4s ease}.glass-card:hover{border-color:transparent;box-shadow:0 8px 32px #0000004d,0 0 0 1px #38bdf81a;background:linear-gradient(var(--glass-bg),var(--glass-bg)) padding-box,var(--accent-gradient) border-box;border:1px solid transparent}.scroll-progress{position:fixed;top:0;left:0;height:3px;width:100%;background:linear-gradient(90deg,var(--primary),var(--accent-violet));z-index:1001;transform-origin:left;transform:scaleX(0);transition:transform .05s linear;pointer-events:none;border-radius:0 2px 2px 0}#navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1rem 0;transition:background-color var(--transition),box-shadow var(--transition)}#navbar.scrolled{background-color:#0f172ae6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 1px 3px #0000004d}.nav-container{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between}.nav-logo{font-family:Space Grotesk,sans-serif;font-size:1.25rem;font-weight:700;color:var(--heading)}.nav-logo:hover{color:var(--primary)}.nav-links{display:flex;align-items:center;gap:1.75rem}.nav-links a{color:var(--muted);font-size:.85rem;position:relative;padding-bottom:4px;letter-spacing:.01em}.nav-links a:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--accent-gradient);transition:width var(--transition)}.nav-links a:hover,.nav-links a.active{color:var(--heading)}.nav-links a:hover:after,.nav-links a.active:after{width:100%}.nav-resume-btn{color:var(--primary)!important;cursor:pointer;background:none;border:none;font-family:inherit;font-size:.85rem;padding-bottom:4px;position:relative}.nav-resume-btn:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--accent-gradient);transition:width var(--transition)}.nav-resume-btn:hover{color:var(--heading)!important;cursor:pointer}.nav-resume-btn:hover:after{width:100%}.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}.hamburger span{display:block;width:24px;height:2px;background:var(--text);transition:transform var(--transition),opacity var(--transition)}.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.lang-switcher{display:flex;gap:.25rem;margin-left:.5rem}.lang-btn{background:transparent;border:1px solid var(--border);color:var(--muted);padding:.4rem .6rem;border-radius:6px;cursor:pointer;font-size:.7rem;font-weight:700;font-family:inherit;transition:all var(--transition);min-width:36px;min-height:36px;display:inline-flex;align-items:center;justify-content:center}.lang-btn:hover,.lang-btn.active{background:var(--primary);color:var(--bg);border-color:var(--primary)}#hero{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:2rem 1.5rem;position:relative;overflow:hidden;background:radial-gradient(ellipse at 20% 50%,rgba(56,189,248,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 50%,rgba(167,139,250,.06) 0%,transparent 50%),var(--bg)}.particle-canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0}.hero-content{position:relative;z-index:1}.hero-name-gradient{font-size:3.5rem;margin-bottom:1rem;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.25rem;color:var(--muted);margin-bottom:1rem}.hero-tagline{font-size:1.15rem;color:var(--text);margin-bottom:2.5rem;min-height:1.8em}.typing-cursor{color:var(--primary);animation:blink 1s step-end infinite;font-weight:300}@keyframes blink{50%{opacity:0}}.hero-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:2.5rem}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 2rem;background:var(--primary);color:var(--bg);font-weight:700;font-family:Space Grotesk,sans-serif;font-size:.95rem;border:none;border-radius:var(--radius);cursor:pointer;transition:all var(--transition)}.btn:hover{background:var(--primary-hover);color:var(--bg);transform:translateY(-2px);box-shadow:0 4px 20px #38bdf84d}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.btn-outline{background:transparent;border:2px solid var(--primary);color:var(--primary)}.btn-outline:hover{background:var(--primary);color:var(--bg)}.hero-socials{display:flex;gap:1rem;justify-content:center}.hero-socials a{width:44px;height:44px;border-radius:50%;border:1px solid var(--glass-border);background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all var(--transition)}.hero-socials a:hover{color:var(--primary);border-color:var(--primary);transform:translateY(-3px);box-shadow:0 4px 15px #38bdf833}.about-content{display:flex;gap:3rem;align-items:flex-start}.about-photo{flex-shrink:0;width:200px;height:200px;border-radius:50%;overflow:hidden;border:3px solid transparent;background:linear-gradient(var(--bg),var(--bg)) padding-box,var(--accent-gradient) border-box}.about-photo img{width:100%;height:100%;object-fit:cover}.about-text p{margin-bottom:1rem}.about-info{margin-top:1.5rem;display:flex;flex-direction:column;gap:.75rem}.info-item{display:flex;gap:1rem;align-items:baseline}.info-label{font-weight:700;color:var(--primary);min-width:100px;font-size:.9rem}.about-education{margin-top:2rem;display:flex;flex-direction:column;gap:1rem}.education-card{padding:1.25rem}.education-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap;margin-bottom:.25rem}.education-header h4{font-size:1rem;margin-bottom:0}.education-degree{color:var(--primary);font-size:.85rem;margin-bottom:.25rem}.education-detail{font-size:.9rem;color:var(--muted)}.timeline{position:relative;padding-left:2.5rem}.timeline:before{content:"";position:absolute;left:6px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--primary),var(--accent-violet),transparent)}.timeline-entry{position:relative;margin-bottom:2rem}.timeline-entry:last-child{margin-bottom:0}.timeline-dot{position:absolute;left:-2.5rem;top:2rem;width:14px;height:14px;border-radius:50%;background:var(--primary);border:3px solid var(--bg);box-shadow:0 0 0 3px #38bdf840;z-index:1}.timeline-card{padding:2rem}.experience-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap}.experience-header h3{margin-bottom:.25rem}.company{color:var(--muted);font-size:.95rem}.date-badge{background:#38bdf81a;color:var(--primary);padding:.35rem .75rem;border-radius:var(--radius);font-size:.8rem;white-space:nowrap;font-weight:600}.experience-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.experience-list li{position:relative;padding-left:1.25rem;font-size:.95rem;color:var(--text)}.experience-list li:before{content:"";position:absolute;left:0;top:10px;width:6px;height:6px;background:var(--primary);border-radius:50%}.project-filter-bar{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}.filter-tag{background:transparent;border:1px solid var(--glass-border);color:var(--muted);padding:.45rem .85rem;border-radius:9999px;font-size:.8rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all var(--transition);min-height:36px}.filter-tag:hover{border-color:var(--primary);color:var(--primary)}.filter-tag--active{background:var(--primary);border-color:var(--primary);color:var(--bg)}.tag.tag--interactive{background:#38bdf81a;border:none;cursor:pointer;font-family:inherit;font-size:inherit}.tag.tag--active{background:#38bdf840;outline:1px solid var(--primary);outline-offset:1px}.projects-empty{color:var(--muted);text-align:center;padding:3rem 0;font-size:.95rem}.projects-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}.project-card{overflow:hidden;display:flex;flex-direction:column;padding:0}.project-accent{height:4px;background:var(--accent-gradient)}.project-image-placeholder{height:160px;background:linear-gradient(135deg,#38bdf80f,#a78bfa0f);display:flex;align-items:center;justify-content:center}.project-image-fallback{color:var(--muted);opacity:.2}.project-body{padding:1.75rem;flex-grow:1;display:flex;flex-direction:column}.project-body h3{margin-bottom:.25rem}.project-label{color:var(--primary);font-size:.85rem;margin-bottom:1rem}.project-body>p{font-size:.95rem;margin-bottom:1.25rem;flex-grow:1}.project-link{display:inline-flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--primary);font-weight:700}.project-link:hover{color:var(--primary-hover)}.project-links{display:flex;gap:1.25rem;margin-top:1.25rem;flex-wrap:wrap;align-items:center}.project-link-note{font-size:.85rem;color:var(--muted);font-style:italic}.project-link--demo{color:var(--accent-violet)}.project-link--demo:hover{color:var(--primary-hover)}.project-image{width:100%;height:100%;object-fit:cover}.skills-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}.skill-category{padding:1.5rem}.skill-category-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.skill-category-header h3{font-size:.9rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.skill-icon{width:20px;height:20px;color:var(--primary)}.tech-tags{display:flex;flex-wrap:wrap;gap:.5rem}.tag{background:#38bdf81a;color:var(--primary);padding:.3rem .75rem;border-radius:9999px;font-size:.8rem;font-weight:700}.skill-badge{display:inline-flex;align-items:center;gap:.5rem;background:#38bdf80f;border:1px solid var(--glass-border);color:var(--text);padding:.4rem .85rem;border-radius:9999px;font-size:.85rem;font-weight:500;transition:all var(--transition)}.skill-badge:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--primary);flex-shrink:0}.skill-badge:hover{background:#38bdf81f;border-color:#38bdf84d}.volunteering-entry{padding:1.5rem}.volunteering-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap;margin-bottom:.75rem}.volunteering-header h3{font-size:1.1rem;margin-bottom:.15rem}.volunteering-org{color:var(--primary);font-size:.85rem}.volunteering-desc{font-size:.9rem;color:var(--text)}#contact{text-align:left}.contact-text{color:var(--muted);margin-bottom:2.5rem;font-size:1.1rem}.contact-split{display:grid;grid-template-columns:1fr;gap:3rem}.contact-form{display:flex;flex-direction:column;gap:1rem}.contact-form input,.contact-form textarea{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius);padding:.85rem 1rem;color:var(--text);font-family:inherit;font-size:1rem;transition:border-color var(--transition);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--muted)}.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--primary)}.contact-form textarea{resize:vertical;min-height:130px}.form-field{display:flex;flex-direction:column;gap:.25rem}.contact-form input.field-error,.contact-form textarea.field-error{border-color:#f87171;box-shadow:0 0 0 3px #f871711a}.field-error-msg{font-size:.78rem;color:#f87171;padding-left:.25rem}.form-status{margin-top:.5rem;font-size:.9rem}.form-status.success{color:#4ade80}.form-status.error{color:#f87171}.contact-info-card{padding:2rem}.contact-info-card h3{margin-bottom:1.5rem}.contact-info-items{display:flex;flex-direction:column;gap:1.25rem;align-items:flex-start}.contact-item{display:inline-flex;align-items:center;gap:.75rem;color:var(--text);font-size:.95rem;transition:color var(--transition)}.contact-item:hover{color:var(--primary)}.contact-item svg{flex-shrink:0}.contact-location{display:flex;align-items:center;gap:.5rem;color:var(--muted);margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--glass-border);font-size:.9rem}footer{border-top:2px solid transparent;border-image:var(--accent-gradient) 1;padding:3rem 1.5rem 2rem;color:var(--muted);font-size:.85rem}.footer-content{max-width:var(--max-width);margin:0 auto;display:grid;grid-template-columns:1fr;gap:2rem;text-align:center}.footer-col h4{font-size:.9rem;color:var(--heading);margin-bottom:1rem;text-transform:uppercase;letter-spacing:.05em}.footer-links{display:flex;flex-direction:column;gap:.5rem}.footer-links a{color:var(--muted);font-size:.85rem;transition:color var(--transition)}.footer-links a:hover{color:var(--primary)}.footer-socials{display:flex;gap:.75rem;justify-content:center}.footer-socials .social-icon{width:36px;height:36px;border-radius:50%;border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all var(--transition)}.footer-socials .social-icon:hover{color:var(--primary);border-color:var(--primary)}.footer-copyright{color:var(--muted);font-size:.85rem}.back-to-top{position:fixed;bottom:2rem;right:2rem;width:44px;height:44px;border-radius:50%;background:var(--accent-gradient);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(10px);transition:opacity var(--transition),transform var(--transition);z-index:999}.back-to-top.visible{opacity:1;transform:translateY(0)}.back-to-top:hover{box-shadow:0 4px 20px #38bdf866;transform:translateY(-2px)}.resume-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:2rem}.resume-modal{background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius);width:100%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.resume-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--glass-border)}.resume-modal-header h3{font-size:1.1rem}.resume-close{background:none;border:none;color:var(--muted);font-size:1.5rem;cursor:pointer;padding:.25rem;line-height:1;transition:color var(--transition)}.resume-close:hover{color:var(--heading)}.resume-close-group,.project-modal-close-group{display:flex;align-items:center;gap:.75rem}.modal-esc-hint{font-size:.75rem;color:var(--muted);opacity:.7;white-space:nowrap}.resume-iframe{width:100%;flex-grow:1;min-height:500px;border:none;background:#fff}.resume-modal-footer{display:flex;justify-content:center;padding:1.25rem 1.5rem;border-top:1px solid var(--glass-border)}.project-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:2rem}.project-modal{background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius);width:100%;max-width:700px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.project-modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem 1.5rem 1rem;border-bottom:1px solid var(--glass-border);gap:1rem}.project-modal-header h3{font-size:1.25rem;margin-bottom:.25rem}.project-modal-label{color:var(--primary);font-size:.85rem}.project-modal-close{background:none;border:none;color:var(--muted);font-size:1.5rem;cursor:pointer;padding:.25rem;line-height:1;transition:color var(--transition);flex-shrink:0}.project-modal-close:hover{color:var(--heading)}.project-modal-body{padding:1.5rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem}.project-modal-screenshots{display:flex;gap:.75rem;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:.5rem}.project-modal-screenshot{flex-shrink:0;width:100%;max-height:300px;object-fit:cover;border-radius:var(--radius);scroll-snap-align:start}.project-modal-description p{font-size:.95rem;line-height:1.7;color:var(--text)}.project-modal-highlights h4{font-size:.9rem;color:var(--heading);margin-bottom:.75rem}.project-modal-highlights ul{display:flex;flex-direction:column;gap:.5rem}.project-modal-highlights li{position:relative;padding-left:1.25rem;font-size:.9rem;color:var(--text)}.project-modal-highlights li:before{content:"";position:absolute;left:0;top:10px;width:6px;height:6px;background:var(--primary);border-radius:50%}.project-modal-links{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;padding-top:.5rem;border-top:1px solid var(--glass-border)}.project-details-btn{background:none;border:none;cursor:pointer;font-family:inherit;font-weight:700;padding:0;transition:color var(--transition)}[data-theme=light] .project-modal-overlay{background:#0006}@media(max-width:767px){.project-modal{max-height:85vh}.project-modal-header{padding:1.25rem 1rem .75rem}.project-modal-body{padding:1rem}.project-modal-links{flex-direction:column;align-items:stretch}.project-modal-links .btn{text-align:center;justify-content:center}}.blog-page{padding:7rem 0 4rem;min-height:100vh}.blog-header{margin-bottom:3rem}.blog-back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--muted);font-size:.9rem;margin-bottom:1.5rem;transition:color var(--transition)}.blog-back-link:hover{color:var(--primary)}.blog-subtitle{color:var(--muted);font-size:1.1rem;margin-top:.5rem}.blog-empty{color:var(--muted);text-align:center;padding:3rem 0;font-size:.95rem}.blog-loading{display:flex;justify-content:center;padding:4rem 0}.blog-loading-spinner{width:36px;height:36px;border:3px solid var(--glass-border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.blog-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}.blog-card{display:block;padding:0;overflow:hidden;text-decoration:none;color:inherit}.blog-card-body{padding:1.75rem}.blog-card-date{font-size:.8rem;color:var(--primary);font-weight:600;display:block;margin-bottom:.5rem}.blog-card h2{font-size:1.25rem;margin-bottom:.75rem;color:var(--heading)}.blog-card p{font-size:.95rem;color:var(--text);margin-bottom:1rem;line-height:1.6}.blog-post{max-width:750px}.blog-post-header{margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--glass-border)}.blog-post-date{font-size:.85rem;color:var(--primary);font-weight:600;display:block;margin-bottom:.75rem}.blog-post-header h1{font-size:2rem;margin-bottom:1rem}.blog-post-content{font-size:1rem;line-height:1.8;color:var(--text)}.blog-post-content h1,.blog-post-content h2,.blog-post-content h3{margin-top:2rem;margin-bottom:1rem}.blog-post-content h1{font-size:1.75rem}.blog-post-content h2{font-size:1.4rem}.blog-post-content h3{font-size:1.15rem}.blog-post-content p{margin-bottom:1.25rem}.blog-post-content ul,.blog-post-content ol{margin-bottom:1.25rem;padding-left:1.5rem}.blog-post-content li{margin-bottom:.5rem;list-style:disc}.blog-post-content ol li{list-style:decimal}.blog-post-content code{background:var(--glass-bg);padding:.15rem .4rem;border-radius:4px;font-size:.9em;color:var(--primary)}.blog-post-content pre{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius);padding:1.25rem;overflow-x:auto;margin-bottom:1.5rem}.blog-post-content pre code{background:none;padding:0;color:var(--text);font-size:.85rem}.blog-post-content blockquote{border-left:3px solid var(--primary);padding-left:1rem;margin:1.5rem 0;color:var(--muted);font-style:italic}.blog-post-content table{width:100%;border-collapse:collapse;margin-bottom:1.5rem}.blog-post-content th,.blog-post-content td{border:1px solid var(--glass-border);padding:.6rem .85rem;text-align:left;font-size:.9rem}.blog-post-content th{background:var(--glass-bg);font-weight:700;color:var(--heading)}.blog-post-content a{color:var(--primary);text-decoration:underline}.blog-post-content a:hover{color:var(--primary-hover)}@media(min-width:768px){.blog-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:767px){.blog-post-header h1{font-size:1.5rem}}.fade-in{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}.fade-in.visible{opacity:1;transform:translateY(0)}.fade-in.fade-in-left{transform:translate(-30px)}.fade-in.fade-in-right{transform:translate(30px)}.fade-in.fade-in-left.visible,.fade-in.fade-in-right.visible{transform:translate(0)}.stagger-item{opacity:0;transform:translateY(15px);transition:opacity .5s ease,transform .5s ease}.stagger-item.stagger-visible{opacity:1;transform:translateY(0)}@media(min-width:768px){.projects-grid,.skills-grid{grid-template-columns:repeat(2,1fr)}.contact-split{grid-template-columns:1fr 1fr}.footer-content{grid-template-columns:1fr 1fr 1fr;text-align:left}.footer-socials{justify-content:flex-start}}@media(min-width:1024px){.hero-name-gradient{font-size:4.5rem}.skills-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:767px){.hamburger{display:flex}.nav-links{position:absolute;top:100%;left:0;right:0;background:#0f172afa;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-direction:column;padding:1.5rem;gap:1rem;transform:translateY(-10px);opacity:0;pointer-events:none;transition:transform var(--transition),opacity var(--transition)}.nav-links.open{transform:translateY(0);opacity:1;pointer-events:auto}.lang-switcher{margin-left:0}.about-content{flex-direction:column;align-items:center;text-align:center}.about-photo{width:160px;height:160px}.info-item{flex-direction:column;gap:.25rem}.experience-header,.volunteering-header{flex-direction:column}h2{font-size:1.6rem}.hero-name-gradient{font-size:2.5rem}section{padding:4rem 0}.timeline{padding-left:2rem}.timeline-dot{left:-2rem;width:12px;height:12px}.resume-iframe{min-height:300px}.contact-split{text-align:center}.contact-info-items{align-items:center}}.github-chart-wrapper{padding:1.5rem;margin-bottom:2rem;text-align:center}.github-chart-wrapper h3{margin-bottom:1rem}.github-chart{width:100%;max-width:800px;margin:0 auto;border-radius:var(--radius)}.theme-toggle{background:none;border:1px solid var(--border);color:var(--muted);width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;transition:all var(--transition)}.theme-toggle:after{content:attr(aria-label);position:absolute;bottom:-2rem;left:50%;transform:translate(-50%);background:var(--card-bg);color:var(--text);font-size:.7rem;padding:.25rem .5rem;border-radius:4px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s;border:1px solid var(--glass-border)}.theme-toggle:hover:after,.theme-toggle:focus-visible:after{opacity:1}.theme-toggle:hover{color:var(--primary);border-color:var(--primary)}[data-theme=light] #navbar.scrolled{background-color:#f8fafce6}[data-theme=light] .glass-card:hover{box-shadow:0 8px 32px #00000014,0 0 0 1px #0284c71a}[data-theme=light] #hero{background:radial-gradient(ellipse at 20% 50%,rgba(2,132,199,.06) 0%,transparent 50%),radial-gradient(ellipse at 80% 50%,rgba(124,58,237,.04) 0%,transparent 50%),var(--bg)}[data-theme=light] .tag,[data-theme=light] .tag.tag--interactive{background:#0284c71a}[data-theme=light] .tag.tag--active{background:#0284c740}[data-theme=light] .date-badge{background:#0284c71a}[data-theme=light] .skill-badge{background:#0284c70f}[data-theme=light] .skill-badge:hover{background:#0284c71f;border-color:#0284c74d}[data-theme=light] .timeline-dot{box-shadow:0 0 0 3px #0284c740}[data-theme=light] .btn:hover{box-shadow:0 4px 20px #0284c74d}[data-theme=light] .hero-socials a:hover{box-shadow:0 4px 15px #0284c733}[data-theme=light] .back-to-top:hover{box-shadow:0 4px 20px #0284c766}[data-theme=light] .resume-overlay{background:#0006}[data-theme=light] body:after{opacity:.015}[data-theme=light] .project-image-placeholder{background:linear-gradient(135deg,#0284c70f,#7c3aed0f)}@media(max-width:767px){[data-theme=light] .nav-links{background:#f8fafcfa}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.fade-in,.fade-in.fade-in-left,.fade-in.fade-in-right,.stagger-item{opacity:1;transform:none}.typing-cursor{animation:none}}@media print{#navbar,.scroll-progress,.particle-bg,.back-to-top,.theme-toggle,.language-switcher,.hamburger,.contact-form,.resume-overlay,.project-modal-overlay{display:none!important}body{background:#fff;color:#000}body:after{display:none}.container{max-width:100%}section{page-break-inside:avoid}.glass-card{background:#fff;border:1px solid #ddd;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}a{color:#000;text-decoration:underline}.hero{min-height:auto;padding:2rem 0}.fade-in,.stagger-item{opacity:1!important;transform:none!important}}
