*{box-sizing:border-box;margin:0;padding:0}body{font-feature-settings:"liga" 1,"kern" 1;background:#fff;color:#1f2937;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,Helvetica Neue,Arial,Segoe UI,Roboto,sans-serif;line-height:1.6;min-height:100vh;overflow-x:hidden;scroll-behavior:smooth;transition:background-color .3s ease,color .3s ease}body.dark-mode{background:#0a0a0a;color:#e5e7eb}body.dark-mode ::-webkit-scrollbar-track{background:#1f2937}body.dark-mode ::-webkit-scrollbar-thumb{background:#4b5563}body.dark-mode ::-webkit-scrollbar-thumb:hover{background:#6b7280}body.dark-mode .section-title{color:#fff}body.dark-mode .section-subtitle{color:#9ca3af}body.dark-mode .card{background:#1f2937;border-color:#374151;color:#e5e7eb}body.dark-mode .card:hover{border-color:#60a5fa}main{position:relative;width:100%;z-index:1}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{margin:0 auto;max-width:1200px;padding:0 20px}.container,.section{position:relative;z-index:1}.section{padding:80px 0}.section-dark{background:#1f2937;color:#fff}.section-dark .section-title{color:#fff}.section-dark .card{background:#374151;border-color:#4b5563;color:#fff}.section-dark .card:hover{border-color:#60a5fa}.section-title{animation:fadeInUp .8s cubic-bezier(.165,.84,.44,1) forwards;animation-delay:.2s;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Helvetica Neue,sans-serif;opacity:0;transform:translateY(30px)}.section-subtitle{animation:fadeInUp .8s cubic-bezier(.165,.84,.44,1) forwards;animation-delay:.4s;font-weight:400;line-height:1.5;opacity:0;text-align:center;transform:translateY(20px)}.btn{-webkit-tap-highlight-color:transparent;border-radius:25px;display:inline-block;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Helvetica Neue,sans-serif;overflow:hidden;padding:16px 32px;position:relative;text-decoration:none;transition:all .4s cubic-bezier(.165,.84,.44,1)}.btn:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .6s cubic-bezier(.165,.84,.44,1);width:100%}.btn:hover:before{left:100%}.btn-primary{background:linear-gradient(135deg,#1f2937,#374151);box-shadow:0 4px 15px #0000001a;color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#111827,#1f2937);box-shadow:0 15px 35px #00000026;transform:translateY(-3px) scale(1.02)}.btn-primary:active{transform:translateY(-1px) scale(.98);transition:all .1s ease}.btn-secondary{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:2px solid #1f293733;color:#1f2937}.btn-secondary:hover{background:#1f2937;border-color:#1f2937;box-shadow:0 15px 35px #1f293733;color:#fff;transform:translateY(-3px) scale(1.02)}.btn-secondary:active{transform:translateY(-1px) scale(.98);transition:all .1s ease}@keyframes fadeInLeft{0%{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes gentleFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.reveal{opacity:0;transform:translateY(30px);transition:all .8s cubic-bezier(.165,.84,.44,1)}.reveal.visible{opacity:1;transform:translateY(0)}*{-webkit-tap-highlight-color:transparent;touch-action:manipulation}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}a,button,input,textarea{min-height:44px;min-width:44px}@media (max-width:768px){.container{max-width:100%;padding:0 1rem}.section{padding:3rem 0}.section-title{font-size:2rem;line-height:1.2}.section-subtitle{font-size:1rem;padding:0 1rem}}@media (max-width:480px){.container{padding:0 .75rem}.section{padding:2.5rem 0}.section-title{font-size:1.75rem}.section-subtitle{font-size:.95rem}}.header{background:#0000;left:0;padding:1rem 1.5rem;pointer-events:none;position:fixed;right:0;top:0;transition:padding .3s ease;z-index:1000}.header-container{margin:0 auto;max-width:1200px;pointer-events:auto;position:relative}.nav-island{align-items:center;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#ffffff14;border:1px solid #ffffff1a;border-radius:9999px;box-shadow:0 4px 24px #00000026;box-sizing:border-box;display:flex;gap:1.5rem;justify-content:space-between;max-width:100%;min-height:52px;padding:.625rem 1.25rem .625rem 1.5rem;width:100%}body:not(.dark-mode) .nav-island{background:#ffffffbf;border-color:#ffffff40;box-shadow:0 4px 24px #00000014}.nav-island-logo{flex-shrink:0}.nav-island-logo span{color:#e5e7eb;font-size:1.0625rem;font-weight:700;letter-spacing:-.02em;white-space:nowrap}body:not(.dark-mode) .nav-island-logo span{color:#1f2937}.nav{flex:1 1;min-width:0}.nav,.nav-list{align-items:center;display:flex;gap:.25rem;justify-content:center}.nav-list{flex-wrap:wrap;list-style:none;margin:0;padding:0}.nav-list li{display:inline-block}.nav-list li button{background:none;border:none;border-radius:9999px;color:#e5e7ebf2;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;padding:.5rem .875rem;transition:color .2s ease,background .2s ease;white-space:nowrap}.nav-list li button:hover{background:#ffffff1a;color:#fff}body:not(.dark-mode) .nav-list li button{color:#374151}body:not(.dark-mode) .nav-list li button:hover{background:#0000000f;color:#1f2937}.theme-toggle{align-items:center;background:#0000;border:none;border-radius:50%;color:#e5e7ebe6;cursor:pointer;display:flex;flex-shrink:0;height:36px;justify-content:center;transition:color .3s ease,transform .2s ease;width:36px}.theme-toggle:hover{color:#fff;transform:scale(1.08)}body:not(.dark-mode) .theme-toggle{color:#4b5563}body:not(.dark-mode) .theme-toggle:hover{color:#1f2937}.theme-icon{height:20px;transition:transform .3s ease;width:20px}.mobile-menu-toggle{align-items:center;background:none;border:none;border-radius:8px;color:inherit;cursor:pointer;display:none;flex-direction:column;gap:5px;height:40px;justify-content:center;padding:0;width:40px}.mobile-menu-toggle span{background:currentColor;border-radius:1px;height:2px;transition:transform .3s ease,opacity .3s ease;width:20px}.nav-dropdown{animation:slideDown .25s ease;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#1e293bf2;border:1px solid #ffffff14;border-radius:16px;box-shadow:0 12px 40px #0006;display:flex;flex-direction:column;gap:.25rem;left:0;list-style:none;margin:0;padding:.5rem;position:absolute;right:0;top:calc(100% + .5rem);z-index:100}body:not(.dark-mode) .nav-dropdown{background:#fffffff2;border-color:#0000000f;box-shadow:0 12px 40px #0000001f}.nav-dropdown li button{background:none;border:none;border-radius:12px;color:#e5e7eb;cursor:pointer;display:block;font-family:inherit;font-size:1rem;font-weight:500;padding:.75rem 1rem;text-align:left;transition:background .2s ease;width:100%}.nav-dropdown li button:hover{background:#ffffff14}body:not(.dark-mode) .nav-dropdown li button{color:#374151}body:not(.dark-mode) .nav-dropdown li button:hover{background:#0000000d}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@media (max-width:900px){.nav-list{display:none}.mobile-menu-toggle{display:flex}.nav{flex:0 1}.nav-island{gap:1rem;padding:.5rem 1rem .5rem 1.25rem}}@media (max-width:768px){.header{padding:.75rem 1rem}.nav-island{border-radius:16px;min-height:48px;padding:.5rem 1rem}.nav-island-logo span{font-size:1rem}.theme-toggle{height:32px;width:32px}.theme-icon{height:18px;width:18px}.mobile-menu-toggle{height:36px;width:36px}.mobile-menu-toggle span{width:18px}}@media (max-width:480px){.header,.nav-island{padding:.5rem .75rem}.nav-island{border-radius:14px}.nav-island-logo span{font-size:.9375rem}}.hero{background:#0000;color:#1f2937;min-height:80vh;overflow:hidden;padding:7rem 0 5rem;position:relative;width:100%;z-index:1}body.dark-mode .hero{background:#0000;color:#e5e7eb}body.dark-mode .hero-title{color:#fff}body.dark-mode .highlight{color:#60a5fa}body.dark-mode .hero-description,body.dark-mode .hero-subtitle{color:#9ca3af}body.dark-mode .btn-primary{background:#2563eb;color:#fff}body.dark-mode .btn-primary:hover{background:#1d4ed8}body.dark-mode .btn-secondary{background:#0000;border-color:#60a5fa;color:#60a5fa}body.dark-mode .btn-secondary:hover{background:#60a5fa;color:#0a0a0a}body.dark-mode .profile-image{box-shadow:0 20px 40px #0006}@media (max-width:768px){.hero{min-height:70vh;padding:5.5rem 0 3rem}.hero-content{gap:2.5rem;grid-template-columns:1fr;text-align:center}.hero-title{font-size:2rem;line-height:1.3;margin-bottom:1rem}.hero-subtitle{font-size:1.125rem;margin-bottom:1.5rem}.hero-description{font-size:1rem;margin-bottom:2rem;max-width:100%}.hero-buttons{flex-direction:column;gap:1rem;margin-bottom:2rem}.hero-buttons .btn{font-size:1rem;margin:0 auto;max-width:280px;padding:1rem 2rem;width:100%}.hero-links{flex-wrap:wrap;gap:1.5rem;justify-content:center}.hero-visual{order:-1}.profile-image-wrapper{height:200px;margin:0 auto;width:200px}.profile-image{height:100%;width:100%}}@media (max-width:480px){.hero{min-height:65vh;padding:4.5rem 0 2.5rem}.hero-content{gap:2rem}.hero-title{font-size:1.75rem;line-height:1.3}.hero-subtitle{font-size:1rem}.hero-description{font-size:.95rem;line-height:1.5}.hero-buttons .btn{font-size:.95rem;max-width:240px;padding:.875rem 1.5rem}.profile-image-wrapper{height:160px;width:160px}.hero-links{gap:1rem}}.hero-content{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr;position:relative;z-index:1}.hero-title{animation:fadeInUp 1s cubic-bezier(.165,.84,.44,1) forwards;animation-delay:.2s;color:#1f2937;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Helvetica Neue,sans-serif;font-size:2.75rem;font-weight:700;letter-spacing:-.025em;line-height:1.2;margin:0 0 1rem;opacity:0;transform:translateY(50px)}.highlight{-webkit-text-fill-color:#0000;animation:gentleFloat 3s ease-in-out infinite;animation-delay:1s;background:linear-gradient(135deg,#2563eb,#1d4ed8 50%,#3b82f6);-webkit-background-clip:text;background-clip:text;color:#2563eb;font-weight:700}@keyframes textGlow{0%,to{filter:drop-shadow(0 0 10px rgba(79,172,254,.5))}50%{filter:drop-shadow(0 0 20px rgba(67,227,123,.8))}}.hero-subtitle{animation:fadeInUp 1s cubic-bezier(.165,.84,.44,1) forwards;animation-delay:.4s;color:#6b7280;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Helvetica Neue,sans-serif;font-size:1.25rem;font-weight:500;line-height:1.6;margin:0 0 1.75rem;opacity:0;transform:translateY(30px)}.hero-description{color:#6b7280;font-size:1.2rem;line-height:1.8;margin-bottom:2.5rem}.hero-buttons{display:flex;flex-wrap:wrap;gap:1rem;margin:0 0 1.75rem}.hero-buttons .btn{font-size:1.1rem;padding:15px 30px}.hero-links{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem}.hero-visual{align-items:center;display:flex;justify-content:center}.hero-image-container{position:relative}.profile-image-wrapper{background:#fff;border:4px solid #e5e7eb;border-radius:50%;box-shadow:0 20px 25px -5px #0000001a;height:300px;padding:8px;position:relative;transition:all .3s ease;width:300px}.profile-image-wrapper:hover{border-color:#2563eb;box-shadow:0 25px 50px -12px #00000040;transform:translateY(-8px)}@keyframes borderRotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes profileGlow{0%{box-shadow:0 20px 60px #0003,inset 0 2px 4px #ffffff4d,0 0 40px #4facfe4d}to{box-shadow:0 20px 60px #0003,inset 0 2px 4px #ffffff4d,0 0 60px #8e44ad80}}.profile-image{border:3px solid #ffffff80;border-radius:50%;height:100%;object-fit:cover;width:100%}@keyframes float{0%,to{transform:translateY(0) rotate(0deg)}33%{transform:translateY(-15px) rotate(1deg)}66%{transform:translateY(-10px) rotate(-1deg)}}@keyframes glow{0%{box-shadow:0 8px 32px #0000001a,inset 0 1px 0 #fff6,0 0 20px #667eea4d}to{box-shadow:0 8px 32px #0000001a,inset 0 1px 0 #fff6,0 0 40px #764ba266}}@media (max-width:768px){.hero{padding:100px 0 60px}.hero-content{gap:3rem;grid-template-columns:1fr;text-align:center}.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.25rem}.hero-description{font-size:1rem}.hero-buttons{align-items:center;flex-direction:column}.hero-buttons .btn{width:200px}.profile-circle{font-size:4rem;height:200px;width:200px}.hero-links{justify-content:center}}.social-icon{align-items:center;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;color:#64748b;display:inline-flex;height:44px;justify-content:center;text-decoration:none;transition:all .3s ease;width:44px}.social-icon:hover{background-color:#2563eb;border-color:#2563eb;box-shadow:0 4px 12px #2563eb4d;color:#fff;transform:translateY(-2px)}.social-icon svg{transition:transform .3s ease}.social-icon:hover svg{transform:scale(1.1)}@media (max-width:768px){.social-icon{height:40px;width:40px}}@media (max-width:480px){.social-icon{height:36px;width:36px}.social-icon svg{height:18px;width:18px}}.services{background:#0000;padding:5rem 0;position:relative;z-index:1}.services .section-header{margin-bottom:3rem;text-align:center}.services-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin:0 auto;max-width:1200px}.service-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 6px #0000000d;padding:2rem;transition:all .3s ease}.service-card:hover{border-color:#2563eb;box-shadow:0 12px 24px #0000001a;transform:translateY(-4px)}.service-title{color:#1f2937;font-size:1.5rem;font-weight:600;margin-bottom:1.5rem}.service-features{list-style:none;margin:0 0 2rem;padding:0}.service-features li{color:#4b5563;font-size:1rem;line-height:1.6;padding:.75rem 0 .75rem 1.5rem;position:relative}.service-features li:before{color:#2563eb;content:"•";font-size:1.2rem;font-weight:700;left:0;position:absolute}.service-cta{background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:.875rem 1.5rem;transition:all .3s ease;width:100%}.service-cta:hover{background:#1d4ed8;box-shadow:0 4px 12px #2563eb4d;transform:translateY(-1px)}body.dark-mode .service-card{background:#1f2937;border-color:#374151}body.dark-mode .service-title{color:#e5e7eb}body.dark-mode .service-features li{color:#9ca3af}body.dark-mode .service-features li:before{color:#60a5fa}body.dark-mode .service-card:hover{border-color:#60a5fa;box-shadow:0 12px 24px #0000004d}body.dark-mode .service-cta{background:#2563eb}body.dark-mode .service-cta:hover{background:#1d4ed8}@media (max-width:768px){.services{padding:3rem 0}.services-grid{gap:1.5rem;grid-template-columns:1fr}.service-card{padding:1.5rem}.service-title{font-size:1.25rem}}.about{background:#fafafa;padding:6rem 0}.about-content{grid-gap:4rem;align-items:start;display:grid;gap:4rem;grid-template-columns:2fr 1fr;margin:0 auto;max-width:1200px}.about-text{font-size:1.125rem;line-height:1.7}.about-text p{color:#4b5563;margin-bottom:1.5rem}.about-stats{grid-gap:1.5rem;display:grid;gap:1.5rem}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:2rem;text-align:center;transition:all .3s cubic-bezier(.165,.84,.44,1)}.stat-card:hover{border-color:#2563eb;box-shadow:0 10px 30px #0000001a;transform:translateY(-4px)}.stat-number{color:#2563eb;font-size:2.5rem;font-weight:700;line-height:1;margin-bottom:.5rem}.stat-label{color:#6b7280;font-size:.875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}body.dark-mode .about{background:#111827}body.dark-mode .about-text p{color:#9ca3af}body.dark-mode .stat-card{background:#1f2937;border-color:#374151}body.dark-mode .stat-card:hover{border-color:#60a5fa;box-shadow:0 10px 30px #0006}body.dark-mode .stat-number{color:#60a5fa}body.dark-mode .stat-label{color:#9ca3af}@media (max-width:768px){.about{padding:4rem 0}.section-title{font-size:2rem}.about-content{gap:3rem;grid-template-columns:1fr}.about-text{font-size:1rem}.about-stats{gap:1rem;grid-template-columns:repeat(3,1fr)}.stat-card{padding:1.5rem 1rem}.stat-number{font-size:2rem}.stat-label{font-size:.75rem}}.skills{background:#0000;padding:6rem 0}.skills-grid{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:0 auto;max-width:1200px}.skill-category{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#fff9;border:1px solid #fff3;border-radius:16px;box-shadow:0 4px 24px #0000000f;opacity:0;padding:2rem;transform:translateY(28px);transition:box-shadow .3s ease}.skill-category.visible{animation:jumpIn .65s cubic-bezier(.34,1.56,.64,1) forwards}.skill-category:first-child.visible{animation-delay:0s}.skill-category:nth-child(2).visible{animation-delay:.1s}.skill-category:nth-child(3).visible{animation-delay:.2s}.skill-category:hover{box-shadow:0 8px 32px #00000014}.category-title{border-bottom:1px solid #00000014;color:#1a1a1a;font-size:1.25rem;font-weight:600;margin-bottom:1.5rem;padding-bottom:.5rem;text-align:left}.skills-list{display:flex;flex-direction:column;gap:1.25rem}.skill-item{background:#0000;border:none;opacity:0;transform:translateY(20px);transition:transform .25s ease}.skill-item.visible{animation:jumpIn .6s cubic-bezier(.34,1.56,.64,1) forwards;animation-delay:var(--delay);opacity:1}.skill-item.visible:hover{transform:translateY(-3px)}.skill-content{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.skill-name{color:#1f2937;font-size:1rem;font-weight:500}.skill-level{color:#6b7280;font-size:.875rem;font-weight:600}.skill-bar{background-color:#0000000f;border-radius:999px;height:6px;overflow:hidden;position:relative}.skill-progress{background:linear-gradient(90deg,#2563eb,#1d4ed8);border-radius:3px;height:100%;position:relative;transition:width 1.2s cubic-bezier(.4,0,.2,1)}.skill-progress:after{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes jumpIn{0%{opacity:0;transform:translateY(24px)}60%{opacity:1;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}body.dark-mode .skill-category{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#1f293b80;border:1px solid #ffffff14;box-shadow:0 4px 24px #0003}body.dark-mode .skill-category:hover{box-shadow:0 8px 32px #0000004d}body.dark-mode .category-title{border-bottom-color:#ffffff1a;color:#e5e7eb}body.dark-mode .skill-item,body.dark-mode .skill-item:hover{background:#0000;border:none}body.dark-mode .skill-name{color:#e5e7eb}body.dark-mode .skill-level{color:#9ca3af}body.dark-mode .skill-bar{background-color:#ffffff1a}body.dark-mode .skill-progress{background:linear-gradient(90deg,#60a5fa,#3b82f6)}@media (max-width:768px){.skills{padding:4rem 0}.section-title{font-size:2rem}.skills-grid{gap:2rem;grid-template-columns:1fr}.skill-category{padding:2rem}}.projects{background:#0000;padding:6rem 0}.projects-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-top:3rem}.project-card{animation-delay:var(--delay);background:#fff;border:1px solid #f3f4f6;border-radius:16px;opacity:0;overflow:hidden;transform:translateY(30px);transition:all .4s cubic-bezier(.165,.84,.44,1)}.project-card.visible{animation:fadeInUp .6s ease forwards;opacity:1;transform:translateY(0)}.project-card:hover{border-color:#e5e7eb;box-shadow:0 20px 40px #0000001a;transform:translateY(-8px)}.project-image{aspect-ratio:16/10;background:#f9fafb;overflow:hidden;position:relative}.project-image img{height:100%;object-fit:cover;transition:transform .4s ease;width:100%}.project-card:hover .project-image img{transform:scale(1.05)}.image-fallback{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:none;font-size:1.1rem;font-weight:500;height:100%;width:100%}.image-fallback,.project-overlay{align-items:center;justify-content:center}.project-overlay{background:#000000b3;bottom:0;display:flex;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.project-card:hover .project-overlay{opacity:1}.overlay-links{display:flex;gap:1rem}.overlay-link{align-items:center;background:#fff;border-radius:50%;color:#1a1a1a;display:flex;height:48px;justify-content:center;text-decoration:none;transition:all .2s ease;width:48px}.overlay-link:hover{background:#2563eb;color:#fff;transform:scale(1.1)}.project-content{padding:1.5rem}.project-meta{margin-bottom:.5rem}.project-category{color:#2563eb;display:inline-block;font-size:.875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.project-title{color:#1a1a1a;font-size:1.5rem;font-weight:600;line-height:1.3;margin-bottom:.75rem}.project-description{color:#6b7280;font-size:.95rem;line-height:1.6;margin-bottom:1.25rem}.project-technologies{display:flex;flex-wrap:wrap;gap:.5rem}body.dark-mode .projects{background:#0000}body.dark-mode .project-card{background:#1f2937;border-color:#374151}body.dark-mode .project-card:hover{border-color:#60a5fa;box-shadow:0 20px 40px #0006}body.dark-mode .project-category{color:#60a5fa}body.dark-mode .project-title{color:#fff}body.dark-mode .project-description{color:#9ca3af}body.dark-mode .overlay-link{background:#1f2937;color:#e5e7eb}body.dark-mode .overlay-link:hover{background:#2563eb;color:#fff}body.dark-mode .image-fallback{background:linear-gradient(135deg,#374151,#4b5563)}@media (max-width:768px){.projects{padding:3rem 0}.section-header{margin-bottom:3rem}.section-title{font-size:2rem}.projects-grid{gap:1.5rem;grid-template-columns:1fr;margin-top:2rem}.project-card{margin-bottom:0}.project-image{aspect-ratio:16/9}.project-content{padding:1.25rem}.project-title{font-size:1.25rem;line-height:1.3}.project-description{font-size:.9rem;line-height:1.5;margin-bottom:1rem}.project-technologies{gap:.375rem;margin-bottom:0}.tech-tag{font-size:.8rem;padding:.2rem .6rem}.overlay-links{gap:.75rem}.overlay-link{height:40px;width:40px}}@media (max-width:480px){.projects{padding:2.5rem 0}.section-header{margin-bottom:2.5rem}.section-title{font-size:1.75rem}.section-subtitle{font-size:.95rem}.projects-grid{gap:1.25rem}.project-content{padding:1rem}.project-title{font-size:1.125rem}.project-description{font-size:.875rem}.tech-tag{font-size:.75rem;padding:.15rem .5rem}}.experience{background:#fafafa;padding:6rem 0}.experience-grid{grid-gap:4rem;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1000px}.experience-column{display:flex;flex-direction:column}.column-title{border-bottom:2px solid #e5e7eb;color:#1a1a1a;font-size:1.5rem;font-weight:600;margin-bottom:2rem;padding-bottom:.5rem;text-align:center}.items-list{display:flex;flex-direction:column;gap:2rem}.experience-item{animation-delay:var(--delay);background:#fff;border:1px solid #e5e7eb;border-radius:12px;opacity:0;padding:2rem;transform:translateY(20px);transition:all .3s cubic-bezier(.165,.84,.44,1)}.experience-item.visible{animation:slideIn .6s ease forwards;opacity:1;transform:translateY(0)}.experience-item:hover{border-color:#2563eb;box-shadow:0 10px 30px #0000001a;transform:translateY(-4px)}.item-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:.75rem}.item-title{color:#1a1a1a;flex:1 1;font-size:1.25rem;font-weight:600;line-height:1.3}.item-period{background:#f3f4f6;border-radius:12px;color:#6b7280;font-size:.875rem;font-weight:500;padding:.25rem .75rem;white-space:nowrap}.item-company{color:#2563eb;font-size:1rem;font-weight:500;margin-bottom:1rem}.item-description{color:#6b7280;font-size:.95rem;line-height:1.6;margin-bottom:1.25rem}.item-technologies{display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag{background:#f3f4f6;border-radius:12px;color:#374151;font-size:.875rem;font-weight:500;padding:.25rem .75rem;transition:all .2s ease}.tech-tag:hover{background:#e5e7eb;color:#1f2937}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}body.dark-mode .experience{background:#111827}body.dark-mode .column-title{border-bottom-color:#374151;color:#fff}body.dark-mode .experience-item{background:#1f2937;border-color:#374151}body.dark-mode .experience-item:hover{border-color:#60a5fa;box-shadow:0 10px 30px #0006}body.dark-mode .item-title{color:#fff}body.dark-mode .item-period{background:#374151;color:#9ca3af}body.dark-mode .item-company{color:#60a5fa}body.dark-mode .item-description{color:#9ca3af}body.dark-mode .tech-tag{background:#374151;color:#e5e7eb}body.dark-mode .tech-tag:hover{background:#4b5563;color:#fff}@media (max-width:768px){.experience{padding:4rem 0}.section-title{font-size:2rem}.experience-grid{gap:3rem;grid-template-columns:1fr}.experience-item{padding:1.5rem}.item-header{align-items:flex-start;flex-direction:column;gap:.5rem}.item-period{align-self:flex-start}}.contact{background:#0000;color:#1a1a1a;padding:6rem 0}.section-header{margin-bottom:4rem;text-align:center}.section-title{color:#1a1a1a;font-size:2.5rem;font-weight:700;letter-spacing:-.02em;margin-bottom:1rem}.section-subtitle{color:#6b7280;font-size:1.125rem;margin:0 auto;max-width:600px}.contact-content{grid-gap:4rem;align-items:start;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1200px}.contact-info h3{color:#1a1a1a;font-size:2rem;font-weight:600;line-height:1.3;margin-bottom:1.5rem}.contact-info p{color:#4b5563;font-size:1.125rem;line-height:1.7;margin-bottom:2rem}.contact-methods{display:flex;flex-direction:column;gap:2rem}.contact-method h4{color:#1a1a1a;font-size:1.125rem;font-weight:600;margin-bottom:.75rem}.contact-method a,.contact-method span{color:#2563eb;font-weight:500;text-decoration:none;transition:all .2s ease}.contact-method a:hover{color:#1d4ed8;text-decoration:underline}.contact-method span{color:#6b7280}.contact-form{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;padding:2.5rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#374151;display:block;font-size:.875rem;font-weight:500;letter-spacing:.05em;margin-bottom:.5rem;text-transform:uppercase}.form-group input,.form-group textarea{border:1px solid #d1d5db;border-radius:8px;font-family:inherit;font-size:1rem;padding:.75rem 1rem;transition:all .2s ease;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.form-group textarea{min-height:120px;resize:vertical}.btn{background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.875rem 2rem;transition:all .2s ease;width:100%}.btn:hover:not(:disabled){background:#1d4ed8;transform:translateY(-1px)}.btn:disabled{cursor:not-allowed;opacity:.6}.form-message{border-radius:8px;font-weight:500;margin-top:1rem;padding:.75rem 1rem}.form-message.success{background:#d1fae5;border:1px solid #a7f3d0;color:#065f46}.form-message.error{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b}.form-hint{color:#6b7280;font-size:.875rem;margin:.75rem 0 0}body.dark-mode .contact{background:#0000;color:#e5e7eb}body.dark-mode .contact-info h3{color:#fff}body.dark-mode .contact-info p{color:#9ca3af}body.dark-mode .contact-method h4{color:#fff}body.dark-mode .contact-method a{color:#60a5fa}body.dark-mode .contact-method a:hover{color:#3b82f6}body.dark-mode .contact-method span{color:#9ca3af}body.dark-mode .contact-form{background:#1f2937;border-color:#374151;box-shadow:0 4px 6px -1px #0006}body.dark-mode .form-group label{color:#e5e7eb}body.dark-mode .form-group input,body.dark-mode .form-group textarea{background:#374151;border-color:#4b5563;color:#e5e7eb}body.dark-mode .form-group input:focus,body.dark-mode .form-group textarea:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa1a}body.dark-mode .btn{background:#2563eb;color:#fff}body.dark-mode .btn:hover:not(:disabled){background:#1d4ed8}body.dark-mode .form-hint{color:#9ca3af}body.dark-mode .form-message.success{background:#064e3b;border-color:#047857;color:#34d399}body.dark-mode .form-message.error{background:#7f1d1d;border-color:#dc2626;color:#f87171}@media (max-width:768px){.contact{padding:4rem 0}.section-title{font-size:2rem}.contact-content{gap:3rem;grid-template-columns:1fr}.contact-info h3{font-size:1.5rem}.contact-form{padding:2rem}}.footer{background:linear-gradient(135deg,#1a1a1a,#2d2d2d);border-top:1px solid #ffffff1a;color:#fff;padding:4rem 0 2rem;position:relative}.footer:before{background:radial-gradient(circle at 25% 25%,#ffffff0d 0,#0000 50%),radial-gradient(circle at 75% 75%,#ffffff05 0,#0000 50%);bottom:0;content:"";left:0;position:absolute;right:0;top:0}.footer-content{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:2fr 1fr 1fr 1fr;margin-bottom:3rem}.footer-section h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#4facfe,#00f2fe);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 0 15px rgba(79,172,254,.5));font-size:1.8rem;font-weight:600;margin-bottom:1rem}.footer-section h4{color:#ffffffe6;font-size:1.3rem;font-weight:600;margin-bottom:1rem;text-shadow:0 0 10px #ffffff4d}.footer-section p{color:#fffc;font-size:1.1rem;line-height:1.7;margin-bottom:1.5rem;text-shadow:0 0 5px #fff3}.social-links{display:flex;gap:1.5rem}.social-links a{color:#ffffffe6;font-size:1.1rem;font-weight:500;text-decoration:none;text-shadow:0 0 5px #fff3;transition:all .3s ease}.social-links a:hover{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#4facfe,#00f2fe);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 0 15px rgba(79,172,254,.6));transform:translateY(-2px)}.footer-links{list-style:none;padding:0}.footer-links li{margin-bottom:.75rem}.footer-links button{background:none;border:none;color:#fffc;cursor:pointer;font-size:1.1rem;padding:0;text-align:left;text-shadow:0 0 5px #ffffff1a;transition:all .3s ease}.footer-links button:hover{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#43e97b,#38f9d7);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 0 10px rgba(67,227,123,.5));transform:translateX(5px)}.footer-links li:not(:has(button)){color:#ffffffb3;font-size:1rem;text-shadow:0 0 5px #ffffff1a}.back-to-top{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:25px;box-shadow:0 4px 20px #0003,inset 0 1px 0 #ffffff1a;color:#fff;cursor:pointer;font-size:1rem;font-weight:400;padding:1rem 2rem;transition:all .4s ease}.back-to-top:hover{background:#fff3;border:1px solid #ffffff4d;box-shadow:0 8px 30px #0000004d,inset 0 1px 0 #fff3;transform:translateY(-2px) scale(1.05)}.footer-bottom{align-items:center;border-top:1px solid #ffffff1a;color:#ffffffb3;display:flex;font-size:1rem;justify-content:space-between;padding-top:2rem;text-align:center}.footer-bottom p{margin:0;text-shadow:0 0 5px #ffffff1a}body.dark-mode .footer{background:linear-gradient(135deg,#0a0a0a,#1f2937);border-top-color:#ffffff0d}body.dark-mode .footer:before{background:radial-gradient(circle at 25% 25%,#60a5fa0d 0,#0000 50%),radial-gradient(circle at 75% 75%,#8b5cf605 0,#0000 50%)}body.dark-mode .footer-section h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#60a5fa,#3b82f6);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 0 15px rgba(96,165,250,.5))}body.dark-mode .footer-section h4{color:#e5e7eb;text-shadow:0 0 10px #fff3}body.dark-mode .footer-section p{color:#e5e7ebcc;text-shadow:0 0 5px #ffffff1a}body.dark-mode .social-links a{color:#e5e7ebe6;text-shadow:0 0 5px #ffffff1a}body.dark-mode .social-links a:hover{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#60a5fa,#3b82f6);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 0 15px rgba(96,165,250,.6))}body.dark-mode .footer-links button{color:#e5e7ebcc;text-shadow:0 0 5px #ffffff0d}body.dark-mode .footer-links button:hover{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#34d399,#10b981);-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 0 10px rgba(52,211,153,.5))}body.dark-mode .footer-links li:not(:has(button)){color:#e5e7ebb3;text-shadow:0 0 5px #ffffff0d}body.dark-mode .back-to-top{background:#0000004d;border-color:#ffffff1a;box-shadow:0 4px 20px #0006,inset 0 1px 0 #ffffff0d;color:#e5e7eb}body.dark-mode .back-to-top:hover{background:#00000080;border-color:#fff3;box-shadow:0 8px 30px #0009,inset 0 1px 0 #ffffff1a}body.dark-mode .footer-bottom{border-top-color:#ffffff0d;color:#e5e7ebb3}body.dark-mode .footer-bottom p{text-shadow:0 0 5px #ffffff0d}@media (max-width:768px){.footer-content{gap:2rem;grid-template-columns:1fr}.footer-bottom,.footer-content,.footer-links button{text-align:center}.footer-bottom{flex-direction:column;gap:1rem}.social-links{justify-content:center}}.floating-elements{height:100%;left:0;overflow:hidden;pointer-events:none;position:fixed;top:0;width:100%;z-index:-1}.floating-shape{animation-iteration-count:infinite;animation-timing-function:linear;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:radial-gradient(circle,#ffffff1a 0,#ffffff05 100%);border-radius:50%;position:absolute}.floating-shape-1{animation:float1 15s infinite;background:radial-gradient(circle,#667eea1a 0,#667eea05 100%);height:120px;left:10%;top:10%;width:120px}.floating-shape-2{animation:float2 12s infinite;background:radial-gradient(circle,#764ba21a 0,#764ba205 100%);height:80px;right:15%;top:60%;width:80px}.floating-shape-3{animation:float3 18s infinite;background:radial-gradient(circle,#f093fb1a 0,#f093fb05 100%);height:100px;left:20%;top:80%;width:100px}.floating-shape-4{animation:float4 14s infinite;background:radial-gradient(circle,#a8edea1a 0,#a8edea05 100%);height:60px;right:30%;top:20%;width:60px}.floating-shape-5{animation:float5 16s infinite;background:radial-gradient(circle,#fed6e31a 0,#fed6e305 100%);height:90px;left:5%;top:40%;width:90px}.floating-shape-6{animation:float6 13s infinite;background:radial-gradient(circle,#f5576c1a 0,#f5576c05 100%);height:70px;right:5%;top:70%;width:70px}@keyframes float4{0%,to{transform:translateY(0) translateX(0) rotate(0deg)}50%{transform:translateY(25px) translateX(-25px) rotate(180deg)}}@keyframes float5{0%,to{transform:translateY(0) translateX(0) rotate(0deg)}25%{transform:translateY(15px) translateX(-10px) rotate(90deg)}50%{transform:translateY(30px) translateX(-20px) rotate(180deg)}75%{transform:translateY(15px) translateX(-10px) rotate(270deg)}}@keyframes float6{0%,to{transform:translateY(0) translateX(0) rotate(0deg)}30%{transform:translateY(-35px) translateX(20px) rotate(108deg)}60%{transform:translateY(35px) translateX(40px) rotate(216deg)}90%{transform:translateY(-10px) translateX(10px) rotate(324deg)}}@media (max-width:768px){.floating-shape{display:none}}.liquid-background{background:linear-gradient(180deg,#fff,#f8fafc 50%,#f1f5f9);height:100vh;left:0;overflow:hidden;pointer-events:none;position:fixed;top:0;width:100vw;z-index:-1}.liquid-blob{opacity:.6;position:absolute}.liquid-blob-1{animation:float1 20s ease-in-out infinite;background:#2563eb1a;border-radius:30% 70% 70% 30%/30% 30% 70% 70%;height:200px;left:10%;top:10%;width:200px}.liquid-blob-2{animation:float2 25s ease-in-out infinite;background:#8b5cf614;border-radius:40% 60% 60% 40%/40% 40% 60% 60%;height:150px;right:15%;top:60%;width:150px}.liquid-blob-3{animation:float3 18s ease-in-out infinite;background:#2563eb0f;border-radius:50% 50% 50% 50%/60% 40% 60% 40%;height:120px;left:70%;top:30%;width:120px}@keyframes float1{0%,to{border-radius:30% 70% 70% 30%/30% 30% 70% 70%;transform:translateY(0) rotate(0deg)}50%{border-radius:70% 30% 30% 70%/70% 70% 30% 30%;transform:translateY(-20px) rotate(180deg)}}@keyframes float2{0%,to{border-radius:40% 60% 60% 40%/40% 40% 60% 60%;transform:translateY(0) rotate(0deg)}50%{border-radius:60% 40% 40% 60%/60% 60% 40% 40%;transform:translateY(-15px) rotate(-180deg)}}@keyframes float3{0%,to{border-radius:50% 50% 50% 50%/60% 40% 60% 40%;transform:translateY(0) rotate(0deg)}50%{border-radius:50% 50% 50% 50%/40% 60% 40% 60%;transform:translateY(-10px) rotate(180deg)}}body.dark-mode .liquid-background{background:linear-gradient(180deg,#0a0a0a,#111827 50%,#1f2937)}body.dark-mode .liquid-blob-1{background:#60a5fa1a}body.dark-mode .liquid-blob-2{background:#8b5cf614}body.dark-mode .liquid-blob-3{background:#60a5fa0f}.whatsapp-button{align-items:center;background-color:#25d366;border-radius:50%;bottom:2rem;box-shadow:0 4px 12px #25d36666;color:#fff;display:flex;height:60px;justify-content:center;position:fixed;right:2rem;text-decoration:none;transition:all .3s ease;width:60px;z-index:1000}.whatsapp-button:hover{background-color:#20ba5a;box-shadow:0 6px 20px #25d36699;transform:scale(1.1)}.whatsapp-button:active{transform:scale(.95)}.whatsapp-button svg{height:28px;width:28px}@media (max-width:768px){.whatsapp-button{bottom:1.5rem;height:56px;right:1.5rem;width:56px}.whatsapp-button svg{height:26px;width:26px}}@media (max-width:480px){.whatsapp-button{bottom:1rem;height:52px;right:1rem;width:52px}.whatsapp-button svg{height:24px;width:24px}}.quote-modal-overlay{align-items:center;animation:fadeIn .3s ease;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:10000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.quote-modal-content{animation:slideUp .3s ease;background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;padding:2.5rem;position:relative;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.quote-modal-close{align-items:center;background:#0000;border:none;border-radius:50%;color:#6b7280;cursor:pointer;display:flex;font-size:1.5rem;height:32px;justify-content:center;line-height:1;padding:0;position:absolute;right:1.5rem;top:1.5rem;transition:all .2s ease;width:32px}.quote-modal-close:hover{background:#f3f4f6;color:#1f2937}.quote-modal-header{margin-bottom:2rem;padding-right:2rem}.quote-modal-header h2{color:#1a1a1a;font-size:2rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.5rem}.quote-modal-header p{color:#6b7280;font-size:1rem;margin:0}.quote-modal-form{display:flex;flex-direction:column;gap:0}.quote-modal-form .form-group{margin-bottom:1.5rem}.quote-modal-form .form-group label{color:#374151;display:block;font-size:.875rem;font-weight:500;letter-spacing:.05em;margin-bottom:.5rem;text-transform:uppercase}.quote-modal-form .form-group input,.quote-modal-form .form-group textarea,.quote-modal-form .form-select{background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#1f2937;font-family:inherit;font-size:1rem;padding:.75rem 1rem;transition:all .2s ease;width:100%}.quote-modal-form .form-group input:focus,.quote-modal-form .form-group textarea:focus,.quote-modal-form .form-select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.quote-modal-form .form-group textarea{min-height:120px;resize:vertical}.quote-modal-form .form-select{appearance:none;-webkit-appearance:none;background-color:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%236b7280' d='M6 9 1 4h10z'/%3E%3C/svg%3E");background-position:right 1rem center;background-repeat:no-repeat;background-size:12px 12px;cursor:pointer;padding-right:2.5rem}.quote-modal-form .btn{background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:.5rem;padding:.875rem 2rem;transition:all .2s ease;width:100%}.quote-modal-form .btn:hover{background:#1d4ed8;transform:translateY(-1px)}body.dark-mode .quote-modal-content{background:#1f2937;border-color:#374151;box-shadow:0 20px 25px -5px #0009}body.dark-mode .quote-modal-close{color:#9ca3af}body.dark-mode .quote-modal-close:hover{background:#374151;color:#e5e7eb}body.dark-mode .quote-modal-header h2{color:#fff}body.dark-mode .quote-modal-header p{color:#9ca3af}body.dark-mode .quote-modal-form .form-group label{color:#e5e7eb}body.dark-mode .quote-modal-form .form-group input,body.dark-mode .quote-modal-form .form-group textarea{background:#374151;border-color:#4b5563;color:#e5e7eb}body.dark-mode .quote-modal-form .form-group input:focus,body.dark-mode .quote-modal-form .form-group textarea:focus,body.dark-mode .quote-modal-form .form-select:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa1a}body.dark-mode .quote-modal-form .form-select{background-color:#374151;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%239ca3af' d='M6 9 1 4h10z'/%3E%3C/svg%3E");background-position:right 1rem center;background-repeat:no-repeat;background-size:12px 12px;border-color:#4b5563;color:#e5e7eb}body.dark-mode .quote-modal-form .btn{background:#2563eb;color:#fff}body.dark-mode .quote-modal-form .btn:hover{background:#1d4ed8}@media (max-width:768px){.quote-modal-overlay{padding:.5rem}.quote-modal-content{max-height:95vh;padding:2rem 1.5rem}.quote-modal-close{right:1rem;top:1rem}.quote-modal-header{margin-bottom:1.5rem;padding-right:2.5rem}.quote-modal-header h2{font-size:1.75rem}.quote-modal-header p{font-size:.9rem}}@media (max-width:480px){.quote-modal-content{border-radius:12px;padding:1.5rem 1rem}.quote-modal-header h2{font-size:1.5rem}}.App{background:#fff;display:flex;flex-direction:column;min-height:100vh;position:relative;width:100%;z-index:1}body.dark-mode .App{background:#0a0a0a}main{flex:1 1}section{position:relative;scroll-margin-top:80px;z-index:1}*{transition:all .4s cubic-bezier(.23,1,.32,1)}html{scroll-behavior:smooth}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}::-webkit-scrollbar-thumb{background:#2563eb;border-radius:3px;-webkit-transition:background .3s ease;transition:background .3s ease}::-webkit-scrollbar-thumb:hover{background:#1d4ed8}h1,h2,h3,h4,h5,h6{color:#1a1a1a;font-weight:600;line-height:1.3}p{color:#4a5568;margin-bottom:1rem}a{color:#1a1a1a;text-decoration:none;transition:all .3s ease}a:hover{opacity:.7}.card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;padding:2rem;position:relative;transition:all .3s ease}.card:hover{border-color:#2563eb;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;transform:translateY(-8px)}.grid{grid-gap:2rem;display:grid;gap:2rem}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.fade-in-up{animation:fadeInUp .6s ease forwards}
/*# sourceMappingURL=main.b3f92404.css.map*/