@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap);@import url(https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.0/css/all.min.css);:root{--primary-color:#007bff;--primary-to-gradian-color:#0056b3;--primary-gradient:linear-gradient(135deg,var(--primary-color),var(--primary-to-gradian-color));--secondary-color:#6c757d;--success-color:#28a745;--danger-color:#dc3545;--warning-color:#ffc107;--info-color:#17a2b8;--light-color:#f8f9fa;--dark-color:#343a40;--white:#fff;--black:#000;--gray-100:#f8f9fa;--gray-200:#e9ecef;--gray-300:#dee2e6;--gray-400:#ced4da;--gray-500:#adb5bd;--gray-600:#6c757d;--gray-700:#495057;--gray-800:#343a40;--gray-900:#212529;--shadow-sm:0 0.125rem 0.25rem rgba(0,0,0,.075);--shadow-md:0 0.5rem 1rem #00000026;--shadow-lg:0 1rem 3rem rgba(0,0,0,.175);--shadow-xl:0 2rem 4rem #0003;--border-radius-sm:0.25rem;--border-radius-md:0.375rem;--border-radius-lg:0.5rem;--border-radius-xl:0.75rem;--border-radius-xxl:1rem;--header-bg:#fffffff2;--header-bg-scrolled:#ffffffb3;--header-bg-hover:#fffffffa;--header-border:#0000001a;--header-shadow:0 2px 10px #0000000d;--nav-mobile-bg:var(--white);--hero-bg-start:#f8f9fa;--hero-bg-end:#e9ecef;--hero-pattern-color:#007bff;--project-card-bg:var(--white);--project-content-bg:var(--gray-100);--project-overlay-bg:#007bffe6;--footer-bg-start:#343a40;--footer-bg-end:#2c3e50;--footer-text:#dee2e6;--footer-border:#ffffff1a;--footer-item-bg:#ffffff1a;--footer-heading:#fff}[data-theme=dark]{--white:#1a1a1a;--light-color:#2d2d2d;--dark-color:#fff;--gray-100:#2d2d2d;--gray-200:#404040;--gray-300:#525252;--gray-400:#737373;--gray-500:#a3a3a3;--gray-600:#d4d4d4;--gray-700:#e5e5e5;--gray-800:#f5f5f5;--gray-900:#fff;--header-bg:#1a1a1af2;--header-bg-scrolled:#1a1a1ab3;--header-bg-hover:#1a1a1afa;--header-border:#ffffff1a;--header-shadow:0 2px 10px #0000004d;--nav-mobile-bg:#1a1a1a;--hero-bg-start:#1a1a1a;--hero-bg-end:#2d2d2d;--hero-pattern-color:#0056b3;--shadow-sm:0 0.125rem 0.25rem #0003;--shadow-md:0 0.5rem 1rem #0000004d;--shadow-lg:0 1rem 3rem #0006;--shadow-xl:0 2rem 4rem #00000080;--project-card-bg:#2d2d2d;--project-content-bg:#3a3a3a;--project-overlay-bg:#0056b3e6;--footer-bg-start:#0a0a0a;--footer-bg-end:#1a1a1a;--footer-text:#a3a3a3;--footer-border:#fff3;--footer-item-bg:#ffffff26;--footer-heading:#e5e5e5}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--white:#1a1a1a;--light-color:#2d2d2d;--dark-color:#fff;--gray-100:#2d2d2d;--gray-200:#404040;--gray-300:#525252;--gray-400:#737373;--gray-500:#a3a3a3;--gray-600:#d4d4d4;--gray-700:#e5e5e5;--gray-800:#f5f5f5;--gray-900:#fff;--header-bg:#1a1a1af2;--header-bg-scrolled:#1a1a1ab3;--header-bg-hover:#1a1a1afa;--header-border:#ffffff1a;--header-shadow:0 2px 10px #0000004d;--nav-mobile-bg:#1a1a1a;--hero-bg-start:#1a1a1a;--hero-bg-end:#2d2d2d;--hero-pattern-color:#0056b3;--shadow-sm:0 0.125rem 0.25rem #0003;--shadow-md:0 0.5rem 1rem #0000004d;--shadow-lg:0 1rem 3rem #0006;--shadow-xl:0 2rem 4rem #00000080;--project-card-bg:#2d2d2d;--project-content-bg:#3a3a3a;--project-overlay-bg:#0056b3e6;--footer-bg-start:#0a0a0a;--footer-bg-end:#1a1a1a;--footer-text:#a3a3a3;--footer-border:#fff3;--footer-item-bg:#ffffff26;--footer-heading:#e5e5e5}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;background-color:var(--white);color:#343a40;color:var(--dark-color);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}a{color:inherit;text-decoration:none;transition:color .3s ease}button{background:none;border:none;cursor:pointer;font-family:inherit;transition:all .3s ease}img{height:auto;max-width:100%}.container{margin:0 auto;max-width:1200px;padding:0 20px}.section-padding{padding:80px 0}.btn{border:none;border-radius:.75rem;border-radius:var(--border-radius-xl);cursor:pointer;display:inline-block;font-weight:500;margin:3px 0;padding:6px 24px;text-align:center;text-decoration:none;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#007bff,#0056b3);background:var(--primary-gradient);color:#fff;color:var(--white)}.btn-primary:hover{background-color:#0056b3;background-color:var(--primary-to-gradian-color);box-shadow:0 .5rem 1rem #00000026;box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn-secondary{background-color:#6c757d;background-color:var(--secondary-color);color:#fff;color:var(--white)}.btn-secondary:hover{background-color:#545b62;box-shadow:0 .5rem 1rem #00000026;box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn-outline{background-color:initial;border:2px solid #007bff;border:2px solid var(--primary-color);color:#007bff;color:var(--primary-color)}.btn-outline:hover{background-color:#007bff;background-color:var(--primary-color);color:#fff;color:var(--white)}.card{background:#fff;background:var(--white);border-radius:.5rem;border-radius:var(--border-radius-lg);box-shadow:0 .5rem 1rem #00000026;box-shadow:var(--shadow-md);overflow:hidden;transition:all .3s ease}.card:hover{box-shadow:0 1rem 3rem rgba(0,0,0,.175);box-shadow:var(--shadow-lg);transform:translateY(-5px)}.text-center{text-align:center}.text-primary{color:#007bff;color:var(--primary-color)}.bg-light{background-color:#f8f9fa;background-color:var(--light-color)}.bg-dark{background-color:#343a40;background-color:var(--dark-color);color:#fff;color:var(--white)}@media (max-width:768px){.section-padding{padding:60px 0}.container{padding:0 15px}.btn{font-size:14px;padding:10px 20px}}@media (max-width:576px){.section-padding{padding:40px 0}}.theme-toggle{position:relative}.theme-toggle-button{align-items:center;background-color:initial;border:1px solid var(--gray-300);border-radius:var(--border-radius-lg);color:var(--dark-color);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.25rem;padding:.5rem .75rem;transition:all .2s ease}.theme-toggle-button:hover{background-color:var(--gray-100);border-color:var(--gray-400)}.theme-toggle-button:focus{outline:2px solid var(--primary-color);outline-offset:2px}.theme-icon{font-size:1.1rem;line-height:1}.theme-chevron{opacity:.7;transition:transform .2s ease}.theme-chevron.open{transform:rotate(180deg)}.theme-dropdown{animation:dropdownFadeIn .2s ease;background-color:var(--white);border:1px solid var(--gray-300);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);min-width:160px;overflow:hidden;position:absolute;right:0;top:calc(100% + .5rem);z-index:1000}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.theme-option{align-items:center;background:none;border:none;color:var(--dark-color);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.75rem;padding:.75rem 1rem;text-align:left;transition:background-color .2s ease;width:100%}.theme-option:hover{background-color:var(--gray-100)}.theme-option.active{background-color:var(--primary-color);color:var(--white)}.theme-option-icon{font-size:1rem;line-height:1;text-align:center;width:20px}.theme-option-label{flex:1 1}.theme-check{margin-left:auto}[data-theme=dark] .theme-toggle-button{background-color:initial;border-color:var(--gray-700);color:var(--gray-100)}[data-theme=dark] .theme-toggle-button:hover{background-color:var(--gray-800);border-color:var(--gray-600)}[data-theme=dark] .theme-dropdown{background-color:var(--gray-900);border-color:var(--gray-700)}[data-theme=dark] .theme-option{color:var(--gray-100)}[data-theme=dark] .theme-option:hover{background-color:var(--gray-800)}[data-theme=dark] .theme-option.active{background-color:var(--primary-color);color:var(--white)}@media (max-width:768px){.theme-toggle-button{padding:.5rem .625rem}.theme-dropdown{right:0}}@media (max-width:576px){.theme-toggle-button{padding:.375rem .5rem}.theme-icon{font-size:1rem}.theme-chevron{height:8px;width:8px}}.header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:var(--header-bg);border-bottom:1px solid #0000;left:0;position:fixed;right:0;top:0;transition:all .3s ease;z-index:1000}.header.scrolled{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background-color:var(--header-bg-scrolled);border-bottom-color:var(--header-border);box-shadow:var(--header-shadow)}.header.scrolled:hover{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:var(--header-bg-hover);border-bottom-color:var(--gray-200);box-shadow:var(--shadow-sm)}.header-content{align-items:center;display:flex;justify-content:space-between;padding:1rem 0;transition:padding .3s ease}.header.scrolled .header-content{padding:.25rem 0}.header.scrolled:hover .header-content{padding:1rem 0}.logo{color:var(--dark-color);cursor:pointer;font-size:1.5rem;font-weight:700}.logo-highlight{background:var(--primary-gradient);border-radius:var(--border-radius-md);color:var(--white);margin-right:.5rem;padding:.25rem .5rem}.nav{align-items:center;display:flex;gap:1.5rem}.nav-link{background:none;border:none;color:var(--dark-color);cursor:pointer;font-weight:500;padding:.5rem 0;position:relative;transition:color .3s ease}.nav-link,.nav-link:focus{outline:none}.nav-link.active,.nav-link:hover{color:var(--primary-color)}.nav-link.active:after{background:var(--primary-gradient);border-radius:1px;bottom:0;content:"";height:2px;left:0;position:absolute;right:0}.cv-btn{margin-left:.5rem}.mobile-controls{align-items:center;display:none;gap:1rem}.mobile-menu-toggle{background:none;border:none;cursor:pointer;display:flex;flex-direction:column;gap:4px;padding:.5rem}.mobile-menu-toggle span{background-color:var(--dark-color);border-radius:2px;height:3px;transition:all .3s ease;width:25px}@media (max-width:768px){.mobile-controls{display:flex}.nav{background-color:var(--nav-mobile-bg);box-shadow:var(--shadow-lg);flex-direction:column;gap:1.5rem;left:0;opacity:0;padding:2rem;position:fixed;right:0;top:100%;transform:translateY(-100%);transition:all .3s ease;visibility:hidden}.nav.nav-open{opacity:1;transform:translateY(0);visibility:visible}.nav-link{font-size:1.1rem;padding:1rem 0;text-align:center;width:100%}.cv-btn{margin-left:0;margin-top:1rem}.nav .theme-toggle{display:none}.mobile-menu-toggle.active span:first-child{transform:rotate(45deg) translate(5px,5px)}.mobile-menu-toggle.active span:nth-child(2){opacity:0}.mobile-menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(7px,-6px)}}@media (max-width:576px){.header-content{padding:.75rem 0}.logo{font-size:1.25rem}.logo-highlight{padding:.2rem .4rem}}.hero{align-items:center;background:linear-gradient(135deg,var(--hero-bg-start) 0,var(--hero-bg-end) 100%);display:flex;min-height:100vh;overflow:hidden;padding-top:90px;position:relative}.hero:before{background-image:radial-gradient(circle at 25% 25%,var(--hero-pattern-color) 1px,#0000 1px),radial-gradient(circle at 75% 75%,var(--hero-pattern-color) 1px,#0000 1px),radial-gradient(circle at 50% 10%,var(--hero-pattern-color) 1px,#0000 1px),radial-gradient(circle at 10% 60%,var(--hero-pattern-color) 1px,#0000 1px),radial-gradient(circle at 90% 40%,var(--hero-pattern-color) 1px,#0000 1px);background-size:100px 100px;bottom:0;content:"";left:0;opacity:.1;position:absolute;right:0;top:0}.hero-content{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr;position:relative;z-index:1}.hero-text{max-width:600px}.hero-title{color:var(--dark-color);font-size:3.5rem;font-weight:700;line-height:1.2;margin-bottom:1.5rem}.highlight{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--primary-color),var(--primary-to-gradian-color));-webkit-background-clip:text;background-clip:text;position:relative;white-space:nowrap}.hero-subtitle{color:var(--gray-600);font-size:1.5rem;font-weight:300;line-height:1.4;margin-bottom:2rem}.hero-description{color:var(--gray-700);font-size:1.1rem;line-height:1.6;margin-bottom:3rem}.hero-actions{display:flex;flex-wrap:wrap;gap:1.5rem}.hero-image{align-items:center;display:flex;justify-content:center}.image-container{border-radius:50%;box-shadow:var(--shadow-xl);height:350px;overflow:hidden;position:relative;width:350px}.profile-image{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.image-container:hover .profile-image{transform:scale(1.1)}.image-overlay{background:var(--primary-gradient);bottom:0;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.image-container:hover .image-overlay{opacity:.2}@media (prefers-color-scheme:dark){.image-overlay{opacity:.05}.image-container:hover .image-overlay{opacity:.15}}.scroll-indicator{bottom:2rem;color:var(--primary-color);font-size:1.5rem;left:50%;position:absolute;transform:translateX(-50%)}.scroll-arrow{cursor:pointer;transition:color .3s ease}.scroll-arrow:hover{color:var(--primary-to-gradian-color)}@media (max-width:992px){.hero-content{gap:3rem;grid-template-columns:1fr;text-align:center}.hero-title{font-size:3rem}.image-container{height:300px;width:300px}}@media (max-width:768px){.hero{padding-top:80px}.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.25rem}.hero-description{font-size:1rem}.hero-actions{justify-content:center}.image-container{height:250px;width:250px}}@media (max-width:576px){.hero-content{gap:2rem}.hero-title{font-size:2rem}.hero-subtitle{font-size:1.1rem}.hero-actions{align-items:center;flex-direction:column}.btn{max-width:250px;width:100%}.image-container{height:200px;width:200px}}.fade-in-left,.fade-in-right,.fade-in-up{opacity:1;transform:translate(0)}.skills{background-color:var(--light-color)}.section-header{margin-bottom:4rem;text-align:center}.section-title{color:var(--dark-color);font-size:2.5rem;font-weight:700;margin-bottom:1rem}.section-subtitle{color:var(--gray-600);font-size:1.1rem;line-height:1.6;margin:0 auto;max-width:600px}.skills-content{align-items:center;display:flex;flex-direction:column;gap:4rem}.skills-grid{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:1fr 1fr}.skills-grid>.skill-category:last-child:nth-child(odd){grid-column:span 2;margin:0 auto;width:50%}.skill-category{background:var(--white);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);padding:1.5rem}.category-title{color:var(--primary-color);font-size:1.5rem;font-weight:600;margin-bottom:1.5rem;position:relative;text-align:center}.category-title:after{background:var(--primary-gradient);border-radius:2px;bottom:-.5rem;content:"";height:3px;left:50%;position:absolute;transform:translateX(-50%);width:50px}.skills-list{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.skill-card{align-items:center;background:var(--gray-100);border-radius:var(--border-radius-md);display:flex;flex-basis:calc(50% - 0.5rem);gap:.75rem;min-width:205px;padding:.75rem}.skill-card:hover,.skill-icon{background:var(--white);box-shadow:var(--shadow-sm)}.skill-icon{align-items:center;border-radius:var(--border-radius-md);display:flex;height:40px;justify-content:center;width:40px}.skill-icon i{font-size:1.5rem}.skill-icon img,.skill-icon svg{height:24px;object-fit:contain;width:24px}.skill-name{color:var(--dark-color);flex:1 1;font-size:1rem;font-weight:600}.skill-level{align-items:center;display:flex;height:30px;justify-content:center;perspective:800px;width:30px}.skill-level-indicator{border-radius:50%;box-shadow:0 2px 8px #0003;height:30px;transform-style:preserve-3d;width:30px}.skills-image{align-items:center;display:flex;justify-content:center;margin-top:2rem;width:100%}.code-montage{border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);max-width:400px;width:100%}@media (max-width:1200px){.skills-content{gap:3rem}.skills-grid{grid-template-columns:1fr 1fr}}@media (max-width:768px){.section-title{font-size:2rem}.skills-grid{gap:2rem;grid-template-columns:1fr}.skills-grid>.skill-category:last-child:nth-child(odd){grid-column:auto;margin:0;width:100%}.skill-category{padding:1.5rem}.skills-list{grid-template-columns:1fr}.skills-content{gap:2rem}}@media (max-width:576px){.section-title{font-size:1.75rem}.section-subtitle{font-size:1rem}}.skill-category:first-child .category-title{color:#e74c3c}.skill-category:first-child .category-title:after{background:linear-gradient(135deg,#e74c3c,#c0392b)}.skill-category:nth-child(2) .category-title{color:#27ae60}.skill-category:nth-child(2) .category-title:after{background:linear-gradient(135deg,#27ae60,#229954)}.skill-category:nth-child(3) .category-title{color:#f39c12}.skill-category:nth-child(3) .category-title:after{background:linear-gradient(135deg,#f39c12,#e67e22)}.skill-category:nth-child(4) .category-title{color:#9b59b6}.skill-category:nth-child(4) .category-title:after{background:linear-gradient(135deg,#9b59b6,#8e44ad)}.skill-legend{background-color:var(--gray-100);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);margin:0 auto 2rem;max-width:600px;padding:1.5rem;text-align:center}.legend-header{align-items:center;display:flex;gap:.75rem;justify-content:center;margin-bottom:1rem}.legend-icon{color:var(--primary-color);font-size:1.5rem}.skill-legend h3{color:var(--dark-color);font-size:1.25rem;font-weight:600;margin:0}.legend-list{align-items:flex-start;display:flex;flex-direction:column;gap:.5rem;list-style:none;margin:0 auto;max-width:400px;padding:0;text-align:left}.legend-list li{align-items:center;color:var(--gray-700);display:flex;font-size:1rem}.legend-dot{border-radius:50%;flex-shrink:0;height:16px;margin-right:.75rem;width:16px}.projects{background:var(--light-color)}.filter-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:3rem}.filter-btn{background:var(--project-card-bg);border:2px solid var(--gray-300);border-radius:var(--border-radius-xl);color:var(--gray-600);cursor:pointer;font-weight:500;padding:.75rem 1.5rem;text-transform:capitalize;transition:all .3s ease}.filter-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.filter-btn.active{background:var(--primary-gradient);border-color:var(--primary-color);color:var(--white)}.projects-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.project-card{background:var(--project-card-bg);border:1px solid #0000;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);cursor:pointer;transition:all .3s ease}@media (prefers-color-scheme:dark){.project-card{border-color:var(--gray-700)}}.project-card:hover{box-shadow:var(--shadow-lg)}.project-image{height:250px;overflow:hidden;position:relative}.project-image img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.project-card:hover .project-image img{transform:scale(1.1)}.project-overlay{align-items:center;background:var(--project-overlay-bg);bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.project-card:hover .project-overlay{opacity:1}.project-actions{text-align:center}.project-content{background:var(--project-content-bg);padding:1.5rem}.project-category{background:var(--primary-gradient);border-radius:var(--border-radius-xl);color:var(--white);display:inline-block;font-size:.75rem;font-weight:600;margin-bottom:1rem;padding:.25rem .75rem;text-transform:uppercase}.project-title{color:var(--dark-color);font-size:1.25rem;font-weight:600;line-height:1.3;margin-bottom:.75rem}.project-description{-webkit-line-clamp:3;-webkit-box-orient:vertical;color:var(--gray-600);display:-webkit-box;line-height:1.5;margin-bottom:1rem;overflow:hidden}.project-technologies{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.tech-tag{background:var(--gray-200);border-radius:var(--border-radius-sm);color:var(--gray-700);font-size:.75rem;font-weight:500;padding:.25rem .5rem}@media (prefers-color-scheme:dark){.tech-tag{background:var(--gray-800);color:var(--gray-300)}}.tech-more{background:var(--gray-300);border-radius:var(--border-radius-sm);color:var(--gray-600);font-size:.75rem;font-weight:600;padding:.25rem .5rem}.project-links{display:flex;gap:.75rem;justify-content:flex-end}.project-link{align-items:center;background:var(--gray-200);border-radius:var(--border-radius-md);color:var(--gray-600);display:flex;height:40px;justify-content:center;transition:all .3s ease;width:40px}@media (prefers-color-scheme:dark){.project-link{background:var(--gray-800);color:var(--gray-400)}}.project-link:hover{background:var(--primary-color);color:var(--white);transform:translateY(-2px)}.modal-overlay{align-items:center;background:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:2rem;position:fixed;right:0;top:0;z-index:2000}.modal-content{background:var(--project-card-bg);border-radius:var(--border-radius-lg);max-height:90vh;max-width:900px;overflow-y:auto;position:relative;width:100%}.modal-close{align-items:center;background:var(--gray-100);border:none;border-radius:50%;cursor:pointer;display:flex;height:40px;justify-content:center;position:absolute;right:1rem;top:1rem;transition:all .3s ease;width:40px;z-index:10}.modal-close:hover{background:var(--danger-color);color:var(--white)}[data-theme=dark] .modal-close{background:#ffffff1a;border:1px solid #ffffff4d;color:#fff}@media (prefers-color-scheme:dark){.modal-close{background:#ffffff1a;border:1px solid #ffffff4d;color:#fff}}.modal-header{border-bottom:1px solid var(--gray-200);padding:2rem 2rem 1rem}.modal-header h2{color:var(--dark-color);font-size:2rem;font-weight:700;margin-bottom:.5rem}.modal-body{padding:2rem}.project-images{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.project-images img{background:var(--gray-100);border-radius:var(--border-radius-md);box-shadow:var(--shadow-sm);height:400px;object-fit:contain;width:100%}.project-long-description{color:var(--gray-700);font-size:1.1rem;line-height:1.6;margin-bottom:2rem}.project-technologies-full h4{color:var(--dark-color);font-size:1.1rem;font-weight:600;margin-bottom:1rem}.tech-list{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:2rem}.tech-list .tech-tag{background:var(--primary-color);color:var(--white);font-size:.875rem;padding:.5rem 1rem}.project-actions-modal{display:flex;flex-wrap:wrap;gap:1rem}.project-actions-modal .btn{align-items:center;display:flex;gap:.5rem}@media (max-width:768px){.projects-grid{gap:1.5rem;grid-template-columns:1fr}.project-card{margin:0 auto;max-width:400px}.filter-buttons{gap:.5rem}.filter-btn{font-size:.875rem;padding:.5rem 1rem}.modal-overlay{padding:1rem}.modal-body,.modal-header{padding:1.5rem}.modal-header h2{font-size:1.5rem}.project-images{grid-template-columns:1fr}.project-actions-modal{flex-direction:column}}@media (max-width:576px){.project-content{padding:1rem}.project-image{height:200px}.modal-body,.modal-header{padding:1rem}.filter-buttons{justify-content:flex-start;overflow-x:auto;padding-bottom:.5rem}.filter-btn{white-space:nowrap}}.project-card{overflow:hidden;position:relative}.project-card:before{background:linear-gradient(135deg,var(--primary-color),var(--primary-to-gradian-color));content:"";height:4px;left:-100%;position:absolute;top:0;transition:left .3s ease;width:100%;z-index:1}.project-card:hover:before{left:0}.project-image img{opacity:1}.image-slider{margin:0 auto;max-width:800px;position:relative;width:100%}.slider-container{border-radius:8px;overflow:hidden}.slider-image{display:block;height:auto;width:100%}.slider-arrow{background:#00000080;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:24px;padding:10px;position:absolute;top:50%;transform:translateY(-50%);z-index:10}.slider-arrow-left{left:10px}.slider-arrow-right{right:10px}.slider-indicators{display:flex;justify-content:center;margin-top:10px}.indicator{background:#ccc;border-radius:50%;cursor:pointer;height:10px;margin:0 5px;width:10px}.indicator.active{background:#007bff}.lightbox-overlay{background:#000000e6;bottom:0;cursor:pointer;left:0;position:fixed;right:0;top:0;z-index:3000}.lightbox-content,.lightbox-overlay{align-items:center;display:flex;justify-content:center}.lightbox-content{height:100vh;position:relative;width:100vw}.lightbox-image{height:100%;object-fit:contain;width:100%}.lightbox-close{font-size:24px;padding:10px;right:0;top:-40px}.lightbox-arrow,.lightbox-close{background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;position:absolute;z-index:10}.lightbox-arrow{font-size:30px;padding:15px;top:50%;transform:translateY(-50%)}.lightbox-arrow-left{left:-60px}.lightbox-arrow-right{right:-60px}.contact{background:linear-gradient(135deg,var(--light-color) 0,var(--white) 100%)}.contact-content{align-items:center;display:flex;flex-direction:column;gap:2rem;justify-content:center;width:100%}.contact-info{max-width:600px;padding:2rem;width:100%}.contact-intro h3{color:var(--dark-color);font-size:1.75rem;font-weight:600;margin-bottom:1rem}.contact-intro p{color:var(--gray-600);font-size:1.1rem;line-height:1.6;margin-bottom:2rem}.contact-methods{display:flex;flex-direction:column;gap:1.5rem}.contact-method{align-items:center;background:var(--white);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);color:inherit;display:flex;gap:1rem;padding:1rem;text-decoration:none;transition:all .3s ease}.contact-method:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.method-icon{align-items:center;background:var(--primary-gradient);border-radius:var(--border-radius-md);color:var(--white);display:flex;flex-shrink:0;font-size:1.25rem;height:45px;justify-content:center;width:45px}.method-info h4{color:var(--dark-color);font-size:1rem;font-weight:600;margin-bottom:.25rem}.method-info p{color:var(--gray-600);margin:0}.contact-form-container{background:var(--white);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);padding:2.5rem}.contact-form{display:flex;flex-direction:column;gap:1.5rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:var(--dark-color);font-size:.9rem;font-weight:600}.form-group input,.form-group textarea{border:2px solid var(--gray-300);border-radius:var(--border-radius-md);font-family:inherit;font-size:1rem;padding:.75rem 1rem;transition:all .3s ease}.form-group input:focus,.form-group textarea:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #007bff1a;outline:none}.form-group textarea{min-height:120px;resize:vertical}.submit-btn{align-items:center;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;margin-top:1rem;overflow:hidden;padding:1rem 2rem;position:relative}.submit-btn.loading{opacity:.8;pointer-events:none}.submit-btn i{font-size:.9rem}.form-message{align-items:center;border-radius:var(--border-radius-md);display:flex;font-weight:500;gap:.5rem;margin-top:1rem;padding:1rem}.form-message.success{background:#28a7451a;border:1px solid #28a74533;color:var(--success-color)}.form-message.error{background:#dc35451a;border:1px solid #dc354533;color:var(--danger-color)}@media (max-width:992px){.contact-content{gap:3rem;grid-template-columns:1fr}.contact-form-container{padding:2rem}}@media (max-width:768px){.form-row{grid-template-columns:1fr}.contact-info{padding:1rem}.contact-form-container{padding:1.5rem}.contact-intro h3{font-size:1.5rem}.contact-intro p{font-size:1rem}}@media (max-width:576px){.contact-method{padding:1rem}.method-icon{height:40px;width:40px}.method-icon,.method-info h4{font-size:1rem}.method-info p{font-size:.9rem}.submit-btn{padding:.875rem 1.5rem}}.contact-method{overflow:hidden;position:relative}.contact-method:before{background:linear-gradient(90deg,#0000,#007bff0d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.contact-method:hover:before{left:100%}.form-group input,.form-group textarea{position:relative}.form-group input:focus,.form-group textarea:focus{transform:translateY(-1px)}.fa-spinner{animation:spin 1s linear infinite}.form-group{position:relative}.form-group input:focus+label,.form-group input:not(:placeholder-shown)+label,.form-group textarea:focus+label,.form-group textarea:not(:placeholder-shown)+label{color:var(--primary-color);transform:translateY(-1.5rem) scale(.8)}.form-group textarea::-webkit-scrollbar{width:6px}.form-group textarea::-webkit-scrollbar-track{background:var(--gray-200);border-radius:3px}.form-group textarea::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:3px}.form-group textarea::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}.submit-btn:not(.loading):hover{animation:pulse .5s ease}.footer{background:linear-gradient(135deg,var(--footer-bg-start) 0,var(--footer-bg-end) 100%);color:var(--white);padding:3rem 0 1rem}.footer-content{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:2fr 1fr 1fr 1fr;margin-bottom:2rem}.footer-section h4{color:var(--footer-heading);font-size:1.25rem;font-weight:600;margin-bottom:1.5rem;position:relative}.footer-section h4:after{background:var(--primary-color);bottom:-.5rem;content:"";height:2px;left:0;position:absolute;width:30px}.footer-brand h3{color:var(--footer-heading);font-size:1.75rem;font-weight:700;margin-bottom:1rem}.brand-highlight{background:var(--primary-gradient);border-radius:var(--border-radius-md);color:#fff;display:inline-block;margin-right:.5rem;padding:.25rem .5rem}.footer-brand p{color:var(--footer-text);line-height:1.6;margin-bottom:2rem}.social-links{display:flex;gap:1rem}.social-link{align-items:center;background:var(--footer-item-bg);border:1px solid var(--footer-border);border-radius:var(--border-radius-md);color:var(--footer-heading);display:flex;font-size:1.25rem;height:45px;justify-content:center;text-decoration:none;transition:all .3s ease;width:45px}.social-link:hover{background:var(--primary-color);background:var(--hover-color,var(--primary-color));box-shadow:0 5px 15px #0000004d;color:#fff}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.footer-nav{display:flex;flex-direction:column;gap:.75rem}.footer-link{background:none;border:none;color:var(--footer-text);cursor:pointer;font-size:1rem;text-align:left;text-decoration:none;transition:color .3s ease}.footer-link:hover{color:var(--primary-color);padding-left:.5rem}.contact-info{display:flex;flex-direction:column;gap:1rem}.contact-item{align-items:center;color:var(--footer-text);display:flex;gap:.75rem;text-decoration:none;transition:color .3s ease}.contact-item:hover{color:var(--primary-color)}.contact-item i{text-align:center;width:20px}.tech-stack{display:flex;flex-wrap:wrap;gap:.5rem}.tech-item{background:var(--footer-item-bg);border:1px solid #0000;border-radius:var(--border-radius-sm);color:var(--footer-text);font-size:.875rem;padding:.25rem .75rem;transition:all .3s ease}@media (prefers-color-scheme:dark){.tech-item{background:#ffffff14;border-color:#ffffff40;color:#d4d4d4;font-weight:500}.tech-item:hover{background:var(--primary-color);border-color:var(--primary-color);box-shadow:0 4px 12px #007bff4d;transform:translateY(-2px)}}.tech-item:hover{background:var(--primary-color);color:#fff}.footer-bottom{border-top:1px solid var(--footer-border);padding-top:2rem}.footer-bottom-content{align-items:center;display:flex;justify-content:center}.copyright{color:var(--footer-text);font-size:.9rem;margin:0}@media (prefers-color-scheme:dark){.copyright{color:var(--gray-500)}}.scroll-to-top{align-items:center;background:var(--primary-color);border:none;border-radius:var(--border-radius-md);color:var(--white);cursor:pointer;display:flex;font-size:1.1rem;height:45px;justify-content:center;transition:all .3s ease;width:45px}.scroll-to-top:hover{background:#0056b3;box-shadow:0 5px 15px #007bff66}@media (max-width:992px){.footer-content{gap:2rem;grid-template-columns:1fr 1fr}}@media (max-width:768px){.footer{padding:2rem 0 1rem}.footer-content{gap:2rem;grid-template-columns:1fr;text-align:center}.footer-section h4:after{left:50%;transform:translateX(-50%)}.contact-info,.footer-nav{align-items:center}.social-links,.tech-stack{justify-content:center}.footer-bottom-content{flex-direction:column;gap:1rem;text-align:center}}@media (max-width:576px){.footer-brand h3{font-size:1.5rem}.social-link{font-size:1.1rem;height:40px;width:40px}.scroll-to-top{font-size:1rem;height:40px;width:40px}}.footer-link,.footer-section{position:relative}.footer-link{overflow:hidden}.footer-link:before{background:linear-gradient(90deg,#0000,#007bff1a,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .3s ease;width:100%}.footer-link:hover:before{left:100%}.social-link{position:relative}.social-link:before{background:radial-gradient(circle,var(--primary-color) 0,#0000 70%);background:radial-gradient(circle,var(--hover-color,var(--primary-color)) 0,#0000 70%);border-radius:inherit;bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.social-link:hover:before{opacity:.2}.scroll-to-top{overflow:hidden;position:relative}.scroll-to-top:before{background:#ffffff4d;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .3s ease;width:0}.scroll-to-top:hover:before{height:100px;width:100px}.footer{position:relative}.footer:before{background:linear-gradient(90deg,#0000,var(--primary-color),#0000);content:"";height:1px;left:0;position:absolute;right:0;top:0}.App{min-height:100vh;position:relative}.loading-screen{align-items:center;background:linear-gradient(135deg,var(--white) 0,var(--light-color) 100%);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.loading-content{max-width:300px;text-align:center}.loading-logo{align-items:center;background:var(--primary-gradient);border-radius:50%;box-shadow:var(--shadow-lg);color:var(--white);display:flex;font-size:2rem;font-weight:700;height:80px;justify-content:center;margin:0 auto 2rem;width:80px}.loading-content h2{color:var(--dark-color);font-size:2rem;font-weight:700;margin-bottom:.5rem}.loading-content p{color:var(--gray-600);font-size:1.1rem;margin-bottom:2rem}.loading-bar{border-radius:2px;margin:0 auto;max-width:200px}.loading-bar,.scroll-progress{background:var(--primary-gradient);height:4px}.scroll-progress{left:0;position:fixed;right:0;top:0;transform-origin:0;z-index:1001}main{position:relative}html{scroll-behavior:smooth}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--gray-200)}::-webkit-scrollbar-thumb{background:var(--primary-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary-to-gradian-color)}*{scrollbar-color:var(--primary-color) var(--gray-200);scrollbar-width:thin}:focus,a:focus,button:focus{outline:2px solid var(--primary-color);outline-offset:2px}.skip-link{background:var(--primary-color);border-radius:4px;color:var(--white);left:6px;padding:8px;position:absolute;text-decoration:none;top:-40px;transition:top .3s ease;z-index:1000}.skip-link:focus{top:6px}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}.loading-logo{animation:none!important}}@media (prefers-contrast:high){.btn{border:2px solid}.card{border:1px solid var(--dark-color)}}@media (prefers-color-scheme:dark){.loading-screen{background:linear-gradient(135deg,var(--white) 0,var(--light-color) 100%)}}@media print{.footer,.header,.loading-screen,.scroll-progress{display:none!important}.section-padding{padding:1rem 0!important}.btn{background:#0000!important;color:#000!important}.btn,.card{border:1px solid #000!important}.card{box-shadow:none!important}}.fade-in{opacity:0;transform:translateY(30px);transition:all .6s ease}.fade-in.visible{opacity:1;transform:translateY(0)}.slide-in-left{opacity:0;transform:translateX(-50px);transition:all .6s ease}.slide-in-left.visible{opacity:1;transform:translateX(0)}.slide-in-right{opacity:0;transform:translateX(50px);transition:all .6s ease}.slide-in-right.visible{opacity:1;transform:translateX(0)}.scale-in{opacity:0;transform:scale(.8);transition:all .6s ease}.scale-in.visible{opacity:1;transform:scale(1)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes bounce{0%,20%,53%,80%,to{transform:translateZ(0)}40%,43%{transform:translate3d(0,-30px,0)}70%{transform:translate3d(0,-15px,0)}90%{transform:translate3d(0,-4px,0)}}.text-gradient{-webkit-text-fill-color:#0000;background:var(--primary-gradient);-webkit-background-clip:text;background-clip:text}.glass-effect{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3}.shadow-glow{box-shadow:0 0 20px #007bff4d}.will-change-transform{will-change:transform}.will-change-opacity{will-change:opacity}.gpu-accelerated{-webkit-backface-visibility:hidden;backface-visibility:hidden;perspective:1000px;transform:translateZ(0)}.floating-scroll-to-top{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--primary-color);border:none;border-radius:50%;bottom:2rem;box-shadow:0 4px 15px #007bff4d;color:var(--white);cursor:pointer;display:flex;font-size:1.2rem;height:50px;justify-content:center;position:fixed;right:2rem;width:50px;z-index:999}.floating-scroll-to-top:hover{background:var(--primary-to-gradian-color);box-shadow:0 6px 20px #007bff66}@media (max-width:768px){.floating-scroll-to-top{bottom:1.5rem;font-size:1.1rem;height:45px;right:1.5rem;width:45px}}@media (max-width:576px){.floating-scroll-to-top{bottom:1rem;font-size:1rem;height:40px;right:1rem;width:40px}}
/*# sourceMappingURL=main.2253eda3.css.map*/