:root{--bg: #070b14;--bg-2: #0a0f1c;--surface: rgba(255, 255, 255, .035);--surface-2: rgba(255, 255, 255, .06);--border: rgba(255, 255, 255, .09);--border-strong: rgba(255, 255, 255, .16);--text: #e8eef7;--muted: #abb6cb;--muted-2: #7c8aa3;--accent: #10b981;--accent-2: #2dd4bf;--accent-3: #6366f1;--grad: linear-gradient(120deg, #2dd4bf 0%, #10b981 45%, #6366f1 110%);--grad-soft: linear-gradient(120deg, rgba(45, 212, 191, .16), rgba(99, 102, 241, .16));--radius: 18px;--radius-sm: 12px;--radius-lg: 28px;--maxw: 1140px;--shadow: 0 24px 60px -20px rgba(0, 0, 0, .6);--shadow-glow: 0 0 0 1px var(--border), 0 30px 80px -30px rgba(16, 185, 129, .35);--font: "Inter", system-ui, -apple-system, sans-serif;--font-head: "Sora", "Inter", system-ui, sans-serif}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:90px}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}::selection{background:#10b9814d;color:#fff}.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,40px)}.grad{background:var(--grad);background-size:220% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:gradFlow 9s ease-in-out infinite}@keyframes gradFlow{0%{background-position:0% center}50%{background-position:100% center}to{background-position:0% center}}.bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;overflow:hidden;background:radial-gradient(1200px 700px at 80% -10%,rgba(16,185,129,.08),transparent 60%),radial-gradient(900px 600px at 0% 100%,rgba(99,102,241,.08),transparent 55%),var(--bg)}.bg-grid{position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:56px 56px;-webkit-mask-image:radial-gradient(ellipse 90% 70% at 50% 0%,#000 30%,transparent 75%);mask-image:radial-gradient(ellipse 90% 70% at 50% 0%,#000 30%,transparent 75%)}.blob{position:absolute;border-radius:50%;filter:blur(90px);opacity:.55;will-change:transform}.blob-1{width:520px;height:520px;top:-120px;right:-80px;background:radial-gradient(circle,#10b981,transparent 70%);animation:drift1 22s ease-in-out infinite}.blob-2{width:460px;height:460px;top:30%;left:-140px;background:radial-gradient(circle,#6366f1,transparent 70%);animation:drift2 26s ease-in-out infinite}.blob-3{width:420px;height:420px;bottom:-120px;left:45%;background:radial-gradient(circle,#2dd4bf,transparent 70%);opacity:.35;animation:drift3 30s ease-in-out infinite}@keyframes drift1{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-60px,50px) scale(1.1)}}@keyframes drift2{0%,to{transform:translate(0) scale(1)}50%{transform:translate(70px,-40px) scale(1.08)}}@keyframes drift3{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-50px,-30px) scale(1.12)}}.bg-noise{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}.bg-vignette{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 40%,transparent 55%,rgba(0,0,0,.55) 100%)}.nav{position:fixed;top:0;left:0;right:0;z-index:50;transition:all .35s ease}.nav__inner{max-width:var(--maxw);margin:0 auto;padding:18px clamp(20px,5vw,40px);display:flex;align-items:center;justify-content:space-between}.nav--scrolled .nav__inner{padding-top:12px;padding-bottom:12px}.nav--scrolled{background:#070b14b8;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}.nav__brand{display:flex;align-items:center;gap:12px;font-family:var(--font-head);font-weight:700}.nav__mono{display:grid;place-items:center;width:38px;height:38px;border-radius:11px;background:var(--grad);color:#04130d;font-weight:800;font-size:.95rem;letter-spacing:.5px;box-shadow:0 8px 24px -8px #10b98199}.nav__name{font-size:1rem}.nav__links{display:flex;align-items:center;gap:28px}.nav__links>a{font-size:.92rem;color:var(--muted);font-weight:500;transition:color .2s;position:relative}.nav__links>a:hover{color:var(--text)}.nav__links>a.btn--primary{color:#04130d}.nav__links>a.btn--primary:hover{color:#04130d}.nav__socials{display:flex;gap:12px;color:var(--muted)}.nav__socials a:hover{color:var(--accent-2)}.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}.nav__burger span{width:24px;height:2px;background:var(--text);border-radius:2px;transition:all .3s}.nav__burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.nav__burger.is-open span:nth-child(2){opacity:0}.nav__burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.btn{display:inline-flex;align-items:center;gap:10px;padding:13px 22px;border-radius:999px;font-family:var(--font);font-weight:600;font-size:.95rem;cursor:pointer;border:1px solid transparent;transition:transform .2s ease,box-shadow .25s ease,background .25s ease,border-color .25s;white-space:nowrap}.btn svg{width:18px;height:18px}.btn--primary{background:var(--grad);color:#04130d;box-shadow:0 12px 30px -10px #10b9818c}.btn--primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px -12px #10b981b3}.btn--ghost{background:var(--surface);color:var(--text);border-color:var(--border-strong);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btn--ghost:hover{transform:translateY(-2px);border-color:var(--accent-2);background:var(--surface-2)}.btn--sm{padding:9px 16px;font-size:.85rem}.btn--lg{padding:15px 26px;font-size:1rem}.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:130px 0 80px;position:relative}.hero__inner{max-width:880px;padding:0 clamp(20px,5vw,40px)}.hero__avatar{width:132px;height:132px;margin:0 auto 26px;border-radius:50%;padding:3px;background:var(--grad);box-shadow:0 0 0 6px #10b98114,0 20px 55px -18px #10b98199}.hero__avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover;border:3px solid var(--bg);display:block}.hero__status{display:inline-flex;align-items:center;gap:10px;padding:8px 16px;border-radius:999px;background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:#6ee7b7;font-size:.85rem;font-weight:600;margin-bottom:28px}.hero__dot{width:8px;height:8px;border-radius:50%;background:#34d399;box-shadow:0 0 #34d39999;animation:pulse 2.2s infinite}@keyframes pulse{0%{box-shadow:0 0 #34d3998c}70%{box-shadow:0 0 0 10px #34d39900}to{box-shadow:0 0 #34d39900}}.hero__title{position:relative;font-family:var(--font-head);font-weight:800;font-size:clamp(2.4rem,6.2vw,4.4rem);line-height:1.05;letter-spacing:-.02em;margin-bottom:24px}.hero__title:before{content:"";position:absolute;top:-34%;right:-12%;bottom:-34%;left:-12%;z-index:-1;background:radial-gradient(48% 50% at 50% 50%,rgba(16,185,129,.2),transparent 72%);filter:blur(22px);pointer-events:none}.hero__lead{font-size:clamp(1.02rem,1.6vw,1.2rem);color:var(--muted);max-width:660px;margin:0 auto 18px}.hero__meta{display:inline-flex;align-items:center;gap:8px;color:var(--muted-2);font-size:.92rem;margin-bottom:34px}.hero__meta svg{width:16px;height:16px}.hero__actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:26px}.hero__socials{display:flex;gap:14px;justify-content:center;margin-bottom:56px}.hero__socials a{display:grid;place-items:center;width:46px;height:46px;border-radius:12px;background:var(--surface);border:1px solid var(--border);color:var(--muted);transition:all .25s}.hero__socials a:hover{color:var(--text);border-color:var(--accent-2);transform:translateY(-3px)}.hero__stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:26px;border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.stat__value{font-family:var(--font-head);font-weight:800;font-size:clamp(1.5rem,3vw,2.1rem);line-height:1}.stat__label{font-size:.8rem;color:var(--muted-2);margin-top:8px}.hero__scroll{position:absolute;bottom:28px;left:50%;transform:translate(-50%);width:26px;height:42px;border:2px solid var(--border-strong);border-radius:14px;display:grid;justify-items:center;padding-top:8px}.hero__scroll span{width:4px;height:8px;border-radius:4px;background:var(--accent-2);animation:scrolldot 1.8s infinite}@keyframes scrolldot{0%{transform:translateY(0);opacity:1}to{transform:translateY(14px);opacity:0}}.section{padding:clamp(70px,11vw,130px) 0;position:relative}.section--contact{padding-bottom:90px}.section__kicker{display:inline-flex;align-items:center;font-size:.82rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-2);margin-bottom:14px}.section__kicker:before{content:"";width:26px;height:2px;margin-right:12px;border-radius:2px;background:var(--grad)}.section__title{font-family:var(--font-head);font-weight:700;font-size:clamp(1.8rem,4vw,2.8rem);line-height:1.12;letter-spacing:-.02em;max-width:760px}.section__lead{color:var(--muted);font-size:1.05rem;max-width:620px;margin-top:18px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:inset 0 1px #ffffff0d}.card__title{font-family:var(--font-head);font-size:1.05rem;margin-bottom:16px}.chips{display:flex;flex-wrap:wrap;gap:9px}.chip{font-size:.82rem;font-weight:500;padding:6px 13px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border);color:#cdd7e6}.chip--accent{background:#10b9811f;border-color:#10b98159;color:#6ee7b7}.about__grid{display:grid;grid-template-columns:1.5fr 1fr;gap:32px;margin-top:48px;align-items:start}.about__text p{color:var(--muted);margin-bottom:18px;font-size:1.04rem}.about__text strong{color:var(--text)}.about__features{margin-top:26px;display:grid;grid-template-columns:1fr 1fr;gap:12px}.feature{display:flex;align-items:flex-start;gap:12px;padding:15px 16px;border-radius:14px;background:var(--surface);border:1px solid var(--border);box-shadow:inset 0 1px #ffffff0d;color:var(--muted);font-size:.92rem;line-height:1.45;transition:transform .2s ease,border-color .2s ease}.feature:hover{transform:translateY(-3px);border-color:var(--border-strong)}.feature__ico{display:grid;place-items:center;width:36px;height:36px;flex-shrink:0;border-radius:10px;background:var(--grad-soft);border:1px solid var(--border);color:var(--accent-2)}.feature__ico svg{width:19px;height:19px}.about__aside{display:grid;gap:18px}.lang{list-style:none;display:grid;gap:14px}.lang li{display:flex;align-items:center;gap:12px;padding-bottom:14px;border-bottom:1px solid var(--border)}.lang li:last-child{border-bottom:none;padding-bottom:0}.lang__flag{width:30px;height:21px;flex-shrink:0;border-radius:4px;overflow:hidden;border:1px solid rgba(255,255,255,.18);box-shadow:0 2px 6px #0006;transition:transform .2s ease}.lang li:hover .lang__flag{transform:scale(1.08)}.lang__flag svg{display:block;width:100%;height:100%}.lang__name{font-weight:600}.lang__level{margin-left:auto;font-size:.8rem;color:var(--muted-2);text-align:right}.dispo__status{display:inline-flex;align-items:center;gap:9px;font-size:.92rem;font-weight:600;color:#6ee7b7;margin-bottom:16px}.dispo__dot{width:9px;height:9px;border-radius:50%;background:#34d399;box-shadow:0 0 #34d39999;animation:pulse 2.2s infinite}.dispo__grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.dispo__item{display:flex;flex-direction:column;gap:2px;padding:11px 13px;border-radius:11px;background:#ffffff08;border:1px solid var(--border)}.dispo__k{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted-2)}.dispo__v{font-weight:600;font-size:.95rem;color:var(--text)}.skills__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}.skill-card{transition:transform .25s,border-color .25s,box-shadow .25s}.skill-card:hover{transform:translateY(-4px);border-color:var(--border-strong);box-shadow:var(--shadow)}.skill-card__head{display:flex;align-items:center;gap:14px;margin-bottom:18px}.skill-card__head h3{font-family:var(--font-head);font-size:1.1rem}.skill-card__icon{display:grid;place-items:center;width:44px;height:44px;border-radius:12px;background:var(--grad-soft);border:1px solid var(--border);color:var(--accent-2)}.skill-card__icon svg{width:22px;height:22px}.tech-list{display:flex;flex-wrap:wrap;gap:8px}.tech{display:inline-flex;align-items:center;gap:8px;padding:7px 12px 7px 10px;border-radius:10px;font-size:.84rem;font-weight:500;color:#d7e0ee;background:#ffffff0a;border:1px solid var(--border);transition:transform .18s ease,border-color .18s ease,background .18s ease}.tech:hover{transform:translateY(-2px);background:#ffffff12;border-color:var(--border-strong)}.tech__ico{display:grid;place-items:center;width:18px;height:18px;flex-shrink:0}.tech__svg{width:18px;height:18px}.featured{margin-top:48px;display:grid;grid-template-columns:1fr .95fr;gap:40px;align-items:center;padding:40px;border-radius:var(--radius-lg);background:radial-gradient(600px 300px at 100% 0%,rgba(16,185,129,.1),transparent 60%),var(--surface);border:1px solid rgba(45,212,191,.2);box-shadow:0 40px 90px -50px #10b98180,inset 0 1px #ffffff0f;overflow:hidden;transform:perspective(1400px) rotateX(var(--tx, 0deg)) rotateY(var(--ty, 0deg));transition:transform .25s ease,box-shadow .3s ease;will-change:transform}.badge{display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:5px 12px;border-radius:999px;background:#10b98124;border:1px solid rgba(16,185,129,.35);color:#6ee7b7;margin-bottom:20px}.featured__head{display:flex;align-items:center;gap:16px;margin-bottom:18px}.featured__logo{width:60px;height:60px;border-radius:16px;border:1px solid var(--border);object-fit:cover}.featured__name{font-family:var(--font-head);font-weight:800;font-size:1.9rem;letter-spacing:-.01em}.featured__subtitle{color:var(--accent-2);font-size:.92rem;font-weight:500}.featured__desc{color:var(--muted);margin-bottom:20px}.featured__list{list-style:none;display:grid;gap:11px;margin-bottom:22px}.featured__list li{display:flex;align-items:flex-start;gap:11px;color:var(--muted);font-size:.95rem}.featured__list svg{width:17px;height:17px;color:var(--accent);flex-shrink:0;margin-top:3px}.featured__gallery{position:relative;height:480px;display:flex;justify-content:center;align-items:center}.phone{position:absolute;width:200px;padding:0;cursor:pointer;border-radius:26px;overflow:hidden;border:5px solid #0d1422;box-shadow:0 30px 70px -20px #000000b3;background:#0d1422;transition:transform .4s ease,box-shadow .3s ease}.phone img{width:100%;border-radius:21px;display:block}.phone__zoom{position:absolute;left:50%;bottom:14px;transform:translate(-50%) translateY(6px);padding:7px 14px;border-radius:999px;font-size:.78rem;font-weight:600;color:#04130d;background:var(--grad);opacity:0;transition:opacity .25s,transform .25s;pointer-events:none;white-space:nowrap}.phone:hover .phone__zoom{opacity:1;transform:translate(-50%) translateY(0)}.phone--0{transform:translate(-92px,-22px) rotate(-7deg);z-index:2}.phone--1{transform:translate(78px,8px) rotate(6deg);z-index:1}.phone--2{transform:translate(-30px,40px) rotate(-2deg);z-index:3}.phone--3{display:none}.featured__gallery:hover .phone--0{transform:translate(-150px,-30px) rotate(-9deg)}.featured__gallery:hover .phone--1{transform:translate(140px,4px) rotate(8deg)}.featured__gallery:hover .phone--2{transform:translate(-5px,44px) rotate(0) scale(1.04)}.projects__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:24px;align-items:stretch}.projects__grid>.reveal,.skills__grid>.reveal{display:flex}.projects__grid>.reveal>*,.skills__grid>.reveal>*{width:100%}.project{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffff0d;transform:perspective(900px) rotateX(var(--tx, 0deg)) rotateY(var(--ty, 0deg)) translateY(var(--lift, 0px));transition:transform .2s ease,border-color .25s,box-shadow .25s;will-change:transform}.project:hover{--lift: -6px;border-color:var(--border-strong)}.project__cover{position:relative;width:100%;height:168px;padding:0;margin:0;border:none;border-bottom:1px solid var(--border);overflow:hidden;font:inherit;color:inherit;cursor:default;background:radial-gradient(120% 120% at 0% 0%,color-mix(in srgb,var(--accent) 30%,transparent),transparent 60%),linear-gradient(135deg,#ffffff0a,#ffffff03);display:grid;place-items:center}.project__cover--clickable{cursor:pointer}.project__cover-hint{position:absolute;bottom:12px;right:12px;z-index:2;display:inline-flex;align-items:center;gap:7px;padding:6px 12px;border-radius:999px;font-size:.76rem;font-weight:600;color:#fff;background:#070b149e;border:1px solid rgba(255,255,255,.18);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:0;transform:translateY(6px);transition:opacity .25s,transform .25s}.project__cover-hint svg{width:14px;height:14px}.project__cover--clickable:hover .project__cover-hint,.project__cover--clickable:focus-visible .project__cover-hint{opacity:1;transform:translateY(0)}.project__demo-badge--static{pointer-events:none}.project__cover:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,transparent 55%,rgba(7,11,20,.55))}.project__cover img{width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .5s ease}.project:hover .project__cover img{transform:scale(1.05)}.project__cover-mono{font-family:var(--font-head);font-weight:800;font-size:4.6rem;line-height:1;color:color-mix(in srgb,var(--accent) 80%,white 5%);opacity:.32;letter-spacing:-.03em;text-shadow:0 6px 30px color-mix(in srgb,var(--accent) 40%,transparent)}.project__body{padding:22px;display:flex;flex-direction:column;gap:12px;flex:1}.project__top{display:flex;align-items:center;gap:11px}.project__dot{width:11px;height:11px;border-radius:50%;background:var(--accent);box-shadow:0 0 14px var(--accent)}.project__name{font-family:var(--font-head);font-size:1.25rem;font-weight:700;flex:1}.project__link{color:var(--muted);transition:color .2s}.project__link:hover{color:var(--accent-2)}.project__subtitle{font-size:.86rem;color:var(--accent-2);font-weight:500;margin-top:-4px}.project__desc{color:var(--muted);font-size:.94rem;flex:1}.projects__more{text-align:center;margin-top:36px}.timeline-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-top:48px}.timeline__heading{font-family:var(--font-head);font-size:1.25rem;margin-bottom:28px;padding-bottom:14px;border-bottom:1px solid var(--border)}.timeline{position:relative;padding-left:32px}.timeline:before{content:"";position:absolute;left:6px;top:10px;bottom:10px;width:2px;border-radius:2px;background:linear-gradient(var(--accent) 0%,color-mix(in srgb,var(--accent-3) 70%,var(--accent)) 55%,transparent 100%)}.tl-item{position:relative;margin-bottom:16px;padding:18px 20px;background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:inset 0 1px #ffffff0d;transition:border-color .22s ease,box-shadow .22s ease}.tl-item:last-child{margin-bottom:0}.tl-item:hover{border-color:color-mix(in srgb,var(--accent) 40%,var(--border-strong));box-shadow:var(--shadow),0 14px 40px -26px #10b98199}.tl-item:after{content:"";position:absolute;left:-18px;top:27px;width:18px;height:2px;background:linear-gradient(to right,var(--accent),transparent)}.tl-item__dot{position:absolute;left:-32px;top:21px;width:14px;height:14px;border-radius:50%;background:var(--bg-2);border:2px solid var(--accent);box-shadow:0 0 0 4px #10b9811f,0 0 12px #10b981a6;z-index:1;transition:transform .22s ease,box-shadow .22s ease}.tl-item:hover .tl-item__dot{transform:scale(1.18);box-shadow:0 0 0 5px #10b98133,0 0 18px #10b981e6}.tl-item__period{display:inline-block;padding:4px 11px;border-radius:999px;background:#10b9811a;border:1px solid rgba(16,185,129,.28);color:#6ee7b7;font-size:.74rem;font-weight:600;letter-spacing:.02em;margin-bottom:10px}.tl-item__role{font-family:var(--font-head);font-size:1.08rem;font-weight:600}.tl-item__company{font-size:.9rem;color:var(--muted);margin-bottom:10px}.tl-item__detail{font-size:.9rem;color:var(--muted-2)}.tl-item__bullets{list-style:none;display:grid;gap:7px}.tl-item__bullets li{position:relative;padding-left:16px;font-size:.92rem;color:var(--muted)}.tl-item__bullets li:before{content:"";position:absolute;left:0;top:9px;width:5px;height:5px;border-radius:50%;background:var(--accent)}.section--contact .container{position:relative}.contact{text-align:center;padding:clamp(40px,6vw,70px) clamp(24px,5vw,60px);border-radius:var(--radius-lg);background:radial-gradient(700px 320px at 50% 0%,rgba(16,185,129,.12),transparent 65%),var(--surface);border:1px solid var(--border)}.contact .section__kicker,.contact .section__title{margin-left:auto;margin-right:auto}.contact .section__title{text-align:center}.contact__lead{margin:18px auto 34px;text-align:center}.contact__lead strong{color:var(--text)}.contact__actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:40px}.contact__cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:720px;margin:0 auto}.contact-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:22px 16px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);transition:transform .25s,border-color .25s}.contact-card:hover{transform:translateY(-4px);border-color:var(--accent-2)}.contact-card__icon{display:grid;place-items:center;width:44px;height:44px;border-radius:12px;background:var(--grad-soft);color:var(--accent-2);margin-bottom:6px}.contact-card__label{font-size:.78rem;color:var(--muted-2);text-transform:uppercase;letter-spacing:.08em}.contact-card__value{font-weight:600;font-size:.95rem;display:inline-flex;align-items:center;gap:6px}.contact-card__value svg{width:14px;height:14px}.footer{border-top:1px solid var(--border);padding:56px 0 30px;margin-top:40px;background:linear-gradient(to bottom,transparent,rgba(16,185,129,.03))}.footer__top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px;padding-bottom:36px;border-bottom:1px solid var(--border)}.footer__brand .nav__name{display:inline}.footer__tagline{color:var(--muted);font-size:.95rem;margin:16px 0 18px;line-height:1.6}.footer__socials{display:flex;gap:12px}.footer__socials a{display:grid;place-items:center;width:42px;height:42px;border-radius:11px;background:var(--surface);border:1px solid var(--border);color:var(--muted);transition:all .25s}.footer__socials a:hover{color:var(--text);border-color:var(--accent-2);transform:translateY(-3px)}.footer__nav,.footer__contact{display:flex;flex-direction:column;gap:11px}.footer__nav-title{font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-2);margin-bottom:6px}.footer__nav a,.footer__contact a{color:var(--muted);font-size:.94rem;transition:color .2s;width:fit-content}.footer__nav a:hover,.footer__contact a:hover{color:var(--text)}.footer__loc{color:var(--muted-2);font-size:.94rem}.footer__bottom{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:24px;color:var(--muted-2);font-size:.88rem}.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}.reveal.is-visible{opacity:1;transform:none}.scrollbar{position:fixed;top:0;left:0;right:0;height:3px;z-index:60;pointer-events:none;background:transparent}.scrollbar__fill{height:100%;background:var(--grad);box-shadow:0 0 12px #10b98199;transition:width .1s linear}.skip-link{position:fixed;top:10px;left:50%;transform:translate(-50%) translateY(-200%);z-index:200;padding:10px 18px;border-radius:999px;background:var(--accent);color:#04130d;font-weight:700;font-size:.9rem;transition:transform .2s ease}.skip-link:focus{transform:translate(-50%) translateY(0)}a:focus-visible,button:focus-visible{outline:2px solid var(--accent-2);outline-offset:3px;border-radius:6px}.nav__links>a.is-active{color:var(--text)}.nav__links>a:after{content:"";position:absolute;left:0;right:0;bottom:-7px;height:2px;border-radius:2px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .28s cubic-bezier(.22,1,.36,1)}.nav__links>a:hover:after,.nav__links>a.is-active:after{transform:scaleX(1)}.backtop{position:fixed;right:24px;bottom:24px;z-index:45;width:48px;height:48px;display:grid;place-items:center;border-radius:50%;cursor:pointer;color:#04130d;background:var(--grad);border:none;box-shadow:0 12px 30px -8px #10b9818c;opacity:0;transform:translateY(16px) scale(.9);pointer-events:none;transition:opacity .3s,transform .3s}.backtop.is-visible{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.backtop:hover{transform:translateY(-3px) scale(1.05)}.spotlight{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;opacity:0;transition:opacity .4s ease;background:radial-gradient(420px circle at var(--mx, 50%) var(--my, 0px),rgba(45,212,191,.1),rgba(99,102,241,.06) 40%,transparent 65%);mix-blend-mode:screen}.project__demo-badge{position:absolute;top:12px;right:12px;z-index:2;display:inline-flex;align-items:center;gap:7px;padding:6px 12px;border-radius:999px;font-size:.74rem;font-weight:700;letter-spacing:.02em;color:#eafff6;background:#070b149e;border:1px solid rgba(255,255,255,.18);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:border-color .2s,transform .2s}.project__demo-badge:hover{transform:translateY(-1px);border-color:var(--accent)}.project__demo-dot{width:7px;height:7px;border-radius:50%;background:#34d399;box-shadow:0 0 #34d39999;animation:pulse 2.2s infinite}.project__demo-link{display:inline-flex;align-items:center;gap:8px;margin-top:4px;font-size:.9rem;font-weight:600;color:var(--accent-2);transition:gap .2s,color .2s}.project__demo-link svg{width:18px;height:18px}.project__demo-link:hover{gap:11px;color:#6ee7b7}.lb{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;gap:clamp(8px,3vw,36px);padding:24px;background:#04070ed1;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);animation:lbfade .25s ease}@keyframes lbfade{0%{opacity:0}to{opacity:1}}.lb__stage{display:flex;flex-direction:column;align-items:center;gap:16px;animation:lbpop .3s cubic-bezier(.22,1,.36,1)}@keyframes lbpop{0%{opacity:0;transform:scale(.94) translateY(10px)}to{opacity:1;transform:none}}.lb__phone{position:relative;width:min(330px,82vw);max-height:84vh;aspect-ratio:9 / 19.5;border-radius:44px;padding:10px;background:linear-gradient(160deg,#1b2536,#0a0f1c);border:1px solid rgba(255,255,255,.12);box-shadow:0 40px 100px -30px #000000d9,0 0 60px -20px #10b98159}.lb__phone img{width:100%;height:100%;object-fit:cover;border-radius:34px}.lb__notch{position:absolute;top:18px;left:50%;transform:translate(-50%);width:42%;height:22px;border-radius:0 0 16px 16px;background:#05080f;z-index:2}.lb__wide{width:min(1080px,92vw);max-height:84vh;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.14);box-shadow:0 40px 100px -30px #000000d9,0 0 70px -25px #10b9814d;background:#0a0f1c}.lb__wide img{display:block;width:100%;max-height:84vh;object-fit:contain}.lb__counter{font-size:.85rem;color:var(--muted);font-weight:500}.lb__close{position:absolute;top:20px;right:24px;width:44px;height:44px;border-radius:50%;background:var(--surface-2);border:1px solid var(--border-strong);color:var(--text);font-size:1.1rem;cursor:pointer;transition:background .2s,transform .2s}.lb__close:hover{background:#ffffff1f;transform:rotate(90deg)}.lb__nav{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;background:var(--surface-2);border:1px solid var(--border-strong);color:var(--text);font-size:1.8rem;line-height:1;cursor:pointer;transition:background .2s,border-color .2s,transform .2s}.lb__nav--prev{left:clamp(12px,4vw,40px)}.lb__nav--next{right:clamp(12px,4vw,40px)}.lb__nav:hover{background:#ffffff1f;border-color:var(--accent-2);transform:translateY(-50%) scale(1.08)}@keyframes heroIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}.hero__avatar{animation:heroIn .7s 0s both cubic-bezier(.22,1,.36,1)}.hero__status{animation:heroIn .7s .05s both cubic-bezier(.22,1,.36,1)}.hero__title{animation:heroIn .75s .14s both cubic-bezier(.22,1,.36,1)}.hero__lead{animation:heroIn .75s .24s both cubic-bezier(.22,1,.36,1)}.hero__meta{animation:heroIn .75s .32s both cubic-bezier(.22,1,.36,1)}.hero__actions{animation:heroIn .75s .4s both cubic-bezier(.22,1,.36,1)}.hero__socials{animation:heroIn .75s .48s both cubic-bezier(.22,1,.36,1)}.hero__stats{animation:heroIn .85s .56s both cubic-bezier(.22,1,.36,1)}.hero__scroll{animation:heroIn 1s .8s both}.btn--primary{position:relative;overflow:hidden;isolation:isolate}.btn--primary:after{content:"";position:absolute;top:0;left:-130%;width:55%;height:100%;z-index:-1;background:linear-gradient(110deg,transparent,rgba(255,255,255,.45),transparent);transform:skew(-20deg);transition:left .6s ease}.btn--primary:hover:after{left:150%}.project:hover{box-shadow:inset 0 1px #ffffff0f,var(--shadow),0 18px 50px -24px color-mix(in srgb,var(--accent) 60%,transparent)}.project:hover .project__dot{animation:dotPulse 1.4s ease-in-out infinite}@keyframes dotPulse{0%,to{box-shadow:0 0 14px var(--accent)}50%{box-shadow:0 0 22px var(--accent),0 0 4px var(--accent)}}.skill-card:hover .tech{border-color:var(--border-strong)}.featured__cta{margin-top:22px}.pm{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;display:flex;align-items:center;justify-content:center;padding:24px;background:#04070ecc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:lbfade .25s ease}.pm__card{position:relative;width:min(880px,100%);max-height:88vh;display:flex;flex-direction:column;border-radius:var(--radius-lg);background:radial-gradient(700px 320px at 100% 0%,color-mix(in srgb,var(--accent) 16%,transparent),transparent 60%),var(--bg-2);border:1px solid color-mix(in srgb,var(--accent) 32%,var(--border));box-shadow:0 50px 120px -40px #000000d9,inset 0 1px #ffffff0f;overflow:hidden;animation:lbpop .3s cubic-bezier(.22,1,.36,1)}.pm__close{position:absolute;top:16px;right:16px;z-index:3;width:40px;height:40px;border-radius:50%;background:var(--surface-2);border:1px solid var(--border-strong);color:var(--text);font-size:1rem;cursor:pointer;transition:background .2s,transform .2s}.pm__close:hover{background:#ffffff1f;transform:rotate(90deg)}.pm__head{display:flex;align-items:center;gap:16px;padding:28px 60px 18px 28px;border-bottom:1px solid var(--border)}.pm__logo{width:56px;height:56px;border-radius:14px;border:1px solid var(--border);object-fit:cover}.pm__mono{display:grid;place-items:center;width:56px;height:56px;border-radius:14px;font-family:var(--font-head);font-weight:800;font-size:1.6rem;color:color-mix(in srgb,var(--accent) 85%,white 10%);background:color-mix(in srgb,var(--accent) 16%,transparent);border:1px solid color-mix(in srgb,var(--accent) 35%,transparent)}.pm__subtitle{color:var(--accent-2);font-size:.9rem;font-weight:500}.pm__name{font-family:var(--font-head);font-weight:800;font-size:1.7rem;line-height:1.1}.pm__body{padding:22px 28px 28px;overflow-y:auto}.pm__desc{color:var(--muted);margin-bottom:4px}.pm__highlights{list-style:none;display:grid;gap:10px;margin-top:18px}.pm__highlights li{display:flex;align-items:flex-start;gap:11px;color:var(--muted);font-size:.96rem}.pm__highlights svg{width:17px;height:17px;color:var(--accent);flex-shrink:0;margin-top:3px}.pm__section-label{font-size:.76rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);margin:24px 0 11px}.pm__actions{display:flex;gap:12px;flex-wrap:wrap}.pm__gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.pm__shot{position:relative;padding:0;cursor:pointer;border:1px solid var(--border);border-radius:12px;overflow:hidden;aspect-ratio:16 / 10;background:var(--surface);transition:border-color .2s,transform .2s}.pm__shot img{width:100%;height:100%;object-fit:cover;object-position:top center}.pm__shot-zoom{position:absolute;top:8px;right:8px;width:26px;height:26px;display:grid;place-items:center;border-radius:7px;background:#070b14b3;color:#fff;font-size:.95rem;opacity:0;transition:opacity .2s}.pm__shot:hover{border-color:var(--accent);transform:translateY(-2px)}.pm__shot:hover .pm__shot-zoom{opacity:1}@media (max-width: 980px){.about__grid{grid-template-columns:1fr}.skills__grid,.projects__grid{grid-template-columns:repeat(2,1fr)}.featured{grid-template-columns:1fr;gap:24px;padding:28px}.featured__gallery{height:420px;order:-1}.timeline-grid{grid-template-columns:1fr;gap:40px}.footer__top{grid-template-columns:1.4fr 1fr;row-gap:30px}}@media (max-width: 720px){.nav__links{position:fixed;inset:0 0 0 auto;width:min(80vw,320px);flex-direction:column;align-items:flex-start;justify-content:center;gap:26px;padding:40px;background:#080c16f5;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-left:1px solid var(--border);transform:translate(100%);transition:transform .35s ease}.nav__links.is-open{transform:translate(0)}.nav__links>a{font-size:1.1rem}.nav__cta{margin-top:6px}.nav__burger{display:flex;z-index:60}.nav__name{display:none}.hero__stats{grid-template-columns:repeat(2,1fr);gap:22px}.skills__grid,.projects__grid,.contact__cards{grid-template-columns:1fr}.phone{width:168px}.phone--0{transform:translate(-72px,-18px) rotate(-7deg)}.phone--1{transform:translate(64px,8px) rotate(6deg)}.phone--2{transform:translate(-24px,34px) rotate(-2deg)}.featured__gallery{height:360px}.featured__name{font-size:1.55rem}.footer__top{grid-template-columns:1fr;gap:30px}.footer__bottom{justify-content:center;text-align:center}.pm{padding:12px}.pm__head{padding:22px 54px 14px 18px}.pm__body{padding:18px 18px 22px}.pm__name{font-size:1.4rem}.pm__logo,.pm__mono{width:48px;height:48px}.about__features{grid-template-columns:1fr}}@media (max-width: 420px){.hero__stats{grid-template-columns:1fr}}@media (prefers-reduced-motion: reduce){.blob,.hero__dot,.hero__scroll span,.grad,.hero__avatar,.hero__status,.hero__title,.hero__lead,.hero__meta,.hero__actions,.hero__socials,.hero__stats,.hero__scroll,.project:hover .project__dot,.project__demo-dot,.dispo__dot{animation:none!important}.btn--primary:after{display:none}html{scroll-behavior:auto}}
