:root{--primary-color:#3b82f6;--primary-dark:#1d4ed8;--secondary-color:#0ea5b7;--accent-color:#22d3ee;--accent-primary:#22d3ee;--bg-primary:#0b1020;--bg-secondary:#11182b;--bg-tertiary:#162238;--bg-card:#141c30ad;--text-primary:#f5f7fb;--text-secondary:#a8b3c7;--text-muted:#6e7b91;--gradient-primary:linear-gradient(135deg,#3b82f6,#2563eb 52%,#22d3ee);--gradient-secondary:linear-gradient(135deg,#172554,#0f172a);--gradient-accent:linear-gradient(135deg,#1d4ed8,#22d3ee);--gradient-dark:linear-gradient(135deg,#1e293b,#0f172a);--shadow-sm:0 2px 4px #04080e61,0 0 14px #7691bd24;--shadow-md:0 6px 12px #04080e85,0 0 26px #7291c233;--shadow-lg:0 10px 18px #03070c9e,0 0 44px #6d8ebf3d;--shadow-xl:0 16px 28px #03070cb3,0 0 58px #6286ba47;--shadow-glow:0 8px 14px #03070c7a,0 0 34px #799dd066;--transition-fast:180ms cubic-bezier(0.4,0,0.2,1);--transition-normal:220ms cubic-bezier(0.4,0,0.2,1);--transition-slow:360ms cubic-bezier(0.4,0,0.2,1);--transition-bounce:220ms cubic-bezier(0.34,1.56,0.64,1);--transition-inertia:260ms cubic-bezier(0.32,0,0.67,0);--radius-sm:0.25rem;--radius-md:0.375rem;--radius-lg:0.5rem;--radius-xl:0.5rem;--radius-2xl:0.5rem;--radius-full:999px;--focus-ring-color:#95b7e09e;--focus-ring-shadow:0 0 0 3px #88a8c92e;--glass-border:#ffffff1a;--glass-surface:#1721309e;--space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;background:var(--mesh-bg),radial-gradient(980px 640px at 68% 106%,#2d3a5457,#0000 62%),radial-gradient(1200px 900px at 10% 12%,#809ac217,#0000 56%),linear-gradient(180deg,var(--bg-primary) 0,#111724 100%);color:var(--text-primary);font-family:Manrope,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.7;overflow-x:hidden}section[id]{scroll-margin-top:96px}i[class*=fa-]{align-items:center;display:inline-flex;justify-content:center;line-height:1}i[class*=fa-]>svg{display:block;height:1em;width:1em}@media (max-width:768px){section[id]{scroll-margin-top:112px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInLeft{0%{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes gradientShift{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.fade-in-up{animation:fadeInUp .8s cubic-bezier(.4,0,.2,1)}.fade-in-left{animation:fadeInLeft .8s cubic-bezier(.4,0,.2,1)}.fade-in-right{animation:fadeInRight .8s cubic-bezier(.4,0,.2,1)}.gradient-text{-webkit-text-fill-color:#0000;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text}.glass-effect{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:var(--glass-surface);border:1px solid var(--glass-border);box-shadow:var(--shadow-md)}.glass-border-glow{position:relative}.glass-border-glow:before{background:radial-gradient(circle at 18% 16%,#afcbf047,#afcbf00a 42%,#51678a38 78%);border-radius:inherit;content:"";inset:0;-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;padding:1px;pointer-events:none;position:absolute}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--primary-color);border-radius:var(--radius-lg)}::-webkit-scrollbar-thumb:hover{background:var(--primary-dark)}.cover-container{align-items:center;background:var(--bg-primary);display:flex;justify-content:center;min-height:100vh;min-height:100svh;overflow:hidden;padding:110px 0 58px;position:relative;width:100%}.cover-overlay{background:radial-gradient(circle at 10% -12%,#88abd740,#0000 54%),radial-gradient(circle at 88% 22%,#6887b647,#0000 52%),radial-gradient(circle at 50% 98%,#4558795c,#0000 60%),linear-gradient(180deg,#0e141df7,#111925f2);inset:0;position:absolute;z-index:0}.cover-content{margin:0 auto;max-width:1200px;padding:0 var(--space-xl);position:relative;width:100%;z-index:2}.hero-text{margin:0 auto;max-width:900px;opacity:1;text-align:center;transform:none}.greeting{align-items:center;background:#1d2635b3;border:1px solid #9aaec933;border-radius:var(--radius-lg);color:#bfd1e8;display:inline-flex;font-size:.8rem;justify-content:center;letter-spacing:.08em;margin-bottom:var(--space-lg);padding:.38rem .9rem;text-transform:uppercase}.hero-name{grid-gap:.45rem;display:grid;font-size:clamp(2rem,6.4vw,4.8rem);gap:.45rem;justify-items:center;letter-spacing:-.026em;line-height:1.02;margin:0}.name-part{-webkit-text-fill-color:#0000;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text}.hero-name-main{display:inline-block;font-weight:800;line-height:1.14;padding-bottom:.1em}.hero-name-sub{color:#dde8f8;font-size:clamp(1.05rem,2.4vw,1.7rem);font-weight:700;letter-spacing:-.01em;line-height:1.25}.hero-title{color:#e4edff;font-size:clamp(1.16rem,2.45vw,1.92rem);font-weight:640;line-height:1.32;margin:var(--space-md) auto var(--space-lg);max-width:860px}.hero-answer{color:#cad6e8;font-size:clamp(.98rem,1.9vw,1.06rem);line-height:1.68;margin:0 auto var(--space-md);max-width:700px}.hero-description{color:var(--text-secondary);font-size:clamp(1rem,2.2vw,1.15rem);line-height:1.73;margin:0 auto var(--space-2xl);max-width:740px}.tech-stack{margin:0 0 var(--space-2xl)}.tech-grid{grid-gap:.8rem;display:grid;gap:.8rem;grid-template-columns:repeat(4,minmax(0,1fr));margin:0 auto;max-width:760px}.tech-item{align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#1721309e;border:1px solid #ffffff1a;border-radius:var(--radius-lg);color:#d4deee;display:inline-flex;gap:.5rem;justify-content:center;opacity:1;padding:.85rem .8rem;transform:none;transition:transform var(--transition-normal),background var(--transition-normal),border-color var(--transition-normal),box-shadow var(--transition-normal);transition-delay:calc(var(--stagger-index, 0)*50ms);will-change:transform}.tech-item i{color:#9ec0e0;font-size:.92rem;transition:transform var(--transition-normal),color var(--transition-normal)}.tech-item span{font-size:.82rem;font-weight:600;transition:color var(--transition-normal)}.tech-item:hover{background:#212e41b8;border-color:#bdd3f040;box-shadow:var(--shadow-glow);transform:translateY(-1px)}.tech-item:hover i{color:#c0d9ee;transform:scale(1.12)}.tech-item:hover span{color:#eef6ff}.hero-actions{display:flex;flex-wrap:wrap;gap:.85rem}.cta-button,.hero-actions{justify-content:center;min-height:48px}.cta-button{align-items:center;border:1px solid #ffffff1a;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:700;gap:.5rem;min-width:180px;overflow:hidden;padding:.9rem 1.35rem;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);will-change:transform}.cta-button.primary{background:var(--gradient-primary);box-shadow:var(--shadow-lg);color:#fff}.cta-button.primary:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px)}.cta-button.secondary{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#1721309e;border-color:#ffffff1a;color:#d7e3f3}.cta-button.secondary:hover{background:#1f2b3ce6;transform:translateY(-1px)}.cta-button:active{transform:scale(.98)}.cta-button:focus-visible{box-shadow:var(--focus-ring-shadow);outline:2px solid var(--focus-ring-color);outline-offset:2px}.floating-elements{inset:0;pointer-events:none;position:absolute;z-index:1}.floating-shape{background:var(--gradient-primary);border-radius:999px;filter:blur(3px);opacity:.04;position:absolute}.shape-1{height:130px;left:8%;top:18%;width:130px}.shape-2{bottom:18%;height:92px;right:12%;width:92px}@media (max-width:768px){.cover-container{align-items:flex-start;padding:94px 0 42px}.cover-content{padding:0 var(--space-lg)}.hero-description{line-height:1.65}.tech-grid{gap:.5rem;grid-template-columns:repeat(3,minmax(0,1fr))}.tech-item{padding:.68rem .62rem}.tech-item span{font-size:.76rem}.cta-button{min-width:164px}}@media (max-width:480px){.cover-content{padding:0 var(--space-md)}.hero-title{font-size:1.07rem}.hero-description{font-size:.94rem}.hero-actions{align-items:stretch;flex-direction:column}.tech-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.cta-button{width:100%}.floating-shape{display:none}}.navbar{-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0);left:0;position:fixed;right:0;top:0;transition:background var(--transition-normal),border-color var(--transition-normal),box-shadow var(--transition-normal);z-index:1000}.navbar-container{align-items:center;display:flex;height:80px;justify-content:space-between;margin:0 auto;max-width:1320px;padding:0 var(--space-xl)}.navbar.scrolling{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#161f2db8;border-bottom:1px solid #ffffff1a;box-shadow:var(--shadow-lg);color:var(--bg-card)}.navbar-logo{align-items:center;background:#0000;border:none;border-radius:var(--radius-lg);cursor:pointer;display:flex;gap:var(--space-sm);overflow:hidden;padding:var(--space-sm) var(--space-md);position:relative;transition:background var(--transition-normal)}.navbar-logo:hover{background:#8295af24}.navbar-logo:active{transform:scale(.98)}.navbar-logo:focus-visible{box-shadow:var(--focus-ring-shadow);outline:2px solid var(--focus-ring-color);outline-offset:2px}.navbar-logo:before{background:var(--gradient-primary);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left var(--transition-slow);width:100%;z-index:-1}.navbar-logo:hover:before{left:0}.logo-icon{align-items:center;background:var(--gradient-primary);border-radius:var(--radius-md);color:#fff;display:flex;font-size:18px;height:40px;justify-content:center;transition:transform var(--transition-normal),box-shadow var(--transition-normal);width:40px}.navbar-logo:hover .logo-icon{box-shadow:var(--shadow-glow);transform:rotate(1turn)}.logo-text{color:var(--text-primary);font-size:24px;font-weight:700;transition:color var(--transition-normal)}.navbar-logo:hover .logo-text{color:#fff}.navbar-menu-desktop{display:flex}.navbar-links{display:flex;gap:.45rem;list-style:none;margin:0;padding:0}.navbar-links li{border-radius:var(--radius-md);position:relative}.navbar-link-button{align-items:center;background:#0000;border:none;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;justify-content:center;overflow:hidden;padding:.6rem .8rem;position:relative;transition:background var(--transition-fast),transform var(--transition-fast);will-change:transform}.navbar-link-button:active{transform:scale(.98)}.navbar-links li{transition:opacity var(--transition-fast),transform var(--transition-fast);transition-delay:calc(var(--stagger-index, 0)*50ms)}.navbar-link-button:focus-visible{box-shadow:var(--focus-ring-shadow);outline:2px solid var(--focus-ring-color);outline-offset:2px}.link-text{color:var(--text-secondary);font-size:.86rem;font-weight:600;letter-spacing:.02em;position:relative;transition:color var(--transition-fast);z-index:2}.navbar-link-button:focus-visible .link-text,.navbar-link-button:hover .link-text,.navbar-links li.active .link-text{color:var(--text-primary)}.link-underline{background:var(--gradient-primary);bottom:0;height:2px;left:50%;position:absolute;transform:translateX(-50%);transition:width var(--transition-fast);width:0}.navbar-link-button:focus-visible .link-underline,.navbar-link-button:hover .link-underline,.navbar-links li.active .link-underline{width:80%}.navbar-toggle{background:#0000;border:none;border-radius:var(--radius-md);cursor:pointer;display:none;flex-direction:column;gap:4px;padding:var(--space-sm);transition:background var(--transition-fast),transform var(--transition-fast)}.navbar-toggle:hover{background:#8295af1f}.navbar-toggle:active{transform:scale(.98)}.navbar-toggle:focus-visible{box-shadow:var(--focus-ring-shadow);outline:2px solid var(--focus-ring-color);outline-offset:2px}.hamburger-line{background:var(--text-primary);border-radius:2px;height:3px;transform-origin:center;transition:transform var(--transition-normal),opacity var(--transition-normal),background var(--transition-fast);width:25px}.navbar-toggle.active .hamburger-line:first-child{transform:rotate(45deg) translate(6px,6px)}.navbar-toggle.active .hamburger-line:nth-child(2){opacity:0;transform:scaleX(0)}.navbar-toggle.active .hamburger-line:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}.mobile-menu-overlay{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#040a14d1;bottom:0;left:0;opacity:0;position:fixed;right:0;top:0;transition:opacity var(--transition-normal),visibility var(--transition-normal);visibility:hidden;z-index:1001}.mobile-menu-overlay.active{opacity:1;visibility:visible}.mobile-menu{-webkit-overflow-scrolling:touch;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#172130c7;border-left:1px solid #ffffff1a;display:flex;flex-direction:column;height:100vh;height:100svh;overflow-y:auto;padding:calc(env(safe-area-inset-top, 0px) + 1.3rem) var(--space-xl) var(--space-xl);position:absolute;right:0;top:0;transform:translateX(100%) scale(.98);transition:transform var(--transition-inertia);width:300px}.mobile-menu.active{transform:translateX(0) scale(1);transition-timing-function:cubic-bezier(.4,0,.2,1)}.mobile-menu-top{align-items:center;border-bottom:1px solid #a9b8d033;display:flex;justify-content:space-between;margin-bottom:var(--space-xl);padding-bottom:var(--space-lg)}.mobile-brand-button{align-items:center;background:#0000;border:none;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;justify-content:center;padding:0;transition:transform var(--transition-fast),background var(--transition-fast)}.mobile-brand-button:hover{background:#8295af1f}.mobile-brand-button:active{transform:scale(.98)}.mobile-close-button{align-items:center;background:#0000;border:none;border-radius:var(--radius-lg);color:#ecf4fff2;cursor:pointer;display:inline-flex;height:44px;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast);width:44px}.mobile-close-button i{font-size:1.9rem}.mobile-close-button:hover{background:#8295af33;color:#fff}.mobile-close-button:active{transform:scale(.98)}.mobile-brand-button:focus-visible,.mobile-close-button:focus-visible{box-shadow:var(--focus-ring-shadow);outline:2px solid var(--focus-ring-color);outline-offset:2px}.mobile-links{display:flex;flex-direction:column;gap:var(--space-sm);list-style:none;margin:0;padding:0}.mobile-links li{margin:0}.mobile-link-button{align-items:center;background:#151d2947;border:none;border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;display:flex;gap:var(--space-md);padding:.92rem var(--space-md);text-align:left;transition:transform var(--transition-fast),background var(--transition-fast),color var(--transition-fast);transition-delay:calc(var(--stagger-index, 0)*50ms);width:100%;will-change:transform}.mobile-link-button:hover{background:var(--bg-card);color:var(--text-primary);transform:translateX(4px)}.mobile-link-button:active{transform:translateX(4px) scale(.98)}.mobile-link-button:focus-visible{box-shadow:var(--focus-ring-shadow);outline:2px solid var(--focus-ring-color);outline-offset:2px}.mobile-link-button i{font-size:18px;text-align:center;width:20px}.mobile-link-button span{font-size:16px;font-weight:500}@media only screen and (min-width:901px){.navbar-menu-desktop{display:flex}.navbar-toggle{display:none}}@media only screen and (max-width:900px){.navbar-container{height:70px;padding:0 var(--space-lg)}.navbar-menu-desktop{display:none}.navbar-toggle{display:flex}.logo-text{font-size:20px}.logo-icon{font-size:16px;height:35px;width:35px}.mobile-menu{padding:calc(env(safe-area-inset-top, 0px) + 1.2rem) var(--space-lg) var(--space-lg);width:min(340px,100%)}}@media only screen and (max-width:480px){.navbar-container{padding:0 var(--space-md)}.mobile-menu{padding:calc(env(safe-area-inset-top, 0px) + 1rem) var(--space-md) var(--space-md);width:100%}.hamburger-line{height:2px;width:22px}}.about-section{background:linear-gradient(180deg,var(--bg-secondary) 0,#141b28 100%);overflow:hidden;padding:var(--space-3xl) 0;position:relative}.about-container{margin:0 auto;max-width:1200px;padding:0 var(--space-xl);position:relative;z-index:1}.section-header{margin-bottom:var(--space-3xl);text-align:center}.section-badge{align-items:center;background:#8a9fbc1f;border:1px solid #94aac63d;border-radius:var(--radius-lg);color:var(--text-secondary);display:inline-flex;font-size:.78rem;gap:var(--space-sm);letter-spacing:.08em;margin-bottom:var(--space-lg);padding:.55rem 1.08rem;text-transform:uppercase}.section-badge i{color:var(--primary-color)}.section-title{color:var(--text-primary);font-size:clamp(2rem,4.6vw,3.2rem);line-height:1.15;margin:0}.about-content{grid-gap:clamp(1.4rem,3vw,3rem);align-items:center;display:grid;gap:clamp(1.4rem,3vw,3rem);grid-template-columns:minmax(0,1.08fr) minmax(0,.92fr);opacity:0;transform:translateY(20px);transition:opacity .75s cubic-bezier(.4,0,.2,1),transform .75s cubic-bezier(.4,0,.2,1);will-change:transform,opacity}.about-content.visible{opacity:1;transform:translateY(0)}.about-text{min-width:0}.intro-text{color:var(--text-primary);font-size:clamp(1.16rem,2vw,1.34rem);line-height:1.72;margin:0 0 var(--space-lg)}.intro-text strong{color:var(--primary-color);font-weight:600}.about-description{grid-gap:1rem;display:grid;gap:1rem}.about-description p{color:var(--text-secondary);font-size:1.03rem;line-height:1.82;margin:0;max-width:64ch}.about-visual{display:flex;justify-content:center}.image-container{width:min(100%,380px)}.image-frame{background:linear-gradient(135deg,#7993b6f0,#85a6c5db);border-radius:var(--radius-2xl);box-shadow:var(--shadow-lg);padding:3px}.image-frame img{border-radius:calc(var(--radius-2xl) - 3px);display:block;height:auto;object-fit:cover;width:100%}.image-tech-badges{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.85rem}.image-tech-badge{align-items:center;background:#708bae33;border:1px solid #92a9c54d;border-radius:var(--radius-lg);color:#d9e5f5;display:inline-flex;font-size:.76rem;padding:.36rem .68rem}@media (max-width:900px){.about-content{grid-template-columns:1fr}.about-visual{order:-1}.image-container{width:min(100%,320px)}}@media (max-width:768px){.about-section{padding:var(--space-2xl) 0}.about-container{padding:0 var(--space-lg)}.section-header{margin-bottom:var(--space-2xl)}.intro-text{font-size:1.08rem}.about-description p{font-size:.97rem;line-height:1.74}}@media (max-width:480px){.about-container{padding:0 var(--space-md)}.image-tech-badge{font-size:.72rem}}.projects-section{background:radial-gradient(circle at top left,#6f8aab29,#0000 30%),radial-gradient(circle at 85% 20%,#89a6c51f,#0000 30%),linear-gradient(180deg,#151d2b,#121926 52%,#101722);overflow:hidden;padding:var(--space-3xl) 0;position:relative}.projects-container{margin:0 auto;max-width:1320px;padding:0 var(--space-xl);position:relative;z-index:1}.projects-header{margin:0 auto var(--space-3xl);max-width:760px;text-align:center}.projects-lead{color:#dde7f7cc;font-size:1rem;line-height:1.72;margin:var(--space-lg) auto 0;max-width:700px}.projects-badge{align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#8a9fbc1f;border:1px solid #94aac63d;border-radius:var(--radius-lg);color:var(--text-secondary);display:inline-flex;font-size:.78rem;font-weight:600;gap:var(--space-sm);letter-spacing:.08em;margin-bottom:var(--space-lg);padding:.55rem 1.08rem;text-transform:uppercase}.projects-badge i{color:var(--primary-color)}.projects-title{font-size:clamp(2rem,4.3vw,3.4rem);letter-spacing:-.03em;line-height:1.08;margin:0}.project-category{margin-bottom:var(--space-3xl);opacity:0;transform:translateY(48px);transition:opacity .9s cubic-bezier(.4,0,.2,1),transform .9s cubic-bezier(.4,0,.2,1);will-change:transform,opacity}.project-category.visible{opacity:1;transform:translateY(0)}.category-header{grid-gap:var(--space-2xl);align-items:flex-end;display:grid;gap:var(--space-2xl);grid-template-columns:minmax(0,.95fr) minmax(0,1.35fr);margin-bottom:var(--space-xl)}.category-info{align-items:flex-start;display:flex;flex-direction:column;gap:var(--space-md)}.category-title{font-size:clamp(1.55rem,2vw,2.2rem);gap:.85rem;letter-spacing:-.03em;margin:0}.category-title,.category-title i{align-items:center;display:inline-flex}.category-title i{background:linear-gradient(135deg,#718badf0,#8ca7c4eb);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);color:#fff;height:46px;justify-content:center;width:46px}.category-period{background:#ffffff0f;border:1px solid #98acc629;border-radius:999px;color:#9fc7ff;font-size:.82rem;font-weight:700;letter-spacing:.08em;margin:0;padding:.4rem .8rem;text-transform:uppercase}.category-description p{color:#ffffffbd;font-size:1rem;line-height:1.75;margin:0}.company-link{color:#7dd3fc;font-weight:700;position:relative;text-decoration:none}.company-link:after{background:currentColor;bottom:-3px;content:"";height:1px;left:0;position:absolute;transform:scaleX(0);transform-origin:left;transition:transform var(--transition-normal);width:100%}.company-link:hover:after{transform:scaleX(1)}.slider-container{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#1721309e;border:1px solid #ffffff1a;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden;padding:clamp(1rem,2vw,1.6rem);position:relative}.slider-container:before{background:radial-gradient(circle at 20% 18%,#b2ccec33,#b2ccec08 42%,#536b9333 78%);content:"";inset:0;pointer-events:none;position:absolute}.slider-indicators,.slider-stage,.slider-toolbar{position:relative;z-index:1}.slider-toolbar{align-items:center;display:flex;gap:var(--space-lg);justify-content:space-between;margin-bottom:var(--space-lg)}.slider-status{align-items:flex-start;display:flex;flex-direction:column;gap:0}.slider-count{color:#cddcf0;font-size:.82rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase}.slider-controls{align-items:center;display:flex;gap:.75rem}.slider-nav{align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#8497b124;border:1px solid #98acc638;border-radius:var(--radius-lg);color:#ffffffeb;cursor:pointer;display:inline-flex;height:52px;justify-content:center;transition:transform var(--transition-normal),background var(--transition-normal),border-color var(--transition-normal),box-shadow var(--transition-normal);width:52px;will-change:transform}.slider-nav:hover{background:#8da2bd2e;border-color:#a2b6cf52;box-shadow:var(--shadow-md);transform:translateY(-1px)}.slider-nav:active{transform:scale(.98)}.slider-nav:focus-visible{box-shadow:var(--focus-ring-shadow);outline:2px solid var(--focus-ring-color);outline-offset:2px}.slider-stage{position:relative}.slider-content,.slider-stage{border-radius:var(--radius-xl);overflow:hidden}.slider-content{cursor:grab;touch-action:pan-y;user-select:none;-webkit-user-select:none}.slider-content,.slider-track{width:100%;will-change:transform}.slider-track{align-items:stretch;display:flex}.slider-track.dragging{cursor:grabbing}.slide-item{flex:0 0 100%;flex-shrink:0;min-width:100%;overflow:hidden}.project-card,.project-card-background,.slide-item{max-width:100%;width:100%}.project-card{height:100%;min-height:0}.project-card-background{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:radial-gradient(circle at 18% 18%,#ffffff24,#0000 30%),radial-gradient(circle at 82% 10%,#ffffff1a,#0000 24%),var(--project-gradient);border-radius:var(--radius-lg);height:100%;min-height:0;overflow:hidden;padding:clamp(1rem,2vw,1.4rem);position:relative}.project-card-grid{grid-gap:clamp(1rem,2vw,1.5rem);display:grid;gap:clamp(1rem,2vw,1.5rem);grid-template-columns:minmax(0,1.35fr) minmax(260px,.85fr);height:100%;min-height:100%;position:relative;z-index:1}.project-copy,.project-visual{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-lg)}.project-copy{background:linear-gradient(180deg,#070a1657,#070a1638);border:1px solid #98acc63d;box-shadow:inset 0 1px 0 #ffffff1a;display:flex;flex-direction:column;height:100%;justify-content:space-between;min-width:0;padding:clamp(1.1rem,2vw,1.6rem);position:relative}.project-copy:before{background:radial-gradient(circle at 18% 16%,#aeccf042,#aeccf00a 48%,#546b9333 80%);border-radius:inherit;content:"";inset:0;-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;padding:1px;pointer-events:none;position:absolute}.project-copy-bottom,.project-copy-top{display:flex;flex-direction:column}.project-copy-top{gap:var(--space-lg)}.project-copy-bottom{gap:var(--space-lg);margin-top:var(--space-lg)}.project-kicker{align-items:center;align-self:flex-start;background:#91a6c133;border:1px solid #98acc63d;border-radius:999px;color:#ffffffe0;display:inline-flex;font-size:.78rem;font-weight:700;letter-spacing:.12em;padding:.45rem .85rem;text-transform:uppercase}.project-meta{display:flex;flex-wrap:wrap;gap:.55rem}.project-meta-chip{background:#070a1647;border:1px solid #98acc638;border-radius:999px;color:#ffffffdb;font-size:.78rem;font-weight:600;letter-spacing:.02em;padding:.45rem .8rem}.project-meta-chip,.project-role{align-items:center;display:inline-flex}.project-role{align-self:flex-start;gap:.45rem}.project-role-label{color:#dfecffc7;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}.project-role-value{background:#708bac38;border:1px solid #95abc54d;border-radius:999px;color:#d6e4f7;font-size:.78rem;font-weight:700;padding:.28rem .62rem}.project-header{gap:var(--space-md);min-width:0}.project-header,.project-icon{align-items:center;display:flex}.project-icon{background:#95aac538;border:1px solid #fff3;border-radius:var(--radius-lg);box-shadow:inset 0 1px 0 #ffffff24;color:#fff;flex-shrink:0;font-size:1.7rem;height:68px;justify-content:center;width:68px}.project-titles{grid-gap:.3rem;align-content:start;display:grid;gap:.3rem;min-width:0}.project-title{color:#fff;font-size:clamp(1.62rem,2.25vw,2.1rem);letter-spacing:-.04em;line-height:1;margin:0 0 .3rem;min-height:2.05em}.project-subtitle,.project-title{-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.project-subtitle{color:#ffffffd1;font-size:1rem;font-weight:500;margin:0;min-height:2.8em}.project-description{min-height:0}.project-description p{-webkit-line-clamp:4;line-clamp:4;-webkit-box-orient:vertical;color:#ffffffe0;display:-webkit-box;font-size:1rem;line-height:1.68;margin:0;max-width:58ch;overflow:hidden}.project-description--expanded p{-webkit-line-clamp:unset;line-clamp:none;display:block;overflow:visible}.project-description-toggle{align-self:flex-start;background:#0000;border:none;color:#c8dbf2;cursor:pointer;display:inline-flex;font-size:.84rem;font-weight:700;padding:.4rem .2rem 0}.project-description-toggle:active{transform:scale(.98)}.project-description-toggle:focus-visible{border-radius:var(--radius-sm);outline:2px solid var(--focus-ring-color);outline-offset:2px}.project-card--expanded,.project-card--expanded .project-card-background,.project-card--expanded .project-copy{height:auto}.project-card--expanded .project-card-grid{min-height:auto}.project-technologies{align-content:flex-start;display:flex;flex-wrap:wrap;gap:.65rem}.tech-tag{align-items:center;background:#060a1657;border:1px solid #98acc63d;border-radius:999px;color:#ffffffeb;display:inline-flex;font-size:.88rem;font-weight:600;gap:.5rem;padding:.62rem .88rem;transition:transform var(--transition-fast),background var(--transition-fast),border-color var(--transition-fast);transition-delay:calc(var(--stagger-index, 0)*50ms);will-change:transform}.tech-tag i{color:#fffffff2}.tech-tag:hover{background:#91a6c13d;border-color:#a5b7ce52;transform:translateY(-1px)}.project-links{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:auto}.project-link{align-items:center;background:#090e1c42;border:1px solid #98acc63d;border-radius:var(--radius-lg);color:#fff;display:inline-flex;font-size:.95rem;font-weight:700;gap:.6rem;justify-content:center;letter-spacing:-.02em;min-height:48px;min-width:148px;padding:.85rem 1.1rem;text-decoration:none;transition:transform var(--transition-normal),border-color var(--transition-normal),background var(--transition-normal),box-shadow var(--transition-normal);transition-delay:calc(var(--stagger-index, 0)*50ms);will-change:transform}.project-link:hover{border-color:#a5b7ce5c;box-shadow:var(--shadow-md);transform:translateY(-1px)}.project-link.github{background:#0f172a66}.project-link.github:hover{background:#0f172a9e}.project-link.demo:hover{background:#6784a75c}.project-link.website:hover{background:#5d817157}.project-link:active{transform:scale(.98)}.company-link:focus-visible,.project-link:focus-visible{box-shadow:var(--focus-ring-shadow);outline:2px solid var(--focus-ring-color);outline-offset:2px}.project-visual{align-items:center;background:linear-gradient(180deg,#060a162e,#060a166b);border:1px solid #98acc638;display:flex;isolation:isolate;justify-content:center;overflow:hidden;padding:clamp(1rem,2vw,1.4rem);position:relative}.project-orbit{border:1px solid #ffffff24;border-radius:999px;position:absolute;z-index:0}.project-orbit--one{animation:float 12s cubic-bezier(.4,0,.2,1) infinite;height:220px;width:220px}.project-visual-card{align-items:center;background:#91a6c133;border:1px solid #ffffff2e;border-radius:var(--radius-lg);box-shadow:0 12px 28px #00000029,inset 0 1px 0 #ffffff1f;display:flex;flex-direction:column;gap:.9rem;padding:1.4rem 1rem 1.2rem;position:relative;text-align:center;width:min(100%,230px);z-index:1}.project-visual-label{background:#070a1640;border:1px solid #98acc638;border-radius:999px;color:#fffc;display:inline-flex;font-size:.72rem;font-weight:700;letter-spacing:.12em;margin-bottom:.1rem;padding:.35rem .7rem;text-transform:uppercase}.project-visual-icon{align-items:center;background:#ffffff29;border:1px solid #ffffff2e;border-radius:var(--radius-xl);color:#fff;display:flex;font-size:2rem;height:82px;justify-content:center;width:82px}.project-visual-card strong{color:#fff;font-size:1.25rem;letter-spacing:-.03em;line-height:1.1;max-width:14ch}.project-visual-card span:last-child{color:#ffffffc2;font-size:.94rem;line-height:1.45;max-width:18ch}.project-card--personal .project-icon,.project-card--personal .project-visual-card{box-shadow:0 18px 40px #131d5c2e}.project-card--professional .project-icon,.project-card--professional .project-visual-card{box-shadow:0 18px 40px #0838462e}.slider-indicators{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:var(--space-lg)}.indicator,.slider-indicators{align-items:center;justify-content:center}.indicator{background:#0000;border:none;border-radius:999rem;cursor:pointer;display:inline-flex;height:2.2rem;padding:0;transition:transform var(--transition-fast);transition-delay:calc(var(--stagger-index, 0)*50ms);width:2.2rem;will-change:transform}.indicator:before{background:#fff3;border-radius:999px;content:"";height:12px;transform:scale(1);transition:transform var(--transition-fast),background var(--transition-fast);width:12px}.indicator:hover:before{background:#b1c2d68c}.indicator.active:before{background:linear-gradient(135deg,#8aa7c8,#6d8db8);transform:scale(1.3)}.indicator:focus-visible{outline:2px solid var(--focus-ring-color);outline-offset:3px}.indicator:active{transform:scale(.98)}@media only screen and (max-width:1100px){.projects-container{padding:0 var(--space-lg)}.category-header{align-items:flex-start;grid-template-columns:1fr}.project-card-grid{grid-template-columns:minmax(0,1fr) minmax(220px,.7fr)}}@media only screen and (max-width:820px){.slider-content,.slider-stage{border-radius:var(--radius-lg)}.project-category{opacity:1;transform:none}.projects-section{padding:var(--space-2xl) 0}.projects-container{padding:0 var(--space-md)}.projects-header{margin-bottom:var(--space-2xl)}.slider-toolbar{align-items:flex-start;flex-direction:column}.slider-controls{justify-content:flex-end;width:100%}.project-card,.project-card-background{height:100%;min-height:0}.project-card-grid{grid-template-columns:1fr;grid-template-rows:minmax(0,1fr);min-height:0}.project-visual{display:none}.project-copy{min-height:0;padding:1.35rem}.project-copy-top{gap:1.15rem}.project-description{min-height:0}.project-copy-bottom{justify-content:flex-end;margin-top:auto;min-height:0}.project-technologies{align-content:flex-start;min-height:0}}@media only screen and (max-width:640px){.projects-container{padding:0 var(--space-sm)}.projects-title{font-size:clamp(1.8rem,9vw,2.5rem)}.projects-badge{font-size:.72rem;padding:.6rem .95rem}.category-header{gap:var(--space-lg);margin-bottom:var(--space-lg)}.category-title{font-size:1.45rem}.category-title i{font-size:1rem;height:42px;width:42px}.slider-container{border-radius:var(--radius-xl);padding:.9rem}.slider-toolbar{gap:var(--space-md);margin-bottom:var(--space-md)}.slider-controls{justify-content:space-between}.slider-nav{height:48px;width:48px}.slider-content,.slider-nav{border-radius:var(--radius-lg)}.project-card,.project-card-background{height:100%;min-height:0}.project-card-background{border-radius:var(--radius-lg);padding:1.2rem}.project-copy{border-radius:var(--radius-lg);padding:1.3rem}.project-meta-chip{font-size:.74rem;padding:.42rem .72rem}.project-kicker{font-size:.7rem}.project-header{align-items:flex-start}.project-icon{border-radius:var(--radius-lg);font-size:1.35rem;height:56px;width:56px}.project-title{font-size:1.42rem;line-height:1.08;min-height:auto}.project-subtitle{font-size:.9rem;min-height:auto}.project-description p{-webkit-line-clamp:6;line-clamp:6;font-size:.91rem;line-height:1.62}.project-description-toggle{display:inline-flex}.project-copy-bottom{gap:1rem;margin-top:var(--space-xl)}.tech-tag{font-size:.78rem;padding:.65rem .82rem}.project-links{gap:.6rem}.project-link{flex:1 1 100%;font-size:.88rem;min-height:48px;min-width:0;padding:.9rem 1rem}.slider-indicators{margin-top:var(--space-md)}}@media only screen and (max-width:390px){.projects-section{padding:var(--space-xl) 0}.project-card,.project-card-background{height:100%;min-height:0}.project-card-background{padding:1rem}.project-copy{padding:1.1rem}.project-meta{gap:.45rem}.project-header{flex-direction:column;gap:.85rem}.project-icon{height:52px;width:52px}.project-title{font-size:1.4rem}.project-description p{font-size:.9rem;line-height:1.6}.tech-tag{justify-content:center;width:100%}.project-link{flex-basis:100%}.project-subtitle{-webkit-line-clamp:3;line-clamp:3}}@media (hover:none) and (pointer:coarse){.slider-content{cursor:default;overscroll-behavior:auto;touch-action:pan-y}.project-link:hover,.slider-nav:hover,.tech-tag:hover{box-shadow:none;transform:none}.slider-nav:active{transform:scale(.96)}}@media only screen and (max-height:500px) and (orientation:landscape){.project-card-grid{grid-template-columns:minmax(0,1.2fr) minmax(190px,.8fr)}.project-copy{padding:.95rem}.project-visual{min-height:0}.project-title{font-size:1.5rem}.project-description p{font-size:.9rem;line-height:1.5}}.experience-section-v2{background:linear-gradient(180deg,#141c2b,#121926);padding:var(--space-3xl) 0;position:relative}.experience-container-v2{margin:0 auto;max-width:1200px;padding:0 var(--space-xl);position:relative;z-index:1}.experience-timeline-v2{margin-top:var(--space-2xl);opacity:0;padding-left:2.2rem;position:relative;transform:translateY(20px);transition:opacity .6s cubic-bezier(.4,0,.2,1),transform .6s cubic-bezier(.4,0,.2,1);will-change:transform,opacity}.experience-timeline-v2.visible{opacity:1;transform:translateY(0)}.experience-timeline-v2:before{background:linear-gradient(180deg,#708cb0eb,#8ca8c485);bottom:.2rem;content:"";left:0;position:absolute;top:.2rem;width:2px}.experience-item-v2{margin-bottom:var(--space-xl);position:relative}.experience-item-v2:last-child{margin-bottom:0}.experience-marker-v2{background:#6e8cba;border-radius:50%;box-shadow:0 0 0 4px #7e95b43d;height:13px;left:-2.45rem;position:absolute;top:.55rem;width:13px}.experience-main-v2{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#1721309e;border:1px solid #ffffff1a;border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:1.3rem 1.35rem}.experience-top-v2{align-items:baseline;display:flex;flex-wrap:wrap;gap:var(--space-md);justify-content:space-between}.experience-top-v2 h3{color:var(--text-primary);font-size:1.15rem;margin:0}.experience-period-v2{background:#6f8aab33;border:1px solid #95abc54d;border-radius:var(--radius-lg);color:#d3e1f5;display:inline-flex;font-size:.78rem;font-weight:700;letter-spacing:.06em;padding:.3rem .76rem;text-transform:uppercase}.experience-company-v2{color:#acc6e6;font-size:.95rem;font-weight:600;margin:.35rem 0 .6rem}.experience-description-v2{color:var(--text-secondary);font-size:.99rem;line-height:1.68;margin:0}.experience-points-v2{color:var(--text-secondary);font-size:.96rem;line-height:1.65;margin:0;padding-left:1.1rem}.experience-points-v2 li{margin-bottom:.4rem}.experience-points-v2 li:last-child{margin-bottom:0}@media (max-width:768px){.experience-section-v2{padding:var(--space-2xl) 0}.experience-container-v2{padding:0 var(--space-lg)}.experience-timeline-v2{padding-left:1.6rem}.experience-marker-v2{left:-1.86rem}.experience-main-v2{padding:1rem}.experience-top-v2 h3{font-size:1.05rem}.experience-description-v2{font-size:.95rem}}@media (max-width:480px){.experience-container-v2{padding:0 var(--space-md)}.experience-top-v2{align-items:flex-start;flex-direction:column;gap:.5rem}.experience-period-v2{font-size:.73rem}}.skills-section-v2{background:linear-gradient(180deg,#151d2b,#121926);padding:var(--space-3xl) 0;position:relative}.skills-section-v2:before{background:radial-gradient(circle at 20% 20%,#728eb22b,#0000 30%),radial-gradient(circle at 80% 75%,#89a6c521,#0000 32%);content:"";inset:0;pointer-events:none;position:absolute}.skills-container-v2{margin:0 auto;max-width:1200px;padding:0 var(--space-xl);position:relative;z-index:1}.skills-lead-v2{color:var(--text-secondary);font-size:1rem;line-height:1.74;margin:var(--space-lg) auto 0;max-width:760px}.skills-layout-v2{grid-gap:var(--space-lg);display:grid;gap:var(--space-lg);grid-template-columns:repeat(2,minmax(0,1fr));margin-top:var(--space-2xl);opacity:0;transform:translateY(18px);transition:opacity .55s cubic-bezier(.4,0,.2,1),transform .55s cubic-bezier(.4,0,.2,1);will-change:transform,opacity}.skills-layout-v2.visible{opacity:1;transform:translateY(0)}.skills-group-v2{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#1721309e;border:1px solid #ffffff1a;border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:1.2rem;transition-delay:calc(var(--stagger-index, 0)*50ms)}.skills-group-v2 h3{color:var(--text-primary);font-size:1.02rem;margin:0 0 .8rem}.skills-group-v2--featured{background:linear-gradient(180deg,#1e2939eb,#17202ee0);border-color:#8da4c059;box-shadow:var(--shadow-lg);grid-column:1/-1;padding:1.4rem}.skills-group-v2--featured h3{color:#e2ebf8;font-size:1.18rem}.skills-tags-v2{display:flex;flex-wrap:wrap;gap:.55rem}.skill-chip-v2{align-items:center;background:#7e94b11f;border:1px solid #97acc633;border-radius:var(--radius-lg);color:#d5e1f2;display:inline-flex;font-size:.86rem;letter-spacing:.01em;padding:.44rem .82rem;transition:transform var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast);transition-delay:calc(var(--stagger-index, 0)*50ms);will-change:transform}.skill-chip-v2:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px)}.skills-group-v2--featured .skill-chip-v2{background:#6c88ad38;border-color:#95acc657;color:#eef3fb;font-weight:600}@media (max-width:900px){.skills-layout-v2{grid-template-columns:1fr}.skills-group-v2--featured{grid-column:auto}}@media (max-width:768px){.skills-section-v2{padding:var(--space-2xl) 0}.skills-container-v2{padding:0 var(--space-lg)}.skills-lead-v2{font-size:.95rem}.skills-group-v2,.skills-group-v2--featured{padding:.95rem}.skill-chip-v2{font-size:.82rem}}@media (max-width:480px){.skills-container-v2{padding:0 var(--space-md)}.skills-tags-v2{gap:.45rem}.skill-chip-v2{font-size:.78rem;padding:.35rem .62rem}}.services-section{background:linear-gradient(180deg,#151d2b,#121a28);padding:var(--space-3xl) 0;position:relative}.services-section:before{background:radial-gradient(circle at 15% 30%,#8ba8c624,#0000 28%),radial-gradient(circle at 85% 70%,#728eb129,#0000 30%);content:"";inset:0;pointer-events:none;position:absolute}.services-container{margin:0 auto;max-width:1200px;padding:0 var(--space-xl);position:relative;z-index:1}.services-lead{color:var(--text-secondary);font-size:1rem;line-height:1.74;margin:var(--space-lg) auto 0;max-width:760px;text-align:center}.services-grid{grid-gap:var(--space-md);display:grid;gap:var(--space-md);grid-template-columns:repeat(2,minmax(0,1fr));margin-top:var(--space-2xl);opacity:0;transform:translateY(18px);transition:opacity .6s cubic-bezier(.4,0,.2,1),transform .6s cubic-bezier(.4,0,.2,1);will-change:transform,opacity}.services-grid.visible{opacity:1;transform:translateY(0)}.service-card{align-items:flex-start;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#1721309e;border:1px solid #ffffff1a;border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);display:flex;gap:.8rem;padding:1.2rem;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast);transition-delay:calc(var(--stagger-index, 0)*50ms);will-change:transform}.service-icon{align-items:center;background:#6f8aab40;border:1px solid #96abc457;border-radius:var(--radius-lg);color:#cfe1f6;display:inline-flex;flex-shrink:0;font-size:.78rem;height:28px;justify-content:center;width:28px}.service-card p{color:var(--text-primary);line-height:1.58;margin:0}.service-card:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px)}.services-faq{margin-top:var(--space-2xl)}.services-faq-title{color:#e3ecf9;font-size:clamp(1.05rem,2.2vw,1.35rem);letter-spacing:-.01em;margin:0 0 var(--space-md)}.services-faq-grid{grid-gap:var(--space-md);display:grid;gap:var(--space-md);grid-template-columns:repeat(3,minmax(0,1fr))}.faq-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#1721309e;border:1px solid #ffffff1a;border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:1.2rem 1.2rem 1.25rem;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast);transition-delay:calc(var(--stagger-index, 0)*50ms);will-change:transform}.faq-card:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px)}.faq-card h4{color:#eef5ff;font-size:.95rem;line-height:1.35;margin:0 0 .42rem}.faq-card p{color:var(--text-secondary);font-size:.92rem;line-height:1.56;margin:0}@media (max-width:768px){.services-section{padding:var(--space-2xl) 0}.services-container{padding:0 var(--space-lg)}.services-grid{grid-template-columns:1fr}.services-lead{font-size:.96rem}.services-faq-grid{grid-template-columns:1fr}}@media (max-width:480px){.services-container{padding:0 var(--space-md)}.service-card p{font-size:.93rem}}.footer{background:#121926;overflow:hidden;padding:var(--space-2xl) 0 var(--space-lg) 0;position:relative}.footer-container{margin:0 auto;max-width:1320px;padding:0 var(--space-xl);position:relative;z-index:2}.footer-header{margin-bottom:var(--space-2xl);text-align:center}.footer-title{color:var(--text-primary);font-size:clamp(2rem,4vw,3rem);font-weight:700;line-height:1.2;margin:var(--space-lg) 0 var(--space-md) 0}.footer-subtitle{color:var(--text-secondary);font-size:18px;line-height:1.6;margin:0 auto;max-width:600px}.footer-actions{margin-bottom:var(--space-2xl);opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.4,0,.2,1),transform .8s cubic-bezier(.4,0,.2,1);will-change:transform,opacity}.footer-actions.visible{opacity:1;transform:translateY(0)}.contact-grid{grid-gap:var(--space-lg);display:grid;gap:var(--space-lg);grid-template-columns:repeat(4,minmax(0,1fr));margin:0 auto;max-width:100%}.contact-card{align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#18212fc7;border:1px solid #ffffff1a;border-radius:var(--radius-lg);color:var(--text-primary);display:flex;gap:var(--space-lg);min-height:80px;min-width:0;overflow:hidden;padding:var(--space-xl) var(--space-xl);position:relative;text-decoration:none;transition:transform var(--transition-fast),background var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast),color var(--transition-fast);transition-delay:calc(var(--stagger-index, 0)*50ms);will-change:transform}.contact-card:before{background:linear-gradient(88deg,#0000,#99adc62e,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left var(--transition-slow);width:100%}.contact-card:hover:before{left:100%}.contact-card:hover{background:#1f2a3ae6;border-color:#a2b6cf47;box-shadow:var(--shadow-md);transform:translateY(-1px)}.contact-card:active{transform:scale(.98)}.contact-card:focus-visible{box-shadow:var(--focus-ring-shadow);outline:2px solid var(--focus-ring-color);outline-offset:2px}.contact-card.cv:hover{background:#543f3952;border-color:#b9847b6b}.contact-card.github:hover{background:#3e485652;border-color:#94a3b86b}.contact-card.linkedin:hover{background:#34495d52;border-color:#6d92b36b}.contact-card.email:hover{background:#384e4352;border-color:#77a08b6b}.contact-icon{align-items:center;background:#8295b02e;border-radius:var(--radius-lg);color:var(--accent-primary);display:flex;flex-shrink:0;font-size:20px;height:50px;justify-content:center;transition:transform var(--transition-fast),background var(--transition-fast),color var(--transition-fast);width:50px}.contact-card:hover .contact-icon{background:#95aac54d;transform:scale(1.04)}.contact-info{flex:1 1;min-width:0;text-align:left}.contact-info h3{color:var(--text-primary);font-size:18px;font-weight:600;margin:0 0 var(--space-xs) 0}.contact-info p{line-height:1.4;margin:0;overflow-wrap:anywhere;word-break:break-word}.contact-arrow,.contact-info p{color:var(--text-secondary);font-size:14px}.contact-arrow{align-items:center;background:#8295b02e;border-radius:var(--radius-lg);display:flex;flex-shrink:0;height:30px;justify-content:center;transition:transform var(--transition-fast),background var(--transition-fast),color var(--transition-fast);width:30px}.contact-card:hover .contact-arrow{background:var(--accent-primary);color:#fff;transform:translateX(3px)}.footer-bottom{margin-top:var(--space-2xl)}.footer-divider{background:linear-gradient(88deg,#0000,#99adc659,#0000);height:1px;margin-bottom:var(--space-lg)}.footer-copyright{padding:var(--space-lg) 0;text-align:center}.footer-copyright p{color:var(--text-secondary);font-size:14px;line-height:1.5;margin:0}.footer-love{color:var(--accent-primary)}.footer-love i{animation:heartbeat 2s cubic-bezier(.4,0,.2,1) infinite;color:#ef4444;margin:0 4px}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}@media (max-width:1024px){.contact-grid{grid-template-columns:repeat(2,1fr);max-width:100%}}@media (max-width:1280px){.contact-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:768px){.footer{padding:var(--space-xl) 0 var(--space-md) 0}.footer-container{padding:0 var(--space-md)}.footer-header{margin-bottom:var(--space-lg)}.footer-title{font-size:1.8rem;line-height:1.3;margin:var(--space-md) 0}.footer-subtitle{font-size:15px;padding:0 var(--space-sm)}.contact-grid{gap:var(--space-md);grid-template-columns:repeat(2,minmax(0,1fr));max-width:100%}.contact-card{flex-direction:row;gap:var(--space-md);min-height:70px;padding:var(--space-lg);text-align:left}.contact-icon{flex-shrink:0;font-size:20px;height:45px;width:45px}.contact-info{flex:1 1}.contact-info h3{font-size:17px;margin-bottom:4px}.contact-info p{font-size:14px;line-height:1.4}.contact-arrow{flex-shrink:0;font-size:14px;height:30px;width:30px}.footer-bottom{margin-top:var(--space-lg);padding-top:var(--space-md)}.footer-copyright p{font-size:12px;line-height:1.5;padding:0 var(--space-sm)}}@media (max-width:480px){.footer{padding:var(--space-lg) 0 var(--space-sm) 0}.footer-container{padding:0 var(--space-sm)}.footer-header{margin-bottom:var(--space-md)}.footer-title{font-size:1.5rem;line-height:1.2;margin:var(--space-sm) 0}.footer-subtitle{font-size:13px;padding:0 var(--space-xs)}.contact-grid{gap:var(--space-sm);grid-template-columns:1fr;max-width:100%}.contact-card{flex-direction:row;gap:var(--space-sm);min-height:60px;padding:var(--space-md);text-align:left}.contact-icon{flex-shrink:0;font-size:18px;height:40px;width:40px}.contact-info{flex:1 1}.contact-info h3{font-size:15px;margin-bottom:2px}.contact-info p{font-size:12px;line-height:1.3}.contact-arrow{flex-shrink:0;font-size:12px;height:25px;width:25px}.footer-bottom{margin-top:var(--space-md);padding-top:var(--space-sm)}.footer-copyright p{font-size:11px;line-height:1.4;padding:0 var(--space-xs)}}
/*# sourceMappingURL=main.644417dd.css.map*/