@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{line-height:1.5;-webkit-text-size-adjust:100%}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}ul,ol{list-style:none}a{text-decoration:none;color:inherit}button{background:none;border:none;cursor:pointer}:root{--color-bg-primary: #0f141b;--color-bg-secondary: #141c26;--color-bg-tertiary: #1b2633;--color-bg-elevated: #223041;--color-surface: rgba(152, 177, 205, .08);--color-surface-hover: rgba(152, 177, 205, .14);--color-border: rgba(152, 177, 205, .28);--color-border-subtle: rgba(152, 177, 205, .16);--color-text-primary: #e9f1fb;--color-text-secondary: #c4d3e6;--color-text-muted: #93a9c2;--color-text-on-accent: #ecf5ff;--color-accent-primary: #2f7fda;--color-accent-secondary: #3c91eb;--color-accent-tertiary: #8ec4ff;--color-accent-gradient: linear-gradient(135deg, #2f7fda 0%, #4ea2f0 100%);--color-accent-glow: rgba(62, 145, 235, .16);--color-success: #22c55e;--color-warning: #eab308;--color-error: #ef4444;--font-family-primary: "Manrope", "Avenir Next", "Segoe UI", sans-serif;--font-family-display: "Manrope", var(--font-family-primary);--font-family-mono: "JetBrains Mono", "Fira Code", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem;--font-size-5xl: 3.5rem;--font-size-6xl: 4.5rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.2;--line-height-normal: 1.5;--line-height-relaxed: 1.7;--letter-spacing-tight: -.02em;--letter-spacing-normal: 0;--letter-spacing-wide: .05em;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--space-32: 8rem;--container-max-width: 1200px;--container-padding: var(--space-6);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(9, 14, 20, .25);--shadow-md: 0 8px 20px rgba(9, 14, 20, .24);--shadow-lg: 0 12px 30px rgba(9, 14, 20, .28);--shadow-xl: 0 20px 42px rgba(9, 14, 20, .3);--shadow-glow: 0 0 40px var(--color-accent-glow);--shadow-glow-lg: 0 0 80px var(--color-accent-glow);--transition-fast: .15s cubic-bezier(.25, .1, .25, 1);--transition-base: .22s cubic-bezier(.25, .1, .25, 1);--transition-slow: .32s cubic-bezier(.25, .1, .25, 1);--transition-spring: .32s cubic-bezier(.25, .1, .25, 1);--z-base: 1;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal: 400;--z-tooltip: 500}[data-theme=light]{--color-bg-primary: #f3f7fc;--color-bg-secondary: #edf3fa;--color-bg-tertiary: #e4edf7;--color-bg-elevated: #dce8f5;--color-surface: rgba(37, 85, 139, .06);--color-surface-hover: rgba(37, 85, 139, .1);--color-border: rgba(45, 88, 137, .24);--color-border-subtle: rgba(45, 88, 137, .14);--color-text-primary: #1d3248;--color-text-secondary: #2f4a63;--color-text-muted: #4f6b84;--color-text-on-accent: #f5f9ff;--color-accent-primary: #1f66bb;--color-accent-secondary: #2c79d3;--color-accent-tertiary: #6ca8e5;--color-accent-gradient: linear-gradient(135deg, #1f66bb 0%, #2c79d3 100%);--color-accent-glow: rgba(31, 102, 187, .1);--shadow-sm: 0 1px 2px rgba(38, 66, 96, .08);--shadow-md: 0 8px 20px rgba(38, 66, 96, .12);--shadow-lg: 0 12px 30px rgba(38, 66, 96, .15);--shadow-xl: 0 20px 42px rgba(38, 66, 96, .18)}@media(max-width:768px){:root{--font-size-5xl: 2.5rem;--font-size-6xl: 3rem;--container-padding: var(--space-4)}}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}body{font-family:var(--font-family-primary);font-size:var(--font-size-base);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg-primary);background-image:radial-gradient(1400px 700px at 100% -10%,var(--color-accent-glow),transparent 58%),radial-gradient(1000px 520px at 0% 12%,rgba(34,96,158,.08),transparent 65%);overflow-x:hidden;transition:background-color var(--transition-base),color var(--transition-base)}.container{width:100%;max-width:var(--container-max-width);margin:0 auto;padding:0 var(--container-padding)}.section{padding:var(--space-24) 0;position:relative}@media(max-width:768px){.section{padding:var(--space-16) 0}}h1,h2,h3,h4,h5,h6{font-family:var(--font-family-display);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight);color:var(--color-text-primary)}h1{font-size:var(--font-size-5xl)}h2{font-size:var(--font-size-4xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}p{color:var(--color-text-secondary);line-height:var(--line-height-relaxed)}strong{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}a{color:inherit;text-decoration:none;transition:color var(--transition-base)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border-radius:var(--radius-lg);border:1px solid transparent;cursor:pointer;transition:background-color var(--transition-base),color var(--transition-base),border-color var(--transition-base),transform var(--transition-fast),box-shadow var(--transition-base);text-decoration:none;white-space:nowrap}.btn-primary{background:var(--color-accent-primary);color:var(--color-text-on-accent);border-color:var(--color-accent-primary)}.btn-primary:hover{background:var(--color-accent-secondary);border-color:var(--color-accent-secondary);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:transparent;color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-surface-hover);border-color:var(--color-border);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--color-text-secondary);border:none;padding:var(--space-2) var(--space-3)}.btn-ghost:hover{color:var(--color-text-primary);background:var(--color-surface)}.card{background:var(--color-bg-secondary);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);transition:border-color var(--transition-base),box-shadow var(--transition-base),transform var(--transition-fast)}.card:hover{border-color:var(--color-border);box-shadow:var(--shadow-md)}.gradient-text{color:var(--color-text-primary)}:focus-visible{outline:2px solid var(--color-accent-primary);outline-offset:2px}.skip-to-main{position:absolute;top:-100px;left:var(--space-4);background:var(--color-accent-primary);color:var(--color-text-on-accent);padding:var(--space-3) var(--space-6);border-radius:var(--radius-md);z-index:var(--z-modal);transition:top var(--transition-fast)}.skip-to-main:focus{top:var(--space-4)}.fade-in{opacity:0;transform:translateY(20px);transition:opacity .6s ease-out,transform .6s ease-out}.fade-in.visible{opacity:1;transform:translateY(0)}.section-header{text-align:left;margin-bottom:var(--space-16);max-width:760px}.section-label{display:inline-block;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-accent-primary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);margin-bottom:var(--space-4)}.section-header h2{margin:0}.bg-gradient-subtle:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 50% at 50% -20%,var(--color-accent-glow),transparent);pointer-events:none}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.nav{position:fixed;top:0;left:0;right:0;background:color-mix(in srgb,var(--color-bg-primary) 88%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--color-border-subtle);z-index:var(--z-fixed);padding:var(--space-3) 0}[data-theme=light] .nav{background:color-mix(in srgb,var(--color-bg-primary) 90%,transparent)}.nav-container{display:flex;justify-content:space-between;align-items:center;gap:var(--space-6)}.nav-logo{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);letter-spacing:.02em;text-transform:uppercase;color:var(--color-text-secondary);transition:color var(--transition-fast)}.nav-logo:hover{color:var(--color-text-primary)}.nav-links{display:flex;gap:var(--space-2);list-style:none;margin:0;padding:0}.nav-links a{display:block;padding:var(--space-2) var(--space-3);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border-radius:var(--radius-sm);transition:color var(--transition-fast),background-color var(--transition-fast)}.nav-links a:hover{color:var(--color-text-primary);background:var(--color-surface)}@media(max-width:768px){.nav-links{display:none}.nav{padding:var(--space-2) 0}.nav-logo{font-size:var(--font-size-sm)}}.hero{min-height:100vh;display:flex;align-items:center;position:relative;padding-top:84px;overflow:hidden}.hero-bg-gradient{position:absolute;inset:0;overflow:hidden;pointer-events:none}.hero-bg-gradient:before{content:"";position:absolute;top:-30%;right:-18%;width:74%;height:74%;background:radial-gradient(circle,rgba(49,127,218,.18) 0%,transparent 62%);animation:float 20s ease-in-out infinite}.hero-bg-gradient:after{content:"";position:absolute;bottom:-24%;left:-10%;width:46%;height:46%;background:radial-gradient(circle,rgba(69,144,225,.14) 0%,transparent 64%);animation:float 25s ease-in-out infinite reverse}@keyframes float{0%,to{transform:translate(0)}50%{transform:translate(-20px,20px)}}.hero-content{display:grid;grid-template-columns:minmax(0,1.18fr) minmax(300px,.82fr);gap:clamp(1.5rem,4vw,4.5rem);align-items:start;position:relative;z-index:var(--z-base)}.hero-text{max-width:680px}.hero-greeting{font-size:var(--font-size-base);color:var(--color-text-secondary);margin-bottom:var(--space-3);opacity:0;animation:fadeUp .6s ease-out .1s forwards}.hero-title{font-size:clamp(2.5rem,5vw,var(--font-size-6xl));font-weight:800;line-height:1.1;letter-spacing:var(--letter-spacing-tight);margin-bottom:var(--space-5);opacity:0;animation:fadeUp .6s ease-out .2s forwards}.hero-subtitle{font-size:clamp(1rem,1vw + .7rem,1.3rem);color:var(--color-text-secondary);font-weight:var(--font-weight-medium);margin-bottom:var(--space-5);opacity:0;animation:fadeUp .6s ease-out .3s forwards}.hero-description{font-size:clamp(1rem,.2vw + .95rem,1.15rem);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin-bottom:var(--space-10);max-width:560px;opacity:0;animation:fadeUp .6s ease-out .4s forwards}.hero-description .highlight{color:var(--color-text-primary);font-weight:var(--font-weight-semibold)}.hero-cta{display:flex;gap:var(--space-4);margin-bottom:var(--space-8);opacity:0;animation:fadeUp .6s ease-out .5s forwards}.hero-social{display:flex;gap:var(--space-3);opacity:0;animation:fadeUp .6s ease-out .6s forwards}.social-link{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:var(--radius-sm);color:var(--color-text-secondary);background:color-mix(in srgb,var(--color-surface) 74%,transparent);border:1px solid var(--color-border-subtle);transition:transform var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),background-color var(--transition-fast)}.social-link:hover{color:var(--color-text-primary);border-color:var(--color-border);background:var(--color-surface-hover);transform:translateY(-2px)}.hero-notes{opacity:0;animation:fadeUp .6s ease-out .5s forwards;padding-top:var(--space-8)}.hero-note-kicker{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.09em;margin-bottom:var(--space-4)}.hero-note-list{border-left:1px solid var(--color-border);padding-left:var(--space-5);display:grid;gap:var(--space-6)}.hero-note-list li{display:grid;gap:var(--space-2)}.hero-note-list span{color:var(--color-text-muted);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.07em}.hero-note-list strong{font-size:var(--font-size-base);color:var(--color-text-primary);line-height:1.4}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:968px){.hero-content{grid-template-columns:1fr;text-align:left;gap:var(--space-10)}.hero-text{max-width:none}.hero-description{max-width:100%}.hero-notes{padding-top:0}.hero-note-list{border-left:none;border-top:1px solid var(--color-border);padding-left:0;padding-top:var(--space-5);gap:var(--space-4)}}@media(max-width:600px){.hero{padding-top:72px}.hero-cta{flex-wrap:wrap}.hero-cta .btn{width:100%;justify-content:center}}.about{position:relative}.about-content{display:grid;grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);gap:clamp(1.2rem,3vw,4rem);align-items:start}.about-text{max-width:500px}.about-intro{font-size:var(--font-size-lg);color:var(--color-text-primary);line-height:var(--line-height-relaxed);margin-bottom:var(--space-4)}.about-text p{margin-bottom:var(--space-4)}.education-timeline{position:relative;padding-left:var(--space-6)}.education-timeline:before{content:"";position:absolute;left:1px;top:4px;bottom:4px;width:1px;background:var(--color-border)}.timeline-item{position:relative;padding-bottom:var(--space-6)}.timeline-item:last-child{padding-bottom:0}.timeline-marker{position:absolute;left:calc(-1 * var(--space-6) - 3px);top:4px;width:7px;height:7px;background:var(--color-accent-primary);border-radius:50%;box-shadow:0 0 0 3px var(--color-bg-primary)}.timeline-content{padding:0 0 var(--space-5);border-bottom:1px solid var(--color-border-subtle);transition:border-color var(--transition-base)}.timeline-content:hover{border-color:var(--color-border)}.timeline-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-2)}.timeline-header h3{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);margin:0}.timeline-date{font-size:var(--font-size-xs);color:var(--color-text-muted);font-weight:var(--font-weight-medium)}.timeline-degree,.timeline-minor,.timeline-focus{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:var(--space-1) 0 0}.timeline-gpa{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-2)}@media(max-width:968px){.about-content{grid-template-columns:1fr}.about-text{max-width:none}.education-timeline{max-width:100%}}.experience{background:linear-gradient(180deg,var(--color-bg-primary) 0%,color-mix(in srgb,var(--color-bg-secondary) 84%,var(--color-bg-primary)) 100%)}.experience-grid{display:flex;flex-direction:column;gap:var(--space-10)}.experience-card{border-top:1px solid var(--color-border);padding-top:var(--space-8);transition:border-color var(--transition-base),transform var(--transition-fast);position:relative}.experience-card:hover{border-color:var(--color-border);transform:translateY(-1px)}.experience-header{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:var(--space-3);margin-bottom:var(--space-4)}.experience-logo{width:fit-content;height:auto;font-weight:var(--font-weight-bold);font-size:var(--font-size-xs);letter-spacing:.08em;color:var(--color-text-muted);text-transform:uppercase;flex-shrink:0}.experience-meta{grid-column:1 / 2}.experience-meta h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin:0 0 var(--space-2)}.experience-role{display:block;color:var(--color-text-secondary);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm)}.experience-date{display:block;color:var(--color-text-muted);font-size:var(--font-size-xs);margin-top:var(--space-1)}.experience-link{color:var(--color-text-secondary);padding:var(--space-1);border-radius:var(--radius-sm);transition:transform var(--transition-fast),color var(--transition-fast),background-color var(--transition-fast)}.experience-link:hover{color:var(--color-text-primary);background:var(--color-surface);transform:translateY(-1px)}.experience-details{list-style:none;padding:0;margin:0 0 var(--space-4)}.experience-details li{position:relative;padding-left:var(--space-5);margin-bottom:var(--space-3);color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:var(--line-height-relaxed)}.experience-details li:before{content:"";position:absolute;left:0;top:10px;width:5px;height:5px;background:var(--color-accent-primary);border-radius:50%}.experience-details li:last-child{margin-bottom:0}.experience-tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.tag{padding:var(--space-1) var(--space-3);background:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-full);font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:var(--font-weight-medium);transition:color var(--transition-fast),border-color var(--transition-fast),background-color var(--transition-fast)}.tag:hover{border-color:var(--color-accent-primary);color:var(--color-text-primary)}@media(max-width:768px){.experience-header{grid-template-columns:1fr;gap:var(--space-2)}.experience-link{justify-self:start}}.projects{background:linear-gradient(180deg,var(--color-bg-primary) 0%,color-mix(in srgb,var(--color-bg-secondary) 86%,var(--color-bg-primary)) 100%);position:relative}.projects:before{content:"";position:absolute;top:-18%;right:-12%;width:50vw;height:50vw;background:radial-gradient(circle,rgba(57,130,209,.12) 0%,transparent 72%);pointer-events:none}.projects-list{display:grid;gap:var(--space-10);position:relative;z-index:var(--z-base)}.project-item{border-top:1px solid var(--color-border);padding-top:var(--space-7);transition:border-color var(--transition-base),transform var(--transition-fast)}.project-item:hover{border-color:var(--color-accent-secondary);transform:translateY(-1px)}.project-head{display:flex;justify-content:space-between;align-items:baseline;gap:var(--space-3);margin-bottom:var(--space-3)}.project-head h3{font-size:var(--font-size-2xl);margin:0}.project-date{font-size:var(--font-size-xs);color:var(--color-text-muted);letter-spacing:.06em;text-transform:uppercase}.project-stack{margin-bottom:var(--space-4);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.project-points{margin:0;padding:0;list-style:none;display:grid;gap:var(--space-3)}.project-points li{position:relative;padding-left:var(--space-5);color:var(--color-text-secondary);line-height:var(--line-height-relaxed)}.project-points li:before{content:"";position:absolute;left:0;top:10px;width:5px;height:5px;border-radius:50%;background:var(--color-accent-primary)}.project-link{margin-top:var(--space-5);display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) 0;border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);transition:color var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast)}.project-link:hover{color:var(--color-accent-secondary);border-color:var(--color-accent-secondary);transform:translate(2px)}@media(max-width:768px){.project-head{flex-direction:column;align-items:flex-start}.project-head h3{font-size:var(--font-size-xl)}}.skills{background:linear-gradient(180deg,color-mix(in srgb,var(--color-bg-secondary) 86%,var(--color-bg-primary)) 0%,var(--color-bg-primary) 100%)}.skills-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-8) var(--space-12)}.skills-lead{max-width:920px;margin:0 0 var(--space-10);color:var(--color-text-secondary);line-height:var(--line-height-relaxed)}.skill-category{text-align:left;padding-bottom:var(--space-5);border-bottom:1px solid var(--color-border-subtle);transition:border-color var(--transition-base)}.skill-category:hover{border-color:var(--color-border)}.skill-category h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0 0 var(--space-4)}.skill-tags{display:flex;flex-wrap:wrap;justify-content:flex-start;gap:var(--space-2)}.skill-tag{padding:var(--space-1) var(--space-3);background:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-full);font-size:var(--font-size-xs);color:var(--color-text-secondary);transition:border-color var(--transition-fast),color var(--transition-fast),background-color var(--transition-fast)}.skill-tag:hover{border-color:var(--color-accent-primary);color:var(--color-text-primary)}.skill-tag.primary{background:color-mix(in srgb,var(--color-accent-primary) 17%,var(--color-bg-secondary));border-color:color-mix(in srgb,var(--color-accent-primary) 40%,transparent);color:var(--color-text-primary);font-weight:var(--font-weight-medium)}@media(max-width:900px){.skills-lead{margin-bottom:var(--space-8)}.skills-grid{grid-template-columns:1fr;gap:var(--space-6)}}.achievements{position:relative}.achievements:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:520px;height:520px;background:radial-gradient(circle,rgba(64,137,214,.12) 0%,transparent 72%);pointer-events:none;opacity:.35}.achievements-grid{display:grid;grid-template-columns:1fr;gap:var(--space-10);position:relative;z-index:var(--z-base)}.achievement-category{border-top:1px solid var(--color-border);padding-top:var(--space-7)}.category-title{display:flex;align-items:center;gap:var(--space-3);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0 0 var(--space-5);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border-subtle)}.category-icon{font-size:var(--font-size-xl)}.achievement-list{display:grid;gap:var(--space-2)}.achievement-item{display:grid;grid-template-columns:84px minmax(0,1fr);align-items:start;gap:var(--space-4);padding:var(--space-3) 0;border-bottom:1px dashed var(--color-border-subtle);transition:border-color var(--transition-base),transform var(--transition-fast)}.achievement-item:hover{border-color:var(--color-border);transform:translate(2px)}.achievement-item.highlight{background:transparent;border-bottom-style:solid}.achievement-rank,.achievement-badge{display:flex;align-items:center;justify-content:center;min-width:52px;padding:var(--space-2) var(--space-2);border-radius:var(--radius-md);font-weight:var(--font-weight-bold);font-size:var(--font-size-xs);flex-shrink:0}.achievement-rank{background:color-mix(in srgb,var(--color-accent-primary) 17%,var(--color-bg-secondary));color:var(--color-text-primary);border:1px solid color-mix(in srgb,var(--color-accent-primary) 40%,transparent)}.achievement-badge{background:var(--color-bg-tertiary);border:1px solid var(--color-border);color:var(--color-text-secondary)}.achievement-info{flex:1;min-width:0}.achievement-info strong{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-1)}.achievement-info p{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin:0;line-height:var(--line-height-normal)}@media(max-width:768px){.achievement-item{grid-template-columns:74px minmax(0,1fr)}}.contact{position:relative}.contact-content{max-width:920px;margin:0;text-align:left}.contact-intro{font-size:var(--font-size-lg);color:var(--color-text-secondary);margin-bottom:var(--space-10);line-height:var(--line-height-relaxed)}.contact-cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-5) var(--space-8);margin-bottom:var(--space-10)}.contact-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-2) 0 var(--space-4);border-bottom:1px solid var(--color-border-subtle);text-decoration:none;transition:border-color var(--transition-fast),transform var(--transition-fast)}.contact-card:hover{border-color:var(--color-border);transform:translate(2px)}.contact-icon{font-size:var(--font-size-xl);width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--color-surface) 72%,transparent);border-radius:var(--radius-sm);flex-shrink:0}.contact-info{text-align:left;min-width:0}.contact-info strong{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:2px}.contact-info span{font-size:var(--font-size-sm);color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.contact-cta{margin-top:var(--space-8);display:flex;gap:var(--space-3);flex-wrap:wrap}.btn-large{padding:var(--space-4) var(--space-8);font-size:var(--font-size-base)}@media(max-width:600px){.contact-cards{grid-template-columns:1fr;gap:var(--space-3)}.contact-cta .btn{width:100%;justify-content:center}}.footer{background:color-mix(in srgb,var(--color-bg-secondary) 92%,var(--color-bg-primary));padding:var(--space-12) 0 var(--space-8);border-top:1px solid var(--color-border-subtle)}.footer-content{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-8);padding-bottom:var(--space-8);border-bottom:1px solid var(--color-border-subtle)}.footer-brand{text-align:left}.footer-logo{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);letter-spacing:.01em}.footer-brand p{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-top:var(--space-2)}.footer-social{display:flex;gap:var(--space-3)}.footer-bottom{text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm)}@media(max-width:600px){.footer-content{flex-direction:column;gap:var(--space-6);text-align:center}.footer-brand{text-align:center}}.theme-toggle{position:fixed;top:16px;right:16px;width:44px;height:44px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.1rem;cursor:pointer;transition:transform var(--transition-fast),background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);z-index:9999;box-shadow:var(--shadow-md);max-width:calc(100vw - 32px)}.theme-toggle:hover{background:var(--color-bg-tertiary);border-color:var(--color-accent-primary);transform:translateY(-1px)}.theme-toggle:active{transform:scale(.95)}@media(max-width:768px){.theme-toggle{top:12px;right:12px;width:40px;height:40px}}.icon-github,.icon-linkedin,.icon-twitter,.icon-email{width:20px;height:20px;display:inline-block}.icon-github svg,.icon-linkedin svg,.icon-twitter svg,.icon-email svg{width:100%;height:100%;fill:currentColor}.social-link .icon-github svg{fill:var(--color-text-primary)}.social-link:hover .icon-github svg,.social-link:hover .icon-linkedin svg,.social-link:hover .icon-twitter svg,.social-link:hover .icon-email svg{fill:var(--color-text-primary)}.sidebar{position:fixed;top:0;left:0;width:280px;height:100vh;background:var(--color-bg-secondary);border-right:1px solid var(--color-border);z-index:10000;transform:translate(-100%);transition:transform var(--transition-base)}.sidebar.open{transform:translate(0)}.sidebar-content{padding:var(--space-8) var(--space-6) var(--space-6);height:100%;display:flex;flex-direction:column;gap:var(--space-6)}.sidebar-close{position:absolute;top:16px;right:16px;width:36px;height:36px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:24px;line-height:1;color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform var(--transition-fast),color var(--transition-fast),background-color var(--transition-fast),border-color var(--transition-fast)}.sidebar-close:hover{background:var(--color-surface-hover);color:var(--color-text-primary);transform:translateY(-1px)}.sidebar-title{margin-top:var(--space-6);color:var(--color-text-muted);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.08em}.sidebar-links{display:grid;gap:var(--space-3)}.sidebar-links a{display:block;padding:var(--space-3) var(--space-2);color:var(--color-text-secondary);border-bottom:1px solid var(--color-border-subtle);transition:color var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast)}.sidebar-links a:hover{color:var(--color-text-primary);border-color:var(--color-border);transform:translate(2px)}.sidebar-resume{margin-top:auto;display:inline-flex;align-items:center;justify-content:center;padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);color:var(--color-text-primary);border-radius:var(--radius-sm);transition:background-color var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast)}.sidebar-resume:hover{background:var(--color-surface-hover);border-color:var(--color-accent-primary);transform:translateY(-1px)}.sidebar-overlay{position:fixed;inset:0;background:#0c141f73;z-index:9999;opacity:0;visibility:hidden;transition:opacity var(--transition-base),visibility var(--transition-base)}.sidebar-overlay.visible{opacity:1;visibility:visible}.menu-toggle{display:flex;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;padding:8px;background:transparent;border:none;cursor:pointer;border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}.menu-toggle:hover{background:var(--color-surface)}.menu-bar{display:block;width:100%;height:2px;background:var(--color-text-primary);border-radius:2px;transition:transform var(--transition-fast),opacity var(--transition-fast),background-color var(--transition-fast)}
