@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Poppins:wght@400;500;600;700&display=swap";:root{--primary: #0066FF;--primary-dark: #0052CC;--primary-light: #4D94FF;--primary-bg: rgba(0, 102, 255, .08);--secondary: #1A1A2E;--dark: #0F0F1A;--darker: #0A0A12;--white: #FFFFFF;--gray-50: #F8FAFC;--gray-100: #F1F5F9;--gray-200: #E2E8F0;--gray-300: #CBD5E1;--gray-400: #94A3B8;--gray-500: #64748B;--gray-600: #475569;--gray-700: #334155;--gray-800: #1E293B;--gray-900: #0F172A;--success: #10B981;--warning: #F59E0B;--error: #EF4444;--font-primary: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-heading: "Poppins", sans-serif;--section-padding: clamp(80px, 12vw, 140px);--container-width: min(1200px, 92%);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-primary: 0 10px 40px -10px rgba(0, 102, 255, .4);--transition-fast: .15s ease;--transition-base: .3s ease;--transition-slow: .5s ease;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:100px}body{font-family:var(--font-primary);background:var(--dark);color:var(--gray-300);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}::selection{background:var(--primary);color:var(--white)}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--darker)}::-webkit-scrollbar-thumb{background:var(--gray-700);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto;display:block}button{font-family:inherit;cursor:pointer;border:none;background:none}.container{width:var(--container-width);max-width:1200px;margin:0 auto}.section{padding:var(--section-padding) 0;position:relative}.section-header{text-align:center;margin-bottom:60px}.section-label{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:var(--primary-bg);border:1px solid rgba(0,102,255,.2);border-radius:var(--radius-full);font-size:.85rem;font-weight:600;color:var(--primary-light);text-transform:uppercase;letter-spacing:.5px;margin-bottom:20px}.section-title{font-family:var(--font-heading);font-size:clamp(2rem,4vw,2.75rem);font-weight:700;color:var(--white);line-height:1.2;margin-bottom:16px}.section-subtitle{font-size:1.1rem;color:var(--gray-400);max-width:600px;margin:0 auto}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;font-size:.95rem;font-weight:600;border-radius:var(--radius-md);transition:var(--transition-base);cursor:pointer}.btn-primary{background:var(--primary);color:var(--white);box-shadow:var(--shadow-primary)}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 14px 44px -10px #0066ff80}.btn-secondary{background:transparent;color:var(--white);border:2px solid var(--gray-700)}.btn-secondary:hover{border-color:var(--primary);color:var(--primary-light);background:var(--primary-bg)}.card{background:var(--secondary);border:1px solid var(--gray-800);border-radius:var(--radius-lg);transition:var(--transition-base)}.card:hover{border-color:var(--gray-700);box-shadow:var(--shadow-xl)}.header{position:fixed;top:0;left:0;right:0;z-index:1000;padding:20px 0;transition:var(--transition-base)}.header--scrolled{padding:14px 0;background:#0f0f1af2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--gray-800)}.header__container{width:var(--container-width);max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.header__logo{display:flex;align-items:center;gap:12px;text-decoration:none}.header__logo-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--primary);border-radius:var(--radius-md);transition:var(--transition-base)}.header__logo-icon span{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--white)}.header__logo:hover .header__logo-icon{transform:scale(1.05);box-shadow:var(--shadow-primary)}.header__logo-text{display:flex;flex-direction:column}.header__logo-name{font-family:var(--font-heading);font-size:1.1rem;font-weight:600;color:var(--white);line-height:1.2}.header__logo-role{font-size:.75rem;color:var(--gray-500);font-weight:500}.header__nav{display:flex;align-items:center;gap:8px}.header__nav-link{position:relative;padding:10px 16px;font-size:.9rem;font-weight:500;color:var(--gray-400);transition:var(--transition-base);border-radius:var(--radius-sm)}.header__nav-link:hover{color:var(--white)}.header__nav-link--active{color:var(--white);background:var(--primary-bg)}.header__nav-link--active:after{content:"";position:absolute;bottom:6px;left:50%;transform:translate(-50%);width:20px;height:2px;background:var(--primary);border-radius:2px}.header__actions{display:flex;align-items:center;gap:20px}.header__socials{display:flex;align-items:center;gap:8px}.header__socials a{width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--gray-400);border:1px solid var(--gray-800);border-radius:var(--radius-sm);transition:var(--transition-base)}.header__socials a:hover{color:var(--primary);border-color:var(--primary);background:var(--primary-bg)}.header__cta{padding:10px 22px;background:var(--primary);color:var(--white);font-size:.9rem;font-weight:600;border-radius:var(--radius-md);transition:var(--transition-base)}.header__cta:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-primary)}.header__toggle{display:none;width:44px;height:44px;align-items:center;justify-content:center;color:var(--white);border:1px solid var(--gray-800);border-radius:var(--radius-sm)}.header__mobile{position:fixed;inset:0;background:var(--dark);padding:100px 24px 40px;display:flex;flex-direction:column;transform:translate(100%);transition:var(--transition-base);z-index:-1}.header__mobile--open{transform:translate(0)}.header__mobile-nav{display:flex;flex-direction:column;gap:8px}.header__mobile-link{padding:16px 20px;font-size:1.1rem;font-weight:500;color:var(--gray-300);border-radius:var(--radius-md);transition:var(--transition-base)}.header__mobile-link:hover{background:var(--secondary);color:var(--white)}.header__mobile-footer{margin-top:auto;display:flex;flex-direction:column;gap:24px}.header__mobile-socials{display:flex;justify-content:center;gap:16px}.header__mobile-socials a{width:48px;height:48px;display:flex;align-items:center;justify-content:center;color:var(--gray-400);border:1px solid var(--gray-800);border-radius:var(--radius-md);transition:var(--transition-base)}.header__mobile-socials a:hover{color:var(--primary);border-color:var(--primary)}@media(max-width:900px){.header__nav,.header__socials,.header__cta{display:none}.header__toggle{display:flex}}@media(max-width:480px){.header__logo-text{display:none}}.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:120px 0 80px;overflow:hidden}.hero__bg{position:absolute;inset:0;z-index:0;overflow:hidden}.hero__grid{position:absolute;inset:0;background-image:linear-gradient(rgba(0,102,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,102,255,.03) 1px,transparent 1px);background-size:80px 80px;-webkit-mask-image:radial-gradient(ellipse 60% 50% at 50% 50%,black,transparent);mask-image:radial-gradient(ellipse 60% 50% at 50% 50%,black,transparent)}.hero__glow{position:absolute;border-radius:50%;filter:blur(100px)}.hero__glow--1{width:600px;height:600px;background:#0066ff26;top:-200px;left:-100px}.hero__glow--2{width:400px;height:400px;background:#0066ff1a;bottom:-100px;right:-100px}.hero__container{position:relative;z-index:1;width:var(--container-width);max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}.hero__content{display:flex;flex-direction:column;gap:24px}.hero__status{display:inline-flex;align-items:center;gap:10px;padding:8px 16px;background:#10b9811a;border:1px solid rgba(16,185,129,.2);border-radius:var(--radius-full);width:fit-content;font-size:.85rem;font-weight:500;color:var(--success)}.hero__status-dot{width:8px;height:8px;background:var(--success);border-radius:50%;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.hero__title{font-family:var(--font-heading);font-size:clamp(2.5rem,5vw,3.5rem);font-weight:700;color:var(--white);line-height:1.15}.hero__name{color:var(--primary)}.hero__role{display:inline-block;background:linear-gradient(135deg,var(--gray-300),var(--gray-500));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero__description{font-size:1.1rem;color:var(--gray-400);line-height:1.7;max-width:500px}.hero__description strong{color:var(--white);font-weight:600}.hero__highlights{display:flex;flex-wrap:wrap;gap:16px}.hero__highlight{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--secondary);border:1px solid var(--gray-800);border-radius:var(--radius-full);font-size:.85rem;font-weight:500;color:var(--gray-300)}.hero__highlight svg{color:var(--primary)}.hero__actions{display:flex;gap:16px;margin-top:8px}.hero__info{display:flex;align-items:center;gap:16px;padding-top:16px;border-top:1px solid var(--gray-800)}.hero__info-item{display:flex;align-items:center;gap:8px;font-size:.9rem;color:var(--gray-500)}.hero__info-item svg{color:var(--gray-600)}.hero__info-divider{width:1px;height:20px;background:var(--gray-800)}.hero__visual{position:relative;display:flex;flex-direction:column;align-items:center;gap:30px}.hero__image-wrapper{position:relative;width:380px;height:380px}.hero__image-bg{position:absolute;inset:-10px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:50%;opacity:.2;animation:float 6s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.hero__image{position:relative;width:100%;height:100%;object-fit:cover;border-radius:50%;border:4px solid var(--gray-800)}.hero__float{position:absolute;display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--secondary);border:1px solid var(--gray-800);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);animation:floatCard 4s ease-in-out infinite}.hero__float--exp{top:30px;right:-30px;animation-delay:0s}.hero__float--projects{bottom:50px;left:-40px;animation-delay:-2s}@keyframes floatCard{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.hero__float-icon{font-size:1.5rem}.hero__float-content{display:flex;flex-direction:column}.hero__float-value{font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--white)}.hero__float-label{font-size:.75rem;color:var(--gray-500)}.hero__tech{display:flex;align-items:center;gap:20px;padding:20px 28px;background:var(--secondary);border:1px solid var(--gray-800);border-radius:var(--radius-xl)}.hero__tech-label{font-size:.85rem;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px}.hero__tech-list{display:flex;gap:12px}.hero__tech-item{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--dark);border:1px solid var(--gray-800);border-radius:var(--radius-md);transition:var(--transition-base)}.hero__tech-item img{width:24px;height:24px}.hero__tech-item:hover{border-color:var(--primary);transform:translateY(-4px)}.hero__scroll{position:absolute;bottom:40px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:10px}.hero__scroll span{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:1px;color:var(--gray-600)}.hero__scroll-line{width:1px;height:60px;background:var(--gray-800);position:relative;overflow:hidden}.hero__scroll-dot{position:absolute;top:0;width:100%;height:20px;background:var(--primary);animation:scrollDown 2s ease-in-out infinite}@keyframes scrollDown{0%{top:-20px}to{top:60px}}@media(max-width:1024px){.hero__container{grid-template-columns:1fr;text-align:center;gap:60px}.hero__content{align-items:center}.hero__description{max-width:600px}.hero__highlights,.hero__actions,.hero__info{justify-content:center}.hero__visual{order:-1}.hero__image-wrapper{width:300px;height:300px}.hero__float--exp{right:10px}.hero__float--projects{left:10px}}@media(max-width:640px){.hero{padding:100px 0 60px}.hero__image-wrapper{width:240px;height:240px}.hero__float{display:none}.hero__actions{flex-direction:column;width:100%}.hero__actions .btn{width:100%}.hero__info{flex-direction:column;gap:8px}.hero__info-divider{display:none}.hero__tech{flex-direction:column;gap:16px}.hero__scroll{display:none}}.about{background:var(--secondary);position:relative}.about:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gray-800),transparent)}.about__grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:80px;align-items:start}.about__image-section{position:sticky;top:120px}.about__image-wrapper{position:relative;border-radius:var(--radius-xl);overflow:hidden}.about__image{width:100%;height:500px;object-fit:cover}.about__image-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.6) 100%)}.about__badge{position:absolute;bottom:24px;right:24px;display:flex;align-items:center;gap:12px;padding:16px 24px;background:var(--primary);border-radius:var(--radius-lg);color:var(--white)}.about__badge-value{font-family:var(--font-heading);font-size:2rem;font-weight:700;line-height:1}.about__badge-label{font-size:.8rem;font-weight:500;opacity:.9;line-height:1.3}.about__content{display:flex;flex-direction:column;gap:32px}.about__intro{display:flex;flex-direction:column;gap:8px}.about__name{font-family:var(--font-heading);font-size:1.75rem;font-weight:600;color:var(--white)}.about__name span{color:var(--primary)}.about__role{font-size:1rem;color:var(--gray-400);font-weight:500}.about__bio{display:flex;flex-direction:column;gap:16px}.about__bio p{font-size:1rem;color:var(--gray-400);line-height:1.8}.about__bio strong{color:var(--white);font-weight:600}.about__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;padding:28px 0;border-top:1px solid var(--gray-800);border-bottom:1px solid var(--gray-800)}.about__stat{display:flex;align-items:center;gap:14px}.about__stat-icon{width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:var(--primary-bg);border-radius:var(--radius-md);color:var(--primary)}.about__stat-content{display:flex;flex-direction:column}.about__stat-value{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;color:var(--white)}.about__stat-label{font-size:.8rem;color:var(--gray-500)}.about__education{display:flex;flex-direction:column;gap:20px}.about__section-title{display:flex;align-items:center;gap:10px;font-size:1.1rem;font-weight:600;color:var(--white)}.about__section-title svg{color:var(--primary)}.about__edu-list{display:flex;flex-direction:column;gap:16px;padding-left:12px;border-left:2px solid var(--gray-800)}.about__edu-item{display:flex;gap:16px;position:relative}.about__edu-dot{position:absolute;left:-19px;top:8px;width:12px;height:12px;background:var(--primary);border-radius:50%;border:2px solid var(--secondary)}.about__edu-content{display:flex;flex-direction:column;gap:4px;padding-left:8px}.about__edu-content h5{font-size:1rem;font-weight:600;color:var(--white)}.about__edu-content p{font-size:.9rem;color:var(--gray-400)}.about__edu-content span{font-size:.8rem;color:var(--primary);font-weight:500}.about__cta{display:flex;gap:16px}@media(max-width:1024px){.about__grid{grid-template-columns:1fr;gap:50px}.about__image-section{position:relative;top:auto}.about__image{height:400px}.about__stats{grid-template-columns:repeat(3,1fr)}}@media(max-width:640px){.about__stats{grid-template-columns:1fr;gap:16px}.about__cta{flex-direction:column}.about__cta .btn{width:100%;justify-content:center}.about__image{height:300px}}.skills{background:var(--dark)}.skills__filters{display:flex;justify-content:center;gap:12px;margin-bottom:50px;flex-wrap:wrap}.skills__filter{padding:10px 24px;background:transparent;border:1px solid var(--gray-800);border-radius:var(--radius-full);font-size:.9rem;font-weight:500;color:var(--gray-400);cursor:pointer;transition:var(--transition-base)}.skills__filter:hover{border-color:var(--primary);color:var(--white)}.skills__filter--active{background:var(--primary);border-color:var(--primary);color:var(--white);box-shadow:var(--shadow-primary)}.skills__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.skill-card{padding:24px;background:var(--secondary);border:1px solid var(--gray-800);border-radius:var(--radius-lg);transition:var(--transition-base);animation:fadeInUp .5s ease forwards;animation-delay:var(--delay);opacity:0}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}0%{opacity:0;transform:translateY(20px)}}.skill-card:hover{border-color:var(--gray-700);transform:translateY(-4px);box-shadow:var(--shadow-lg)}.skill-card__header{display:flex;align-items:center;gap:16px;margin-bottom:16px}.skill-card__icon{width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:var(--dark);border:1px solid var(--gray-800);border-radius:var(--radius-md);padding:10px}.skill-card__icon img{width:100%;height:100%;object-fit:contain}.skill-card__info{flex:1;display:flex;justify-content:space-between;align-items:center}.skill-card__name{font-size:1rem;font-weight:600;color:var(--white)}.skill-card__level{font-size:.9rem;font-weight:600;color:var(--primary)}.skill-card__progress{height:6px;background:var(--dark);border-radius:var(--radius-full);overflow:hidden}.skill-card__progress-bar{height:100%;width:var(--width);background:linear-gradient(90deg,var(--primary),var(--primary-light));border-radius:var(--radius-full);transition:width 1s ease}.skills__footer{margin-top:50px;display:flex;justify-content:center}.skills__note{display:flex;align-items:center;gap:14px;padding:20px 28px;background:var(--primary-bg);border:1px solid rgba(0,102,255,.2);border-radius:var(--radius-lg);max-width:600px}.skills__note-icon{font-size:1.5rem}.skills__note p{font-size:.95rem;color:var(--gray-300);line-height:1.6}@media(max-width:640px){.skills__grid{grid-template-columns:1fr}.skills__filters{gap:8px}.skills__filter{padding:8px 16px;font-size:.85rem}}.projects{background:var(--bg-card)}.projects:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--border-color),transparent)}.projects__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}.project-card{background:var(--bg-dark);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden;transition:var(--transition-base);animation:fadeInUp .5s ease forwards;animation-delay:var(--delay);opacity:0}.project-card:hover{border-color:var(--border-hover);transform:translateY(-6px);box-shadow:var(--shadow-xl)}.project-card__image{position:relative;height:220px;overflow:hidden}.project-card__image img{width:100%;height:100%;object-fit:cover;transition:var(--transition-slow)}.project-card:hover .project-card__image img{transform:scale(1.05)}.project-card__overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%,rgba(10,10,15,.9) 100%);display:flex;align-items:flex-end;justify-content:center;padding-bottom:20px;opacity:0;transition:var(--transition-base)}.project-card:hover .project-card__overlay{opacity:1}.project-card__view{display:flex;align-items:center;gap:8px;padding:10px 22px;background:var(--primary);border:none;border-radius:var(--radius-full);color:var(--text-white);font-size:.85rem;font-weight:600;cursor:pointer;transform:translateY(20px);transition:var(--transition-base)}.project-card:hover .project-card__view{transform:translateY(0)}.project-card__view:hover{background:var(--primary-dark);box-shadow:var(--shadow-primary)}.project-card__badge{position:absolute;top:14px;right:14px;padding:6px 12px;background:var(--warning);border-radius:var(--radius-full);font-size:.7rem;font-weight:600;color:var(--bg-dark);text-transform:uppercase;letter-spacing:.5px}.project-card__content{padding:24px;display:flex;flex-direction:column;gap:12px}.project-card__category{font-size:.8rem;font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:.5px}.project-card__title{font-family:var(--font-heading);font-size:1.2rem;font-weight:600;color:var(--text-white)}.project-card__description{font-size:.9rem;color:var(--text-gray-400);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-card__tech{display:flex;flex-wrap:wrap;gap:8px}.project-card__tech span{padding:5px 12px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-full);font-size:.75rem;font-weight:500;color:var(--text-gray-400)}.project-card__tech span.more{background:var(--primary-bg);border-color:transparent;color:var(--primary)}.project-card__actions{display:flex;gap:10px;margin-top:6px;padding-top:16px;border-top:1px solid var(--border-color)}.project-card__link{display:flex;align-items:center;gap:6px;padding:10px 16px;background:var(--primary);border-radius:var(--radius-md);font-size:.8rem;font-weight:600;color:var(--text-white);transition:var(--transition-base)}.project-card__link:hover{background:var(--primary-dark);transform:translateY(-2px)}.project-card__link--secondary{background:transparent;border:1px solid var(--border-color);color:var(--text-gray-300)}.project-card__link--secondary:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-bg)}.projects__footer{display:flex;justify-content:center;margin-top:50px}.project-modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px;background:#0a0a0fe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:fadeIn .3s ease}.project-modal__content{position:relative;width:100%;max-width:850px;max-height:90vh;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden;overflow-y:auto;animation:slideUp .3s ease}.project-modal__close{position:absolute;top:16px;right:16px;z-index:10;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--bg-dark);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-white);cursor:pointer;transition:var(--transition-base)}.project-modal__close:hover{background:var(--error);border-color:var(--error)}.project-modal__image{height:300px;overflow:hidden}.project-modal__image img{width:100%;height:100%;object-fit:cover}.project-modal__body{padding:30px;display:flex;flex-direction:column;gap:16px}.project-modal__category{font-size:.8rem;font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:.5px}.project-modal__title{font-family:var(--font-heading);font-size:1.6rem;font-weight:700;color:var(--text-white)}.project-modal__description{font-size:.95rem;color:var(--text-gray-400);line-height:1.7}.project-modal__tech h4{font-size:.9rem;font-weight:600;color:var(--text-white);margin-bottom:12px}.project-modal__tech-list{display:flex;flex-wrap:wrap;gap:10px}.project-modal__tech-list span{padding:8px 16px;background:var(--bg-dark);border:1px solid var(--border-color);border-radius:var(--radius-full);font-size:.85rem;font-weight:500;color:var(--text-gray-300)}.project-modal__actions{display:flex;gap:14px;margin-top:8px}@media(max-width:900px){.projects__grid{grid-template-columns:1fr}}@media(max-width:640px){.project-card__image{height:180px}.project-card__content{padding:20px}.project-card__actions{flex-direction:column}.project-card__link{justify-content:center}.project-modal__image{height:200px}.project-modal__body{padding:24px}.project-modal__actions{flex-direction:column}.project-modal__actions .btn{width:100%;justify-content:center}}.contact{background:var(--dark)}.contact__grid{display:grid;grid-template-columns:1fr 1.4fr;gap:50px;align-items:start}.contact__info{position:relative;padding:40px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);border-radius:var(--radius-xl);color:var(--white);overflow:hidden}.contact__info-header{margin-bottom:36px}.contact__info-header h3{font-family:var(--font-heading);font-size:1.5rem;font-weight:600;margin-bottom:12px}.contact__info-header p{font-size:.95rem;opacity:.9;line-height:1.7}.contact__info-list{display:flex;flex-direction:column;gap:24px;margin-bottom:36px}.contact__info-item{display:flex;align-items:center;gap:16px}.contact__info-icon{width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:#ffffff26;border-radius:var(--radius-md);flex-shrink:0}.contact__info-content{display:flex;flex-direction:column;gap:4px}.contact__info-label{font-size:.8rem;font-weight:500;opacity:.7;text-transform:uppercase;letter-spacing:.5px}.contact__info-value{font-size:1rem;font-weight:500;color:var(--white);text-decoration:none;transition:var(--transition-base)}.contact__info-value:hover{opacity:.8}.contact__socials{position:relative;z-index:1}.contact__socials-label{display:block;font-size:.85rem;font-weight:500;opacity:.7;margin-bottom:16px}.contact__socials-list{display:flex;gap:12px}.contact__social{width:46px;height:46px;display:flex;align-items:center;justify-content:center;background:#ffffff26;border-radius:var(--radius-md);color:var(--white);transition:var(--transition-base)}.contact__social:hover{background:#ffffff40;transform:translateY(-4px)}.contact__decoration{position:absolute;bottom:-80px;right:-80px}.contact__decoration-circle{width:200px;height:200px;border-radius:50%;background:#ffffff14}.contact__decoration-circle--2{width:150px;height:150px;position:absolute;bottom:60px;right:60px;background:#ffffff0d}.contact__form-wrapper{padding:40px;background:var(--secondary);border:1px solid var(--gray-800);border-radius:var(--radius-xl)}.contact__form{display:flex;flex-direction:column;gap:24px}.contact__form-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}.contact__form-group{display:flex;flex-direction:column;gap:8px}.contact__form-group label{font-size:.9rem;font-weight:600;color:var(--white)}.contact__form-group input,.contact__form-group textarea{width:100%;padding:16px 18px;background:var(--dark);border:2px solid var(--gray-800);border-radius:var(--radius-md);font-family:var(--font-primary);font-size:.95rem;color:var(--white);transition:var(--transition-base);resize:none}.contact__form-group input::placeholder,.contact__form-group textarea::placeholder{color:var(--gray-600)}.contact__form-group input:focus,.contact__form-group textarea:focus{outline:none;border-color:var(--primary);background:var(--secondary);box-shadow:0 0 0 4px #0066ff1a}.contact__form-group input.error,.contact__form-group textarea.error{border-color:var(--error)}.contact__form-error{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--error)}.contact__form-submit{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:18px 36px;background:var(--primary);border:none;border-radius:var(--radius-md);font-family:var(--font-primary);font-size:1rem;font-weight:600;color:var(--white);cursor:pointer;transition:var(--transition-base);box-shadow:var(--shadow-primary)}.contact__form-submit:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-3px);box-shadow:0 14px 44px -10px #0066ff80}.contact__form-submit:disabled{opacity:.7;cursor:not-allowed}.contact__form-submit .spinner{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.contact__form-status{display:flex;align-items:center;gap:12px;padding:16px 20px;border-radius:var(--radius-md);font-size:.95rem;font-weight:500}.contact__form-status--success{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:var(--success)}.contact__form-status--error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--error)}@media(max-width:1024px){.contact__grid{grid-template-columns:1fr;gap:40px}.contact__info{order:2}}@media(max-width:640px){.contact__form-row{grid-template-columns:1fr}.contact__info,.contact__form-wrapper{padding:28px}}.footer{background:var(--secondary);padding:80px 0 30px;border-top:1px solid var(--gray-800)}.footer__container{width:var(--container-width);max-width:1200px;margin:0 auto}.footer__main{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:50px;margin-bottom:50px}.footer__brand{display:flex;flex-direction:column;gap:20px}.footer__logo{display:flex;align-items:center;gap:14px;text-decoration:none}.footer__logo-icon{width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:var(--primary);border-radius:var(--radius-md);color:var(--white)}.footer__logo-text{display:flex;flex-direction:column}.footer__logo-name{font-family:var(--font-heading);font-size:1.2rem;font-weight:600;color:var(--white)}.footer__logo-role{font-size:.8rem;color:var(--gray-500)}.footer__description{font-size:.95rem;color:var(--gray-400);line-height:1.7;max-width:300px}.footer__socials{display:flex;gap:10px}.footer__social{width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:var(--dark);border:1px solid var(--gray-800);border-radius:var(--radius-md);color:var(--gray-400);transition:var(--transition-base)}.footer__social:hover{background:var(--primary);border-color:var(--primary);color:var(--white);transform:translateY(-4px)}.footer__title{font-size:1rem;font-weight:600;color:var(--white);margin-bottom:24px}.footer__links{list-style:none;display:flex;flex-direction:column;gap:14px}.footer__links a{font-size:.95rem;color:var(--gray-400);transition:var(--transition-base)}.footer__links a:hover{color:var(--primary);padding-left:6px}.footer__contact-list{list-style:none;display:flex;flex-direction:column;gap:14px;margin-bottom:24px}.footer__contact-list li{display:flex;align-items:center;gap:10px;font-size:.95rem;color:var(--gray-400)}.footer__contact-list li svg{color:var(--primary);flex-shrink:0}.footer__contact-list a{color:var(--gray-400);transition:var(--transition-base)}.footer__contact-list a:hover{color:var(--primary)}.footer__cta{display:inline-flex;align-items:center;padding:12px 24px;background:var(--primary);border-radius:var(--radius-md);font-size:.9rem;font-weight:600;color:var(--white);transition:var(--transition-base)}.footer__cta:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-primary)}.footer__divider{height:1px;background:linear-gradient(90deg,transparent,var(--gray-800),transparent);margin-bottom:30px}.footer__bottom{display:flex;align-items:center;justify-content:space-between}.footer__copyright{display:flex;align-items:center;gap:6px;font-size:.9rem;color:var(--gray-500)}.footer__heart{color:var(--error);animation:heartbeat 1.5s ease-in-out infinite}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.footer__scroll-top{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--primary);border:none;border-radius:var(--radius-md);color:var(--white);cursor:pointer;transition:var(--transition-base);box-shadow:var(--shadow-primary)}.footer__scroll-top:hover{background:var(--primary-dark);transform:translateY(-4px)}@media(max-width:1024px){.footer__main{grid-template-columns:repeat(2,1fr);gap:40px}.footer__brand{grid-column:span 2}}@media(max-width:640px){.footer{padding:60px 0 24px}.footer__main{grid-template-columns:1fr;text-align:center}.footer__brand{grid-column:span 1;align-items:center}.footer__description{max-width:100%}.footer__socials{justify-content:center}.footer__links,.footer__contact-list{align-items:center}.footer__bottom{flex-direction:column;gap:20px}}.app{min-height:100vh;display:flex;flex-direction:column}main{flex:1}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.fade-in-up{animation:fadeInUp .6s ease forwards}
