:root{--color-bg:#0c0f16;--color-bg-elevated:#131720;--color-bg-card:#171c28;--color-surface:#f7f8fa;--color-surface-alt:#eef0f4;--color-text:#e8ecf4;--color-text-muted:#8a92a6;--color-text-dark:#1a1f2e;--color-text-dark-muted:#5c6478;--color-accent:#4f7df9;--color-accent-soft:#4f7df91f;--color-accent-glow:#4f7df940;--color-accent-gradient:linear-gradient(135deg,#4f7df9,#7c5cfc);--color-success:#34d399;--color-border:#ffffff0f;--color-border-light:#00000014;--font-heading:"Sora",sans-serif;--font-body:"General Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--section-py:6rem;--radius-sm:8px;--radius-md:14px;--ease-out-expo:cubic-bezier(0.16,1,0.3,1);--transition-base:0.3s var(--ease-out-expo)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;font-size:15px;scroll-behavior:smooth}@media (min-width:768px){html{font-size:16px}}body{background:#f7f8fa;background:var(--color-surface);color:#1a1f2e;color:var(--color-text-dark);font-family:General Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-body);line-height:1.7;overflow-x:hidden}img{display:block;height:auto;max-width:100%}a{color:inherit;text-decoration:none}ul{list-style:none}.container{margin:0 auto;max-width:1100px;padding:0 1.5rem}.navbar{align-items:center;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:#0c0f16d9;border-bottom:1px solid #ffffff0f;border-bottom:1px solid var(--color-border);display:flex;height:64px;justify-content:space-between;left:0;padding:0 2rem;position:fixed;right:0;top:0;z-index:100}.navbar-logo{color:#e8ecf4;color:var(--color-text);font-family:Sora,sans-serif;font-family:var(--font-heading);font-size:1.1rem;font-weight:700}.navbar-logo span{color:#4f7df9;color:var(--color-accent)}.navbar-links{display:flex;gap:.5rem}.navbar-links a{border-radius:100px;color:#8a92a6;color:var(--color-text-muted);font-size:.82rem;font-weight:500;padding:.5rem 1rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all var(--transition-base)}.navbar-links a.active,.navbar-links a:hover{background:#ffffff0f;color:#e8ecf4;color:var(--color-text)}.navbar-toggle{align-items:center;background:none;border:1px solid #fff3;border-radius:8px;border-radius:var(--radius-sm);cursor:pointer;display:none;flex-direction:column;gap:4px;justify-content:center;padding:.4rem .6rem}.navbar-toggle span{background:#e8ecf4;background:var(--color-text);display:block;height:2px;transition:all .3s;width:20px}.navbar-toggle.open span:first-child{transform:rotate(45deg) translate(4px,4px)}.navbar-toggle.open span:nth-child(2){opacity:0}.navbar-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}.navbar-mobile{background:#0c0f16;background:var(--color-bg);border-bottom:1px solid #ffffff0f;border-bottom:1px solid var(--color-border);box-shadow:0 12px 32px #0006;display:none;flex-direction:column;gap:.25rem;left:0;padding:1rem 2rem;position:absolute;right:0;top:64px}.navbar-mobile.open{display:flex}.navbar-mobile a{border-bottom:1px solid #ffffff0d;color:#e8ecf4;color:var(--color-text);font-size:.95rem;font-weight:500;padding:.75rem 0;transition:color .2s}.navbar-mobile a:last-child{border-bottom:none}.navbar-mobile a:hover{color:#4f7df9;color:var(--color-accent)}@media (max-width:768px){.navbar-links{display:none}.navbar-toggle{display:flex}}.hero{align-items:center;background:#0c0f16;background:var(--color-bg);color:#e8ecf4;color:var(--color-text);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:120px 1.5rem 80px;position:relative;text-align:center}.hero-bg{background:url(/portfolio/static/media/hero.cff22402632e78df0e92.jpg) 50%/cover no-repeat;filter:brightness(.5) contrast(1.1) saturate(.7);opacity:.35;z-index:0}.hero-bg,.hero-overlay{inset:0;position:absolute}.hero-overlay{background:linear-gradient(180deg,#0c0f1680,#0c0f1633 40%,#0c0f16b3),linear-gradient(135deg,#4f7df914,#0000 50%);z-index:1}.hero-content{max-width:640px;position:relative;z-index:2}.hero-badge{align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff0a;border:1px solid #ffffff0f;border:1px solid var(--color-border);border-radius:999px;color:#8a92a6;color:var(--color-text-muted);display:inline-flex;font-size:.8rem;font-weight:500;gap:.5rem;margin-bottom:2rem;padding:.45rem 1rem}.badge-dot{animation:dotPulse 2s ease-in-out infinite;background:#34d399;background:var(--color-success);border-radius:50%;box-shadow:0 0 8px #34d39980;height:7px;width:7px}@keyframes dotPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.hero h1{color:#fff;font-family:Sora,sans-serif;font-family:var(--font-heading);font-size:clamp(3rem,10vw,6rem);font-weight:700;letter-spacing:-.03em;line-height:1.05;margin-bottom:1rem}.hero h1 .gradient{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#4f7df9,#7c5cfc);background:var(--color-accent-gradient);-webkit-background-clip:text;background-clip:text}.hero-role{color:#8a92a6;color:var(--color-text-muted);font-family:Sora,sans-serif;font-family:var(--font-heading);font-size:1.1rem;font-weight:400;letter-spacing:.08em;margin-bottom:1.5rem;text-transform:uppercase}.hero-desc{color:#e8ecf4b3;font-size:1.05rem;line-height:1.75;margin-bottom:2.5rem}.hero-actions{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.btn{align-items:center;border:none;border-radius:8px;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-family:Sora,sans-serif;font-family:var(--font-heading);font-size:.9rem;font-weight:600;gap:.5rem;padding:.85rem 1.8rem;text-decoration:none;transition:transform .3s cubic-bezier(.16,1,.3,1),box-shadow .3s cubic-bezier(.16,1,.3,1);transition:transform var(--transition-base),box-shadow var(--transition-base)}.btn-primary{background:linear-gradient(135deg,#4f7df9,#7c5cfc);background:var(--color-accent-gradient);box-shadow:0 4px 20px #4f7df94d;color:#fff}.btn-primary:hover{box-shadow:0 8px 30px #4f7df973;color:#fff;transform:translateY(-2px)}.btn-outline{background:#0000;border:1px solid #ffffff26;color:#e8ecf4;color:var(--color-text)}.btn-outline:hover{background:#4f7df91f;background:var(--color-accent-soft);border-color:#4f7df9;border-color:var(--color-accent);color:#fff;transform:translateY(-2px)}.btn svg{height:16px;width:16px}.scroll-indicator{bottom:2.5rem;left:50%;position:absolute;transform:translateX(-50%);z-index:2}.scroll-line{animation:scrollPulse 2s ease-in-out infinite;background:linear-gradient(180deg,#4f7df9,#0000);background:linear-gradient(to bottom,var(--color-accent),#0000);height:48px;width:1px}@keyframes scrollPulse{0%,to{opacity:1;transform:scaleY(1)}50%{opacity:.3;transform:scaleY(.6)}}.section{padding:6rem 0;padding:var(--section-py) 0;scroll-margin-top:80px}.section-light{background:#f7f8fa;background:var(--color-surface)}.section-alt{background:#eef0f4;background:var(--color-surface-alt)}.section-dark{background:#0c0f16;background:var(--color-bg);color:#e8ecf4;color:var(--color-text)}.section-header{align-items:baseline;display:flex;gap:1rem;margin-bottom:3rem}.section-number{color:#4f7df9;color:var(--color-accent);font-size:.8rem;font-weight:600;letter-spacing:.05em}.section-number,.section-title{font-family:Sora,sans-serif;font-family:var(--font-heading)}.section-title{font-size:clamp(1.6rem,4vw,2.2rem);font-weight:700;letter-spacing:-.02em;position:relative}.section-title:after{background:linear-gradient(135deg,#4f7df9,#7c5cfc);background:var(--color-accent-gradient);border-radius:999px;bottom:-8px;content:"";height:3px;left:0;position:absolute;width:40px}.section-dark .section-title{color:#e8ecf4;color:var(--color-text)}.about-grid{grid-gap:4rem;display:grid;gap:4rem;grid-template-columns:3fr 2fr}.about-text p{color:#5c6478;color:var(--color-text-dark-muted);font-size:1rem;line-height:1.8;margin-bottom:1.2rem}.about-text strong{color:#1a1f2e;color:var(--color-text-dark);font-weight:600}.detail-card{background:#fff;border:1px solid #00000014;border:1px solid var(--color-border-light);border-radius:14px;border-radius:var(--radius-md);gap:1.2rem;padding:1.8rem}.detail-card,.detail-item{display:flex;flex-direction:column}.detail-item{gap:.25rem}.detail-label{color:#4f7df9;color:var(--color-accent);font-family:Sora,sans-serif;font-family:var(--font-heading);font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase}.detail-value{color:#1a1f2e;color:var(--color-text-dark);font-size:.95rem;font-weight:500}.skills-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(3,1fr)}.skill-group{background:#fff;border:1px solid #00000014;border:1px solid var(--color-border-light);border-radius:14px;border-radius:var(--radius-md);padding:1.8rem}.skill-group-header{align-items:center;display:flex;gap:.65rem;margin-bottom:1.2rem}.skill-group-icon{align-items:center;background:#4f7df91f;background:var(--color-accent-soft);border-radius:8px;border-radius:var(--radius-sm);color:#4f7df9;color:var(--color-accent);display:flex;height:36px;justify-content:center;width:36px}.skill-group-header h3{color:#1a1f2e;color:var(--color-text-dark);font-family:Sora,sans-serif;font-family:var(--font-heading);font-size:1rem;font-weight:600}.skill-tags{display:flex;flex-wrap:wrap;gap:.5rem}.skill-tag{background:#4f7df90f;border:1px solid #4f7df92e;border-radius:999px;color:#5c6478;color:var(--color-text-dark-muted);cursor:default;font-size:.82rem;font-weight:500;padding:.3rem .75rem;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all var(--transition-base)}.skill-tag:hover{background:#4f7df91f;background:var(--color-accent-soft);border-color:#4f7df9;border-color:var(--color-accent);box-shadow:0 4px 12px #4f7df91f;color:#4f7df9;color:var(--color-accent);transform:translateY(-2px)}.projects-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(3,1fr)}.project-card{background:#fff;border:1px solid #00000014;border:1px solid var(--color-border-light);border-radius:14px;border-radius:var(--radius-md);color:inherit;display:block;overflow:hidden;text-decoration:none;transition:transform .3s cubic-bezier(.16,1,.3,1),box-shadow .3s cubic-bezier(.16,1,.3,1);transition:transform var(--transition-base),box-shadow var(--transition-base)}.project-card:hover{box-shadow:0 20px 40px #0000000f,0 8px 16px #0000000a;transform:translateY(-5px)}.project-img-wrap{overflow:hidden}.project-img{height:200px;object-fit:cover;transition:transform .5s cubic-bezier(.16,1,.3,1);transition:transform .5s var(--ease-out-expo);width:100%}.project-card:hover .project-img{transform:scale(1.05)}.project-body{padding:1.4rem}.project-title{color:#1a1f2e;color:var(--color-text-dark);font-family:Sora,sans-serif;font-family:var(--font-heading);font-size:1.05rem;font-weight:600;margin-bottom:.6rem}.project-desc{color:#5c6478;color:var(--color-text-dark-muted);font-size:.88rem;line-height:1.65;margin-bottom:.8rem}.project-tech{font-size:.78rem;font-weight:500;margin-bottom:.8rem}.project-link-label,.project-tech{color:#4f7df9;color:var(--color-accent);font-family:Sora,sans-serif;font-family:var(--font-heading)}.project-link-label{align-items:center;display:inline-flex;font-size:.82rem;font-weight:600;gap:.35rem;transition:gap .3s cubic-bezier(.16,1,.3,1);transition:gap var(--transition-base)}.project-card:hover .project-link-label{gap:.6rem}.contact-grid{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:1fr 1fr}.contact-intro{color:#8a92a6;color:var(--color-text-muted);margin-bottom:2.5rem;margin-top:-1.5rem;max-width:500px}.contact-form{gap:1.3rem}.contact-form,.form-group{display:flex;flex-direction:column}.form-group{gap:.4rem}.form-label{color:#8a92a6;color:var(--color-text-muted);font-family:Sora,sans-serif;font-family:var(--font-heading);font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.form-input{background:#ffffff0a;border:1px solid #ffffff14;border-radius:8px;border-radius:var(--radius-sm);color:#e8ecf4;color:var(--color-text);font-family:General Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-body);font-size:.95rem;outline:none;padding:.8rem 1rem;resize:vertical;transition:border-color .3s cubic-bezier(.16,1,.3,1),box-shadow .3s cubic-bezier(.16,1,.3,1);transition:border-color var(--transition-base),box-shadow var(--transition-base);width:100%}.form-input::placeholder{color:#8a92a680}.form-input:focus{border-color:#4f7df9;border-color:var(--color-accent);box-shadow:0 0 0 3px #4f7df91f;box-shadow:0 0 0 3px var(--color-accent-soft)}.contact-info-card{background:#171c28;background:var(--color-bg-card);border:1px solid #ffffff0f;border:1px solid var(--color-border);border-radius:14px;border-radius:var(--radius-md);display:flex;flex-direction:column;gap:1.2rem;padding:2rem}.contact-info-title{color:#e8ecf4;color:var(--color-text);font-family:Sora,sans-serif;font-family:var(--font-heading);font-size:1rem;font-weight:600;margin-bottom:.5rem}.contact-link{align-items:center;background:#ffffff08;border:1px solid #ffffff0f;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-sm);color:inherit;display:flex;gap:.85rem;padding:.9rem 1rem;text-decoration:none;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all var(--transition-base)}.contact-link:hover{border-color:#4f7df9;border-color:var(--color-accent)}.contact-link-icon,.contact-link:hover{background:#4f7df91f;background:var(--color-accent-soft)}.contact-link-icon{align-items:center;border-radius:8px;border-radius:var(--radius-sm);color:#4f7df9;color:var(--color-accent);display:flex;flex-shrink:0;height:38px;justify-content:center;width:38px}.contact-link-label{color:#8a92a6;color:var(--color-text-muted);font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.contact-link-value{color:#e8ecf4;color:var(--color-text);font-size:.9rem;font-weight:500}.contact-link-arrow{color:#8a92a6;color:var(--color-text-muted);margin-left:auto;transition:transform .3s cubic-bezier(.16,1,.3,1),color .3s cubic-bezier(.16,1,.3,1);transition:transform var(--transition-base),color var(--transition-base)}.contact-link:hover .contact-link-arrow{color:#4f7df9;color:var(--color-accent);transform:translate(2px,-2px)}.footer{background:#131720;background:var(--color-bg-elevated);border-top:1px solid #ffffff0f;border-top:1px solid var(--color-border);color:#8a92a6;color:var(--color-text-muted);font-size:.85rem;padding:1.5rem 0;text-align:center}.fade-up{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);transition:opacity .7s var(--ease-out-expo),transform .7s var(--ease-out-expo)}.fade-up.visible{opacity:1;transform:translateY(0)}.fade-up-d1{transition-delay:.1s}.fade-up-d2{transition-delay:.2s}.fade-up-d3{transition-delay:.3s}.hero-anim{animation:heroFadeUp .8s cubic-bezier(.16,1,.3,1) both;animation:heroFadeUp .8s both var(--ease-out-expo)}.hero-anim-1{animation-delay:.2s}.hero-anim-2{animation-delay:.35s}.hero-anim-3{animation-delay:.5s}.hero-anim-4{animation-delay:.65s}.hero-anim-5{animation-delay:.8s}@keyframes heroFadeUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){:root{--section-py:4rem}.about-grid{gap:2rem}.about-grid,.contact-grid,.projects-grid,.skills-grid{grid-template-columns:1fr}.hero{padding:100px 1.5rem 60px}.hero h1{font-size:clamp(2.6rem,12vw,4rem)}.hero-desc,.hero-role{font-size:.95rem}.hero-actions{flex-direction:column;gap:.75rem}.hero-actions .btn{justify-content:center;width:100%}}.lang-toggle{background:#ffffff0a;border:1px solid #ffffff1f;border-radius:100px;color:#8a92a6;color:var(--color-text-muted);cursor:pointer;font-family:Sora,sans-serif;font-family:var(--font-heading);font-size:.72rem;font-weight:600;letter-spacing:.08em;padding:.4rem .85rem;text-transform:uppercase;transition:all .3s cubic-bezier(.16,1,.3,1);transition:all var(--transition-base)}.lang-toggle:hover{background:#4f7df91f;background:var(--color-accent-soft);border-color:#4f7df9;border-color:var(--color-accent);color:#4f7df9;color:var(--color-accent)}.navbar-links .lang-toggle{margin-left:.5rem}.navbar-right-mobile{align-items:center;display:none;gap:.6rem}@media (max-width:768px){.navbar-right-mobile{display:flex}.navbar-links .lang-toggle{display:none}}.spinner{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}@keyframes spin{to{transform:rotate(1turn)}}.form-input:disabled{cursor:not-allowed;opacity:.5}.btn:disabled{cursor:not-allowed;opacity:.7;transform:none!important}.form-message{animation:fadeIn .4s cubic-bezier(.16,1,.3,1);animation:fadeIn .4s var(--ease-out-expo);border-radius:8px;border-radius:var(--radius-sm);font-size:.9rem;margin-top:.5rem;padding:.75rem 1rem}.form-success{background:#34d39914;border:1px solid #34d39926;color:#34d399;color:var(--color-success)}.form-error{background:#f8717114;border:1px solid #f8717126;color:#f87171;color:var(--color-danger,#f87171)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
/*# sourceMappingURL=main.16fb0bac.css.map*/