:root{--bg:#fffbf5;--bg-card:#fff;--text:#2d3436;--text-muted:#636e72;--coral:#ff6b6b;--coral-dark:#ee5a5a;--sun:#ffe066;--sun-dark:#f4a623;--sky:#74b9ff;--sky-dark:#0984e3;--mint:#55efc4;--mint-dark:#00b894;--lavender:#a29bfe;--shadow:0 8px 32px #2d343614;--shadow-lg:0 16px 48px #2d34361f;--radius:16px;--radius-lg:24px;--font-display:"Outfit", system-ui, sans-serif;--font-body:"DM Sans", system-ui, sans-serif;--nav-h:88px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}ul{list-style:none}img,svg{max-width:100%;display:block}.site-slider__progress{z-index:120;pointer-events:none;background:#0000000f;height:3px;position:fixed;top:0;left:0;right:0}.site-slider__progress-fill{background:var(--coral);height:100%;transition:width .12s ease-out;display:block}@media (prefers-reduced-motion:reduce){.site-slider__progress-fill,.site-slider__pip,.site-slider__label{transition:none}}.site-slider{z-index:90;pointer-events:none;position:fixed;top:50%;left:clamp(.75rem,2vw,1.5rem);transform:translateY(-50%)}.site-slider__list{flex-direction:column;gap:.85rem;margin:0;padding:0;list-style:none;display:flex}.site-slider__dot{cursor:pointer;pointer-events:auto;text-align:left;background:0 0;border:none;align-items:center;gap:.65rem;padding:0;display:flex}.site-slider__pip{border:2px solid var(--text-muted);background:0 0;border-radius:50%;flex-shrink:0;width:10px;height:10px;transition:transform .2s,background .2s,border-color .2s}.site-slider__label{font-family:var(--font-display);letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);opacity:0;white-space:nowrap;font-size:.72rem;font-weight:700;transition:opacity .2s,transform .2s,color .2s;transform:translate(-6px)}.site-slider__dot:hover .site-slider__label,.site-slider__dot--active .site-slider__label{opacity:1;transform:translate(0)}.site-slider__dot--active .site-slider__pip{background:var(--coral);border-color:var(--coral);transform:scale(1.25)}.site-slider__dot--active .site-slider__label{color:var(--coral)}.site-slider__dot:hover .site-slider__pip{border-color:var(--coral)}@media (width<=900px){.site-slider{display:none}}.navbar{z-index:100;pointer-events:none;padding:.75rem clamp(1rem,4vw,2rem);position:fixed;top:0;left:0;right:0}.navbar__bar{pointer-events:auto;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffe0;border:1px solid #0000000f;border-radius:999px;align-items:center;gap:1.5rem;max-width:1100px;margin:0 auto;padding:.6rem .6rem .6rem 1rem;transition:box-shadow .3s,background .3s;display:flex}.navbar--scrolled .navbar__bar{background:#fffffff5;box-shadow:0 8px 32px #00000014}.navbar__brand{flex-shrink:0;align-items:center;gap:.65rem;display:flex}.logo{object-fit:cover;border-radius:50%;flex-shrink:0;display:block}.navbar__logo{border:2px solid #ffffffe6;box-shadow:0 4px 14px #0000001f}.navbar__name{font-family:var(--font-display);color:var(--text);font-size:1.05rem;font-weight:700;line-height:1.2}.navbar__surname{color:var(--text-muted);font-size:.75rem;font-weight:600;display:block}.navbar__nav{flex:1;justify-content:center;min-width:0;display:flex}.navbar__links{align-items:center;gap:.25rem;list-style:none;display:flex}.navbar__links a{color:var(--text-muted);border-radius:999px;padding:.45rem .85rem;font-size:.88rem;font-weight:600;transition:color .2s,background .2s}.navbar__links a:hover{color:var(--text);background:var(--bg)}.navbar__close{display:none}.navbar__toggle{background:var(--bg);cursor:pointer;z-index:110;border:1px solid #0000000f;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;padding:0;display:none;position:relative}.navbar__toggle-icon{flex-direction:column;justify-content:space-between;width:20px;height:14px;display:flex}.navbar__toggle-icon span{background:var(--text);transform-origin:50%;border-radius:2px;width:100%;height:2px;transition:transform .25s,opacity .25s;display:block}.navbar__toggle--open .navbar__toggle-icon span:first-child{transform:translateY(6px)rotate(45deg)}.navbar__toggle--open .navbar__toggle-icon span:nth-child(2){opacity:0;transform:scaleX(0)}.navbar__toggle--open .navbar__toggle-icon span:nth-child(3){transform:translateY(-6px)rotate(-45deg)}.navbar__backdrop{pointer-events:auto;display:none}.btn{font-family:var(--font-display);cursor:pointer;border:2px solid #0000;border-radius:999px;justify-content:center;align-items:center;padding:.85rem 1.75rem;font-size:1rem;font-weight:600;transition:transform .2s,box-shadow .2s,background .2s;display:inline-flex}.btn:hover{transform:translateY(-2px)}.btn--primary{background:var(--coral);color:#fff;box-shadow:0 4px 20px #ff6b6b66}.btn--primary:hover{background:var(--coral-dark);box-shadow:0 6px 28px #ff6b6b80}.btn--outline{border-color:var(--text);color:var(--text);background:#fff}.btn--outline:hover{border-color:var(--coral);color:var(--coral)}.btn--full{width:100%}.section{max-width:1100px;margin:0 auto;padding:6rem clamp(1.25rem,4vw,3rem);position:relative}.section__header{text-align:center;margin-bottom:3rem}.section__header--left{text-align:left}.section__label{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.12em;color:var(--coral);margin-bottom:.5rem;font-size:.85rem;font-weight:600;display:inline-block}.section__title{font-family:var(--font-display);font-size:clamp(2rem,5vw,2.75rem);font-weight:800;line-height:1.2}.hero{width:100%;height:100dvh;min-height:100vh;padding:var(--nav-h) clamp(1.25rem, 4vw, 3rem) 2rem;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.hero__inner{z-index:2;text-align:center;flex-direction:column;justify-content:center;align-items:center;width:100%;max-width:1200px;display:flex;position:relative}.hero-fade{opacity:0;animation:1s forwards hero-fade-in}.hero-fade--1{animation-delay:.15s}.hero-fade--2{animation-delay:.4s}.hero-fade--3{animation-delay:.65s}.hero-fade--4{animation-delay:.85s}.hero-fade--5{animation-delay:1s}.hero-fade--6{animation-delay:1.15s}.hero__bg-shapes{pointer-events:none;position:absolute;inset:0}.hero__bg-shapes .shape{opacity:.5;border-radius:50%;animation:6s ease-in-out infinite float;position:absolute}.shape--1{background:radial-gradient(circle, var(--sun) 0%, transparent 70%);width:300px;height:300px;animation-delay:0s;top:10%;left:-5%}.shape--2{background:radial-gradient(circle, var(--sky) 0%, transparent 70%);width:200px;height:200px;animation-delay:-2s;top:60%;right:10%}.shape--3{background:radial-gradient(circle, var(--mint) 0%, transparent 70%);width:150px;height:150px;animation-delay:-4s;bottom:15%;left:30%}.shape--4{background:radial-gradient(circle, var(--lavender) 0%, transparent 70%);width:120px;height:120px;animation-delay:-1s;top:25%;right:25%}.hero__greeting{font-family:var(--font-display);letter-spacing:.2em;text-transform:uppercase;color:#e84393;text-shadow:0 2px 12px #e8439340;margin-bottom:1rem;font-size:clamp(1.25rem,3vw,1.75rem);font-weight:700}.wave-hand{transform-origin:70% 70%;margin-right:.35rem;animation:1.5s ease-in-out 1.2s infinite wave;display:inline-block}.hero__name{font-family:var(--font-display);letter-spacing:.04em;color:#0984e3;text-shadow:0 4px 24px #0984e34d;margin-bottom:1.5rem;font-size:clamp(2.5rem,10vw,6.5rem);font-weight:800;line-height:1}.hero__subtitle{color:#6c5ce7;max-width:520px;margin-bottom:2rem;font-size:clamp(1rem,2vw,1.2rem)}.hero__cta{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.hero__mascot{z-index:1;pointer-events:none;opacity:0;position:absolute}.hero__mascot--star-1{animation:1s 1s forwards hero-fade-in,5s ease-in-out 1s infinite float;top:15%;right:8%}.hero__mascot--star-2{animation:1s 1.1s forwards hero-fade-in,4s ease-in-out -.5s infinite reverse float;bottom:18%;left:6%}.hero__mascot--rocket{animation:1s 1.05s forwards hero-fade-in,3s ease-in-out 1s infinite rocket-fly;top:14%;left:8%}.hero__mascot--blob{animation:1s 1.2s forwards hero-fade-in,3s ease-in-out 1.2s infinite blob-wiggle;bottom:12%;right:8%}.about{position:relative}.about__header{margin-bottom:2.5rem}.about__card{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);background:#fff;border:1px solid #0000000a;padding:clamp(1.75rem,4vw,3rem)}.about__top{border-bottom:2px dashed #6c5ce726;grid-template-columns:minmax(260px,340px) 1.5fr;align-items:center;gap:2.5rem;margin-bottom:2.5rem;padding-bottom:2.5rem;display:grid}.about__visual{justify-content:center;align-items:center;width:100%;display:flex;position:relative}.about__avatar{aspect-ratio:1;object-fit:cover;object-position:center;width:min(280px,100%);height:auto;box-shadow:var(--shadow-lg);border:3px solid #fff}.about__blob-mini{z-index:2;animation:2.5s ease-in-out infinite blob-wiggle;position:absolute;bottom:0;right:5%}.about__text p{color:var(--text-muted);margin-bottom:1.25rem;font-size:1.08rem;line-height:1.75}.about__text p:last-child{margin-bottom:0}.about__text strong{color:#0984e3}.about__stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:1.25rem;width:100%;list-style:none;display:grid}.about__stat-card{background:var(--bg);border-radius:var(--radius);text-align:center;border-top:4px solid var(--stat-color);min-width:0;padding:1.75rem 1rem;transition:transform .25s,box-shadow .25s}.about__stat-card:hover{box-shadow:var(--shadow);transform:translateY(-6px)}.about__stat-num{font-family:var(--font-display);color:var(--stat-color);font-variant-numeric:tabular-nums;margin-bottom:.5rem;font-size:clamp(2.25rem,5vw,3rem);font-weight:800;line-height:1.1;display:block}.about__stat-num .count-up{display:inline-block}.about__stat-label{color:var(--text-muted);font-size:.85rem;font-weight:500;line-height:1.35;display:block}.about-fade{opacity:0;transition:opacity .7s,transform .7s;transform:translateY(24px)}.about--visible .about-fade--1{transition-delay:50ms}.about--visible .about-fade--2{transition-delay:.15s}.about--visible .about-fade--3{transition-delay:.25s}.about--visible .about-fade--4{transition-delay:.35s}.about--visible .about-fade--5{transition-delay:.45s}.about--visible .about-fade--6{transition-delay:.55s}.about--visible .about-fade--7{transition-delay:.65s}.about--visible .about-fade{opacity:1;transform:translateY(0)}@keyframes about-ring-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.85;transform:scale(1.08)}}.skills{border-radius:var(--radius-lg);background:linear-gradient(#0000,#74b9ff14,#0000);max-width:calc(1100px + 4rem)}.skills__mascot{animation:5s ease-in-out infinite spin-wiggle;position:absolute;top:2rem;right:2rem}.skills__grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;display:grid}.skills__group{border-radius:var(--radius);box-shadow:var(--shadow);border-left:4px solid var(--group-color);background:#fff;padding:1.5rem;transition:transform .25s,box-shadow .25s}.skills__group:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.skills__group-title{font-family:var(--font-display);color:var(--group-color);border-bottom:2px solid #0000000f;align-items:center;gap:.5rem;margin-bottom:1rem;padding-bottom:.5rem;font-size:1.1rem;font-weight:700;display:flex}.skills__group-icon{flex-shrink:0;font-size:1.25rem}.skills__tags{flex-wrap:wrap;gap:.5rem;list-style:none;display:flex}.skills__tag{background:var(--bg);color:var(--text);border:1px solid #0000000f;border-radius:999px;align-items:center;gap:.4rem;padding:.45rem .9rem;font-size:.88rem;font-weight:500;transition:background .2s,color .2s,border-color .2s,transform .2s;display:inline-flex}.skills__tag-icon{color:var(--group-color);flex-shrink:0;font-size:1.05rem;transition:color .2s}.skills__tag:hover{background:var(--group-color);color:#fff;border-color:var(--group-color);transform:scale(1.04)}.skills__tag:hover .skills__tag-icon{color:#fff}.skills-fade{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(20px)}.skills--visible .skills-fade--1{transition-delay:50ms}.skills--visible .skills-fade--2{transition-delay:.1s}.skills--visible .skills-fade--3{transition-delay:.15s}.skills--visible .skills-fade--4{transition-delay:.2s}.skills--visible .skills-fade--5{transition-delay:.25s}.skills--visible .skills-fade--6{transition-delay:.3s}.skills--visible .skills-fade--7{transition-delay:.35s}.skills--visible .skills-fade{opacity:1;transform:translateY(0)}.slide-section{height:calc(var(--slide-count,5) * 100dvh);max-width:none;margin:0;padding:0;position:relative}.slide-section__deck{z-index:2;height:100dvh;position:sticky;top:0;overflow:hidden}.slide-section__track{will-change:transform;transition:transform .75s cubic-bezier(.77,0,.18,1)}.slide-section__panel{height:100dvh;padding:calc(var(--nav-h) + 1rem) clamp(1rem, 4vw, 2rem) 1.5rem;box-sizing:border-box;opacity:.35;flex-shrink:0;justify-content:center;align-items:center;transition:opacity .55s,transform .75s cubic-bezier(.77,0,.18,1);display:flex;transform:scale(.94)}.slide-section__panel--active{opacity:1;transform:scale(1)}.slide-section__nav{z-index:10;pointer-events:none;flex-direction:column;align-items:center;gap:.65rem;display:flex;position:absolute;top:50%;right:clamp(1rem,3vw,2rem);transform:translateY(-50%)}.slide-section__dot{border:2px solid var(--text-muted);cursor:pointer;pointer-events:auto;background:0 0;border-radius:50%;width:10px;height:10px;padding:0;transition:transform .2s,background .2s,border-color .2s}.slide-section__dot--active{background:var(--coral);border-color:var(--coral);transform:scale(1.25)}.slide-section__counter{font-family:var(--font-display);color:var(--text-muted);letter-spacing:.08em;pointer-events:none;margin-top:.25rem;font-size:.7rem;font-weight:700}@media (prefers-reduced-motion:reduce){.slide-section__track,.slide-section__panel{transition-duration:.01ms}}.process__panel--intro{position:relative}.process__mascot{top:calc(var(--nav-h) + .5rem);z-index:2;pointer-events:none;animation:3s ease-in-out infinite code-bob;position:absolute;left:clamp(1.25rem,4vw,3rem)}.process__intro{text-align:center;max-width:520px;padding:0 1rem}.process__hint{color:var(--text-muted);align-items:center;gap:.5rem;margin-top:1rem;font-size:.95rem;display:inline-flex}.process__hint-icon{color:var(--coral);animation:1.8s ease-in-out infinite scroll-hint-bounce}.process__step{border-radius:var(--radius-lg);width:100%;max-width:min(480px,90vw);box-shadow:var(--shadow-lg);border-left:5px solid var(--coral);background:#fff;padding:2rem 2rem 2rem 2.25rem}.process__step-num{font-family:var(--font-display);letter-spacing:.12em;color:var(--coral);margin-bottom:.75rem;font-size:.85rem;font-weight:700;display:block}.process__step-title{font-family:var(--font-display);color:var(--text);margin-bottom:1rem;font-size:clamp(1.75rem,5vw,2.25rem);font-weight:800;line-height:1.15}.process__step-desc{color:var(--text-muted);font-size:1.05rem;line-height:1.75}.process-fade{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(20px)}.process--visible .process-fade--1{opacity:1;transform:translateY(0)}.projects__panel--intro{position:relative}.projects__panel--intro .projects__mascot{top:calc(var(--nav-h) + .5rem);z-index:2;pointer-events:none;animation:4s ease-in-out infinite rocket-fly;position:absolute;left:clamp(1.25rem,4vw,3rem)}.projects__intro{text-align:center;max-width:640px;padding:0 1rem}.projects__intro .section__header{margin-bottom:0}.projects__hint{color:var(--text-muted);align-items:center;gap:.5rem;margin-top:1rem;font-size:.95rem;display:inline-flex}.projects__hint-icon{color:var(--coral);animation:1.8s ease-in-out infinite scroll-hint-bounce;display:inline-block}.projects__panel-inner{width:100%;max-width:min(440px,88vw);margin:0 auto}.project-card{width:100%;max-height:calc(100dvh - var(--nav-h) - 3.5rem);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);background:#fff;border:1px solid #0000000d;flex-direction:column;margin:0 auto;transition:box-shadow .35s;display:flex;position:relative;overflow:hidden}.project-card:after{content:"";border-radius:inherit;pointer-events:none;opacity:0;transition:opacity .35s;position:absolute;inset:0;box-shadow:inset 0 0 0 1px #0000000f}.projects__panel--active .project-card,.project-card:hover{box-shadow:0 20px 40px #0000001a, var(--shadow-lg)}.projects__panel--active .project-card:after,.project-card:hover:after{opacity:1}.project-card__header{color:#fff;flex-shrink:0;padding:1rem 1.25rem 1.15rem;position:relative;overflow:hidden}.project-card__header-bg{background:linear-gradient(135deg, var(--card-accent) 0%, #fff 100%);position:absolute;inset:0}.project-card__orb{background:#ffffff26;border-radius:50%;position:absolute}.project-card__orb--1{width:120px;height:120px;top:-40px;right:-20px}.project-card__orb--2{background:#ffffff1a;width:80px;height:80px;bottom:-30px;left:20%}.project-card__watermark{opacity:.35;filter:drop-shadow(0 2px 8px #0000001a);font-size:clamp(2rem,8vw,3rem);line-height:1;position:absolute;bottom:.25rem;right:1rem}.project-card__header-inner{z-index:1;justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex;position:relative}.project-card__num{font-family:var(--font-display);letter-spacing:.15em;opacity:.85;font-size:.8rem;font-weight:700}.project-card__badges{flex-wrap:wrap;justify-content:flex-end;gap:.35rem;display:flex}.project-card__badge{text-transform:uppercase;letter-spacing:.05em;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:999px;padding:.28rem .6rem;font-size:.65rem;font-weight:700}.project-card__badge--featured{color:#fff;background:#ffffff40;border:1px solid #fff6}.project-card__badge--live{color:#00b894;background:#fffffff2;border:none;align-items:center;gap:.35rem;display:inline-flex}.project-card__badge--ongoing{color:#f4a623;background:#fffffff2;border:none;animation:2s ease-in-out infinite ongoing-glow}.project-card__badge--hold{color:#636e72;background:#fffffff2;border:none}.project-card__live-dot{background:#00b894;border-radius:50%;width:6px;height:6px;animation:1.5s ease-in-out infinite live-pulse}.project-card__title{z-index:1;font-family:var(--font-display);text-shadow:0 2px 12px #0000001f;font-size:clamp(1.2rem,4vw,1.45rem);font-weight:800;line-height:1.15;position:relative}.project-card__body{flex-direction:column;flex:1;min-height:0;padding:1rem 1.25rem 1.25rem;display:flex;overflow:hidden}.project-card__highlight{color:var(--card-accent);border-left:3px solid var(--card-accent);background:#f8f9fa;border-radius:8px;align-self:flex-start;margin-bottom:.85rem;padding:.35rem .75rem;font-size:.78rem;font-weight:700;display:inline-flex}.project-card__desc{color:var(--text-muted);scrollbar-width:thin;flex:1;min-height:0;margin-bottom:1rem;font-size:clamp(.8rem,2.5vw,.9rem);line-height:1.6;overflow-y:auto}.project-card__footer{border-top:1px dashed #00000014;flex-direction:column;gap:1rem;margin-top:auto;padding-top:1.15rem;display:flex}.project-card__tags{flex-wrap:wrap;gap:.4rem;list-style:none;display:flex}.project-card__tags li{background:var(--bg);color:var(--text);border:1px solid #0000000d;border-radius:6px;padding:.3rem .65rem;font-size:.72rem;font-weight:600;transition:background .2s,color .2s,border-color .2s}.project-card:hover .project-card__tags li{border-color:#0000001a}.project-card__cta{font-family:var(--font-display);color:#fff;background:var(--card-accent);border-radius:999px;justify-content:center;align-self:flex-start;align-items:center;gap:.5rem;padding:.65rem 1.25rem;font-size:.9rem;font-weight:700;transition:transform .2s,box-shadow .2s,gap .2s;display:inline-flex;box-shadow:0 4px 16px #ff6b6b59}.project-card__cta:hover{gap:.75rem;transform:scale(1.04);box-shadow:0 6px 22px #ff6b6b73}.project-card__cta-arrow{transition:transform .2s;display:inline-block}.project-card__cta:hover .project-card__cta-arrow{transform:translate(3px)}.project-card__cta--outline{color:var(--card-accent);border:2px solid var(--card-accent);box-shadow:none;background:0 0}.project-card__cta--outline:hover{box-shadow:none;background:#fffbf5}.project-card__cta--status{cursor:default;color:var(--text-muted);background:var(--bg);box-shadow:none;border:1px dashed #0000001f}.project-card__highlight--ongoing{color:#f4a623;background:#f4a6231f;border-left-color:#f4a623}.project-card__highlight--hold{color:#636e72;background:#636e721a;border-left-color:#636e72}.projects-fade{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(20px)}.projects--visible .projects-fade--1{transition-delay:50ms}.projects--visible .projects-fade--2{transition-delay:.12s}.projects--visible .projects-fade--3{transition-delay:.2s}.projects--visible .projects-fade--4{transition-delay:.28s}.projects--visible .projects-fade--5{transition-delay:.36s}.projects--visible .projects-fade--6{transition-delay:.44s}.projects--visible .projects-fade{opacity:1;transform:translateY(0)}@keyframes live-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}@keyframes ongoing-glow{0%,to{box-shadow:0 0 #f4a6234d}50%{box-shadow:0 0 0 4px #f4a62326}}@keyframes scroll-hint-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(4px)}}.contact{background:var(--bg);max-width:none;padding:5rem clamp(1.25rem,4vw,3rem) 6rem}.contact__card{border-radius:var(--radius-lg);max-width:1000px;box-shadow:var(--shadow-lg);background:#fff;border:1px solid #0000000f;grid-template-columns:1fr 1.1fr;margin:0 auto;display:grid;overflow:hidden}.contact__info{background:var(--coral);color:#fff;flex-direction:column;min-height:420px;padding:2.5rem;display:flex;position:relative}.contact__info .section__label{color:#ffffffd9}.contact__title{font-family:var(--font-display);margin:.5rem 0 1rem;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:800;line-height:1.2}.contact__title-accent{color:var(--coral);background:#fff;border-radius:8px;padding:.1em .35em;display:inline-block}.contact__lead{opacity:.92;max-width:320px;margin-bottom:1.75rem;font-size:1rem;line-height:1.65}.contact__channels{flex-wrap:wrap;gap:.5rem;margin-bottom:auto;list-style:none;display:flex}.contact__channel{background:#fff3;border:1px solid #ffffff59;border-radius:999px;align-items:center;gap:.45rem;padding:.55rem 1rem;font-size:.88rem;font-weight:600;transition:background .2s,transform .2s;display:inline-flex}.contact__channel:hover{color:var(--coral);background:#fff;transform:translateY(-2px)}.contact__channel svg{font-size:1.1rem}.contact__location{opacity:.8;margin-top:1.25rem;font-size:.85rem}.contact__mascot{opacity:.95;pointer-events:none;animation:3s ease-in-out infinite blob-wiggle;position:absolute;bottom:1rem;right:1rem}.contact__form-wrap{background:#fafafa;flex-direction:column;justify-content:center;padding:2.5rem;display:flex}.contact__form-label{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:1.25rem;font-size:.8rem;font-weight:700}.contact__mailto-lead{color:var(--text-muted);max-width:36ch;margin-bottom:1.75rem;font-size:1.05rem;line-height:1.65}.contact__mailto{width:100%;font-family:var(--font-display);color:#fff;background:var(--coral);border-radius:12px;justify-content:center;align-items:center;gap:.6rem;padding:1.1rem 1.5rem;font-size:1.05rem;font-weight:700;transition:background .2s,transform .2s,box-shadow .2s;display:inline-flex;box-shadow:0 10px 28px #ff6b6b4d}.contact__mailto:hover{background:var(--coral-dark);transform:translateY(-2px);box-shadow:0 14px 32px #ff6b6b59}.contact__mailto svg{font-size:1.25rem}.contact-fade{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(20px)}.contact--visible .contact-fade--1{transition-delay:50ms}.contact--visible .contact-fade--2{transition-delay:.12s}.contact--visible .contact-fade--3{transition-delay:.2s}.contact--visible .contact-fade{opacity:1;transform:translateY(0)}.footer{background:var(--bg);padding:2rem clamp(1rem,4vw,2rem) 2.5rem}.footer__copy{text-align:center;color:var(--text-muted);font-size:.85rem;font-weight:600}.blob-mascot .blob-body{transform-origin:bottom;animation:3s ease-in-out infinite blob-squish}.blob-mascot .blob-eye-l{animation:4s infinite blink}.blob-mascot .blob-eye-r{animation:4s .1s infinite blink}.star-mascot .star-body{transform-origin:50%;animation:2s ease-in-out infinite star-pulse}.star-mascot{animation:6s ease-in-out infinite spin-wiggle}.code-mascot .code-leg-l{animation:.6s ease-in-out infinite alternate leg-walk}.code-mascot .code-leg-r{animation:.6s ease-in-out infinite alternate-reverse leg-walk}.code-mascot .code-bulb{animation:1.5s ease-in-out infinite bulb-glow}.code-mascot .code-bracket-l,.code-mascot .code-bracket-r{animation:2s step-end infinite bracket-blink}.rocket-mascot .rocket-body{transform-origin:bottom;animation:2s ease-in-out infinite rocket-tilt}.rocket-mascot .rocket-flame,.rocket-mascot .rocket-flame-inner{animation:.3s ease-in-out infinite alternate flame-flicker}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-16px)}}@keyframes wave{0%,to{transform:rotate(0)}25%{transform:rotate(20deg)}75%{transform:rotate(-10deg)}}@keyframes card-float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes badge-bounce{0%,to{transform:translate(-50%)scale(1)}50%{transform:translate(-50%)scale(1.05)}}@keyframes rocket-fly{0%,to{transform:translate(0)rotate(-5deg)}50%{transform:translate(8px,-20px)rotate(5deg)}}@keyframes blob-squish{0%,to{transform:scaleY(1)scaleX(1)}50%{transform:scaleY(.95)scaleX(1.05)}}@keyframes blob-wiggle{0%,to{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}@keyframes blink{0%,90%,to{transform:scaleY(1)}95%{transform:scaleY(.1)}}@keyframes star-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}@keyframes spin-wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(8deg)}75%{transform:rotate(-8deg)}}@keyframes code-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes leg-walk{0%{transform:translateY(0)}to{transform:translateY(-4px)}}@keyframes bulb-glow{0%,to{opacity:1;filter:drop-shadow(0 0 4px #ffe066)}50%{opacity:.7;filter:drop-shadow(0 0 8px #ffe066)}}@keyframes bracket-blink{0%,49%{opacity:1}50%,to{opacity:.3}}@keyframes rocket-tilt{0%,to{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}@keyframes flame-flicker{0%{opacity:.7;transform:scaleY(1)}to{opacity:1;transform:scaleY(1.2)}}@keyframes hero-fade-in{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes bar-grow{0%{width:0!important}}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}@media (width<=900px){.hero__name{letter-spacing:.02em}.hero__mascot--rocket,.hero__mascot--blob{opacity:.6;transform:scale(.85)}.about__top,.contact__card{grid-template-columns:1fr}.contact__info{min-height:auto;padding:2rem}.contact__mascot{width:70px;height:70px;bottom:.75rem;right:.75rem}.about__top{text-align:center}.skills__mascot,.projects__mascot{display:none}}@media (width<=768px){.navbar{z-index:200}.navbar__bar{justify-content:space-between;gap:.75rem;padding:.5rem .5rem .5rem .85rem}.navbar__brand{flex:1;min-width:0}.navbar__name{font-size:.95rem}.navbar__surname{display:none}.navbar__nav{z-index:199;pointer-events:none;background:var(--bg);width:100vw;height:100dvh;padding:calc(var(--nav-h) + 1.5rem) clamp(1.25rem, 6vw, 3rem) 3rem;opacity:0;visibility:hidden;flex-direction:column;flex:none;justify-content:center;align-items:stretch;transition:opacity .35s,visibility .35s;position:fixed;inset:0}.navbar__nav--open{opacity:1;visibility:visible;pointer-events:auto}.navbar__close{width:42px;height:42px;box-shadow:var(--shadow);cursor:pointer;opacity:0;background:#fff;border:1px solid #00000014;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:opacity .3s 50ms,transform .3s 50ms,border-color .2s 50ms;display:inline-flex;position:absolute;top:1.25rem;right:clamp(1.25rem,6vw,3rem);transform:translateY(-.5rem)}.navbar__nav--open .navbar__close{opacity:1;transform:translateY(0)}.navbar__close-icon{color:var(--text);font-size:1.5rem;line-height:1;transition:color .2s}.navbar__close:hover{border-color:#ff6b6b59}.navbar__close:hover .navbar__close-icon{color:var(--coral)}.navbar__links{flex-direction:column;flex:1;justify-content:center;gap:0;width:100%;max-width:none}.navbar__links li{opacity:0;width:100%;transition:opacity .4s,transform .4s;transition-delay:calc(var(--nav-i,0) * 60ms + 80ms);transform:translateY(1.25rem)}.navbar__nav--open .navbar__links li{opacity:1;transform:translateY(0)}.navbar__links a{font-family:var(--font-display);letter-spacing:-.03em;text-align:left;width:100%;color:var(--text);background:0 0;border-bottom:1px solid #0000000f;border-radius:0;padding:.75rem 0;font-size:clamp(2.75rem,12vw,4.25rem);font-weight:800;line-height:1.05;transition:color .2s,padding-left .25s;display:block}.navbar__links a:hover{color:var(--coral);background:0 0;padding-left:.75rem}.navbar__toggle{display:flex}.navbar--open .navbar__bar{z-index:210;position:relative}.navbar--open .navbar__toggle{box-shadow:var(--shadow);background:#fff;border-color:#00000014}}@media (width<=640px){.contact__form-wrap{padding:1.5rem}.contact{padding-bottom:4rem}.about__card{padding:1.25rem .75rem}.about__stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem}.about__stat-card{padding:1rem .35rem}.about__stat-num{margin-bottom:.35rem;font-size:clamp(1.35rem,7vw,1.85rem)}.about__stat-label{font-size:.62rem;line-height:1.25}.skills__grid{grid-template-columns:1fr}.skills__group{padding:1.25rem}.skills__tag{font-size:.82rem}.slide-section__panel{padding-bottom:5rem;padding-left:1rem;padding-right:1rem}.process__step{padding:1.5rem}.slide-section__nav{box-shadow:var(--shadow);background:#fffbf5eb;border-radius:999px;flex-flow:wrap;justify-content:center;gap:.5rem;padding:.5rem .75rem;top:auto;bottom:1.25rem;right:50%;transform:translate(50%)}.slide-section__counter{text-align:center;flex-basis:100%;order:-1;width:100%;margin-top:0}.projects__panel-inner{max-width:100%}.project-card{max-height:calc(100dvh - var(--nav-h) - 5rem)}.project-card__footer{gap:.75rem}.project-card__tags li{font-size:.68rem}}
