h1,h2,h3,h4,h5,h6{font-family:Playfair Display,Georgia,serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#080808;--bg-1:#0f0f0f;--bg-2:#161616;--bg-3:#1e1e1e;--border:#ffffff0f;--border-h:#ffffff21;--border-a:#ffffff38;--text:#efefef;--text-2:#9a9a9a;--text-3:#5e5e5e;--white:#fff;--black:#080808;--accent:#fff;--accent-2:#ffffff0f;--green:#22c55e;--grid-c:#ffffff06;--nav-h:64px;--max-w:1100px;--r:12px;--r-sm:8px;--r-xs:5px;--t:.18s ease;--t-med:.32s ease;--vt-x:50%;--vt-y:50%}[data-theme=light]{--bg:#f6f4ef;--bg-1:#eeebe3;--bg-2:#e4e0d6;--bg-3:#d8d3c8;--border:#00000012;--border-h:#00000021;--border-a:#00000038;--text:#111;--text-2:#4a4a4a;--text-3:gray;--white:#111;--black:#f6f4ef;--accent:#111;--accent-2:#0000000d;--green:#16a34a;--grid-c:#00000005}@keyframes vt-reveal{0%{clip-path:circle(0% at var(--vt-x)var(--vt-y))}to{clip-path:circle(150% at var(--vt-x)var(--vt-y))}}::view-transition-new(root){animation:.6s cubic-bezier(.4,0,.2,1) vt-reveal}::view-transition-old(root){z-index:-1;animation:none}html{scroll-behavior:smooth;scroll-padding-top:calc(var(--nav-h) + 16px);overflow-x:hidden}body{font-family:"Inter",var(--font-inter,-apple-system),sans-serif;background-color:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;text-rendering:optimizeLegibility;font-feature-settings:"kern" 1,"liga" 1;line-height:1.6;transition:background-color .3s,color .3s;position:relative;overflow-x:hidden}body:before{content:"";background-image:linear-gradient(var(--grid-c)1px,transparent 1px),linear-gradient(90deg,var(--grid-c)1px,transparent 1px);pointer-events:none;z-index:0;background-size:52px 52px;position:fixed;inset:0}body:after{content:"";background:radial-gradient(ellipse 80% 60% at 50% 0%,transparent 0%,var(--bg)100%);opacity:.55;pointer-events:none;z-index:0;position:fixed;inset:0}[data-theme=light] body:before{opacity:.6}section,nav,footer,main{z-index:2;position:relative}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}img{max-width:100%;display:block}.container{max-width:var(--max-w);margin:0 auto;padding:0 24px}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-h);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-3)}::selection{color:var(--text);background:#ffffff1f}[data-theme=light] ::selection{background:#0000001a}a:focus-visible,button:focus-visible{outline:2px solid var(--border-h);outline-offset:3px;border-radius:4px}
.nav{height:var(--nav-h);z-index:100;transition:background var(--t-med),border-color var(--t-med);position:fixed;top:0;left:0;right:0}.nav.scrolled{background:color-mix(in srgb,var(--bg)88%,transparent);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid var(--border);box-shadow:0 1px 0 var(--border)}.nav-inner{max-width:var(--max-w);justify-content:space-between;align-items:center;gap:12px;height:100%;margin:0 auto;padding:0 24px;display:flex}.nav-logo{color:var(--white);letter-spacing:0;transition:opacity var(--t);-webkit-user-select:none;user-select:none;flex-shrink:0;align-items:center;font-family:JetBrains Mono,monospace;font-size:.9rem;font-weight:700;display:flex}.nav-logo:hover{opacity:.6}.nav-logo-bracket{color:var(--text-3);font-size:.82rem;font-weight:400}.nav-logo-text{color:var(--white);font-weight:700}.nav-links{align-items:center;gap:2px;list-style:none;display:flex}.nav-links a{color:var(--text-2);transition:color var(--t),background var(--t);letter-spacing:.02em;border-radius:6px;padding:6px 10px;font-size:.82rem;font-weight:500;position:relative}.nav-links a:hover{color:var(--text);background:var(--accent-2)}.nav-links a:after{content:"";background:var(--white);height:1px;transition:left .2s,right .2s;position:absolute;bottom:2px;left:50%;right:50%}.nav-links a:hover:after{left:10px;right:10px}.nav-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.nav-greeting{color:var(--text-3);letter-spacing:.03em;white-space:nowrap;border:1px solid var(--border);transition:all var(--t);background:0 0;border-radius:999px;flex-shrink:0;align-items:center;gap:5px;padding:4px 10px;font-family:JetBrains Mono,monospace;font-size:.72rem;font-weight:500;display:flex}.nav-greeting:hover{color:var(--text-2);border-color:var(--border-h)}.mobile-menu-greeting{color:var(--text-3);border-bottom:1px solid var(--border);letter-spacing:.04em;margin-bottom:2px;padding:10px 0 12px;font-family:JetBrains Mono,monospace;font-size:.7rem;display:block}.mobile-menu-arrow{color:var(--text-3);font-size:.72rem}.theme-toggle{background:linear-gradient(155deg,color-mix(in srgb,var(--bg-2)72%,var(--accent-2)),color-mix(in srgb,var(--bg-1)88%,transparent));border:1px solid color-mix(in srgb,var(--border-h)70%,var(--border));width:40px;height:40px;color:var(--text-2);box-shadow:0 8px 24px #00000038,inset 0 1px 0 color-mix(in srgb,var(--white)20%,transparent);transition:background var(--t),border-color var(--t),color var(--t),transform .2s ease,box-shadow var(--t);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.theme-toggle:hover{background:linear-gradient(155deg,color-mix(in srgb,var(--bg-3)70%,var(--accent-2)),color-mix(in srgb,var(--bg-2)90%,transparent));border-color:var(--border-h);color:var(--text);box-shadow:0 12px 28px #00000047,0 0 0 1px color-mix(in srgb,var(--border-h)45%,transparent);transform:translateY(-1px)}.theme-toggle:active{transform:translateY(0);box-shadow:0 8px 18px #0000003d}.theme-toggle-glow{background:radial-gradient(circle at 30% 30%,color-mix(in srgb,var(--border-h)35%,transparent),transparent 58%);opacity:.75;pointer-events:none;position:absolute;inset:-16px}.theme-toggle-icon-wrap{z-index:1;color:color-mix(in srgb,var(--text)92%,var(--text-2));background:color-mix(in srgb,var(--bg)45%,transparent);border:1px solid color-mix(in srgb,var(--border)80%,transparent);border-radius:8px;justify-content:center;align-items:center;width:24px;height:24px;display:flex;position:relative}.btn-resume-nav{color:var(--bg);background:var(--white);border-radius:var(--r-sm);transition:all var(--t);letter-spacing:.03em;white-space:nowrap;padding:7px 16px;font-size:.8rem;font-weight:600}.btn-resume-nav:hover{opacity:.85;transform:translateY(-1px)}.hamburger{border-radius:var(--r-xs);border:1px solid var(--border);width:34px;height:34px;transition:border-color var(--t);flex-direction:column;justify-content:center;align-items:center;gap:5px;display:none}.hamburger:hover{border-color:var(--border-h)}.hamburger span{background:var(--text);border-radius:1px;width:18px;height:1.5px;transition:all .28s;display:block}.hamburger span:nth-child(2){width:12px}.hamburger.open span:first-child{width:18px;transform:rotate(45deg)translate(4.7px,4.7px)}.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger.open span:nth-child(3){transform:rotate(-45deg)translate(4.7px,-4.7px)}.mobile-menu{top:var(--nav-h);background:color-mix(in srgb,var(--bg)96%,transparent);border-bottom:1px solid var(--border);z-index:199;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);flex-direction:column;padding:8px 24px 22px;animation:.22s slideDown;display:flex;position:fixed;left:0;right:0}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.mobile-menu a{color:var(--text-2);border-bottom:1px solid var(--border);transition:color var(--t),padding-left var(--t);justify-content:space-between;align-items:center;padding:13px 0;font-size:.94rem;font-weight:500;display:flex}.mobile-menu a:last-child{border-bottom:none}.mobile-menu a:hover{color:var(--text);padding-left:4px}
.hero{min-height:100vh;padding-top:var(--nav-h);align-items:center;display:flex;position:relative;overflow-x:hidden}.hero:before{content:"";pointer-events:none;z-index:1;background:radial-gradient(circle,#ffffff06 0%,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:-120px;right:-100px}[data-theme=light] .hero:before{background:radial-gradient(circle,#00000005 0%,#0000 70%)}.hero-inner{max-width:var(--max-w);z-index:2;grid-template-columns:1fr 300px;align-items:center;gap:72px;width:100%;margin:0 auto;padding:48px 24px 60px;display:grid;position:relative}.hero-body{max-width:640px}.hero-meta{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:26px;display:flex}.hero-badge{color:var(--text-2);background:var(--bg-1);border:1px solid var(--border);letter-spacing:.04em;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:999px;align-items:center;gap:8px;padding:5px 12px 5px 10px;font-family:JetBrains Mono,monospace;font-size:.73rem;font-weight:500;display:inline-flex}.hero-badge-dot{background:var(--green);border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:2.4s ease-in-out infinite pulse-status;box-shadow:0 0 #22c55e66}@keyframes pulse-status{0%,to{box-shadow:0 0 #22c55e66}50%{box-shadow:0 0 0 5px #22c55e00}}.hero-location{color:var(--text-3);align-items:center;gap:5px;font-family:JetBrains Mono,monospace;font-size:.73rem;display:flex}.hero-name-wrap{margin-bottom:0}.hero-name{letter-spacing:-.04em;margin-bottom:22px;font-family:JetBrains Mono,monospace;font-size:clamp(3rem,7.5vw,5.6rem);font-weight:700;line-height:.93}.hero-name-line1{color:var(--text-2);display:block}.hero-name-line2{color:var(--white);display:block}.hero-name-period{color:var(--text-3)}.hero-role-row{flex-wrap:nowrap;justify-content:flex-start;align-items:center;gap:14px;margin-bottom:22px;display:flex}.hero-role-line{background:var(--border);flex:44px;min-width:24px;max-width:72px;height:1px}.hero-role{color:var(--text-2);white-space:nowrap;text-align:left;letter-spacing:.02em;flex-wrap:nowrap;flex-shrink:1;justify-content:flex-start;align-items:center;min-width:max-content;max-width:100%;font-family:JetBrains Mono,monospace;font-size:.84rem;font-weight:500;display:flex;overflow:visible}.hero-role-words{white-space:nowrap;flex-wrap:nowrap;justify-content:flex-start;align-items:center;gap:4px 6px;display:inline-block}.hero-role-word{cursor:default;will-change:transform,opacity,filter;font-weight:600;transition:color .22s,transform .32s cubic-bezier(.22,1,.36,1);display:inline-block}.hero-role-word:hover{color:var(--accent);text-shadow:0 4px 18px #ffffff2e;transform:scale(1.08)translateY(-2px)}.hero-role-cursor{background:var(--text);vertical-align:middle;width:2px;height:.9em;margin-left:2px;animation:1.1s step-end infinite blink-cursor;display:inline-block}@keyframes blink-cursor{0%,to{opacity:1}50%{opacity:0}}.hero-quote{color:var(--text-3);letter-spacing:.04em;align-items:center;gap:4px;margin-bottom:14px;font-size:.78rem;font-style:italic;display:flex}.hero-quote-mark{color:var(--text-2);font-size:1.1rem;font-style:normal;line-height:1}.hero-desc{color:var(--text-2);letter-spacing:.01em;max-width:490px;margin-bottom:26px;font-size:.91rem;line-height:1.85}.hero-actions{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:28px;display:flex}.btn-arrow{transition:transform var(--t);font-size:.82em}.btn-primary:hover .btn-arrow{transform:translate(2px,-2px)}.btn-primary{color:var(--black);background:var(--white);border-radius:var(--r-sm);transition:all var(--t);letter-spacing:.03em;border:1px solid var(--white);align-items:center;gap:6px;padding:11px 24px;font-size:.86rem;font-weight:600;display:inline-flex}.btn-primary:hover{color:var(--white);background:0 0;transform:translateY(-2px);box-shadow:0 8px 24px #ffffff12}[data-theme=light] .btn-primary:hover{color:var(--black);box-shadow:0 8px 24px #0000001a}.btn-secondary{color:var(--text);border:1px solid var(--border);border-radius:var(--r-sm);transition:all var(--t);letter-spacing:.02em;background:0 0;align-items:center;gap:6px;padding:11px 22px;font-size:.86rem;font-weight:500;display:inline-flex}.btn-secondary:hover{border-color:var(--border-h);background:var(--bg-1);transform:translateY(-2px)}.btn-icon-only{border:1px solid var(--border);border-radius:var(--r-sm);width:42px;height:42px;color:var(--text-2);transition:all var(--t);background:0 0;justify-content:center;align-items:center;display:inline-flex}.btn-icon-only:hover{border-color:var(--border-h);color:var(--text);background:var(--bg-1);transform:translateY(-2px)}.hero-visual{justify-content:center;align-items:center;display:flex}.profile-wrap{width:290px;height:360px;position:relative}.profile-wrap:before{content:"";border-top:1px solid var(--border-h);border-right:1px solid var(--border-h);border-radius:0 var(--r)0 0;pointer-events:none;z-index:3;width:64px;height:64px;animation:3s ease-in-out infinite alternate corner-fade;position:absolute;top:-14px;right:-14px}.profile-wrap:after{content:"";border-bottom:1px solid var(--border-h);border-left:1px solid var(--border-h);border-radius:0 0 0 var(--r);pointer-events:none;z-index:3;width:64px;height:64px;animation:3s ease-in-out 1.5s infinite alternate corner-fade;position:absolute;bottom:-14px;left:-14px}@keyframes corner-fade{0%{opacity:.25}to{opacity:.8}}.profile-frame{background:var(--bg-1);border:1px solid var(--border-h);border-radius:16px;width:100%;height:100%;position:relative;overflow:hidden;box-shadow:0 28px 60px #00000080,0 8px 20px #00000040}[data-theme=light] .profile-frame{border-color:var(--border-h);box-shadow:0 20px 40px #00000026,0 4px 12px #00000014}.hero-code-badge{background:color-mix(in srgb,var(--bg)92%,transparent);border:1px solid var(--border-h);border-radius:var(--r-sm);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);z-index:4;white-space:nowrap;flex-direction:column;gap:3px;padding:10px 14px;font-family:JetBrains Mono,monospace;font-size:.67rem;line-height:1.6;display:flex;position:absolute;bottom:20px;right:-20px;box-shadow:0 10px 32px #00000059}[data-theme=light] .hero-code-badge{background:color-mix(in srgb,var(--bg)94%,transparent);box-shadow:0 8px 24px #0000001f}.hcb-line{display:block}.hcb-k{color:#93c5fd}.hcb-v{color:var(--text)}.hcb-s{color:#86efac}.hcb-n{color:#fde68a}[data-theme=light] .hcb-k{color:#2563eb}[data-theme=light] .hcb-s{color:#16a34a}[data-theme=light] .hcb-n{color:#b45309}.hero-scroll-hint{align-items:center;gap:10px;display:flex;position:absolute;bottom:28px;left:50%;transform:translate(-50%)}.hero-scroll-line{background:linear-gradient(90deg,var(--text-3),transparent);width:40px;height:1px;display:block}.hero-scroll-text{color:var(--text-3);letter-spacing:.2em;text-transform:uppercase;font-family:JetBrains Mono,monospace;font-size:.6rem;font-weight:600;animation:2s ease-in-out infinite alternate fadeUpIn}@keyframes fadeUpIn{0%{opacity:.35;transform:translateY(2px)}to{opacity:.9;transform:translateY(-1px)}}
.section{padding:80px 0}.section-header{align-items:center;gap:18px;margin-bottom:48px;display:flex}.section-num{color:var(--text-3);letter-spacing:.12em;text-transform:uppercase;flex-shrink:0;font-family:JetBrains Mono,monospace;font-size:.68rem;font-weight:700}.section-title{letter-spacing:-.02em;color:var(--white);white-space:nowrap;font-family:Playfair Display,Georgia,serif;font-size:clamp(1.6rem,3vw,2.1rem);font-weight:600;line-height:1.1}.section-line{background:var(--border);flex:1;height:1px}
.edu-card-v2{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r);transition:border-color var(--t),box-shadow var(--t);overflow:hidden}.edu-card-v2:hover{border-color:var(--border-h);box-shadow:0 8px 40px #0000002e}.edu-accent-bar{background:linear-gradient(90deg,var(--white)0%,#ffffff26 50%,transparent 100%);opacity:.35;height:2px}[data-theme=light] .edu-accent-bar{background:linear-gradient(90deg,var(--black)0%,#00000026 50%,transparent 100%)}.edu-content{grid-template-columns:1fr 1.2fr;display:grid}.edu-left{border-right:1px solid var(--border);flex-direction:column;gap:24px;padding:32px;display:flex}.edu-right{flex-direction:column;gap:24px;padding:32px;display:flex}.edu-uni-logo{border-radius:var(--r-sm);background:var(--bg-2);border:1px solid var(--border-h);width:52px;height:52px;color:var(--text);letter-spacing:.04em;flex-shrink:0;justify-content:center;align-items:center;font-family:JetBrains Mono,monospace;font-size:.88rem;font-weight:700;display:flex}.edu-uni-info{flex-direction:column;gap:6px;display:flex}.edu-badge-pill{text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);background:var(--bg-2);border:1px solid var(--border);border-radius:999px;width:fit-content;padding:3px 10px;font-family:JetBrains Mono,monospace;font-size:.62rem;font-weight:600;display:inline-block}.edu-degree-title{color:var(--white);letter-spacing:-.03em;font-size:1.4rem;font-weight:700;line-height:1.2}.edu-uni-location{color:var(--text-2);font-family:JetBrains Mono,monospace;font-size:.8rem}.edu-timeline{flex-direction:column;gap:8px;margin-top:auto;display:flex}.edu-timeline-header{justify-content:space-between;align-items:center;display:flex}.edu-timeline-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);font-family:JetBrains Mono,monospace;font-size:.61rem;font-weight:700}.edu-timeline-value{color:var(--text-2);font-family:JetBrains Mono,monospace;font-size:.68rem}.edu-progress-bar{background:var(--bg-2);border-radius:999px;height:5px;overflow:hidden}.edu-progress-fill{background:linear-gradient(90deg,var(--white),#ffffff4d);border-radius:999px;height:100%}[data-theme=light] .edu-progress-fill{background:linear-gradient(90deg,var(--black),#00000040)}.edu-timeline-years{color:var(--text-3);justify-content:space-between;font-family:JetBrains Mono,monospace;font-size:.6rem;display:flex}.edu-stats-grid{flex-wrap:wrap;gap:12px;display:flex}.edu-stat-box{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-sm);text-align:center;min-width:80px;transition:border-color var(--t);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:6px;padding:16px 18px;display:flex}.edu-stat-box:hover{border-color:var(--border-h)}.edu-stat-main{position:relative}.edu-stat-ring{width:64px;height:64px;position:relative}.edu-ring-svg{width:100%;height:100%;transform:rotate(-90deg)}.edu-ring-bg{fill:none;stroke:var(--bg-1);stroke-width:5px}.edu-ring-fill{fill:none;stroke:var(--white);stroke-width:5px;stroke-linecap:round;stroke-dashoffset:0}[data-theme=light] .edu-ring-fill{stroke:var(--black)}.edu-ring-label{color:var(--white);justify-content:center;align-items:center;font-family:JetBrains Mono,monospace;font-size:.95rem;font-weight:700;display:flex;position:absolute;inset:0}.edu-stat-num{color:var(--white);font-family:JetBrains Mono,monospace;font-size:2rem;font-weight:700;line-height:1}.edu-stat-small{font-size:1rem}.edu-stat-name{color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;font-family:JetBrains Mono,monospace;font-size:.62rem}.edu-active-dot{align-items:center;gap:5px;font-family:inherit;display:flex;color:#22c55e!important;font-size:.8rem!important}.edu-active-dot:before{content:"";background:#22c55e;border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:2.4s ease-in-out infinite pulse-status}.edu-courses-section{flex-direction:column;gap:10px;display:flex}.edu-courses-title{text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);font-family:JetBrains Mono,monospace;font-size:.62rem;font-weight:700}.edu-courses-grid{flex-wrap:wrap;gap:6px;display:flex}.edu-course-chip{color:var(--text-2);background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-sm);transition:all var(--t);cursor:default;padding:4px 10px;font-size:.74rem}.edu-course-chip:hover{color:var(--text);border-color:var(--border-h)}
.about-grid{grid-template-columns:1.1fr .9fr;align-items:start;gap:48px;display:grid}.about-bio p{color:var(--text-2);letter-spacing:.01em;margin-bottom:16px;font-size:.95rem;line-height:1.9}.about-bio p:last-child{margin-bottom:0}.about-bio strong{color:var(--text);font-weight:600}.connect-label{color:var(--text-3);letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px;font-family:JetBrains Mono,monospace;font-size:.68rem;font-weight:700}.connect-grid{flex-direction:column;gap:10px;display:flex}.connect-card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r);transition:border-color var(--t),background var(--t),transform var(--t),box-shadow var(--t);color:inherit;align-items:center;gap:14px;padding:14px 16px;display:flex}.connect-card:hover{border-color:var(--border-a);background:var(--bg-2);transform:translate(3px);box-shadow:0 4px 16px #0000001a}.connect-icon-box{border-radius:var(--r-sm);background:var(--bg-2);border:1px solid var(--border);width:40px;height:40px;color:var(--text-2);transition:color var(--t),background var(--t),border-color var(--t);flex-shrink:0;justify-content:center;align-items:center;display:flex}.connect-card:hover .connect-icon-box{color:var(--white);background:var(--bg-3);border-color:var(--border-h)}[data-theme=light] .connect-card:hover .connect-icon-box{color:var(--black)}.connect-info{flex:1;min-width:0}.connect-name{color:var(--text);font-size:.88rem;font-weight:600;line-height:1.3}.connect-handle{color:var(--text-2);white-space:nowrap;text-overflow:ellipsis;font-family:JetBrains Mono,monospace;font-size:.75rem;overflow:hidden}.connect-arrow{color:var(--text-3);transition:color var(--t),transform var(--t);flex-shrink:0;font-size:.95rem}.connect-card:hover .connect-arrow{color:var(--text);transform:translate(2px,-2px)}
.exp-list{border-left:1px solid var(--border);flex-direction:column;margin-left:8px;padding-left:36px;display:flex}.exp-item{padding-bottom:44px;position:relative}.exp-item:last-child{padding-bottom:0}.exp-dot{background:var(--bg);border:1.5px solid var(--border-h);border-radius:50%;width:11px;height:11px;position:absolute;top:6px;left:-42px}.exp-item:first-child .exp-dot,.exp-item-open-source .exp-dot{background:var(--white);border-color:var(--white);box-shadow:0 0 0 3px #ffffff14}[data-theme=light] .exp-item:first-child .exp-dot,[data-theme=light] .exp-item-open-source .exp-dot{background:var(--black);border-color:var(--black);box-shadow:0 0 0 3px #00000014}.exp-top{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:4px;display:flex}.exp-role{color:var(--white);letter-spacing:-.02em;font-size:1.02rem;font-weight:700}.exp-period{color:var(--text-3);background:var(--bg-1);border:1px solid var(--border);white-space:nowrap;border-radius:4px;flex-shrink:0;padding:3px 8px;font-family:JetBrains Mono,monospace;font-size:.73rem}.exp-company{color:var(--text-2);align-items:center;gap:8px;margin-bottom:14px;font-size:.86rem;display:flex}.exp-badge{color:var(--text-3);border:1px solid var(--border);border-radius:999px;padding:1px 7px;font-family:JetBrains Mono,monospace;font-size:.68rem}.exp-bullets{flex-direction:column;gap:7px;list-style:none;display:flex}.exp-bullets li{color:var(--text-2);padding-left:18px;font-size:.87rem;line-height:1.75;position:relative}.exp-bullets li:before{content:"→";color:var(--text-3);font-size:.72rem;position:absolute;top:1px;left:0}
.projects-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;display:grid}.project-card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r);transition:border-color var(--t),transform var(--t-med),box-shadow var(--t-med);will-change:transform;flex-direction:column;display:flex;position:relative;overflow:hidden;transform:translateZ(0)}.project-card:before{content:"";pointer-events:none;z-index:0;opacity:0;transition:opacity var(--t-med);background:linear-gradient(135deg,#ffffff05 0%,#0000 60%);position:absolute;inset:0}.project-card:hover:before{opacity:1}.project-card:hover{border-color:var(--border-a);box-shadow:0 24px 48px #0000004d,0 0 0 1px var(--border-h);transform:translateY(-5px)translateZ(0)}.project-image{aspect-ratio:16/8.5;background:var(--bg-2);width:100%;position:relative;overflow:hidden}.project-image:after{content:"";pointer-events:none;background:linear-gradient(#0000 50%,#00000059 100%);position:absolute;inset:0}.project-image img,.project-image>*{object-fit:cover;width:100%;height:100%;transition:transform .5s}.project-card:hover .project-image img{transform:scale(1.05)}.project-image-placeholder{background:linear-gradient(135deg,var(--bg-3)0%,var(--bg-2)40%,var(--bg-1)100%);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.project-image-placeholder span{color:var(--border-a);font-family:Playfair Display,serif;font-size:3.5rem;font-weight:700}.project-body{z-index:1;flex-direction:column;flex:1;gap:9px;padding:16px 18px 18px;display:flex;position:relative}.project-top-row{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.project-name{color:var(--white);letter-spacing:-.02em;font-family:Playfair Display,serif;font-size:1rem;font-weight:700}.project-subtitle{color:var(--text-2);margin-top:2px;font-size:.8rem;font-weight:400}.project-year{color:var(--text-3);background:var(--bg-2);border:1px solid var(--border);white-space:nowrap;border-radius:4px;flex-shrink:0;padding:2px 8px;font-family:JetBrains Mono,monospace;font-size:.7rem}.project-desc{color:var(--text-2);-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;font-size:.82rem;line-height:1.7;display:-webkit-box;overflow:hidden}.project-tags{flex-wrap:wrap;gap:5px;display:flex}.project-tag{color:var(--text-2);background:var(--bg-2);border:1px solid var(--border);transition:all var(--t);border-radius:999px;padding:3px 9px;font-size:.68rem}.project-tag:hover{color:var(--text);border-color:var(--border-h);background:var(--bg-3)}.project-actions{gap:7px;margin-top:auto;padding-top:4px;display:flex}.pbtn{border-radius:var(--r-sm);border:1px solid var(--border);color:var(--text-2);transition:all var(--t);background:0 0;align-items:center;gap:5px;padding:7px 13px;font-size:.77rem;font-weight:500;display:inline-flex}.pbtn:hover{border-color:var(--border-h);color:var(--text);background:var(--bg-2)}.pbtn.prim{background:var(--bg-2);border-color:var(--border-h);color:var(--text)}.view-more-wrap{text-align:center;margin-top:32px}.btn-gh-more{color:var(--text-2);border:1px solid var(--border);border-radius:var(--r-sm);transition:all var(--t);background:0 0;align-items:center;gap:10px;padding:12px 28px;font-size:.86rem;font-weight:600;display:inline-flex}.btn-gh-more:hover{border-color:var(--border-a);color:var(--text);background:var(--bg-1);transform:translateY(-2px);box-shadow:0 6px 20px #0000001a}.projects-section{overflow:visible}.projects-carousel-header{flex-wrap:wrap;align-items:center;gap:24px;margin-bottom:36px;display:flex}.projects-nav-controls{flex-shrink:0;align-items:center;gap:10px;display:flex}.proj-nav-btn{color:var(--text-2);border:1px solid var(--border);background:var(--bg-1);transition:all var(--t);letter-spacing:.06em;cursor:pointer;border-radius:8px;padding:8px 20px;font-family:JetBrains Mono,monospace;font-size:.72rem;font-weight:600}.proj-nav-btn:hover{border-color:var(--border-h);color:var(--text);background:var(--bg-2);transform:translateY(-1px);box-shadow:0 4px 16px #00000038}.proj-nav-btn:active{box-shadow:none;transform:translateY(0)}.proj-counter{color:var(--text-3);letter-spacing:.1em;text-align:center;background:var(--bg-1);border:1px solid var(--border);border-radius:8px;min-width:60px;padding:6px 12px;font-family:JetBrains Mono,monospace;font-size:.72rem}.projects-carousel-body{grid-template-columns:1fr 1fr;align-items:start;gap:36px;display:grid}.projects-lanyard-col,.projects-info-col{position:relative;overflow:hidden}.lanyard-root{-webkit-user-select:none;user-select:none;flex-direction:column;align-items:center;width:100%;padding-top:10px;display:flex}.lanyard-clip{background:var(--bg-2);border:2.5px solid;border-top:none;border-radius:0 0 14px 14px;flex-shrink:0;width:56px;height:18px}.lanyard-swing{transform-origin:top;flex-direction:column;align-items:center;width:100%;display:flex}.lanyard-strap{clip-path:polygon(4px 0,calc(100% - 4px) 0,100% 100%,0 100%);border-radius:0 0 3px 3px;flex-shrink:0;width:22px;height:72px}.lanyard-card{background:var(--bg-1);border:1px solid var(--border);cursor:pointer;will-change:transform;border-radius:16px;width:100%;max-width:460px;overflow:hidden}.lanyard-card-bar{height:5px}.lanyard-img-area{background:var(--bg-2);width:100%;height:260px;position:relative;overflow:hidden}.lanyard-img{object-fit:contain;object-position:center;background:linear-gradient(160deg,color-mix(in srgb,var(--bg-2)82%,transparent),color-mix(in srgb,var(--bg-1)90%,transparent));border-radius:10px;width:100%;height:100%;padding:10px;transition:transform .5s;display:block}.lanyard-card:hover .lanyard-img{transform:scale(1.05)}.lanyard-img-placeholder{flex-direction:column;justify-content:center;align-items:center;gap:8px;width:100%;height:100%;display:flex}.lanyard-placeholder-text{letter-spacing:-.04em;font-family:JetBrains Mono,monospace;font-size:52px;font-weight:800}.lanyard-placeholder-sub{color:var(--text-3);letter-spacing:.1em;font-family:JetBrains Mono,monospace;font-size:10px}.lanyard-img-overlay{pointer-events:none;background:linear-gradient(#0000 60%,#00000047 100%);position:absolute;inset:0}.lanyard-card-footer{border-top:1px solid var(--border);background:var(--bg-1);justify-content:space-between;align-items:center;gap:8px;padding:13px 18px;display:flex}.lanyard-card-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}.lanyard-card-year{letter-spacing:.06em;flex-shrink:0;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:700}.project-info-card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r);flex-direction:column;gap:10px;padding:30px;display:flex}.pic-meta-row{justify-content:space-between;align-items:center;margin-bottom:2px;display:flex}.pic-num-tag{color:var(--text-3);letter-spacing:.14em;text-transform:uppercase;font-family:JetBrains Mono,monospace;font-size:.62rem;font-weight:700}.pic-title{color:var(--white);letter-spacing:-.03em;margin:0;font-family:Playfair Display,Georgia,serif;font-size:1.65rem;font-weight:700;line-height:1.15}.pic-subtitle{color:var(--text-2);margin:0;font-size:.88rem;font-weight:400}.pic-divider{background:var(--border);height:1px;margin:4px 0}.pic-desc{color:var(--text-2);-webkit-line-clamp:5;line-clamp:5;-webkit-box-orient:vertical;margin:0;font-size:.86rem;line-height:1.75;display:-webkit-box;overflow:hidden}.proj-dots{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.proj-dot{background:var(--border-h);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;width:6px;height:6px;padding:0;transition:all .25s}.proj-dot.active{background:var(--white);border-radius:3px;width:22px}.proj-dot:hover:not(.active){background:var(--text-3);transform:scale(1.3)}
.skills-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.skill-cat{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r);transition:border-color var(--t),box-shadow var(--t);padding:22px}.skill-cat:hover{border-color:var(--border-h);box-shadow:0 4px 24px #0000001f}.skill-cat-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.skill-cat-title{text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);font-family:JetBrains Mono,monospace;font-size:.64rem;font-weight:700}.skill-cat-count{color:var(--text-3);background:var(--bg-2);border:1px solid var(--border);border-radius:999px;padding:1px 7px;font-family:JetBrains Mono,monospace;font-size:.58rem;font-weight:600}.skill-tags{flex-wrap:wrap;gap:7px;display:flex}.skill-tag{color:var(--text-2);background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-sm);transition:all var(--t);cursor:default;align-items:center;gap:6px;padding:5px 10px;font-size:.77rem;font-weight:500;display:inline-flex}.skill-tag:hover{color:var(--text);border-color:var(--border-h);background:var(--bg-3)}.skill-tag-icon{opacity:.65;flex-shrink:0;justify-content:center;align-items:center;width:13px;height:13px;display:inline-flex}.skill-tag:hover .skill-tag-icon{opacity:1}
.ach-layout{grid-template-columns:1fr 1fr;gap:32px;display:grid}.ach-section-block{margin-top:10px}.ach-sub-header{margin-top:56px}.ach-col-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);border-bottom:1px solid var(--border);align-items:center;gap:8px;margin-bottom:16px;padding-bottom:12px;font-family:JetBrains Mono,monospace;font-size:.71rem;font-weight:700;display:flex}.cred-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.cred-card{background:linear-gradient(180deg,color-mix(in oklab,var(--bg-1)92%,transparent),var(--bg-0));border:1px solid color-mix(in srgb,var(--border)85%,transparent);border-radius:14px;flex-direction:column;gap:8px;min-height:206px;padding:8px;display:flex}.cred-card-shell{min-height:206px}.cred-glow{border-radius:16px;width:100%;height:100%}.cred-glow .border-glow-inner{height:100%}.cred-card-title-wrap{min-height:34px}.cred-card-title{color:var(--text);margin:0;font-size:.86rem;line-height:1.25}.cred-thumb-wrap{border:1px solid var(--border);background:linear-gradient(150deg,color-mix(in srgb,var(--bg-2)92%,transparent),var(--bg-1));border-radius:10px;justify-content:center;align-items:center;width:100%;height:102px;display:flex;overflow:hidden}.cred-thumb{object-fit:contain;width:100%;height:100%}.cred-thumb-placeholder-wrap{background:linear-gradient(135deg,color-mix(in srgb,var(--bg-2)95%,transparent),color-mix(in srgb,var(--bg-3)90%,transparent))}.cred-thumb-placeholder{letter-spacing:.09em;text-transform:uppercase;color:var(--text-3);font-family:JetBrains Mono,monospace;font-size:.75rem}.cred-card-meta{justify-content:space-between;align-items:center;gap:8px;display:flex}.cred-org{color:var(--text-3);font-family:JetBrains Mono,monospace;font-size:.68rem;line-height:1.35}.cred-year{color:var(--text-2);white-space:nowrap;font-family:JetBrains Mono,monospace;font-size:.68rem}.cred-note{color:var(--text-3);margin:0;font-family:JetBrains Mono,monospace;font-size:.68rem;line-height:1.35}@media (max-width:1180px){.cred-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:760px){.cred-grid{grid-template-columns:1fr}}
.resume-header-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:40px;margin-bottom:36px;display:flex}.resume-header-left{flex-shrink:0}.resume-header-left .section-num{margin-bottom:14px;display:block}.resume-big-title{letter-spacing:-.03em;color:var(--white);font-size:clamp(2rem,4vw,3.2rem);font-weight:700;line-height:1.1}.resume-header-right{flex-direction:column;justify-content:flex-end;gap:18px;max-width:420px;padding-top:8px;display:flex}.resume-desc{color:var(--text-2);font-size:.9rem;line-height:1.8}.resume-btns{flex-wrap:wrap;gap:10px;display:flex}.btn-download-resume{letter-spacing:.08em;text-transform:uppercase;color:var(--bg);background:var(--white);border-radius:var(--r-sm);transition:all var(--t);align-items:center;gap:8px;width:fit-content;padding:12px 22px;font-size:.82rem;font-weight:700;display:inline-flex}.btn-download-resume:hover{opacity:.88;transform:translateY(-2px);box-shadow:0 8px 24px #00000026}.btn-view-resume{letter-spacing:.06em;color:var(--text);border:1px solid var(--border);border-radius:var(--r-sm);transition:all var(--t);background:0 0;align-items:center;gap:8px;width:fit-content;padding:12px 22px;font-size:.82rem;font-weight:600;display:inline-flex}.btn-view-resume:hover{border-color:var(--border-h);background:var(--bg-1);transform:translateY(-2px)}.resume-preview-wrap{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r);height:75vh;min-height:400px;position:relative;overflow:hidden}.resume-iframe{border:none;width:100%;height:100%;display:block}.resume-fallback{color:var(--text-3);text-align:center;padding:0 24px;font-size:.88rem;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.resume-fallback-ui{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:24px;display:flex;position:absolute;inset:0}.resume-fallback-icon{font-size:3rem}.resume-fallback-text{color:var(--text-2);font-size:.9rem}.resume-fallback-btns{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:8px;display:flex}
.contact-grid{grid-template-columns:1fr 1.5fr;align-items:start;gap:48px;display:grid}.contact-info{flex-direction:column;gap:28px;display:flex}.contact-info-title{color:var(--white);letter-spacing:-.03em;font-size:1.3rem;font-weight:700;line-height:1.3}.contact-info-text{color:var(--text-2);font-size:.87rem;line-height:1.85}.contact-details{flex-direction:column;gap:10px;display:flex}.contact-detail-item{color:var(--text-2);transition:color var(--t);align-items:center;gap:10px;font-size:.84rem;display:flex}.contact-detail-item:hover{color:var(--text)}.contact-detail-item svg{color:var(--text-3);flex-shrink:0}.contact-form{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r);flex-direction:column;gap:16px;padding:28px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-3);letter-spacing:.08em;text-transform:uppercase;font-family:JetBrains Mono,monospace;font-size:.68rem;font-weight:600}.form-input,.form-textarea{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text);transition:border-color var(--t);outline:none;width:100%;padding:11px 14px;font-family:inherit;font-size:.88rem}.form-input:focus,.form-textarea:focus{border-color:var(--border-h)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-3)}.form-textarea{resize:vertical;min-height:118px;line-height:1.65}.form-submit{color:var(--bg);background:var(--white);border-radius:var(--r-sm);transition:all var(--t);border:none;justify-content:center;align-items:center;gap:8px;width:100%;padding:13px 24px;font-size:.88rem;font-weight:600;display:flex}.form-submit:hover:not(:disabled){opacity:.87;transform:translateY(-2px)}.form-submit:disabled{opacity:.5;cursor:not-allowed}.form-msg{border-radius:var(--r-sm);text-align:center;padding:10px 14px;font-size:.84rem}.form-msg.success{color:#22c55e;background:#22c55e12;border:1px solid #22c55e33}.form-msg.error{color:#f87171;background:#f8717114;border:1px solid #f871712e}.form-error-link{color:#f87171;text-underline-offset:2px;transition:opacity var(--t);text-decoration:underline}.form-error-link:hover{opacity:.75}
.footer{border-top:1px solid var(--border);padding:26px 24px}.footer-inner{max-width:var(--max-w);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin:0 auto;display:flex}.footer-copy{color:var(--text-3);font-family:JetBrains Mono,monospace;font-size:.76rem}.footer-links{gap:20px;display:flex}.footer-link{color:var(--text-3);transition:color var(--t);font-size:.78rem}.footer-link:hover{color:var(--text-2)}
