:root{--primary-color:#2563eb;--secondary-color:#1e40af;--accent-color:#f59e0b;--text-primary:#1f2937;--text-secondary:#6b7280;--background-light:#f9fafb;--background-white:#fff;--border-color:#e5e7eb;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#1f2937;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}html{scroll-behavior:smooth}.container{margin:0 auto;max-width:1200px;padding:0 1rem}.btn{border:none;border-radius:.5rem;cursor:pointer;display:inline-block;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease}.btn-primary{background-color:#2563eb;background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:#1e40af;background-color:var(--secondary-color);box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-secondary{background-color:initial;border:2px solid #2563eb;border:2px solid var(--primary-color);color:#2563eb;color:var(--primary-color)}.btn-secondary:hover{background-color:#2563eb;background-color:var(--primary-color);color:#fff}.section{padding:4rem 0}.section-title{color:#1f2937;color:var(--text-primary);font-size:2.5rem;font-weight:700;margin-bottom:1rem;text-align:center}.section-subtitle{color:#6b7280;color:var(--text-secondary);font-size:1.125rem;margin-bottom:3rem;margin-left:auto;margin-right:auto;max-width:600px;text-align:center}@media (max-width:768px){.section{padding:2rem 0}.section-title{font-size:2rem}.container{padding:0 1.5rem}}.header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-bottom:1px solid var(--border-color);left:0;position:fixed;right:0;top:0;transition:all .3s ease;z-index:1000}.header-content{justify-content:space-between;padding:1rem 0}.header-content,.logo{align-items:center;display:flex}.logo{color:inherit;gap:.75rem;text-decoration:none}.logo-icon{align-items:center;display:flex;height:3rem;justify-content:center;width:3rem}.logo-icon img{border-radius:50%;height:100%;object-fit:contain;width:100%}.logo-title{color:var(--primary-color);font-size:1.25rem;font-weight:700;line-height:1.2}.logo-subtitle{color:var(--text-secondary);font-size:.75rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.nav{align-items:center;display:flex;gap:2rem}.nav-link{color:var(--text-primary);font-weight:500;position:relative;text-decoration:none;transition:color .3s ease}.nav-link:hover{color:var(--primary-color)}.nav-link:after{background:var(--primary-color);bottom:-5px;content:"";height:2px;left:0;position:absolute;transition:width .3s ease;width:0}.nav-link:hover:after{width:100%}.nav-cta{background:linear-gradient(135deg,var(--primary-color) 0,var(--secondary-color) 100%);border-radius:.5rem;box-shadow:0 2px 10px #3b82f633;color:#fff!important;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.nav-cta:hover{background:linear-gradient(135deg,var(--secondary-color) 0,var(--primary-color) 100%);box-shadow:0 4px 20px #3b82f64d;color:#fff!important;transform:translateY(-2px)}.nav-cta:after{display:none}.mobile-menu-btn{background:none;border:none;cursor:pointer;display:none;padding:.5rem}.hamburger{display:block;position:relative}.hamburger,.hamburger:after,.hamburger:before{background:var(--text-primary);height:2px;transition:all .3s ease;width:24px}.hamburger:after,.hamburger:before{content:"";position:absolute}.hamburger:before{top:-8px}.hamburger:after{bottom:-8px}.hamburger.open{background:#0000}.hamburger.open:before{top:0;transform:rotate(45deg)}.hamburger.open:after{bottom:0;transform:rotate(-45deg)}@media (max-width:768px){.nav{background:#fff;border-top:1px solid var(--border-color);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-open{opacity:1;transform:translateY(0);visibility:visible}.mobile-menu-btn{display:block}.logo-title{font-size:1rem}.logo-icon{font-size:1.5rem;height:2.5rem;width:2.5rem}.nav-cta{font-size:.9rem;margin:0 auto;max-width:200px;padding:.75rem 1.25rem;text-align:center;width:100%}}@media (max-width:480px){.nav-cta{font-size:.85rem;max-width:180px;padding:.65rem 1rem}}.hero{background:linear-gradient(135deg,#f8fafc,#e2e8f0);display:flex;min-height:100vh;overflow:hidden;padding-top:80px}.hero,.hero-content{align-items:center;position:relative}.hero-content{grid-gap:4rem;display:grid;gap:4rem;grid-template-columns:1fr 1fr;z-index:2}.hero-text{animation:slideInLeft 1s ease-out}.hero-title{color:var(--text-primary);font-size:3.5rem;font-weight:700;line-height:1.1;margin-bottom:1.5rem}.hero-description{color:var(--text-secondary);font-size:1.25rem;line-height:1.6;margin-bottom:2.5rem}.hero-cta{display:flex;flex-wrap:wrap;gap:1rem}.hero-visual{animation:slideInRight 1s ease-out}.hero-image,.hero-visual{align-items:center;display:flex;justify-content:center;position:relative}.hero-image{max-width:700px;width:100%;z-index:2}.hero-image img{height:auto;object-fit:contain;transition:transform .3s ease;width:100%}.hero-image img:hover{transform:scale(1.05)}.floating-elements{height:100%;position:absolute;width:100%}.floating-element{animation:float 6s ease-in-out infinite;font-size:2rem;position:absolute}.element-1{animation-delay:0s;left:10%;top:10%}.element-2{animation-delay:1.5s;right:20%;top:20%}.element-3{animation-delay:3s;bottom:20%;left:20%}.element-4{animation-delay:4.5s;bottom:10%;right:10%}.hero-background{bottom:0;left:0;position:absolute;right:0;top:0;z-index:1}.hero-shape{background:linear-gradient(135deg,#2563eb1a,#f59e0b1a);border-radius:50%;position:absolute}.shape-1{animation:pulse 4s ease-in-out infinite;height:300px;right:10%;top:10%;width:300px}.shape-2{animation:pulse 4s ease-in-out 1s infinite;bottom:20%;height:200px;left:5%;width:200px}.shape-3{animation:pulse 4s ease-in-out 2s infinite;height:150px;right:20%;top:60%;width:150px}@keyframes pulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.5;transform:scale(1.1)}}@media (max-width:768px){.hero-content{gap:2rem;grid-template-columns:1fr;text-align:center}.hero-title{font-size:2.5rem}.hero-description{font-size:1.125rem}.hero-cta{justify-content:center}.hero-image{max-width:400px}.floating-elements,.hero-shape{display:none}}.services{background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:80px 0}.services-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(2,1fr);margin-top:50px}.service-card{background:#fff;border:1px solid #0000000d;border-radius:16px;box-shadow:0 4px 20px #00000014;overflow:hidden;padding:30px;position:relative;transition:all .3s ease}.service-card:before{background:linear-gradient(90deg,#3b82f6,#8b5cf6);content:"";height:4px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.service-card:hover:before{transform:scaleX(1)}.service-card:hover{box-shadow:0 12px 40px #00000026;transform:translateY(-8px)}.service-icon{display:block;font-size:3rem;margin-bottom:20px}.service-title{color:#1e293b;font-size:1.5rem;font-weight:700;line-height:1.3;margin-bottom:15px}.service-description{color:#64748b;font-size:.95rem;line-height:1.6;margin-bottom:20px}.service-features{list-style:none;margin:0;padding:0}.service-feature{align-items:center;color:#475569;display:flex;font-size:.9rem;margin-bottom:8px}.feature-check{color:#10b981;font-size:1rem;font-weight:700;margin-right:8px}.service-card{animation:fadeInUp .6s ease forwards;opacity:0}@media (max-width:768px){.services{padding:60px 0}.services-grid{gap:20px;grid-template-columns:1fr;margin-top:30px}.service-card{padding:25px}.service-icon{font-size:2.5rem}.service-title{font-size:1.3rem}}.why-choose-us{background:var(--background-light)}.reasons-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.reason-card{animation:fadeInUp .8s ease-out both;background:var(--background-white);border:1px solid #0000;border-radius:1rem;padding:2rem;text-align:center;transition:all .3s ease}.reason-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-lg);transform:translateY(-5px)}.reason-icon{align-items:center;background:linear-gradient(135deg,var(--accent-color),var(--primary-color));border-radius:50%;display:inline-block;display:flex;font-size:3rem;height:5rem;justify-content:center;margin:0 auto 1.5rem;width:5rem}.reason-title{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin-bottom:1rem}.reason-description{color:var(--text-secondary);line-height:1.6}@media (max-width:768px){.reasons-grid{gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.reason-card{padding:1.5rem}.reason-icon{font-size:2.5rem;height:4rem;width:4rem}}.portfolio{background:var(--background-white)}.portfolio-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:3rem}.project-card{animation:fadeInUp .8s ease-out both;background:var(--background-white);border:1px solid var(--border-color);border-radius:1rem;cursor:pointer;overflow:hidden;transition:all .3s ease}.project-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-5px)}.project-image{height:200px;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.05)}.project-content{padding:1.5rem}.project-name{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.project-category{color:var(--primary-color);font-size:.875rem;font-weight:500;letter-spacing:.05em;margin-bottom:.75rem;text-transform:uppercase}.project-description{color:var(--text-secondary);font-size:.9rem;line-height:1.6;margin-bottom:1rem}.project-link{margin-top:auto}.link-text{color:var(--primary-color);font-size:.875rem;font-weight:500;transition:all .3s ease}.project-card:hover .link-text{transform:translateX(5px)}.portfolio-cta{text-align:center}@media (max-width:768px){.portfolio-grid{gap:1.5rem;grid-template-columns:1fr}.project-image{height:150px}.project-icon{font-size:3rem}.project-content{padding:1.25rem}}.technologies{background:var(--background-light)}.tech-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));margin:0 auto;max-width:800px}.tech-item{animation:fadeInUp .8s ease-out both;background:var(--background-white);border:1px solid var(--border-color);border-radius:1rem;padding:1.5rem;text-align:center;transition:all .3s ease}.tech-item:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md);transform:translateY(-3px)}.tech-logo{align-items:center;display:flex;height:4rem;justify-content:center}.tech-logo img{filter:grayscale(100%);max-height:100%;max-width:100%;object-fit:contain;transition:filter .3s ease}.tech-item:hover .tech-logo img{filter:grayscale(0)}@media (max-width:768px){.tech-grid{gap:1rem;grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.tech-item{padding:1rem}.tech-logo{height:3rem}}.cta{background:linear-gradient(135deg,var(--primary-color) 0,var(--secondary-color) 100%);color:#fff;overflow:hidden;position:relative}.cta-content{position:relative;text-align:center;z-index:2}.cta-title{font-size:2.5rem;font-weight:700;line-height:1.2;margin-bottom:1.5rem}.cta-description{font-size:1.25rem;margin-bottom:2.5rem;margin-left:auto;margin-right:auto;max-width:600px;opacity:.9}.cta-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.cta .btn-primary{background:#fff;color:var(--primary-color)}.cta .btn-primary:hover{background:var(--background-light);transform:translateY(-2px)}.cta .btn-secondary{background:#0000;border-color:#fff;color:#fff}.cta .btn-secondary:hover{background:#fff;color:var(--primary-color)}.cta-background{bottom:0;left:0;position:absolute;right:0;top:0;z-index:1}.cta-shape{background:#ffffff1a;border-radius:50%;position:absolute}.shape-1{animation:float 6s ease-in-out infinite;height:200px;right:-100px;top:-100px;width:200px}.shape-2{animation:float 6s ease-in-out 2s infinite;bottom:-75px;height:150px;left:-75px;width:150px}.contact-modal-overlay{align-items:center;animation:fadeIn .4s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;padding:2rem;position:fixed;right:0;top:0;z-index:1000}.contact-modal-content{animation:slideInUp .4s ease;background:linear-gradient(145deg,#fff,#f8fafc);border:1px solid #fff3;border-radius:2rem;box-shadow:0 25px 80px #00000040,0 0 0 1px #ffffff1a;max-width:550px;position:relative;width:100%}.contact-modal-close{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0000000d;border:none;border-radius:50%;color:#000;cursor:pointer;display:flex;font-size:1.5rem;height:3rem;justify-content:center;position:absolute;right:1.5rem;top:1.5rem;transition:all .3s ease;width:3rem;z-index:10}.contact-modal-close:hover{background:#0000001a;color:#000;transform:scale(1.1) rotate(90deg)}.contact-modal-header{background:linear-gradient(135deg,#3b82f60d,#9333ea0d);border-radius:2rem 2rem 0 0;overflow:hidden;padding:3rem 3rem 2rem;position:relative;text-align:center}.contact-modal-header:before{animation:shimmer 3s infinite;background:linear-gradient(45deg,#0000 30%,#ffffff4d 50%,#0000 70%);bottom:0;content:"";left:0;position:absolute;right:0;top:0}.contact-modal-title{color:#000;font-size:2rem;font-weight:800;line-height:1.2;margin-bottom:1.5rem;position:relative;z-index:1}.contact-modal-intro{color:#000;font-size:1.1rem;font-weight:500;line-height:1.7;margin-bottom:0;opacity:.9;position:relative;z-index:1}.contact-modal-body{padding:2.5rem 3rem 3rem}.contact-info{gap:2rem;margin-bottom:2rem}.contact-item{align-items:flex-start;background:linear-gradient(145deg,#fff,#f8fafc);border:1px solid #00000014;border-radius:1.5rem;box-shadow:0 4px 20px #0000000d;gap:1.5rem;overflow:hidden;padding:2rem;position:relative;transition:all .4s ease}.contact-item:before{background:linear-gradient(90deg,var(--primary-color) 0,var(--secondary-color) 100%);content:"";height:3px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.contact-item:hover{background:linear-gradient(145deg,#fff,#f1f5f9);border-color:var(--primary-color);box-shadow:0 8px 30px #0000001a;transform:translateY(-4px)}.contact-item:hover:before{transform:scaleX(1)}.contact-icon{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--primary-color) 0,var(--secondary-color) 100%);-webkit-background-clip:text;background-clip:text;color:#000;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));flex-shrink:0;font-size:2rem}.contact-details h3{margin-bottom:.75rem}.contact-details h3,.contact-link{color:#000;font-size:1.25rem;font-weight:700;letter-spacing:-.025em}.contact-link{display:block;margin-bottom:.5rem;text-decoration:none;transition:all .3s ease}.contact-link:hover{color:#000;text-decoration:none;transform:translateX(4px)}.contact-info a,.contact-info p{color:#000!important}.contact-details p{color:#000;font-size:.95rem;font-weight:500;margin:0;opacity:1}.contact-cta{background:linear-gradient(135deg,var(--primary-color) 0,var(--secondary-color) 100%);border-radius:1.5rem;box-shadow:0 8px 30px #3b82f64d;color:#fff;overflow:hidden;padding:2rem;position:relative;text-align:center}.contact-cta:before{animation:shimmer 2s infinite;background:linear-gradient(45deg,#0000 30%,#ffffff1a 50%,#0000 70%);bottom:0;content:"";left:0;position:absolute;right:0;top:0}.contact-cta-text{font-size:1rem;font-weight:500;line-height:1.6;margin:0;position:relative;z-index:1}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(40px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}@media (max-width:768px){.cta-title{font-size:2rem}.cta-description{font-size:1.125rem}.cta-buttons{align-items:center;flex-direction:column}.cta .btn{max-width:300px;width:100%}.contact-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:.5rem}.contact-modal-content{border-radius:1rem;margin:0;max-height:95vh;max-width:100%;overflow-y:auto}.contact-modal-header{border-radius:1rem 1rem 0 0;padding:1.5rem 1.5rem 1rem}.contact-modal-title{font-size:1.25rem;line-height:1.3}.contact-modal-intro{font-size:.95rem;line-height:1.5}.contact-modal-body{padding:1rem 1.5rem 1.5rem}.contact-info{gap:1rem;margin-bottom:1rem}.contact-item{flex-direction:column;gap:.75rem;padding:1rem;text-align:center}.contact-icon{align-self:center;font-size:1.5rem}.contact-details h3{font-size:1rem;margin-bottom:.5rem}.contact-link{font-size:1rem;margin-bottom:.25rem}.contact-details p{font-size:.85rem}.contact-cta{border-radius:1rem;padding:1rem}.contact-cta-text{font-size:.9rem}.contact-modal-close{font-size:1.25rem;height:2.5rem;right:1rem;top:1rem;width:2.5rem}}@media (max-width:480px){.contact-modal-overlay{padding:.25rem}.contact-modal-content{border-radius:.75rem;max-height:98vh}.contact-modal-header{border-radius:.75rem .75rem 0 0;padding:1rem 1rem .75rem}.contact-modal-title{font-size:1.125rem}.contact-modal-intro{font-size:.9rem}.contact-modal-body{padding:.75rem 1rem 1rem}.contact-item{border-radius:1rem;padding:.75rem}.contact-icon{font-size:1.25rem}.contact-details h3,.contact-link{font-size:.95rem}.contact-details p{font-size:.8rem}.contact-cta{border-radius:.75rem;padding:.75rem}.contact-cta-text{font-size:.85rem}}.footer{background:var(--text-primary);color:#fff;padding:4rem 0 2rem}.footer-content{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:2fr 1fr 1fr 1.5fr;margin-bottom:3rem}.footer-logo{gap:.75rem;margin-bottom:1.5rem}.footer-logo,.footer-logo-icon{align-items:center;display:flex}.footer-logo-icon{border-radius:50%;height:3rem;justify-content:center;padding:.25rem;width:3rem}.footer-logo-icon img{height:100%;object-fit:contain;width:100%}.footer-logo-title{color:var(--primary-color);font-size:1.25rem;font-weight:700;line-height:1.2}.footer-logo-subtitle{color:#9ca3af;font-size:.75rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.footer-description{color:#9ca3af;line-height:1.6;max-width:300px}.footer-section-title{color:#fff;font-size:1.125rem;font-weight:600;margin-bottom:1.5rem}.footer-nav{display:flex;flex-direction:column;gap:.75rem}.footer-nav-link{color:#9ca3af;text-decoration:none;transition:color .3s ease}.footer-nav-link:hover{color:var(--primary-color)}.contact-info{display:flex;flex-direction:column;gap:1rem}.contact-item{align-items:center;color:#9ca3af;display:flex;gap:.75rem}.contact-icon{color:var(--primary-color);font-size:1.125rem}.footer-bottom{border-top:1px solid #374151;padding-top:2rem}.footer-bottom-content{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between}.copyright{color:#9ca3af;font-size:.875rem}.footer-bottom-links{display:flex;gap:2rem}.footer-bottom-link{color:#9ca3af;font-size:.875rem;text-decoration:none;transition:color .3s ease}.footer-bottom-link:hover{color:var(--primary-color)}@media (max-width:768px){.footer-content{gap:2rem;grid-template-columns:1fr;text-align:center}.footer-logo{justify-content:center}.footer-description{margin:0 auto;max-width:none}.footer-bottom-content{flex-direction:column;text-align:center}.footer-bottom-links{justify-content:center}}.portfolio-page{background:var(--background-white);padding:6rem 0}.portfolio-header{margin-bottom:4rem;text-align:center}.portfolio-title{color:var(--text-primary);font-size:3rem;font-weight:700;margin-bottom:1rem}.portfolio-subtitle{color:var(--text-secondary);font-size:1.25rem;line-height:1.6;margin:0 auto;max-width:600px}.portfolio-filters{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:3rem}.filter-btn{background:#0000;border:2px solid var(--border-color);border-radius:2rem;color:var(--text-primary);cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:all .3s ease}.filter-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.filter-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.portfolio-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-bottom:4rem}.portfolio-item{animation:fadeInUp .8s ease-out both;background:var(--background-white);border-radius:1rem;box-shadow:var(--shadow-sm);overflow:hidden;transition:all .3s ease}.portfolio-item:hover{box-shadow:var(--shadow-lg);transform:translateY(-5px)}.portfolio-image{height:250px;overflow:hidden;position:relative}.portfolio-image img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.portfolio-item:hover .portfolio-image img{transform:scale(1.05)}.portfolio-overlay{align-items:center;background:#2563ebe6;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.portfolio-item:hover .portfolio-overlay{opacity:1}.portfolio-overlay-content{color:#fff;padding:2rem;text-align:center}.portfolio-item-title{font-size:1.5rem;font-weight:600;margin-bottom:1rem}.portfolio-item-description{font-size:.9rem;line-height:1.5;margin-bottom:1.5rem}.portfolio-technologies{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.tech-tag{background:#fff3;border-radius:1rem;color:#fff;font-size:.75rem;font-weight:500;padding:.25rem .75rem}.portfolio-item-info{padding:1.5rem}.portfolio-item-name{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.portfolio-item-category{color:var(--primary-color);font-size:.875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.modal-overlay{align-items:center;animation:fadeIn .3s ease;background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;padding:2rem;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:slideIn .3s ease;background:#fff;border-radius:1rem;max-height:90vh;max-width:90vw;overflow-y:auto;position:relative}.modal-close{align-items:center;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:3rem;justify-content:center;position:absolute;right:1rem;top:1rem;transition:all .3s ease;width:3rem;z-index:10}.modal-close:hover{background:#000000e6;transform:scale(1.1)}.modal-image-container{max-height:none;overflow:visible;width:100%}.modal-image{display:block;height:auto;max-width:100%;object-fit:contain;width:100%}.modal-info{background:#fff;padding:2rem}.modal-title{color:var(--text-primary);font-size:1.75rem;font-weight:700;margin-bottom:1rem}.modal-description{color:var(--text-secondary);font-size:1rem;line-height:1.6;margin-bottom:1.5rem}.modal-technologies{display:flex;flex-wrap:wrap;gap:.5rem}.modal-tech-tag{background:var(--primary-color);border-radius:1rem;color:#fff;font-size:.875rem;font-weight:500;padding:.5rem 1rem}@media (max-width:768px){.portfolio-page{padding:4rem 0}.portfolio-title{font-size:2.5rem}.portfolio-subtitle{font-size:1.125rem}.portfolio-filters{gap:.5rem}.filter-btn{font-size:.875rem;padding:.5rem 1rem}.portfolio-grid{gap:1.5rem;grid-template-columns:1fr}.portfolio-image{height:200px}.modal-overlay{padding:1rem}.modal-content{max-height:95vh;max-width:95vw}.modal-close{font-size:1.25rem;height:2.5rem;right:.5rem;top:.5rem;width:2.5rem}.modal-image-container{max-height:none}.modal-info{padding:1.5rem}.modal-title{font-size:1.5rem}.modal-description{font-size:.9rem}.modal-tech-tag{font-size:.8rem;padding:.4rem .8rem}}.privacy-policy-page{background:var(--background-white);min-height:100vh;padding:6rem 0}.privacy-header{border-bottom:2px solid var(--border-color);margin-bottom:4rem;padding-bottom:2rem;text-align:center}.privacy-header-top{display:flex;justify-content:flex-start;margin-bottom:2rem}.privacy-title{color:var(--text-primary);font-size:3rem;font-weight:700;margin-bottom:1rem}.privacy-subtitle{color:var(--text-secondary);font-size:1.125rem;font-style:italic}.privacy-content{margin:0 auto;max-width:800px}.privacy-section{background:#fff;border:1px solid var(--border-color);border-radius:1rem;box-shadow:0 2px 10px #0000000d;margin-bottom:3rem;padding:2rem}.privacy-section h2{border-bottom:2px solid var(--primary-color);color:var(--primary-color);font-size:1.75rem;font-weight:700;margin-bottom:1.5rem;padding-bottom:.5rem}.privacy-section h3{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin:1.5rem 0 1rem}.privacy-section p{color:var(--text-secondary);font-size:1rem;line-height:1.7;margin-bottom:1rem}.privacy-section ul{margin:1rem 0;padding-left:1.5rem}.privacy-section li{color:var(--text-secondary);font-size:1rem;line-height:1.6;margin-bottom:.5rem}.privacy-section strong{color:var(--text-primary);font-weight:600}.privacy-section{animation:fadeInUp .6s ease forwards;opacity:0}.privacy-section:first-child{animation-delay:.1s}.privacy-section:nth-child(2){animation-delay:.2s}.privacy-section:nth-child(3){animation-delay:.3s}.privacy-section:nth-child(4){animation-delay:.4s}.privacy-section:nth-child(5){animation-delay:.5s}.privacy-section:nth-child(6){animation-delay:.6s}.privacy-section:nth-child(7){animation-delay:.7s}.privacy-section:nth-child(8){animation-delay:.8s}.privacy-section:nth-child(9){animation-delay:.9s}.privacy-section:nth-child(10){animation-delay:1s}.privacy-section:nth-child(11){animation-delay:1.1s}@media (max-width:768px){.privacy-policy-page{padding:4rem 0}.privacy-header-top{justify-content:center;margin-bottom:1.5rem}.back-home-btn{font-size:.9rem;padding:.6rem 1.25rem}.privacy-title{font-size:2.5rem}.privacy-subtitle{font-size:1rem}.privacy-section{margin-bottom:2rem;padding:1.5rem}.privacy-section h2{font-size:1.5rem}.privacy-section h3{font-size:1.125rem}.privacy-section li,.privacy-section p{font-size:.95rem}.contact-info{padding:1.25rem}}@media (max-width:480px){.privacy-policy-page{padding:3rem 0}.privacy-title{font-size:2rem}.privacy-section{padding:1rem}.privacy-section h2{font-size:1.25rem}}.legal-notice-page{background:var(--background-white);min-height:100vh;padding:6rem 0}.legal-header{border-bottom:2px solid var(--border-color);margin-bottom:4rem;padding-bottom:2rem;text-align:center}.legal-header-top{display:flex;justify-content:flex-start;margin-bottom:2rem}.back-home-btn{align-items:center;background:var(--primary-color);border-radius:2rem;box-shadow:0 2px 10px #3b82f64d;color:#fff;display:inline-flex;font-size:.95rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease}.back-home-btn:hover{background:var(--secondary-color);box-shadow:0 4px 20px #3b82f666;color:#fff;text-decoration:none;transform:translateY(-2px)}.legal-title{color:var(--text-primary);font-size:3rem;font-weight:700;margin-bottom:1rem}.legal-subtitle{color:var(--text-secondary);font-size:1.125rem;font-style:italic}.legal-content{margin:0 auto;max-width:800px}.legal-section{background:#fff;border:1px solid var(--border-color);border-radius:1rem;box-shadow:0 2px 10px #0000000d;margin-bottom:3rem;padding:2rem}.legal-section h2{border-bottom:2px solid var(--primary-color);color:var(--primary-color);font-size:1.75rem;font-weight:700;margin-bottom:1.5rem;padding-bottom:.5rem}.legal-section h3{color:var(--text-primary);font-size:1.25rem;font-weight:600;margin:1.5rem 0 1rem}.legal-section p{color:var(--text-secondary);font-size:1rem;line-height:1.7;margin-bottom:1rem}.legal-section ul{margin:1rem 0;padding-left:1.5rem}.legal-section li{color:var(--text-secondary);font-size:1rem;line-height:1.6;margin-bottom:.5rem}.legal-section strong{color:var(--text-primary);font-weight:600}.company-info{background:#f8fafc;border-left:4px solid var(--primary-color);border-radius:.75rem;padding:1.5rem}.company-info p{margin-bottom:.75rem}.company-info p:last-child{margin-bottom:0}.legal-section a{color:var(--primary-color);font-weight:500;text-decoration:none;transition:color .3s ease}.legal-section a:hover{color:var(--secondary-color);text-decoration:underline}.legal-link{color:var(--primary-color);font-weight:500;text-decoration:none;transition:color .3s ease}.legal-link:hover{color:var(--secondary-color);text-decoration:underline}.contact-info{background:linear-gradient(135deg,var(--primary-color) 0,var(--secondary-color) 100%);border-radius:1rem;color:#fff;margin-top:1rem;padding:1.5rem}.contact-info p{color:#fff;margin-bottom:.5rem}.contact-info a{color:#fff;font-weight:500;text-decoration:none;transition:opacity .3s ease}.contact-info a:hover{opacity:.8;text-decoration:underline}.legal-section{animation:fadeInUp .6s ease forwards;opacity:0}.legal-section:first-child{animation-delay:.1s}.legal-section:nth-child(2){animation-delay:.2s}.legal-section:nth-child(3){animation-delay:.3s}.legal-section:nth-child(4){animation-delay:.4s}.legal-section:nth-child(5){animation-delay:.5s}.legal-section:nth-child(6){animation-delay:.6s}.legal-section:nth-child(7){animation-delay:.7s}.legal-section:nth-child(8){animation-delay:.8s}.legal-section:nth-child(9){animation-delay:.9s}.legal-section:nth-child(10){animation-delay:1s}@media (max-width:768px){.legal-notice-page{padding:4rem 0}.legal-header-top{justify-content:center;margin-bottom:1.5rem}.back-home-btn{font-size:.9rem;padding:.6rem 1.25rem}.legal-title{font-size:2.5rem}.legal-subtitle{font-size:1rem}.legal-section{margin-bottom:2rem;padding:1.5rem}.legal-section h2{font-size:1.5rem}.legal-section h3{font-size:1.125rem}.legal-section li,.legal-section p{font-size:.95rem}.company-info,.contact-info{padding:1.25rem}}@media (max-width:480px){.legal-notice-page{padding:3rem 0}.legal-title{font-size:2rem}.legal-section{padding:1rem}.legal-section h2{font-size:1.25rem}}.cookie-banner{animation:slideUp .3s ease;background:#fff;border-top:1px solid var(--border-color);bottom:0;box-shadow:0 -4px 20px #0000001a;left:0;padding:1.5rem;position:fixed;right:0;z-index:1000}.cookie-content{flex-wrap:wrap;gap:2rem;margin:0 auto;max-width:1200px}.cookie-content,.cookie-header{align-items:center;display:flex}.cookie-header{flex-shrink:0;gap:.75rem}.cookie-icon{font-size:1.5rem}.cookie-header h3{color:var(--text-primary);font-size:1.125rem;font-weight:600;margin:0}.cookie-content p{color:var(--text-secondary);flex:1 1;font-size:.95rem;line-height:1.5;margin:0}.cookie-actions{display:flex;flex-shrink:0;flex-wrap:wrap;gap:.75rem}.cookie-btn{border:none;border-radius:.5rem;cursor:pointer;font-size:.9rem;font-weight:500;padding:.75rem 1.5rem;transition:all .3s ease;white-space:nowrap}.cookie-btn-primary{background:var(--primary-color);color:#fff}.cookie-btn-primary:hover{background:var(--secondary-color);transform:translateY(-1px)}.cookie-btn-secondary{background:#f1f5f9;border:1px solid var(--border-color);color:var(--text-primary)}.cookie-btn-secondary:hover{background:#e2e8f0;transform:translateY(-1px)}.cookie-modal-overlay{align-items:center;animation:fadeIn .3s ease;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:2rem;position:fixed;right:0;top:0;z-index:1001}.cookie-modal{animation:slideIn .3s ease;background:#fff;border-radius:1rem;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.cookie-modal-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:1.5rem 2rem}.cookie-modal-header h2{color:var(--text-primary);font-size:1.5rem;font-weight:700;margin:0}.cookie-modal-close{background:none;border:none;border-radius:.25rem;color:var(--text-secondary);cursor:pointer;font-size:1.5rem;padding:.5rem;transition:all .3s ease}.cookie-modal-close:hover{background:#f1f5f9;color:var(--text-primary)}.cookie-modal-content{padding:2rem}.cookie-modal-intro{color:var(--text-secondary);line-height:1.6;margin-bottom:2rem}.cookie-options{display:flex;flex-direction:column;gap:1.5rem}.cookie-option{border:1px solid var(--border-color);border-radius:.75rem;padding:1.5rem;transition:all .3s ease}.cookie-option:hover{border-color:var(--primary-color);box-shadow:0 2px 10px #0000000d}.cookie-option-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between}.cookie-option-info h4{color:var(--text-primary);font-size:1.125rem;font-weight:600;margin:0 0 .5rem}.cookie-option-info p{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:0}.cookie-toggle{flex-shrink:0;position:relative}.cookie-toggle input{height:0;opacity:0;width:0}.toggle-slider{background:#cbd5e1;border-radius:1rem;cursor:pointer;display:block;height:1.5rem;position:relative;transition:all .3s ease;width:3rem}.toggle-slider:before{background:#fff;border-radius:50%;box-shadow:0 2px 4px #0003;content:"";height:1.25rem;left:.125rem;position:absolute;top:.125rem;transition:all .3s ease;width:1.25rem}.cookie-toggle input:checked+.toggle-slider{background:var(--primary-color)}.cookie-toggle input:checked+.toggle-slider:before{transform:translateX(1.5rem)}.cookie-toggle input:disabled+.toggle-slider{background:var(--primary-color);cursor:not-allowed;opacity:.7}.cookie-modal-footer{border-top:1px solid var(--border-color);display:flex;flex-wrap:wrap;gap:1rem;padding:1.5rem 2rem}.cookie-modal-footer .cookie-btn{flex:1 1;min-width:120px}.cookie-manage-btn{background:var(--primary-color);border:none;border-radius:50%;bottom:2rem;box-shadow:0 4px 20px #3b82f64d;color:#fff;cursor:pointer;font-size:1.25rem;height:3rem;position:fixed;right:2rem;transition:all .3s ease;width:3rem;z-index:999}.cookie-manage-btn:hover{background:var(--secondary-color);box-shadow:0 6px 30px #3b82f666;transform:scale(1.1)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media (max-width:768px){.cookie-banner{border-radius:1rem 1rem 0 0;padding:.75rem}.cookie-content{gap:.75rem}.cookie-content,.cookie-header{align-items:flex-start;flex-direction:column}.cookie-header{gap:.5rem}.cookie-header h3{font-size:1rem}.cookie-content p{font-size:.9rem;line-height:1.4}.cookie-actions{flex-direction:column;gap:.5rem;width:100%}.cookie-btn{border-radius:.5rem;font-size:.9rem;padding:.75rem 1rem;width:100%}.cookie-modal-overlay{padding:.5rem}.cookie-modal{border-radius:1rem;max-height:95vh}.cookie-modal-header{border-radius:1rem 1rem 0 0;padding:1rem 1.25rem}.cookie-modal-header h2{font-size:1.25rem}.cookie-modal-content{padding:1.25rem}.cookie-modal-intro{font-size:.9rem;margin-bottom:1.5rem}.cookie-options{gap:1rem}.cookie-option{border-radius:.75rem;padding:1rem}.cookie-option-header{align-items:flex-start;flex-direction:column;gap:.75rem}.cookie-option-info h4{font-size:1rem}.cookie-option-info p{font-size:.85rem}.cookie-toggle{align-self:flex-end}.cookie-modal-footer{border-radius:0 0 1rem 1rem;flex-direction:column;gap:.5rem;padding:1rem 1.25rem}.cookie-modal-footer .cookie-btn{padding:.75rem 1rem;width:100%}.cookie-manage-btn{bottom:1rem;font-size:1rem;height:2.5rem;right:1rem;width:2.5rem}}@media (max-width:480px){.cookie-banner{border-radius:.75rem .75rem 0 0;padding:.5rem}.cookie-content{gap:.5rem}.cookie-header h3{font-size:.95rem}.cookie-content p{font-size:.85rem;line-height:1.3}.cookie-btn{border-radius:.4rem;font-size:.85rem;padding:.65rem .75rem}.cookie-modal-overlay{padding:.25rem}.cookie-modal{border-radius:.75rem;max-height:98vh}.cookie-modal-header{border-radius:.75rem .75rem 0 0;padding:.75rem 1rem}.cookie-modal-header h2{font-size:1.125rem}.cookie-modal-close{font-size:1.25rem;padding:.25rem}.cookie-modal-content{padding:1rem}.cookie-modal-intro{font-size:.85rem;margin-bottom:1rem}.cookie-options{gap:.75rem}.cookie-option{border-radius:.5rem;padding:.75rem}.cookie-option-header{gap:.5rem}.cookie-option-info h4{font-size:.95rem}.cookie-option-info p{font-size:.8rem}.toggle-slider{height:1.25rem;width:2.5rem}.toggle-slider:before{height:1rem;left:.125rem;top:.125rem;width:1rem}.cookie-toggle input:checked+.toggle-slider:before{transform:translateX(1.25rem)}.cookie-modal-footer{border-radius:0 0 .75rem .75rem;padding:.75rem 1rem}.cookie-modal-footer .cookie-btn{font-size:.85rem;padding:.65rem .75rem}.cookie-manage-btn{bottom:.75rem;font-size:.9rem;height:2.25rem;right:.75rem;width:2.25rem}}.preloader-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#fffffff2;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.preloader-content{align-items:center;display:flex;flex-direction:column;gap:1rem;text-align:center}.preloader-spinner{height:60px;position:relative;width:60px}.spinner-ring{animation:spin 1.2s linear infinite;border:3px solid #0000;border-radius:50%;border-top:3px solid var(--primary-color);height:100%;left:0;position:absolute;top:0;width:100%}.spinner-ring:nth-child(2){animation-direction:reverse;animation-duration:1s;border-top-color:var(--secondary-color);height:80%;left:10%;top:10%;width:80%}.spinner-ring:nth-child(3){animation-duration:.8s;border-top-color:var(--primary-color);height:60%;left:20%;top:20%;width:60%}.preloader-text{color:var(--text-primary);font-size:1rem;font-weight:500;margin:0;opacity:.8}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width:768px){.preloader-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.preloader-spinner{height:50px;width:50px}.preloader-text{font-size:.9rem}}@media (max-width:480px){.preloader-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.preloader-spinner{height:40px;width:40px}.preloader-text{font-size:.85rem}.spinner-ring{border-width:2px}}.App{text-align:left}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}.fade-in-up{animation:fadeInUp .8s ease-out}.slide-in-left{animation:slideInLeft .8s ease-out}.slide-in-right{animation:slideInRight .8s ease-out}.hover-lift{transition:transform .3s ease,box-shadow .3s ease}.hover-lift:hover{box-shadow:var(--shadow-lg);transform:translateY(-5px)}.gradient-bg{background:linear-gradient(135deg,var(--primary-color) 0,var(--secondary-color) 100%)}.gradient-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--primary-color) 0,var(--accent-color) 100%);-webkit-background-clip:text;background-clip:text}
/*# sourceMappingURL=main.37db2f79.css.map*/