.portfolio{color:#f5f1e8;background-color:#101010;width:100vw;height:100vh;overflow:hidden}.portfolio__track{will-change:transform;width:max-content;height:100vh;display:flex}.portfolio__section{flex-shrink:0;width:100vw;height:100vh;display:flex;position:relative;overflow:hidden}.portfolio__section:before{content:"";opacity:.6;pointer-events:none;background:radial-gradient(circle at 20% 20%,#ffffff1f,#0000 28%),radial-gradient(circle at 80% 80%,#ffffff14,#0000 32%);position:absolute;inset:0}.portfolio__section--hero{color:#f5f1e8;background-color:#101010}.portfolio__section--about{color:#161616;background-color:#efe7da}.portfolio__section--projects{color:#f3efe6;background-color:#16211f}.portfolio__section--skills{color:#121212;background-color:#e7e7df}.portfolio__section--contact{color:#f5f1e8;background-color:#12151c}.portfolio__section-content{z-index:1;flex-direction:column;justify-content:center;align-items:center;width:min(1120px,100% - 48px);margin:0 auto;padding:72px 0;display:flex;position:relative}.portfolio__section--hero .portfolio__section-content{justify-content:flex-start;padding-top:160px}.portfolio__intro{align-items:center;gap:36px;display:flex}.portfolio__photo{background-color:#f5f1e814;border:1px solid #f5f1e880;border-radius:999px;flex-shrink:0;width:156px;height:204px;overflow:hidden}.portfolio__photo-image{object-fit:cover;width:100%;height:100%;display:block}.portfolio__photo-placeholder{letter-spacing:-.08em;opacity:.7;justify-content:center;align-items:center;width:100%;height:100%;font-size:42px;display:flex}.portfolio__intro-text{flex-direction:column;display:flex}.portfolio__eyebrow{letter-spacing:.16em;text-transform:uppercase;opacity:.6;margin:0 0 20px;font-size:13px;line-height:1}.portfolio__title{letter-spacing:-.08em;max-width:760px;margin:0 0 8px;font-size:clamp(48px,8vw,112px);line-height:.9}.portfolio__section--hero .portfolio__title{font-size:clamp(54px,8vw,118px)}.portfolio__subtitle{letter-spacing:-.04em;opacity:.76;max-width:560px;margin:18px 0 0;font-size:clamp(18px,2vw,28px);line-height:1.3}.portfolio__hint{letter-spacing:.08em;text-transform:uppercase;opacity:.48;margin:0;font-size:13px;position:absolute;bottom:72px;right:0}@media screen and (width<=1000px),screen and (height<=760px){.portfolio__section{overflow:hidden auto}.portfolio__section-content{justify-content:flex-start;min-height:100vh;padding-top:72px;padding-bottom:128px}}@media screen and (width<=720px){.portfolio__section--hero{padding-left:30px}.portfolio__section--hero .portfolio__section-content{padding-top:70px}.portfolio__section-content{justify-content:flex-start;align-items:flex-start;width:min(100% - 32px,1120px);min-height:100vh;padding-bottom:120px}.portfolio__intro{flex-direction:column;align-items:flex-start;gap:24px}.portfolio__photo{width:120px;height:154px}.portfolio__title{font-size:clamp(44px,15vw,76px)}.portfolio__hint{max-width:220px;line-height:1.4;bottom:24px;right:auto}}.section-controls{z-index:10;color:inherit;transition:top .35s ease-out,bottom .35s ease-out,transform .35s ease-out;display:flex}.section-controls--hero{flex-direction:column;align-items:flex-start;gap:16px;position:fixed;top:55%;left:max(24px,50vw - 560px)}.section-controls--bottom{color:#141414;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background-color:#f5f1e8b8;border:1px solid #14141424;border-radius:999px;flex-direction:row;align-items:center;gap:14px;padding:12px 18px;position:fixed;bottom:32px;right:50%;transform:translate(50%);box-shadow:0 18px 60px #00000029}.section-controls__button{color:inherit;font:inherit;cursor:pointer;background-color:#0000;border:0;align-items:center;gap:14px;padding:0;display:flex;position:relative}.section-controls--hero .section-controls__button{letter-spacing:-.03em;opacity:.65;justify-content:flex-start;min-width:220px;padding:12px 0;font-size:18px;transition:opacity .25s,transform .25s}.section-controls--hero .section-controls__button:hover{opacity:1;transform:translate(8px)}.section-controls--bottom .section-controls__button{justify-content:center;width:26px;height:18px}.section-controls__dot{opacity:.75;border:1px solid;border-radius:999px;width:8px;height:8px;transition:width .25s,opacity .25s,border-color .25s;display:block;position:relative}.section-controls__button--active .section-controls__dot{opacity:1;background-color:#0000;width:22px;height:8px}.section-controls__active-indicator{background-color:currentColor;border-radius:999px;position:absolute;inset:-1px}.section-controls__label{font-size:18px}.section-controls__number{opacity:0;font-size:10px;transition:opacity .25s;position:absolute;top:-24px;left:50%;transform:translate(-50%)}.section-controls--bottom .section-controls__button:hover .section-controls__number{opacity:.75}.section-controls__counter{color:#141414;letter-spacing:.12em;opacity:.85;white-space:nowrap;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background-color:#f5f1e8b8;border-radius:999px;margin:0;padding:4px 8px;font-size:12px;position:absolute;top:-34px;left:50%;transform:translate(-50%)}@media screen and (width<=720px){.section-controls--hero{bottom:48px;left:44px}.section-controls--bottom{bottom:24px}}@media screen and (width<=720px),screen and (height<=760px){.section-controls--bottom{padding:10px 14px;bottom:18px}.section-controls__counter{display:none}}.about{grid-template-columns:minmax(0,1fr) 360px;align-items:center;gap:72px;width:100%;display:grid}.about__content{max-width:720px}.about__eyebrow{letter-spacing:.16em;text-transform:uppercase;opacity:.62;margin:0 0 18px;font-size:13px;line-height:1}.about__title{letter-spacing:-.07em;max-width:780px;margin:0;font-size:clamp(38px,5vw,72px);line-height:.95}.about__text{flex-direction:column;gap:22px;max-width:650px;margin-top:36px;display:flex}.about__paragraph{letter-spacing:-.03em;opacity:.78;margin:0;font-size:clamp(17px,1.45vw,21px);line-height:1.55}.about__stack{flex-direction:column;gap:14px;display:flex}.about__card{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background-color:#ffffff61;border:1px solid #16161624;border-radius:24px;padding:18px;transition:transform .25s,border-color .25s,background-color .25s;box-shadow:0 18px 60px #00000014}.about__card:hover{background-color:#ffffff8f;border-color:#16161647;transform:translate(-8px)}.about__card-header{align-items:center;gap:14px;display:flex}.about__card-icon{letter-spacing:-.04em;text-transform:uppercase;border:1px solid #16161629;border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;font-size:13px;font-weight:700;display:flex}.about__card-title{letter-spacing:-.04em;margin:0;font-size:20px;line-height:1}.about__card-label{letter-spacing:.12em;text-transform:uppercase;opacity:.58;margin:6px 0 0;font-size:12px;line-height:1}.about__card-description{letter-spacing:-.02em;opacity:.72;margin:14px 0 0;font-size:14px;line-height:1.45}@media screen and (width<=900px){.about{grid-template-columns:1fr;align-items:start;gap:40px;padding-bottom:80px}.about__content{max-width:none}.about__stack{grid-template-columns:repeat(2,minmax(0,1fr));display:grid}}@media screen and (width<=560px){.about{gap:32px;padding-bottom:96px}.about__text{gap:18px;margin-top:28px}.about__stack{grid-template-columns:1fr}.about__card{border-radius:20px;padding:16px}}.projects{grid-template-rows:auto minmax(0,1fr);gap:34px;width:100%;display:grid}.projects__header{max-width:760px}.projects__eyebrow{letter-spacing:.16em;text-transform:uppercase;opacity:.62;margin:0 0 18px;font-size:13px;line-height:1}.projects__title{letter-spacing:-.065em;max-width:780px;margin:0;font-size:clamp(36px,4.6vw,68px);line-height:.98}.projects__intro{letter-spacing:-.03em;opacity:.72;max-width:620px;margin:22px 0 0;font-size:clamp(16px,1.25vw,19px);line-height:1.5}.projects__grid{grid-template-columns:repeat(3,minmax(0,1fr));align-items:center;gap:18px;min-height:330px;display:grid}.projects__card{color:#f5f1e8;background:radial-gradient(circle at 20% 20%,#f5f1e824,#0000 34%),#f5f1e812;border:1px solid #f5f1e829;border-radius:30px;min-height:230px;transition:min-height .38s,transform .38s,border-color .38s,box-shadow .38s,background-color .38s;position:relative;overflow:hidden;transform:scale(1);box-shadow:0 20px 70px #0003}.projects__card:hover{z-index:5;border-color:#f5f1e852;min-height:360px;transform:translateY(-18px)scale(1.06);box-shadow:0 30px 110px #00000057}.projects__image{object-fit:cover;filter:saturate(.85)brightness(.56)blur(4px);opacity:0;width:100%;height:100%;transition:opacity .38s,filter .38s,transform .38s;display:block;position:absolute;inset:0;transform:scale(1.08)}.projects__card:hover .projects__image{opacity:1;filter:saturate(.9)brightness(.62)blur(3px);transform:scale(1.14)}.projects__overlay{background:linear-gradient(#0c0e0e1a 0%,#0c0e0e99 100%);flex-direction:column;justify-content:space-between;padding:24px;display:flex;position:absolute;inset:0}.projects__card-main{z-index:1;max-width:420px;position:relative}.projects__type{letter-spacing:.14em;text-transform:uppercase;opacity:.68;margin:0 0 12px;font-size:11px;line-height:1}.projects__card-title{letter-spacing:-.07em;margin:0;font-size:clamp(30px,3.2vw,48px);line-height:.95}.projects__details{z-index:1;opacity:0;transition:opacity .35s,transform .35s;position:relative;transform:translateY(18px)}.projects__card:hover .projects__details{opacity:1;transform:translateY(0)}.projects__description{letter-spacing:-.02em;opacity:.86;margin:0;font-size:14px;line-height:1.45}.projects__tech-list{flex-wrap:wrap;gap:7px;margin:16px 0 0;padding:0;list-style:none;display:flex}.projects__tech-item{letter-spacing:-.02em;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background-color:#f5f1e81a;border:1px solid #f5f1e838;border-radius:999px;padding:7px 9px;font-size:11px;line-height:1}.projects__links{gap:10px;margin-top:20px;display:flex}.projects__link{color:#121212;background-color:#f5f1e8eb;border:1px solid #f5f1e852;border-radius:999px;justify-content:center;align-items:center;min-height:38px;padding:0 15px;font-size:13px;line-height:1;text-decoration:none;transition:background-color .25s,color .25s,transform .25s;display:inline-flex}.projects__link:hover{transform:translateY(-2px)}.projects__link--secondary{color:#f5f1e8;background-color:#0000}@media screen and (width<=1100px){.projects{gap:30px;padding-bottom:96px}.projects__grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch;min-height:0}.projects__card{min-height:320px}.projects__card:hover{min-height:320px;transform:translateY(-6px)scale(1.02)}.projects__image{opacity:1;filter:saturate(.85)brightness(.48)blur(4px)}.projects__details{opacity:1;transform:none}}@media screen and (width<=720px){.projects__grid{grid-template-columns:1fr}.projects__card{min-height:360px}.projects__card:hover{min-height:360px;transform:translateY(-4px)}}@media screen and (width<=560px){.projects{gap:26px;padding-bottom:112px}.projects__overlay{padding:22px}.projects__card{border-radius:26px;min-height:380px}.projects__links{flex-wrap:wrap}.projects__link{flex:1}}.skills{grid-template-columns:1.15fr .85fr;align-items:center;gap:48px;width:100%;display:grid}.skills__header{max-width:680px}.skills__eyebrow{letter-spacing:.16em;text-transform:uppercase;opacity:.62;margin:0 0 18px;font-size:13px;line-height:1}.skills__title{letter-spacing:-.055em;margin:0;font-size:clamp(40px,4.6vw,74px);line-height:1}.skills__intro{letter-spacing:-.03em;opacity:.72;max-width:520px;margin:28px 0 0;font-size:clamp(16px,1.35vw,20px);line-height:1.55}.skills__list{flex-direction:column;justify-self:end;gap:10px;width:min(100%,560px);display:flex}.skills__item{color:#121212;cursor:default;background-color:#ffffff57;border:1px solid #1212121f;border-radius:24px;outline:none;min-height:130px;padding:18px 22px;transition:transform .32s,background-color .32s,border-color .32s,box-shadow .32s;display:flex;position:relative;overflow:hidden;box-shadow:0 18px 60px #0000000f}.skills__item:before{content:"";opacity:0;pointer-events:none;background:radial-gradient(circle at 12%,#1212121c,#0000 30%),linear-gradient(135deg,#12121214,#0000 50%);transition:opacity .35s;position:absolute;inset:0}.skills__item:hover,.skills__item:focus-visible{background-color:#ffffffbd;border-color:#12121242;transform:translate(-8px)scale(1.01);box-shadow:0 24px 80px #0000001f}.skills__item:hover:before,.skills__item:focus-visible:before{opacity:1}.skills__item-main{z-index:2;align-items:center;gap:16px;min-height:42px;display:flex;position:relative}.skills__number{letter-spacing:.08em;opacity:.78;border:1px solid #12121229;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:11px;display:flex}.skills__item-title{letter-spacing:-.06em;margin:0;font-size:clamp(30px,3.2vw,48px);line-height:.95;transition:opacity .25s,transform .25s}.skills__item:hover .skills__item-title,.skills__item:focus-visible .skills__item-title{opacity:0;transform:translate(18px)}.skills__item-details{z-index:3;opacity:0;pointer-events:none;transition:opacity .28s,transform .28s;position:absolute;top:50%;left:78px;right:20px;transform:translateY(-40%)}.skills__item:hover .skills__item-details,.skills__item:focus-visible .skills__item-details{opacity:1;transform:translateY(-50%)}.skills__description{letter-spacing:-.02em;opacity:.78;margin:0;font-size:13px;line-height:1.35}.skills__tech-list{flex-wrap:wrap;gap:6px;margin:10px 0 0;padding:0;list-style:none;display:flex}.skills__tech-item{letter-spacing:-.02em;background-color:#1212120f;border:1px solid #12121229;border-radius:999px;padding:6px 8px;font-size:11px;line-height:1}@media screen and (width<=1000px){.skills{grid-template-columns:1fr;align-items:start;gap:36px;padding-bottom:92px}.skills__header{max-width:720px}.skills__list{justify-self:stretch;width:100%}.skills__item{gap:12px;min-height:auto;padding:18px}.skills__item-main{margin-bottom:14px}.skills__item-title{opacity:1;transform:none}.skills__item-details{opacity:1;pointer-events:auto;position:static;transform:none}.skills__item:hover,.skills__item:focus-visible{transform:translateY(-4px)}.skills__item:hover .skills__item-title,.skills__item:focus-visible .skills__item-title{opacity:1;transform:none}.skills__item:hover .skills__item-details,.skills__item:focus-visible .skills__item-details{transform:none}}@media screen and (width<=560px){.skills{gap:28px;padding-bottom:108px}.skills__item{border-radius:22px;flex-direction:column}.skills__item-main{gap:14px}.skills__number{width:40px;height:40px;font-size:11px}.skills__item-title{font-size:clamp(30px,12vw,48px)}}.contact{grid-template-columns:1fr 430px;align-items:center;gap:72px;width:100%;display:grid}.contact__content{max-width:720px}.contact__eyebrow{letter-spacing:.16em;text-transform:uppercase;opacity:.62;margin:0 0 18px;font-size:13px;line-height:1}.contact__title{letter-spacing:-.08em;max-width:780px;margin:0;font-size:clamp(44px,5.6vw,86px);line-height:.94}.contact__description{letter-spacing:-.03em;opacity:.76;max-width:620px;margin:30px 0 0;font-size:clamp(17px,1.45vw,21px);line-height:1.55}.contact__meta{flex-wrap:wrap;gap:10px;margin-top:32px;display:flex}.contact__meta-item{letter-spacing:-.01em;opacity:.82;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background-color:#f5f1e814;border:1px solid #f5f1e829;border-radius:999px;margin:0;padding:10px 14px;font-size:13px;line-height:1}.contact__actions{flex-direction:column;gap:16px;display:flex}.contact__card{color:#f5f1e8;background-color:#f5f1e814;border:1px solid #f5f1e829;border-radius:32px;grid-template-columns:64px 1fr;align-items:center;gap:18px;min-height:150px;padding:24px;text-decoration:none;transition:transform .3s,background-color .3s,border-color .3s,box-shadow .3s;display:grid;position:relative;overflow:hidden;box-shadow:0 24px 80px #00000038}.contact__card:before{content:"";opacity:0;background:radial-gradient(circle at 15% 20%,#f5f1e833,#0000 28%),linear-gradient(135deg,#f5f1e829,#0000 58%);transition:opacity .3s;position:absolute;inset:0}.contact__card:hover{background-color:#f5f1e824;border-color:#f5f1e857;transform:translate(-10px)scale(1.015);box-shadow:0 28px 100px #0000004d}.contact__card:hover:before{opacity:1}.contact__card-icon{z-index:1;background-color:#f5f1e81a;border:1px solid #f5f1e838;border-radius:22px;justify-content:center;align-items:center;width:64px;height:64px;font-size:28px;line-height:1;display:flex;position:relative}.contact__card-info{z-index:1;flex-direction:column;min-width:0;display:flex;position:relative}.contact__card-label{letter-spacing:.14em;text-transform:uppercase;opacity:.58;margin-bottom:12px;font-size:12px;line-height:1}.contact__card-title{letter-spacing:-.07em;font-size:clamp(30px,3vw,44px);line-height:.95}.contact__card-value{letter-spacing:-.02em;opacity:.72;text-overflow:ellipsis;white-space:nowrap;margin-top:10px;font-size:14px;line-height:1.2;overflow:hidden}.contact__socials{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.contact__social-link{color:#f5f1e8;background-color:#f5f1e80f;border:1px solid #f5f1e824;border-radius:999px;justify-content:center;align-items:center;min-height:58px;font-size:14px;line-height:1;text-decoration:none;transition:transform .25s,background-color .25s,border-color .25s;display:flex}.contact__social-link:hover{background-color:#f5f1e81f;border-color:#f5f1e847;transform:translateY(-3px)}@media screen and (width<=960px){.contact{grid-template-columns:1fr;gap:42px;padding-bottom:96px}.contact__content{max-width:760px}.contact__actions{max-width:640px}}@media screen and (width<=560px){.contact{gap:34px;padding-bottom:108px}.contact__title{font-size:clamp(42px,13vw,70px)}.contact__card{border-radius:26px;grid-template-columns:52px 1fr;gap:14px;min-height:128px;padding:18px}.contact__card-icon{border-radius:18px;width:52px;height:52px;font-size:24px}.contact__card-title{font-size:30px}.contact__socials{grid-template-columns:1fr}}*{box-sizing:border-box}html,body,#root{background-color:#101010;width:100%;min-height:100%;margin:0}body{background-color:#101010;font-family:Arial,Helvetica,sans-serif;overflow:hidden}html{scroll-behavior:auto}button,input,textarea,select{font:inherit}
