*{box-sizing:border-box;margin:0;padding:0}:root{--strava-orange:#fc4c02;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--orange-600:#ea580c}.skip-link{background:var(--strava-orange);color:#fff;left:6px;padding:8px;position:absolute;text-decoration:none;top:-40px;transition:top .3s;z-index:100}.skip-link:focus{top:6px}.visually-hidden{height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;clip:rect(0,0,0,0);border:0;white-space:nowrap}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;scroll-padding-top:80px}body{background-color:var(--gray-100);color:var(--gray-900);display:flex;flex-direction:column;font-family:Inter,sans-serif;line-height:1.5;min-height:100vh}header{background-color:#fff;box-shadow:0 1px 3px 0 rgba(0,0,0,.1);position:sticky;top:0;width:100%;z-index:50}nav{justify-content:space-between;margin:0 auto;max-width:1280px;padding:1rem 1.5rem}.logo,nav{align-items:center;display:flex}.logo{color:var(--strava-orange);font-size:1.875rem;font-weight:800}.logo svg{height:2rem;margin-right:.5rem;width:2rem}.logo .text-gray{color:var(--gray-900)}.nav-links{align-items:center;display:flex;gap:1.5rem}.nav-links a{color:var(--gray-600);font-weight:600;position:relative;text-decoration:none;transition:color .3s ease}.nav-links a:hover{color:var(--strava-orange)}.nav-links a:after{background-color:var(--strava-orange);bottom:-4px;content:"";height:2px;left:0;position:absolute;transition:width .3s ease;width:0}.nav-links a:hover:after{width:100%}.nav-btn-upload{background-color:var(--strava-orange);border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-family:Inter,sans-serif;font-size:.875rem;font-weight:600;letter-spacing:normal;padding:.5rem 1rem;text-transform:none;transition:all .3s ease}.nav-btn-upload:hover{background-color:var(--orange-600);box-shadow:0 4px 6px -1px rgba(252,76,2,.3);transform:translateY(-2px)}@media (max-width:640px){.nav-links a{display:none}.logo{font-size:1.5rem}}.hero-section{background-color:var(--gray-900);color:#fff;overflow:hidden;padding:6rem 1rem;position:relative;text-align:center}@media (min-width:1024px){.hero-section{padding:10rem 1rem}}.hero-bg{animation:gradientShift 15s ease infinite;background-image:radial-gradient(circle at 10% 20%,rgba(252,76,2,.1) 0,rgba(252,76,2,0) 60%),radial-gradient(circle at 90% 80%,hsla(220,9%,46%,.1) 0,hsla(220,9%,46%,0) 60%);background-size:200% 200%;inset:0;opacity:.7;position:absolute;z-index:0}.hero-content{margin:0 auto;max-width:1280px;position:relative;z-index:10}.hero-title-orange{color:var(--strava-orange);font-size:2.5rem;font-weight:800;letter-spacing:-.025em;line-height:1.2;margin-bottom:1rem}.hero-seo-description{color:var(--gray-300);font-size:1.1rem;line-height:1.6;margin-bottom:1.5rem;margin-left:auto;margin-right:auto;max-width:800px}.hero-subtitle{color:var(--gray-300);display:block;font-size:1.5rem;font-weight:600;margin-bottom:2rem}@media (min-width:1024px){.hero-title-orange{font-size:3.5rem}.hero-seo-description{font-size:1.25rem}.hero-subtitle{font-size:1.75rem}}.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin:2rem 0}.cta-button-primary,.cta-button-secondary{align-items:center;border-radius:9999px;display:inline-flex;font-size:1.125rem;font-weight:700;gap:.5rem;padding:1rem 2rem;text-decoration:none;transition:all .3s ease}.cta-button-primary{background:var(--strava-orange);border:none;box-shadow:0 10px 15px -3px rgba(252,76,2,.3);color:#fff;cursor:pointer}.cta-button-primary:hover{background:var(--orange-600);box-shadow:0 20px 25px -5px rgba(252,76,2,.4);transform:translateY(-2px)}.cta-button-secondary{background:transparent;border:2px solid var(--gray-300);color:var(--gray-300)}.cta-button-secondary:hover{background:hsla(0,0%,100%,.1);border-color:var(--strava-orange);color:#fff;transform:translateY(-2px)}.hero-note{align-items:center;color:var(--gray-400);display:flex;font-size:.9rem;gap:.5rem;justify-content:center;margin-top:1rem}.quick-tools{background:var(--gray-50);padding:4rem 1rem}.tools-container{margin:0 auto;max-width:900px}.tools-grid{display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.tool-card{background:#fff;border-radius:12px;border-top:4px solid var(--strava-orange);box-shadow:0 4px 6px -1px rgba(0,0,0,.1);padding:2rem;text-align:center}.tool-card h3{color:var(--gray-800);font-size:1.25rem;margin-bottom:1rem}.tool-btn{align-items:center;background:var(--gray-100);border:2px dashed var(--gray-300);border-radius:8px;color:var(--gray-700);cursor:pointer;display:inline-flex;font-family:inherit;font-weight:600;gap:.5rem;justify-content:center;margin-bottom:1rem;padding:1rem;text-decoration:none;transition:all .3s ease;width:100%}.tool-btn:hover{background:rgba(252,76,2,.05);border-color:var(--strava-orange);box-shadow:0 4px 12px rgba(252,76,2,.1);transform:translateY(-2px)}.tool-card p{color:var(--gray-600);font-size:.9rem;line-height:1.5}.intentions-section{background:#fff;padding:4rem 1rem}.intentions-container{margin:0 auto;max-width:900px}.intentions-title{color:var(--gray-900);font-size:2rem;font-weight:800;margin-bottom:3rem;text-align:center}.intentions-grid{display:grid;gap:2rem;grid-template-columns:repeat(2,1fr)}.intention-card{background:var(--gray-50);border:2px solid transparent;border-radius:12px;padding:2rem;text-align:center;transition:all .3s ease}.intention-card:hover{border-color:var(--strava-orange);box-shadow:0 8px 20px rgba(252,76,2,.1);transform:translateY(-4px)}.intention-card h3{color:var(--gray-800);font-size:1.5rem;margin-bottom:1rem}.intention-card p{color:var(--gray-600);line-height:1.6}.sports-section{background:#fff;padding:4rem 1rem}.sports-container{margin:0 auto;max-width:800px;text-align:center}.sports-section h2{color:var(--gray-900);font-size:2.25rem;font-weight:800;margin-bottom:3rem}.sports-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.sport-item{align-items:center;background:var(--gray-50);border:2px solid transparent;border-radius:12px;display:flex;flex-direction:column;gap:.75rem;padding:1.5rem 1rem;transition:all .3s ease}.sport-item:hover{border-color:var(--strava-orange);box-shadow:0 8px 20px rgba(252,76,2,.1);transform:translateY(-4px)}.sport-item i{color:var(--strava-orange);font-size:2.5rem}.sport-item span{color:var(--gray-700);font-weight:600;text-align:center}.seo-content-section{background:linear-gradient(135deg,var(--gray-50) 0,var(--gray-100) 100%);padding:4rem 1rem}.seo-container{margin:0 auto;max-width:1280px}.seo-grid{display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:2rem}.seo-card{background:#fff;border-left:4px solid var(--strava-orange);border-radius:12px;box-shadow:0 4px 6px -1px rgba(0,0,0,.1);padding:2rem}.seo-card h3{color:var(--gray-900);font-size:1.25rem;font-weight:700;margin-bottom:1rem}.seo-card ul{list-style:none;padding-left:0}.seo-card li{padding:.5rem 0 .5rem 1.5rem;position:relative}.seo-card li:before{color:var(--strava-orange);content:"✓";font-weight:700;left:0;position:absolute}.seo-card a{color:var(--strava-orange);font-weight:600;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px;transition:all .3s ease}.seo-card a:hover{color:var(--orange-600);text-decoration-thickness:2px;text-underline-offset:3px}.seo-card a:visited{color:#d97706}.format-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));margin-top:1rem}.format-item{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:8px;padding:1rem;text-align:center}.format-item strong{color:var(--strava-orange);display:block;margin-bottom:.25rem}.format-item span{color:var(--gray-600);font-size:.875rem}.functions-section{background:#fff;padding:4rem 1rem}.functions-container{margin:0 auto;max-width:1280px}.functions-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-top:2rem}.function-item{background:var(--gray-50);border-left:4px solid var(--strava-orange);border-radius:8px;padding:1.5rem;transition:all .3s ease}.function-item:hover{box-shadow:0 4px 12px rgba(252,76,2,.1);transform:translateY(-2px)}.function-item h3{color:var(--gray-800);font-size:1.1rem;font-weight:700;margin-bottom:.5rem}.function-item p{color:var(--gray-600);font-size:.9rem;line-height:1.5}.feature-card-link{color:inherit;text-decoration:none}.feature-card{align-items:center;background-color:#fff;border:2px solid var(--gray-200);border-radius:.75rem;box-shadow:0 10px 15px -3px rgba(0,0,0,.1);display:flex;flex-direction:column;height:100%;padding:2rem;position:relative;text-align:center;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease}.feature-card:hover{border-color:var(--strava-orange);box-shadow:0 15px 30px -5px rgba(252,76,2,.3),0 4px 6px -2px rgba(252,76,2,.1);transform:translateY(-5px)}.feature-cta{align-items:center;color:var(--strava-orange);display:flex;font-size:.9rem;font-weight:600;gap:.5rem;justify-content:center;margin-top:auto;padding-top:1rem;transition:transform .3s ease}.feature-card:hover .feature-cta{transform:translateX(5px)}.feature-icon{color:var(--strava-orange);font-size:3rem;margin-bottom:1rem;transition:transform .3s ease}.feature-card:hover .feature-icon{transform:scale(1.2) rotate(5deg)}.feature-card h3{color:var(--gray-900);font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.feature-card p{color:var(--gray-600);margin-bottom:1rem}a{color:var(--strava-orange);text-decoration:none;transition:color .3s ease,text-decoration .3s ease}a:hover{color:var(--orange-600);text-decoration:underline}a:visited{color:#d97706}a:focus{border-radius:2px;outline:2px solid var(--strava-orange);outline-offset:2px}.contact-button,.cta-button-primary,.cta-button-secondary,.feature-card-link,.nav-links a,.tool-btn{text-decoration:none!important}.contact-button:visited,.cta-button-primary:visited,.cta-button-secondary:visited,.feature-card-link:visited,.tool-btn:visited{color:inherit}.separator-top{background-color:var(--gray-900);clip-path:polygon(0 0,100% 0,100% 100%,0 calc(100% - 40px));z-index:10}.separator-bottom,.separator-top{height:2.5rem;margin-top:-2.5rem;position:relative}.separator-bottom{background-color:var(--gray-100);z-index:0}.features-section{background-color:var(--gray-100);padding:5rem 1rem}.features-container{margin:0 auto;max-width:1280px}.features-section h2{color:var(--gray-900);font-size:2.25rem;font-weight:800;margin-bottom:4rem;text-align:center}.features-grid{display:grid;gap:2rem;grid-template-columns:1fr}@media (min-width:768px){.features-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.features-grid{grid-template-columns:repeat(3,1fr)}}.contact-section{background-color:#fff;border-top:1px solid var(--gray-200);padding:5rem 1rem}.contact-container{margin:0 auto;max-width:56rem;text-align:center}.contact-section h2{color:var(--gray-900);font-size:2.25rem;font-weight:700;margin-bottom:1.5rem}.contact-section p{color:var(--gray-600);font-size:1.125rem;font-weight:300;margin-bottom:2rem}.contact-footer-link{background-color:var(--gray-900);border:2px solid var(--strava-orange);border-radius:9999px;box-shadow:0 10px 15px -3px rgba(0,0,0,.1);color:var(--strava-orange);display:inline-block;font-weight:700;padding:.75rem 2rem;text-decoration:none;transition:background-color .3s ease}.contact-footer-link:hover{background-color:var(--gray-700)}.contact-footer-link i{margin-left:.5rem}footer[role=contentinfo]{background:linear-gradient(135deg,var(--gray-900) 0,var(--gray-800) 100%);border-top:3px solid var(--strava-orange);box-shadow:0 -4px 20px rgba(0,0,0,.1);color:var(--gray-300);font-size:.875rem;margin-top:2rem;padding:2rem 1rem;text-align:center;width:100%}footer[role=contentinfo] p{color:var(--gray-100);font-weight:500;margin-bottom:1rem}.footer-links{align-items:center;display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;margin-top:1rem}.footer-links a{border-radius:4px;color:var(--gray-300);font-size:.875rem;font-weight:500;padding:.25rem .5rem;text-decoration:none;transition:all .3s ease}.footer-links a:hover{background:rgba(252,76,2,.1);color:var(--strava-orange)}.footer-links a:not([href*=strava]):hover{transform:translateY(-2px)}.footer-links a[href*=strava]{background-color:#fc5200;background-image:url(https://badges.strava.com/logo-strava-echelon.png);background-position:10px;background-repeat:no-repeat;border-radius:3px;color:#fff;display:inline-block;font-family:Helvetica,Arial,sans-serif;font-size:11px;padding:5px 10px 5px 30px;text-decoration:none;transition:all .3s ease;white-space:nowrap}.footer-links a[href*=strava]:hover{background-color:#e04800;box-shadow:0 4px 8px rgba(252,82,0,.3);transform:translateY(-2px)}.footer-links a[href*=strava] img{margin-left:2px;vertical-align:text-bottom}@media (max-width:768px){.footer-links{flex-direction:column;gap:1rem}footer[role=contentinfo]{padding:1.5rem 1rem}.footer-links a{font-size:.8125rem}}.overlay{align-items:center;backdrop-filter:blur(4px);background-color:rgba(17,24,39,.8);display:none;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:50}.overlay.active{display:flex}.overlay-content{background-color:#fff;border-radius:.5rem;max-height:90vh;max-width:42rem;overflow-y:auto;padding:2rem;width:100%}.overlay-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.overlay-header h3{color:var(--gray-900);font-size:1.875rem;font-weight:700}.overlay-close{background:none;border:none;color:var(--gray-500);cursor:pointer;font-size:1.5rem;transition:color .3s ease}.overlay-close:hover{color:var(--strava-orange)}.overlay-text{color:var(--gray-700)}.overlay-text p{margin-bottom:1.5rem}.overlay-text .question{align-items:center;color:var(--strava-orange);display:flex;font-size:1.1rem;font-weight:600;gap:.5rem;margin-bottom:.5rem}.overlay-text .section-title{color:var(--gray-900);font-size:1.125rem;font-weight:600;margin-top:1.5rem}.overlay-text a{color:var(--strava-orange);font-weight:600;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px;transition:all .3s ease}.overlay-text a:hover{color:var(--orange-600);text-decoration-thickness:2px;text-underline-offset:3px}.overlay-text a:visited{color:#d97706}.highlight{color:var(--strava-orange)}body.overlay-open{overflow:hidden}.faq-list{margin-bottom:1rem;margin-left:1.5rem}.faq-list li{margin-bottom:.5rem;padding-left:.5rem}.faq-feature-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:1rem 0}.faq-feature-item{background:var(--gray-50);border-left:4px solid var(--strava-orange);border-radius:.5rem;padding:1rem}.faq-compatibility-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin:1rem 0}.compatibility-item{background:var(--gray-50);border-radius:.5rem;padding:.5rem;text-align:center}.security-badge{align-items:center;background:var(--gray-100);border-radius:2rem;display:inline-flex;font-size:.9rem;gap:.5rem;margin:.25rem;padding:.5rem 1rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes gradientShift{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}header{animation:slideDown .5s ease-out}.hero-content{animation:fadeIn .8s ease-out}.feature-card{animation:fadeIn .6s ease-out backwards}.feature-card:first-child{animation-delay:.1s}.feature-card:nth-child(2){animation-delay:.2s}.feature-card:nth-child(3){animation-delay:.3s}.feature-card:nth-child(4){animation-delay:.4s}.feature-card:nth-child(5){animation-delay:.5s}.feature-card:nth-child(6){animation-delay:.6s}.feature-card:nth-child(7){animation-delay:.7s}.feature-card:nth-child(8){animation-delay:.8s}.tool-card{animation:fadeIn .6s ease-out backwards}.tool-card:first-child{animation-delay:.1s}.tool-card:nth-child(2){animation-delay:.2s}.tool-card:nth-child(3){animation-delay:.3s}.sport-item{animation:fadeIn .6s ease-out backwards}.sport-item:first-child{animation-delay:.1s}.sport-item:nth-child(2){animation-delay:.2s}.sport-item:nth-child(3){animation-delay:.3s}.sport-item:nth-child(4){animation-delay:.4s}.sport-item:nth-child(5){animation-delay:.5s}.sport-item:nth-child(6){animation-delay:.6s}.overlay{transition:opacity .3s ease}.overlay.active .overlay-content{animation:fadeIn .3s ease-out}a:focus,button:focus{outline:2px solid var(--strava-orange);outline-offset:2px}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--gray-100)}::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--strava-orange)}@media (max-width:640px){.hero-title-orange{font-size:2rem}.hero-seo-description{font-size:1rem}.hero-subtitle{font-size:1.25rem}.hero-actions{align-items:center;flex-direction:column}.cta-button-primary,.cta-button-secondary{justify-content:center;width:100%}.contact-section h2,.features-section h2{font-size:1.875rem}.sports-grid{grid-template-columns:repeat(2,1fr)}.faq-compatibility-grid,.faq-feature-grid,.functions-grid,.intentions-grid,.tools-grid{grid-template-columns:1fr}.overlay-content{margin:1rem;padding:1.5rem}.seo-grid{grid-template-columns:1fr}.format-grid{grid-template-columns:repeat(2,1fr)}.seo-card{padding:1.5rem}}@media (max-width:768px){.sports-section h2{font-size:1.875rem}.intentions-title{font-size:1.75rem}.features-grid{grid-template-columns:1fr}}