:root{--color-bg: #ffffff;--color-text:#000000;--color-accent: #556b2f;--color-accent-clear:#e4ecdf;--color-border-subtle: #e5e7eb;--font-base: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--text-xxs:.5rem;--text-xs: .7rem;--text-sm: .875rem;--text-md: 1rem;--text-lg: 1.125rem;--text-xl: 1.5rem;--text-2xl: 3rem;--text-3xl: 5.5rem;--line-height-base: 1.6;--line-height-tight:1.25;--page-padding-x: 24px;--page-padding-y: 40px;--section-spacing-y: 120px;--container-max-width: 1120px;--grid-columns: 12;--grid-gutter: 16px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 999px;--transition-fast: .15s ease-out;--transition-med: .22s ease-out}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-height:100vh;font-family:var(--font-base);color:var(--color-text);background-color:var(--color-bg);line-height:var(--line-height-base);-webkit-font-smoothing:antialiased}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}a:hover{text-decoration:none}main{padding-top:80px}h1,h2,h3,h4{font-weight:700;letter-spacing:-.03em}h1{margin:0 0 24px;font-size:var(--text-3xl);line-height:var(--line-height-tight)}h2{margin:0 0 16px;font-size:var(--text-2xl)}P{font-size:var(--text-xl);line-height:var(--line-height-tight)}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 20px;border-radius:var(--radius-lg);border:1px solid transparent;font-size:var(--text-sm);font-weight:500;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;background:none;color:var(--color-text);transition:background-color var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.btn:focus-visible,.nav__link:focus-visible,.icon-link:focus-visible,.project-link:focus-visible{outline:none;box-shadow:0 0 0 3px #556b2f59;border-radius:999px}.container{max-width:var(--container-max-width);margin:0 auto;padding-inline:var(--page-padding-x)}.section{padding-block:var(--section-spacing-y)}.section--hero{padding-block:calc(var(--section-spacing-y) * 1.1)}.section--contact{border-top:1px solid var(--color-border-subtle)}.section__header{max-width:720px;margin-bottom:48px}.section__header h2{margin:0 0 16px;font-size:var(--text-2xl);letter-spacing:-.03em}.section__header p{margin:0;font-size:var(--text-md);color:#000000b3}@media(max-width:1024px){h1{font-size:4rem}h2{font-size:2.5rem}h3{font-size:1.8rem}p{font-size:1rem}.section{padding-block:80px}.section--hero{padding-block:100px}.section__header{margin-bottom:36px}.section__header h2{font-size:2rem}.section__header p{font-size:.95rem}.container{padding-inline:20px}.grid--2col{grid-template-columns:1fr 1fr;gap:16px}.grid--3col{grid-template-columns:repeat(2,1fr);gap:16px}.grid--2col>*{grid-column:auto}.btn{padding:10px 18px;font-size:.95rem}header,.nav__list{flex-wrap:wrap}.nav__item{margin:8px}}@media(max-width:600px){h1{font-size:2.5rem}h2{font-size:1.8rem}h3{font-size:1.5rem}p{font-size:.9rem}.section{padding-block:60px}.section--hero{padding-block:80px}.section__header{margin-bottom:28px}.section__header h2{font-size:1.6rem}.section__header p{font-size:.85rem}.container{padding-inline:16px}.grid--2col,.grid--3col{grid-template-columns:1fr;gap:12px}.grid--2col>*{grid-column:auto}.btn{width:100%;padding:12px 0;font-size:1rem}header,.nav__list{flex-direction:column;align-items:flex-start}.nav__item{margin:6px 0}img{width:100%;height:auto}main{padding-top:60px}}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.site-header{position:fixed;inset-inline:0;top:0;z-index:20;background-color:#fffffff5;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid transparent;transition:border-color var(--transition-med),backgrund-color var(--transition-med)}.site-header--scrolled{border-bottom-color:var(--color-border-subtle)}.nav{display:flex;align-items:center;justify-content:space-between;padding-block:16px}.nav__brand img{width:15%;height:auto}.nav__right{display:flex;align-items:center;gap:24px}.nav__links{display:flex;align-items:center;gap:20px;list-style:none;margin:0;padding:0}.nav__link{font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.16rem;position:relative;padding-block:4px}.nav__link:after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background-color:var(--color-accent);transition:width var(--transition-fast)}.nav__link:hover:after,.nav__link:focus-visible:after{width:100%}.nav__toggle{display:none;flex-direction:column;gap:4px;border:none;background:none;padding:8px}.nav__toggle span{width:20px;height:2px;background-color:var(--color-text)}.download__resume{border-color:var(--color-accent)}.download-icon{margin-right:8px;vertical-align:middle;font-size:1rem}.download__resume:hover,.download__resume:focus-visible{background-color:var(--color-accent);color:var(--color-bg)}@media(max-width:1024px){.nav{padding-block:14px;gap:16px}.nav__link{font-size:.875rem}.nav__right{gap:20px}.download__resume{font-size:.875rem;padding:10px 16px}}@media(max-width:720px){.nav__toggle{display:inline-flex}.nav__right{position:fixed;inset-inline:0;top:56px;background-color:#556b2fb3;border-bottom:1px solid var(--color-border-subtle);padding:16px var(--page-padding-x) 24px;flex-direction:column;align-items:flex-start;gap:16px;transform:translateY(-120%);opacity:0;pointer-events:none;transition:transform var(--transition-med),opacity var(--transition-med);color:var(--color-accent-clear)}.nav__right.is-open{transform:translateY(0);opacity:1;pointer-events:auto}.nav__links{flex-direction:column;align-items:flex-start}.nav__link{font-size:.9rem;padding-block:6px}.download__resume{width:100%;text-align:center;padding:12px 0;font-size:.9rem;background-color:var(--color-accent);color:var(--color-accent-clear)}}.section--hero{min-height:80vh;margin:0 auto;width:90%;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:0 var(--page-padding-x)}.hero__content{max-width:fit-content}.hero__actions{display:flex;gap:16px;justify-content:center}.btn--primary{background-color:var(--color-accent);color:var(--color-bg);font-size:var(--text-lg)}.btn--primary:hover,.btn--primary:focus-visible{transform:translateY(-1px);background-color:#475826}.hi{align-self:flex-start;color:var(--color-accent);font-size:var(--text-lg)}@media(max-width:1024px){.section--hero{width:95%;padding-block:80px}.hero__content{max-width:100%}.hero__actions{gap:12px;flex-wrap:wrap}.btn--primary{font-size:1rem;padding:12px 20px}.hi{font-size:1rem}}@media(max-width:600px){.section--hero{padding-block:60px}.hero__content{max-width:100%}.hero__actions{flex-direction:column;gap:10px}.btn--primary{font-size:.95rem;width:100%;padding:10px 0}.hi{font-size:.95rem;text-align:center;align-self:center}}.specific--info{display:flex;align-items:center;gap:3rem;margin-top:2rem}.skills-container{flex:1.5}.specific--info p{flex:1;min-width:0;margin:0;font-size:var(--text-lg)}.specific--info .skills-container{flex:1}.skills-grid{display:grid;grid-template-columns:repeat(4,minmax(100px,1fr));gap:15px;margin-top:2rem}.skill-card{position:relative;background-color:var(--color-bg);min-height:100px;padding:12px;border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;transition:transform .3s ease;border:1px solid var(--color-border-subtle)}.skill-card:hover{transform:translateY(-5px);box-shadow:0 5px 8px var(--color-accent)}.skill-icon{width:50px;height:50px;margin-bottom:10px;object-fit:contain}.skill-name{font-weight:600;font-size:.9rem;color:var(--color-accent)}.skills-title{text-align:center;width:100%;margin-bottom:2rem;font-size:1.5rem;color:var(--color-accent)}.learning-badge{position:absolute;top:-8px;right:-8px;color:#fff;font-size:12px;font-weight:700;padding:3px 10px;border-radius:10px;text-transform:uppercase;box-shadow:0 2px 4px #0003;background-color:var(--color-accent)}.skill-card--learning{background-color:var(--color-accent-clear);border-color:#c5d1bc}@media(max-width:1024px){.specific--info{flex-direction:column;gap:2rem;text-align:center}.specific--info p{font-size:1rem}.skills-container{flex:1}.skills-grid{grid-template-columns:repeat(2,minmax(100px,1fr));gap:12px}.skill-card{min-height:90px;padding:10px}.skill-icon{width:45px;height:45px;margin-bottom:8px}.skill-name{font-size:.85rem}.skills-title{font-size:1.3rem;margin-bottom:1.5rem}.learning-badge{font-size:11px;padding:2px 8px}}@media(max-width:600px){.specific--info{flex-direction:column;gap:1.5rem;text-align:center}.specific--info p{font-size:.95rem}.skills-container{flex:1}.skills-grid{grid-template-columns:1fr;gap:10px}.skill-card{min-height:80px;padding:8px}.skill-icon{width:40px;height:40px;margin-bottom:6px}.skill-name{font-size:.8rem}.skills-title{font-size:1.1rem;margin-bottom:1rem}.learning-badge{font-size:10px;padding:2px 6px}}.section__header{max-width:640px;margin-bottom:48px}.projects-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:40px;margin-top:2rem}.project-card{display:flex;flex-direction:column;background-color:var(--color-bg);border-radius:var(--radius-md);border:2px solid var(--color-border-subtle);overflow:hidden;transition:transform var(--transition-med),box-shadow var(--transition-med);height:100%}.project-card__image{height:auto;display:flex;justify-content:center;align-items:center;padding:10px 30px;flex-shrink:0;position:relative}.project-card__image img{max-width:100%;max-height:100%;object-fit:contain;border-radius:var(--radius-md);filter:grayscale(100%) contrast(1.2) brightness(.7);transition:filter .3s ease}.project-card__image:after{content:"";position:absolute;inset:10px 30px;background-color:#556b2f;mix-blend-mode:multiply;opacity:.7;pointer-events:none;border-radius:var(--radius-md)}.project-card:hover .project-card__image img{filter:none}.project-card__body{padding:1.5rem;display:flex;flex-direction:column;flex-grow:1}.project-card__body{padding:24px}.project-card__title{margin:0 0 12px;font-size:var(--text-xl)}.project-card__text{margin:0 0 16px;font-size:var(--text-sm);color:#000000bf}.project-card__tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.tag{padding:4px 10px;border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);font-size:var(--text-xs);letter-spacing:.08em;opacity:.5}.project-card__links{display:flex;gap:10px}.project-card__links a{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.12em;color:var(--color-accent)}.project-card__links a:hover{text-decoration:underline;text-decoration-color:var(--color-accent)}@media(max-width:1024px){.section__header{max-width:100%;margin-bottom:36px}.projects-grid{grid-template-columns:repeat(2,1fr);gap:32px}.project-card{padding:0}.project-card__body{padding:20px}.project-card__title{font-size:1.25rem}.project-card__text{font-size:.95rem}.tag{font-size:.75rem;padding:3px 8px}.project-card__links a{font-size:.75rem}}@media(max-width:600px){.projects-grid{grid-template-columns:1fr;gap:20px}.project-card__body{padding:16px}.project-card__title{font-size:1.1rem}.project-card__text{font-size:.85rem}.tag{font-size:.7rem;padding:2px 6px}.project-card__links a{font-size:.7rem}}.education-header p{font-size:var(--text-lg)}.education-card{border-bottom:solid 2px var(--color-border-subtle);padding-bottom:40px;padding-top:15px;display:flex;flex-direction:column;position:relative}.education-name{font-size:var(--text-xl);margin-bottom:0}.education-place{font-size:var(--text-sm);opacity:.5;margin-top:.5px}.education-description{font-size:var(--text-md)}.learning-education-badge{position:absolute;top:10px;right:10px;background-color:#ff4d4d1a;color:#ff4d4d;padding:4px 12px;border-radius:50px;border:1px solid #ff4d4d;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px}@media(max-width:1024px){.education-header p{font-size:1rem}.education-card{padding-top:12px;padding-bottom:30px}.education-name{font-size:1.25rem}.education-place{font-size:.85rem}.education-description{font-size:.95rem}}@media(max-width:600px){.education-header p{font-size:.9rem;text-align:center}.education-card{padding-top:10px;padding-bottom:24px}.education-name{font-size:1.1rem;text-align:center}.education-place{font-size:.8rem;text-align:center}.education-description{font-size:.9rem;text-align:center}}.section-contact{padding:100px 0}.contact-form{max-width:680px;margin:40px auto 0;display:flex;flex-direction:column;gap:28px;border:solid 1px var(--color-border-subtle);padding:25px;border-radius:var(--radius-md)}.form-field{position:relative;width:100%}.form-field input,.form-field textarea{width:100%;padding:22px 16px 16px 46px;border-radius:14px;border:1px solid #e5e5e5;background-color:#f9f9f9;font-size:15px;transition:all .25s ease}.form-field input:hover,.form-field textarea:hover{background-color:#f2f2f2}.form-field input:focus,.form-field textarea:focus{outline:none;border-color:var(--color-accent);background-color:#fff;box-shadow:0 0 0 3px #0071e326}.form-field label{position:absolute;left:46px;top:22px;font-size:15px;color:#8e8e93;pointer-events:none;transition:all .2s ease}.form-field input:focus+label,.form-field input:not(:placeholder-shown)+label,.form-field textarea:focus+label,.form-field textarea:not(:placeholder-shown)+label{top:8px;font-size:12px;color:var(--color-accent)}.input-icon{position:absolute;left:16px;top:24px;font-size:16px;color:#8e8e93}.valid-icon{position:absolute;right:16px;top:24px;font-size:18px;color:#34c759;animation:pop .2s ease}.textarea-icon,.textarea-valid{top:26px}.form-field.error input,.form-field.error textarea{border-color:#ff3b30;background-color:#fff5f5}.form-field.error label{color:#ff3b30}.form-field.success input,.form-field.success textarea{border-color:#34c759;background-color:#f4fff8}.form-field.success label{color:#34c759}.contact-submit{margin-top:10px;padding:16px;border-radius:14px;background-color:var(--color-accent);color:#fff;font-weight:600;font-size:15px;transition:all .2s ease}.contact-submit:hover{transform:translateY(-1px);background-color:#475826}.contact-socials{margin-top:60px;display:flex;justify-content:center;gap:24px}.social-icon{width:48px;height:48px;border-radius:50%;background-color:var(--color-accent);display:flex;align-items:center;justify-content:center;font-size:30px;color:#fff;transition:all .25s ease}.social-icon:hover{transform:translateY(-1px);background-color:#475826}@keyframes pop{0%{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}@media(max-width:1024px){.section-contact{padding:80px 0}.contact-form{max-width:100%;padding:20px;gap:24px}.form-field input,.form-field textarea{padding:20px 14px 14px 40px;font-size:14px}.form-field label{left:40px;top:20px;font-size:14px}.input-icon{left:14px;top:22px;font-size:15px}.valid-icon{top:22px;font-size:17px}.textarea-icon,.textarea-valid{top:24px}.contact-submit{padding:14px;font-size:14px}.contact-socials{gap:20px}.social-icon{width:44px;height:44px;font-size:28px}}@media(max-width:600px){.section-contact{padding:60px 0}.contact-form{margin:20px auto 0;padding:16px;gap:20px}.form-field input,.form-field textarea{padding:16px 12px 12px 36px;font-size:13px}.form-field label{left:36px;top:16px;font-size:12px}.input-icon{left:12px;top:18px;font-size:14px}.valid-icon{top:18px;font-size:16px}.textarea-icon,.textarea-valid{top:20px}.contact-submit{padding:12px;font-size:13px}.contact-socials{gap:16px;flex-wrap:wrap}.social-icon{width:40px;height:40px;font-size:24px}}.footer{border-top:1px solid var(--color-border-subtle);padding-block:32px;text-align:center;color:#0009}.container p{font-size:.9rem}@media(max-width:1024px){.footer{padding-block:28px}.container p{font-size:.85rem}}@media(max-width:600px){.footer{padding-block:24px}.container p{font-size:.8rem}}
