:root{--bg-primary: #0b0c0b;--bg-secondary: #101110;--bg-tertiary: #181917;--text-primary: #cef9e2;--text-secondary: #9079cd;--text-muted: #5e5180;--accent: #5dcb83;--accent-hover: #4eb873;--accent-glow: rgba(93, 203, 131, .15);--accent-subtle: rgba(93, 203, 131, .08);--accent-secondary: #9079cd;--accent-secondary-glow: rgba(144, 121, 205, .15);--surface: #101110;--surface-hover: #181917;--border: rgba(93, 203, 131, .1);--border-hover: rgba(93, 203, 131, .2);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .15);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .2), 0 2px 4px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .3), 0 4px 6px -2px rgba(0, 0, 0, .15);--shadow-glow: 0 0 20px rgba(93, 203, 131, .12);--container-width: 1200px;--header-height: 64px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--transition-fast: .12s cubic-bezier(.16, 1, .3, 1);--transition-base: .22s cubic-bezier(.16, 1, .3, 1);--transition-slow: .35s cubic-bezier(.16, 1, .3, 1)}[data-theme=light]{--bg-primary: #fcfdfc;--bg-secondary: #f4f7f4;--bg-tertiary: #eaf0eb;--text-primary: #121a14;--text-secondary: #5e5180;--text-muted: #7e749c;--accent: #16a34a;--accent-hover: #15803d;--accent-glow: rgba(22, 163, 74, .12);--accent-subtle: rgba(22, 163, 74, .06);--accent-secondary: #7c3aed;--accent-secondary-glow: rgba(124, 58, 237, .08);--surface: #ffffff;--surface-hover: #f4f7f4;--border: rgba(22, 163, 74, .08);--border-hover: rgba(22, 163, 74, .14);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .05), 0 2px 4px -1px rgba(0, 0, 0, .03);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .05), 0 4px 6px -2px rgba(0, 0, 0, .03);--shadow-glow: 0 0 15px rgba(22, 163, 74, .08)}.mobile-text{display:none!important}@media(max-width:768px){.desktop-text{display:none!important}.mobile-text{display:inline!important}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);height:100%}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px;border:2px solid var(--bg-primary)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}*{scrollbar-width:thin;scrollbar-color:var(--bg-tertiary) var(--bg-primary)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;font-size:.9375rem;transition:background-color var(--transition-base),color var(--transition-base);letter-spacing:-.011em;min-height:100%;overflow-x:hidden;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{text-decoration:none;color:inherit;transition:color var(--transition-fast)}ul,ol{list-style:none}img{max-width:100%;height:auto;display:block}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;letter-spacing:-.025em;color:var(--text-primary)}h1{font-size:clamp(2.25rem,4.5vw,3.5rem);font-weight:700}h2{font-size:clamp(1.5rem,2.5vw,2.25rem)}h3{font-size:1.25rem}h4{font-size:1.0625rem}p{color:var(--text-secondary);margin-bottom:1.25rem}.text-gradient{color:var(--accent);display:inline-block}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}::selection{background:var(--accent);color:#fff}.text-accent{color:var(--accent)}.text-muted{color:var(--text-muted)}.container{max-width:var(--container-width);margin:0 auto;padding:0 24px}.section{padding:100px 0}.section-header{margin-bottom:48px}.section-header h2{margin-bottom:12px}.section-header p{max-width:500px;margin-bottom:0}.page-header-section{padding-top:140px!important;padding-bottom:40px!important}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 22px;border-radius:var(--radius-sm);font-weight:500;font-size:.875rem;border:none;cursor:pointer;transition:all var(--transition-base);text-decoration:none;position:relative;overflow:hidden}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 2px 8px #5dcb8340}.btn-primary:hover{background:var(--accent-hover);box-shadow:0 4px 14px #5dcb834d}.btn-primary:active{transform:scale(.98)}.btn-secondary{background:var(--surface);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--surface-hover);border-color:var(--border-hover)}.btn-ghost{background:transparent;color:var(--text-secondary);padding:8px 16px}.btn-ghost:hover{color:var(--accent);background:var(--accent-subtle)}.btn-icon{padding:8px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast)}.btn-icon:hover{color:var(--accent);background:var(--accent-subtle)}.navbar{position:fixed;top:0;left:0;right:0;height:var(--header-height);z-index:1000;background:transparent;border-bottom:1px solid transparent;transition:background var(--transition-base),border-color var(--transition-base)}.navbar.scrolled{background:#09090bcc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}[data-theme=light] .navbar.scrolled{background:#fffc}.nav-container{height:100%;display:flex;justify-content:space-between;align-items:center}.nav-logo{font-size:1.6rem;font-weight:800;color:var(--accent);display:flex;align-items:center;gap:6px;letter-spacing:-.02em}.nav-logo span{font-weight:600;color:var(--text-primary)}.nav-links{display:flex;gap:28px;align-items:center}.nav-links a{color:var(--text-muted);font-size:.875rem;font-weight:500;transition:color var(--transition-fast);position:relative;padding:6px 0}.nav-links a:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--accent);transition:width .2s ease;border-radius:1px}.nav-links a:hover,.nav-links a.active{color:var(--text-primary)}.nav-links a.active:after{width:100%}.nav-links a.btn-icon{padding:8px;display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--radius-sm)}.nav-links a.btn-icon:after{display:none!important}.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;z-index:1001}.bar{width:22px;height:2px;background:var(--text-primary);border-radius:2px;transition:all var(--transition-base);transform-origin:center}.mobile-drawer{display:none}.hero{min-height:100vh;display:flex;align-items:center;padding-top:var(--header-height);position:relative;overflow:hidden}.hero-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:center}.hero-content{position:relative;z-index:2}.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:5px 14px;background:var(--accent-subtle);border:1px solid rgba(93,203,131,.2);border-radius:100px;font-size:.8rem;font-weight:500;color:var(--accent);margin-bottom:24px}.hero-badge .dot{width:7px;height:7px;background:#ef4444;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.hero h1{margin-bottom:24px;line-height:1.1}.hero-description{font-size:1.125rem;line-height:1.8;max-width:500px;margin-bottom:32px}.hero-cta{display:flex;gap:16px;flex-wrap:wrap}.hero-image{position:relative;display:flex;justify-content:center}.hero-image-frame{width:380px;height:460px;border-radius:var(--radius-md);overflow:hidden;transform:skew(-3deg);box-shadow:var(--shadow-md);position:relative;z-index:2;border:1px solid var(--border)}.hero-image-frame img{width:100%;height:100%;object-fit:cover;object-position:center 20%;transform:skew(3deg) scale(1.15);transition:transform var(--transition-slow);display:block}.hero-image-frame:hover img{transform:skew(3deg) scale(1.2)}.hero-image-glow{display:none}.card{background:var(--surface);border-radius:var(--radius-md);padding:24px;border:1px solid var(--border);transition:transform .3s cubic-bezier(.175,.885,.32,1.275),box-shadow .3s ease,border-color .3s ease}.card:hover{border-color:var(--accent);transform:translateY(-8px) scale(1.01);box-shadow:var(--shadow-md)}[data-theme=light] .card{background:var(--surface);border:1px solid var(--border)}.card-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--accent-subtle);border-radius:var(--radius-sm);margin-bottom:16px;color:var(--accent)}.card h3{margin-bottom:8px}.card p{font-size:.9rem;margin-bottom:0}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.project-card{background:var(--surface);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border);transition:transform .3s cubic-bezier(.175,.885,.32,1.275),box-shadow .3s ease,border-color .3s ease;display:flex;flex-direction:column;transform-style:preserve-3d;will-change:transform}[data-theme=light] .project-card{background:var(--surface);border:1px solid var(--border)}[data-theme=light] .project-card:hover{border-color:var(--border-hover)}.project-header{height:120px;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border)}.project-header svg{color:var(--accent);opacity:.7}.project-content p{font-size:.9rem;line-height:1.6;flex:1}.experience-card{background:var(--surface);border-radius:var(--radius-md);padding:28px;border:1px solid var(--border);border-left:3px solid var(--accent)}[data-theme=light] .experience-card{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--accent)}.experience-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:16px;margin-bottom:16px}.experience-header h3{font-size:1.25rem}.experience-badge{font-size:.75rem;padding:5px 12px;background:var(--accent-subtle);color:var(--text-secondary);border-radius:100px}.experience-card p{margin-bottom:0;line-height:1.75}.quote-section{padding:80px 0;background:radial-gradient(ellipse at center,var(--accent-subtle) 0%,transparent 90%);border-top:1px solid var(--border);border-bottom:1px solid var(--border);text-align:center;position:relative;overflow:hidden}.quote-section:before{content:'"';position:absolute;top:60%;left:50%;transform:translate(-50%,-50%);font-size:24rem;color:var(--accent);opacity:.04;z-index:0;font-family:serif;line-height:1}.quote-section blockquote{font-size:clamp(1rem,1.8vw,1.25rem);font-style:italic;color:var(--text-primary);max-width:1200px;margin:0 auto;line-height:1.7;position:relative;z-index:1;text-shadow:0 0 20px rgba(93,203,131,.2)}.skill-card{background:var(--surface);border-radius:var(--radius-md);padding:28px;border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.skill-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.skill-card h3{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border);font-size:1.2rem}.skill-card h3 svg{color:var(--accent)}.skill-list{display:flex;flex-direction:column;gap:14px}.skill-item{color:var(--text-secondary);line-height:1.6;font-size:.95rem}.skill-item strong{color:var(--text-primary);font-weight:600}.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:48px}.contact-info h3,.contact-info-item{margin-bottom:24px}.contact-info-item h4{font-size:.85rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.contact-info-item a{font-size:1.1rem;color:var(--accent);transition:color var(--transition-fast)}.contact-info-item a:hover{color:var(--accent-hover)}.social-links{display:flex;gap:12px}.social-link{padding:8px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.95rem;transition:all var(--transition-base);display:flex;align-items:center;gap:8px}.social-link:hover{background:var(--surface-hover);border-color:var(--text-secondary);color:var(--text-primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.contact-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:.9rem;font-weight:500;color:var(--text-secondary);transition:color .2s ease}.form-group:focus-within label{color:var(--accent)}.form-control{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;color:var(--text-primary);font-family:inherit;font-size:.9375rem;transition:border-color var(--transition-fast)}.form-control:hover{border-color:var(--border-hover)}.form-control:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #5dcb8326}[data-theme=light] .form-control{background:var(--bg-secondary);border:1px solid var(--border)}[data-theme=light] .form-control:hover{border-color:var(--border-hover)}[data-theme=light] .form-control:focus{background:var(--surface)}.form-control::placeholder{color:var(--text-muted)}textarea.form-control{resize:vertical;min-height:140px}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.project-card{background:var(--surface);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border);transition:transform .3s cubic-bezier(.175,.885,.32,1.275),box-shadow .3s ease,border-color .3s ease;display:flex;flex-direction:column;cursor:pointer;position:relative}.project-card:hover{border-color:var(--accent);transform:translateY(-10px);box-shadow:var(--shadow-lg)}.project-card.expanded{position:fixed;top:0;right:0;bottom:0;left:0;margin:auto;width:90%;max-width:700px;height:fit-content;max-height:85vh;overflow-y:scroll;overflow-x:hidden;overscroll-behavior:none;-webkit-overflow-scrolling:touch;scroll-behavior:auto;z-index:1001;cursor:default;box-shadow:var(--shadow-lg);transform:none;contain:layout}.project-card.expanded:hover{transform:none}.project-header{height:100px;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border);flex-shrink:0}.project-card.expanded .project-header{height:120px}.project-header svg{color:var(--accent);opacity:.8}.project-content{padding:24px;flex:1;display:flex;flex-direction:column}.project-content h3{margin-bottom:12px;font-size:1.2rem}.project-summary{font-size:.9rem;line-height:1.6;color:var(--text-secondary);margin-bottom:0}.project-details{display:none;margin-top:24px;padding-top:24px;border-top:1px solid var(--border);animation:fadeIn .4s ease}.project-card.expanded .project-details{display:block}.project-details-grid{display:grid;grid-template-columns:1fr;gap:24px;margin-bottom:32px}@media(min-width:768px){.project-details-grid{grid-template-columns:1fr 1fr}.challenge-card,.approach-card{grid-column:1}.tech-card{grid-column:2;grid-row:1 / 3}.features-card{grid-column:1 / -1}}.detail-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:24px;transition:transform .3s cubic-bezier(.175,.885,.32,1.275),box-shadow .3s ease,border-color .3s ease}.detail-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:var(--shadow-md)}.detail-card h4{display:flex;align-items:center;gap:10px;font-size:1.1rem;color:var(--text-primary);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.detail-card h4 svg{color:var(--accent)}.detail-card p{font-size:.95rem;line-height:1.7;color:var(--text-secondary);margin-bottom:0}.tech-list{display:flex;flex-direction:column;gap:12px}.tech-list li{display:flex;flex-direction:column;padding:12px;background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border)}.tech-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:4px;font-weight:600}.tech-value{font-size:.9rem;color:var(--text-primary);font-weight:500}.feature-list{display:grid;grid-template-columns:1fr;gap:12px}@media(min-width:600px){.feature-list{grid-template-columns:1fr 1fr}}.feature-list li{display:flex;align-items:flex-start;gap:12px;padding:12px;background:var(--accent-subtle);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.95rem;line-height:1.5}.check-icon{color:var(--accent);flex-shrink:0;margin-top:3px}.project-footer{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.project-tags{display:flex;gap:6px;flex-wrap:wrap}.tag{font-size:.7rem;padding:4px 10px;background:var(--accent-subtle);color:var(--accent);border-radius:100px;font-weight:500}.project-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-secondary);font-size:1.25rem;font-weight:300;line-height:1;cursor:pointer;display:none;align-items:center;justify-content:center;transition:all var(--transition-fast);z-index:10}.project-close:hover{background:#ffffff26;color:var(--text-primary);border-color:#fff3}.project-card.expanded .project-close{display:flex}.project-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000a6;opacity:0;visibility:hidden;transition:all var(--transition-base);z-index:1000}.project-overlay.active{opacity:1;visibility:visible}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.skill-section{padding:40px 0}.skill-block{background:var(--surface);border-radius:var(--radius-lg);padding:36px;border:1px solid var(--border);transition:transform .3s cubic-bezier(.175,.885,.32,1.275),box-shadow .3s ease,border-color .3s ease;position:relative;overflow:hidden}.skill-block:hover{border-color:var(--accent);transform:translateY(-8px) scale(1.01);box-shadow:var(--shadow-lg)}[data-theme=light] .skill-block{background:var(--surface);border:1px solid var(--border)}.skill-block-header{display:flex;align-items:center;gap:16px;margin-bottom:16px}.skill-icon-large{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--accent-subtle);border-radius:var(--radius-md);color:var(--accent);flex-shrink:0}.skill-block-header h2{font-size:1.5rem;margin:0}.skill-intro{font-size:1.05rem;line-height:1.7;color:var(--text-secondary);margin-bottom:32px;max-width:800px}.skill-details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:28px}.skill-detail-item{padding:22px;background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border);transition:transform .3s cubic-bezier(.175,.885,.32,1.275),box-shadow .3s ease,border-color .3s ease;cursor:pointer}.skill-detail-item:hover{border-color:var(--accent);transform:translateY(-8px) scale(1.01);box-shadow:var(--shadow-md)}[data-theme=light] .skill-detail-item{background:var(--bg-secondary);border:1px solid var(--border)}.skill-detail-item h4{font-size:1rem;color:var(--text-primary);margin-bottom:12px}.skill-detail-item p{font-size:.9rem;line-height:1.7;color:var(--text-secondary);margin:0}.skill-detail-item a{color:var(--accent);text-decoration:none;border-bottom:1px solid transparent;transition:border-color var(--transition-fast)}.skill-detail-item a:hover{border-bottom-color:var(--accent)}.skill-detail-item code{background:var(--bg-tertiary);padding:2px 6px;border-radius:4px;font-size:.85em;color:var(--accent)}.skill-tech-stack{display:flex;flex-wrap:wrap;gap:10px}.tech-pill{padding:6px 12px;background:var(--bg-primary);color:var(--text-secondary);border-radius:var(--radius-sm);font-size:.8rem;font-weight:500;border:1px solid var(--border);transition:all var(--transition-fast)}.tech-pill:hover{color:var(--text-primary);border-color:var(--border-hover);background:var(--surface-hover)}@media(max-width:1024px){.skill-details-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.skill-block{padding:28px}.skill-details-grid{grid-template-columns:1fr}.skill-block-header{flex-direction:column;align-items:flex-start;gap:12px}}.footer{padding:48px 0;border-top:1px solid var(--border);margin-top:80px}.footer-content{display:flex;justify-content:space-between;align-items:center}.footer-text{color:var(--text-muted);font-size:.95rem}.footer-links{display:flex;gap:32px}.footer-links a{color:var(--text-secondary);font-size:.95rem;transition:all var(--transition-fast);position:relative}.footer-links a:hover{color:var(--accent);transform:translateY(-2px)}.back-to-top{position:fixed;bottom:32px;right:32px;width:48px;height:48px;background:var(--accent);color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);opacity:0;visibility:hidden;transform:translateY(20px);transition:all .3s ease;z-index:1000}.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}.back-to-top:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}@media(max-width:768px){.back-to-top{bottom:20px;right:20px;width:44px;height:44px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.animate-in{opacity:0;animation:fadeInUp .5s ease-out forwards}.delay-1{animation-delay:.05s}.delay-2{animation-delay:.1s}.delay-3{animation-delay:.15s}.delay-4{animation-delay:.2s}.delay-5{animation-delay:.25s}.delay-6{animation-delay:.3s}.delay-7{animation-delay:.35s}.delay-8{animation-delay:.4s}.delay-9{animation-delay:.45s}.delay-10{animation-delay:.5s}.delay-11{animation-delay:.55s}.delay-12{animation-delay:.6s}.page-transition{animation:pageEnter .4s ease-out;flex:1;display:flex;flex-direction:column}@keyframes pageEnter{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1024px){.grid-3{grid-template-columns:repeat(2,1fr)}.hero-grid{gap:48px}.skill-details-grid{grid-template-columns:repeat(2,1fr)}}.nav-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;z-index:999}.nav-overlay.active{opacity:1;visibility:visible}@media(max-width:768px){.section{padding:56px 0}.section-header{margin-bottom:32px}.section-header p{max-width:100%}.page-header-section{padding-top:100px!important;padding-bottom:32px!important}.hamburger{display:flex;width:44px;height:44px;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.hamburger:active{background:var(--accent-subtle)}.hamburger.active .bar:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger.active .bar:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger.active .bar:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.nav-links-desktop{display:none!important}.mobile-drawer{display:flex!important;flex-direction:column;position:fixed;top:0;right:0;width:320px;max-width:85vw;height:100vh;height:100dvh;background:var(--bg-primary);border-left:1px solid var(--border);box-shadow:-12px 0 40px #0006;z-index:1001;padding:0;transform:translate(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);overflow-y:auto;-webkit-overflow-scrolling:touch}.mobile-drawer.active{transform:translate(0)}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border);flex-shrink:0}.drawer-name{font-size:1.05rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.drawer-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.drawer-close:hover{background:var(--surface-hover);color:var(--text-primary)}.drawer-nav{padding:16px 16px 8px;display:flex;flex-direction:column;gap:2px}.drawer-link{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.9rem;font-weight:500;text-decoration:none;transition:all var(--transition-fast)}.drawer-link:hover{color:var(--text-primary);background:var(--surface-hover)}.drawer-link.active{color:#fff;background:var(--accent);font-weight:600}.drawer-link.active svg{color:#fff}.drawer-divider{height:1px;background:var(--border);margin:8px 24px}.drawer-section{padding:12px 24px}.drawer-section-title{font-size:.85rem;font-weight:700;color:var(--text-primary);margin-bottom:8px;letter-spacing:-.01em}.drawer-about-text{font-size:.85rem;line-height:1.6;color:var(--text-muted);margin:0}.drawer-social-links{display:flex;flex-wrap:wrap;gap:8px}.drawer-social-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:var(--surface-hover);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem;font-weight:500;text-decoration:none;transition:all var(--transition-fast)}.drawer-social-pill:hover{border-color:var(--accent);background:var(--accent-subtle);color:var(--accent)}.drawer-social-pill svg{color:var(--text-muted);flex-shrink:0}.drawer-social-pill:hover svg{color:var(--accent)}.drawer-footer{margin-top:auto;padding:16px 24px 24px;border-top:1px solid var(--border)}.drawer-theme-toggle{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;background:var(--surface-hover);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.85rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all var(--transition-fast)}.drawer-theme-toggle:hover{border-color:var(--accent);color:var(--accent)}.hero{min-height:65vh;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding-top:calc(var(--header-height) + 24px);padding-bottom:24px}.hero-grid{grid-template-columns:1fr;gap:40px;text-align:left}.hero-content{order:1;display:flex;flex-direction:column;align-items:flex-start;text-align:left}.hero-image{display:none!important}.hero h1{font-size:clamp(2.4rem,9.5vw,3.25rem);letter-spacing:-.035em;margin-bottom:16px;line-height:1.1;text-align:left}.hero-badge{margin-bottom:20px;font-size:.75rem;padding:4px 12px;align-self:flex-start}.hero-description{font-size:1rem;line-height:1.7;max-width:100%;margin-left:0;margin-right:0;margin-bottom:28px;text-align:left}.hero-cta{display:flex;flex-direction:row;justify-content:flex-start;align-items:center;gap:12px;width:100%}.hero-cta .btn{padding:12px 20px;font-size:.9rem;flex:1;width:auto;white-space:nowrap;justify-content:center}.hero-image-frame{width:260px;height:320px;margin:0 auto}.grid-2,.grid-3,.projects-grid{grid-template-columns:1fr;gap:16px}.card{padding:20px}.card:hover{transform:translateY(-4px) scale(1)}.card-icon{width:40px;height:40px}.experience-card{padding:20px;border-left-width:3px}.experience-header{flex-direction:column;gap:12px;align-items:flex-start}.experience-header h3{font-size:1.1rem}.experience-badge{font-size:.7rem;padding:4px 10px}.experience-card p{font-size:.9rem;line-height:1.65}.project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.project-header{height:80px}.project-header svg{width:28px;height:28px}.project-content h3{font-size:1.05rem}.project-summary{font-size:.85rem}.project-card.expanded{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;max-width:100%;height:100%;max-height:100%;margin:0;border-radius:0;z-index:1001;overflow-y:auto;-webkit-overflow-scrolling:touch;transform:none;animation:slideUpSheet .3s ease-out}@keyframes slideUpSheet{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.project-card.expanded .project-header{height:100px;position:sticky;top:0;z-index:5;background:var(--bg-tertiary)}.project-card.expanded .project-close{position:fixed;top:16px;right:16px;width:40px;height:40px;font-size:1.5rem;z-index:1002;background:var(--bg-secondary);border:1px solid var(--border);border-radius:50%}.project-card.expanded .project-content{padding:20px}.project-card.expanded .project-content h3{font-size:1.2rem;padding-right:48px}.project-details{margin-top:16px;padding-top:16px}.project-details-grid{grid-template-columns:1fr!important;gap:16px;margin-bottom:24px}.project-details-grid .challenge-card,.project-details-grid .approach-card,.project-details-grid .tech-card,.project-details-grid .features-card{grid-column:1!important;grid-row:auto!important}.detail-card{padding:16px}.detail-card:hover{transform:none}.detail-card h4{font-size:1rem;margin-bottom:12px;padding-bottom:10px}.detail-card p{font-size:.9rem}.feature-list{grid-template-columns:1fr!important;gap:8px}.feature-list li{padding:10px;font-size:.875rem}.tech-list li{padding:10px}.project-footer{flex-direction:column;gap:12px;align-items:flex-start}.project-tags{gap:4px}.tag{font-size:.65rem;padding:3px 8px}.skill-block{padding:24px}.skill-block:hover{transform:translateY(-4px) scale(1)}.skill-block-header{flex-direction:column;align-items:flex-start;gap:12px}.skill-block-header h2{font-size:1.3rem}.skill-icon-large{width:48px;height:48px}.skill-icon-large svg{width:24px;height:24px}.skill-intro{font-size:.95rem;margin-bottom:24px}.skill-details-grid{grid-template-columns:1fr;gap:12px}.skill-detail-item{padding:16px}.skill-detail-item:hover{transform:translateY(-2px) scale(1)}.skill-detail-item h4{font-size:.95rem;margin-bottom:8px}.skill-detail-item p{font-size:.85rem;line-height:1.6}.skill-tech-stack{gap:8px}.tech-pill{padding:6px 12px;font-size:.8rem}.contact-grid{grid-template-columns:1fr;gap:32px}.contact-info h3{margin-bottom:20px;font-size:1.2rem}.contact-info-item{margin-bottom:20px}.contact-info-item a{font-size:1rem}.social-links{flex-wrap:wrap;gap:8px}.social-link{padding:10px 16px;font-size:.9rem}.form-control{padding:14px;font-size:1rem}textarea.form-control{min-height:120px}.contact-form .btn{width:100%;padding:14px;font-size:1rem}.quote-section{padding:56px 0}.quote-section blockquote{font-size:clamp(.95rem,3.5vw,1.15rem);line-height:1.8;padding:0 8px}.quote-section:before{display:none!important}.footer{padding:32px 0;margin-top:48px}.footer-content{flex-direction:column;gap:16px;text-align:center}.footer-text{font-size:.85rem}.footer-links{gap:20px;justify-content:center}.footer-links a{font-size:.85rem}.back-to-top{bottom:20px;right:20px;width:44px;height:44px}}@media(max-width:480px){.container{padding:0 16px}.section{padding:44px 0}.page-header-section{padding-top:80px!important;padding-bottom:24px!important}.hero{min-height:65vh;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding-top:calc(var(--header-height) + 24px);padding-bottom:24px}.hero-content{align-items:flex-start;text-align:left}.hero h1{font-size:clamp(2.25rem,11vw,2.75rem);line-height:1.1;text-align:left}.hero-badge{font-size:.7rem;padding:4px 10px;margin-bottom:16px;align-self:flex-start}.hero-description{font-size:.9rem;line-height:1.65;margin-bottom:24px;text-align:left}.hero-cta{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;gap:10px;width:100%}.hero-cta .btn{flex:1;width:auto;padding:12px 14px;font-size:.825rem;font-weight:600;justify-content:center;letter-spacing:-.01em;white-space:nowrap}.hero-cta .btn:active{transform:scale(.97)}.hero-cta .btn-secondary{background:transparent;border:1px solid var(--border);color:var(--text-primary)}.hero-image-frame{width:220px;height:270px}.card,.project-content{padding:16px}.card h3{font-size:1.05rem}.card p{font-size:.85rem}.experience-card{padding:16px}.experience-header h3{font-size:1rem}.experience-header>div:last-child{flex-wrap:wrap}.skill-block{padding:16px}.skill-block-header h2{font-size:1.15rem}.skill-intro{font-size:.88rem;margin-bottom:20px}.skill-detail-item{padding:14px}.tech-pill{padding:5px 10px;font-size:.75rem}.contact-info h3{font-size:1.1rem}.section-header h2{font-size:clamp(1.25rem,5vw,1.5rem)}.nav-logo{font-size:1.4rem}}@media(max-width:360px){.container{padding:0 12px}.hero h1{font-size:2rem}.hero-description{font-size:.85rem}.hero-image-frame{width:200px;height:240px}.hero-cta .btn{padding:10px 12px;font-size:.775rem}.nav-links{width:240px}}.global-bg{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:-1;overflow:hidden;background:var(--bg-primary)}.global-bg:before{content:"";position:absolute;width:100%;height:100%;background-image:radial-gradient(var(--border) 1px,transparent 1px);background-size:32px 32px;opacity:.15;mask-image:linear-gradient(to bottom,transparent,10% black,90% black,transparent);-webkit-mask-image:linear-gradient(to bottom,transparent,10% black,90% black,transparent)}.loading-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;z-index:99999;transition:opacity .5s ease,visibility .5s ease}.loading-screen.fade-out{opacity:0;visibility:hidden}.loading-content{display:flex;flex-direction:column;align-items:center;gap:24px}.loading-logo{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center}.loading-initial{font-size:2.5rem;font-weight:700;color:var(--accent);z-index:2}.loading-ring{position:absolute;width:80px;height:80px;border:3px solid transparent;border-top-color:var(--accent);border-right-color:#60a5fa;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{display:flex;gap:8px;font-size:1.25rem;font-weight:600}.lazy-image-wrapper{position:relative;overflow:hidden;background:var(--bg-tertiary)}.lazy-image{width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .5s ease}.lazy-image.loaded{opacity:1}.lazy-image-blur{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;filter:blur(20px);transform:scale(1.1);opacity:1;transition:opacity .5s ease}.lazy-image.loaded+.lazy-image-blur,.lazy-image-blur.hidden{opacity:0}.skill-block{transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease,background-color .3s ease}.highlight-active{border-color:var(--accent)!important;box-shadow:0 0 15px var(--accent-glow)!important;transform:translateY(-2px)}.research-layout{display:grid;grid-template-columns:260px 1fr;gap:64px;align-items:start;margin-top:40px}.research-sidebar{position:sticky;top:100px;max-height:calc(100vh - 140px);overflow-y:auto;padding-right:12px}.research-sidebar::-webkit-scrollbar{width:4px}.research-sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.sidebar-category{margin-bottom:24px}.sidebar-category-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:10px;padding-left:12px}.sidebar-link{display:block;padding:6px 12px;color:var(--text-secondary);border-left:2px solid var(--border);font-size:.85rem;line-height:1.4;transition:all var(--transition-fast);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-link:hover{color:var(--text-primary);border-left-color:var(--border-hover);padding-left:14px}.sidebar-link.active{color:var(--accent);border-left-color:var(--accent);font-weight:500;padding-left:14px}@media(max-width:1024px){.research-layout{grid-template-columns:1fr;gap:32px}.research-sidebar{display:none}}.research-sub-box{padding:16px;border-radius:var(--radius-sm);background:var(--bg-primary);border:1px solid var(--border);transition:transform var(--transition-fast),border-color var(--transition-fast),background-color var(--transition-fast),box-shadow var(--transition-fast)}.research-sub-box:hover{transform:translateY(-2px);border-color:var(--accent);background:var(--bg-secondary);box-shadow:0 4px 12px #0003}
