*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--color-text: #ffffff;--color-text-secondary: rgba(255, 255, 255, .9);--color-text-muted: #a4a4a4;--color-text-light: rgb(144, 144, 144);--color-bg: #101011;--color-border: #2b2b2b;--color-card-bg: #1a1a1b;--font-heading: "Figtree", sans-serif;--font-body: "Inter", sans-serif;--container: 880px;--section-gap: 128px}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:auto}body{font-family:var(--font-body);font-weight:400;color:var(--color-text);background-color:var(--color-bg);line-height:1.6;overflow-x:hidden}body.ready{opacity:1}body.loading{overflow:hidden}img{display:block;max-width:100%;height:auto}a{color:inherit;text-decoration:none}button{font:inherit;color:inherit;background:none;border:none;cursor:pointer;outline:none}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;line-height:1.15}::selection{background:#fff3;color:#fff}.container{width:100%;max-width:var(--container);margin:0 auto}main{display:flex;flex-direction:column;gap:128px;padding-bottom:128px}.section__grid{display:grid;grid-template-columns:310px 1fr;gap:var(--section-gap);align-items:start}.section__label{position:sticky;top:120px}.section__label-text{font-family:var(--font-heading);font-size:15px;font-weight:500;color:var(--color-text)}.section__content{max-width:100%}.bottom-nav{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:100;display:flex;align-items:center;gap:0;background:#1a1a1b;border-radius:50px;padding:8px 6px;box-shadow:0 4px 24px #0000004d,0 1px 4px #0003;border:1px solid #2b2b2b}.bottom-nav__link{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;color:var(--color-text-light);transition:color .3s ease,background .3s ease}.bottom-nav__link:hover,.bottom-nav__link.active{color:var(--color-text)}.bottom-nav__link svg{width:18px;height:18px}.project__item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:20px;cursor:pointer;transition:background .25s ease,border-color .25s ease}.project__item:hover{background:#1f1f20;border-color:#3a3a3a}.project__item__icon{width:44px;height:44px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.project__item__icon-letter{font-family:var(--font-heading);font-size:18px;font-weight:700;color:#ffffff80}.project__item__icon-svg{width:28px;height:28px;color:#ffffff80}.project__item__info{display:flex;flex-direction:column;gap:2px;min-width:0}.project__item__name,.project__item__subtitle{line-height:normal}.project__item__name{font-family:var(--font-heading);font-weight:600;color:var(--color-text)}.project__item__subtitle{font-size:14px;color:var(--color-text-muted);font-weight:400}.project-modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;pointer-events:none}.project-modal__overlay{position:absolute;inset:0;background:#0009;opacity:0}.project-modal__content{position:relative;background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:20px;max-width:720px;width:90%;max-height:80vh;overflow-y:auto;overscroll-behavior:contain;padding:40px}.project-modal__close{position:absolute;top:16px;right:20px;font-size:26px;color:var(--color-text-muted);transition:color .2s ease;line-height:1}.project-modal__close:hover{color:var(--color-text)}.project-modal__grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}.project-modal__image{display:none;aspect-ratio:4 / 3;border-radius:6px;background:var(--color-card-bg)}.project-modal__info{display:flex;flex-direction:column;gap:18px}.project-modal__icon{width:44px;height:44px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.project-modal__icon svg{width:28px;height:28px;color:#ffffff80}.project-modal__detail{display:flex;flex-direction:column;gap:3px}.project-modal__detail-label{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted)}.project-modal__detail-value{font-size:15px;font-weight:500;color:var(--color-text)}.experience__list{display:flex;flex-direction:column;gap:24px}.experience-entry{border-bottom:1px solid var(--color-border);display:grid;grid-template-columns:1fr auto;gap:16px;align-items:start;padding-bottom:24px}.experience-entry__header{display:flex;align-items:center;gap:12px}.experience-entry__logo{width:38px;height:38px;border-radius:8px;flex-shrink:0}.experience-entry__role,.experience-entry__company{line-height:normal}.experience-entry__role{font-family:var(--font-heading);font-weight:600;margin-bottom:2px}.experience-entry__company{font-size:14px;color:var(--color-text-muted);font-weight:500}.experience-entry__description{grid-column:1 / -1;font-size:14px;color:var(--color-text-muted);line-height:1.6;max-width:480px}.experience-entry__period{font-size:13px;color:var(--color-text-light);white-space:nowrap}.proficiency-group{padding:24px 0;border-bottom:1px solid var(--color-border);display:grid;grid-template-columns:160px 1fr;gap:16px;align-items:baseline}.proficiency-group:first-child{border-top:none;padding-top:0}.proficiency-group__label{font-family:var(--font-heading);font-size:14px;font-weight:600}.proficiency-group__items{display:flex;flex-direction:column;gap:6px;font-size:14px;color:var(--color-text-muted)}.contact__badge{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--color-text-secondary)}.contact__badge-dot{width:8px;height:8px;border-radius:50%;background:#4caf50;animation:pulse 1.4s ease-out infinite}@keyframes pulse{0%{box-shadow:0 0 #4caf5099}70%{box-shadow:0 0 0 6px #4caf5000}to{box-shadow:0 0 #4caf5000}}.social-link{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1px solid var(--color-border);transition:border-color .3s ease,background .3s ease}.social-link:hover{border-color:#ffffff4d;background:#ffffff1a}.social-link__icon{width:20px;height:20px;color:var(--color-text-muted);transition:color .3s ease}.social-link__icon--x{width:18px;height:18px}.social-link:hover .social-link__icon{color:var(--color-text)}.hero{display:flex;align-items:center;padding-top:150px}.hero__left{padding-top:20px}.hero__signature{margin-bottom:48px}.hero__signature-svg{width:130px;height:120px}.hero__contact{display:flex;flex-direction:column}.hero__contact-item{font-size:14px;color:var(--color-text);line-height:1.6}.hero__right{display:flex;flex-direction:column;gap:40px}.hero__portrait-area{position:relative;width:200px;height:260px}.hero__portrait{position:absolute;width:200px;height:260px;border-radius:32px;overflow:hidden;z-index:2}.hero__portrait-img{width:100%;height:100%;object-fit:cover;display:block}.about__description{font-size:15px;line-height:1.75;color:var(--color-text);margin-bottom:24px}.about__detail{font-size:15px;line-height:1.75;color:var(--color-text-muted)}.projects__background{position:relative;border-radius:16px}.projects__background:before{content:"";position:absolute;inset:0;border-radius:16px;background-image:radial-gradient(circle,var(--color-border) 1px,transparent 1px);background-size:24px 24px;opacity:.4;pointer-events:none}.projects__grid{display:flex;flex-direction:column;gap:12px;position:relative;z-index:1}.contact__heading{font-size:15px;line-height:1.75;color:var(--color-text);margin-bottom:32px;max-width:420px}.contact__details{display:flex;flex-direction:column;gap:6px;margin-bottom:40px}.contact__detail-value{font-size:14px;color:var(--color-text)}.contact__detail-link{border-bottom:1px solid var(--color-border);transition:border-color .3s ease}.contact__detail-link:hover{border-color:var(--color-text)}.contact__bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid var(--color-border)}.contact__socials{display:flex;gap:10px}@media(max-width:1200px){:root{--section-gap: 50px}main{gap:80px}.section__grid{grid-template-columns:160px 1fr}.hero__portrait-area{width:300px;height:300px}.hero__portrait{width:180px;height:230px}}@media(max-width:810px){:root{--section-gap: 32px}main{gap:60px;padding-bottom:100px}.container{padding:0 24px}.section__grid{grid-template-columns:1fr;gap:20px}.section__label{position:static}.hero__left{order:2;padding-top:0;display:flex;gap:32px;align-items:flex-start}.hero__signature{margin-bottom:0;flex-shrink:0}.hero__contact{flex-direction:row;gap:16px;flex-wrap:wrap}.hero__right{order:1}.hero__portrait-area{width:280px;height:280px}.hero__portrait{width:170px;height:220px}.projects__grid{gap:10px}.project-modal__grid{grid-template-columns:1fr;gap:20px}.experience-entry,.proficiency-group{grid-template-columns:1fr;gap:8px}}@media(max-width:640px){.container{padding:0 20px}.hero{padding-top:48px;min-height:auto}.hero__left{flex-direction:column;gap:20px}.hero__contact{flex-direction:column;gap:4px}.hero__portrait-area,.hero__portrait{width:150px;height:190px}.project__item{padding:12px 14px}.project__item__icon-letter{font-size:16px}.contact__bottom{flex-direction:column;gap:16px;align-items:flex-start}.bottom-nav{bottom:16px;padding:6px 4px}.bottom-nav__link{width:34px;height:34px}.bottom-nav__link svg{width:16px;height:16px}.project-modal__content{padding:28px 20px}}
