/* ============================================
   StepToGoal — Shared Styles
   ============================================ */

/* Reset */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:#0a0a1a;min-height:100vh;color:#fff;overflow-x:hidden}

/* Background Effects */
.bg-gradient{position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#0f0f23 0%,#1a1a2e 50%,#16213e 100%);z-index:-2}
.orb{position:fixed;border-radius:50%;filter:blur(100px);z-index:-1;animation:float 20s ease-in-out infinite}
.orb-1{width:500px;height:500px;background:rgba(99,102,241,.2);top:-150px;right:-100px}
.orb-2{width:400px;height:400px;background:rgba(139,92,246,.15);bottom:-100px;left:-100px;animation-delay:-7s}
.orb-3{width:300px;height:300px;background:rgba(34,197,94,.1);top:40%;left:10%;animation-delay:-14s}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}25%{transform:translate(30px,-30px) scale(1.05)}50%{transform:translate(-20px,20px) scale(.95)}75%{transform:translate(-30px,-20px) scale(1.02)}}

.grid-pattern{position:fixed;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(rgba(255,255,255,.015) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.015) 1px,transparent 1px);background-size:60px 60px;z-index:-1}

.particles{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:-1;overflow:hidden}
.particle{position:absolute;width:4px;height:4px;background:rgba(99,102,241,.5);border-radius:50%;animation:particleFloat 15s linear infinite}
@keyframes particleFloat{0%{transform:translateY(100vh);opacity:0}10%{opacity:1}90%{opacity:1}100%{transform:translateY(-100vh);opacity:0}}
.particle:nth-child(1){left:10%;animation-delay:0s;animation-duration:12s}
.particle:nth-child(2){left:20%;animation-delay:2s;animation-duration:14s}
.particle:nth-child(3){left:30%;animation-delay:4s;animation-duration:16s}
.particle:nth-child(4){left:50%;animation-delay:1s;animation-duration:13s}
.particle:nth-child(5){left:70%;animation-delay:3s;animation-duration:15s}
.particle:nth-child(6){left:85%;animation-delay:5s;animation-duration:17s}

/* Container */
.container{max-width:1100px;margin:0 auto;padding:0 24px}

/* ============================================
   Navigation
   ============================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:16px 0;transition:background .3s ease}
.nav.scrolled{background:rgba(10,10,26,.85);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.05)}
.nav-container{max-width:1100px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{font-size:22px;font-weight:800;text-decoration:none;background:linear-gradient(135deg,#6366f1,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.nav-links{display:flex;align-items:center;gap:32px}
.nav-links a{color:#94a3b8;text-decoration:none;font-size:15px;font-weight:500;transition:color .2s}
.nav-links a:hover{color:#fff}
.nav-links a.active{color:#a5b4fc}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;flex-direction:column;gap:5px}
.nav-toggle span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:all .3s ease}

/* ============================================
   Animations
   ============================================ */
@keyframes fadeInUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInDown{from{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}
@keyframes pulse{0%,100%{box-shadow:0 20px 60px rgba(99,102,241,.4)}50%{box-shadow:0 30px 80px rgba(99,102,241,.6)}}
@keyframes gradient{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

/* ============================================
   Hero
   ============================================ */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:100px 24px 60px}

.logo-container{animation:scaleIn .6s ease-out}
.logo{width:120px;height:120px;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 50%,#a855f7 100%);border-radius:32px;display:flex;align-items:center;justify-content:center;margin:0 auto 40px;box-shadow:0 20px 60px rgba(99,102,241,.4);animation:pulse 3s ease-in-out infinite;position:relative}
.logo::before{content:'';position:absolute;inset:-3px;border-radius:35px;background:linear-gradient(135deg,#6366f1,#a855f7,#6366f1);z-index:-1;animation:gradient 3s ease infinite;background-size:200% 200%}
.logo-icon{font-size:56px}

.badge{display:inline-block;background:rgba(34,197,94,.15);border:1px solid rgba(34,197,94,.3);color:#4ade80;padding:10px 20px;border-radius:100px;font-size:14px;font-weight:600;margin-bottom:32px;animation:fadeInDown .6s ease-out .2s both;letter-spacing:.5px}

h1{font-size:64px;font-weight:800;margin-bottom:20px;line-height:1.1;animation:fadeInUp .6s ease-out .3s both}
.gradient-text{background:linear-gradient(135deg,#fff 0%,#a5b4fc 50%,#c4b5fd 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.highlight{color:#a855f7}

.hero .subtitle{font-size:22px;color:#94a3b8;margin-bottom:48px;max-width:600px;line-height:1.6;animation:fadeInUp .6s ease-out .4s both}

.cta-buttons{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;animation:fadeInUp .6s ease-out .5s both}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:12px;padding:18px 32px;border-radius:16px;font-size:17px;font-weight:600;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;cursor:pointer}
.btn-primary{background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);color:#fff;box-shadow:0 10px 40px rgba(99,102,241,.4)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 20px 50px rgba(99,102,241,.5)}
.btn-secondary{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);color:#fff;backdrop-filter:blur(10px)}
.btn-secondary:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);transform:translateY(-3px)}
.btn svg{width:24px;height:24px}

.store-badges{display:flex;gap:16px;margin-top:32px;animation:fadeInUp .6s ease-out .6s both}
.store-badge{height:52px;opacity:.7;transition:all .3s ease;filter:grayscale(100%)}
.store-badge:hover{opacity:1;filter:grayscale(0%);transform:scale(1.05)}

/* ============================================
   Features
   ============================================ */
.features{padding:100px 24px}
.section-title{text-align:center;margin-bottom:64px}
.section-title h2{font-size:42px;font-weight:700;margin-bottom:16px}
.section-title p{color:#94a3b8;font-size:18px;max-width:500px;margin:0 auto}

.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;max-width:1100px;margin:0 auto}

.feature-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:24px;padding:32px;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}
.feature-card::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(99,102,241,.1) 0%,transparent 50%);opacity:0;transition:opacity .4s ease}
.feature-card:hover{transform:translateY(-8px);border-color:rgba(99,102,241,.3);box-shadow:0 30px 60px rgba(0,0,0,.3)}
.feature-card:hover::before{opacity:1}

.feature-icon{width:64px;height:64px;background:linear-gradient(135deg,rgba(99,102,241,.2) 0%,rgba(139,92,246,.2) 100%);border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:24px;font-size:32px;position:relative;z-index:1}
.feature-card h3{font-size:20px;font-weight:600;margin-bottom:12px;position:relative;z-index:1}
.feature-card p{color:#94a3b8;line-height:1.6;position:relative;z-index:1}

/* ============================================
   App Showcase (Screenshots)
   ============================================ */
.app-showcase{padding:100px 24px;overflow:hidden}
.phone-carousel{display:flex;justify-content:center;align-items:center;gap:32px;perspective:1000px}
.phone-frame{width:260px;flex-shrink:0;background:rgba(255,255,255,.04);border:2px solid rgba(255,255,255,.08);border-radius:36px;padding:12px;transition:all .5s cubic-bezier(.4,0,.2,1);transform:rotateY(-5deg) scale(.95)}
.phone-frame:hover{transform:rotateY(0) scale(1);border-color:rgba(99,102,241,.3)}
.phone-frame-center{transform:scale(1.08) rotateY(0);z-index:2;border-color:rgba(99,102,241,.2);box-shadow:0 30px 80px rgba(99,102,241,.2)}
.phone-frame-center:hover{transform:scale(1.1) rotateY(0)}
.phone-frame img{width:100%;border-radius:26px;display:block}
.screenshot-label{text-align:center;color:#94a3b8;font-size:14px;font-weight:600;margin-top:16px;letter-spacing:.5px}

/* ============================================
   How It Works
   ============================================ */
.how-it-works{padding:100px 24px;background:rgba(255,255,255,.02)}
.steps{display:flex;justify-content:center;gap:40px;flex-wrap:wrap;max-width:900px;margin:0 auto}
.step{text-align:center;flex:1;min-width:200px;max-width:250px}
.step-number{width:80px;height:80px;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;font-size:32px;font-weight:700;box-shadow:0 10px 40px rgba(99,102,241,.3)}
.step h3{font-size:18px;font-weight:600;margin-bottom:8px}
.step p{color:#94a3b8;font-size:15px;line-height:1.5}

/* ============================================
   Pricing
   ============================================ */
.pricing-section{padding:100px 24px}
.pricing-cards{display:flex;justify-content:center;gap:32px;max-width:820px;margin:0 auto;align-items:stretch}
.pricing-card{background:rgba(255,255,255,.03);border:2px solid rgba(255,255,255,.08);border-radius:28px;padding:44px 36px;flex:1;min-width:280px;max-width:380px;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow:visible}
.pricing-card:hover{transform:translateY(-6px);border-color:rgba(255,255,255,.15);box-shadow:0 20px 50px rgba(0,0,0,.3)}
.pricing-card-pro{background:linear-gradient(160deg,rgba(99,102,241,.12) 0%,rgba(139,92,246,.08) 50%,rgba(168,85,247,.06) 100%);border-color:rgba(99,102,241,.4);transform:scale(1.04);box-shadow:0 20px 60px rgba(99,102,241,.15)}
.pricing-card-pro:hover{transform:scale(1.04) translateY(-6px);border-color:rgba(99,102,241,.6);box-shadow:0 30px 70px rgba(99,102,241,.25)}
.pricing-badge{position:absolute;top:-16px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,#6366f1 0%,#a855f7 100%);color:#fff;padding:8px 24px;border-radius:100px;font-size:13px;font-weight:700;letter-spacing:.8px;white-space:nowrap;text-transform:uppercase;box-shadow:0 4px 20px rgba(99,102,241,.4)}
.pricing-header{text-align:center;margin-bottom:32px;padding-bottom:28px;border-bottom:1px solid rgba(255,255,255,.08)}
.pricing-header h3{font-size:24px;font-weight:700;margin-bottom:16px;color:#e2e8f0}
.pricing-price{font-size:52px;font-weight:800;line-height:1;color:#fff}
.pricing-price span{font-size:18px;font-weight:500;color:#94a3b8}
.pricing-period{color:#64748b;font-size:14px;margin-top:10px;line-height:1.4}
.pricing-features{list-style:none;padding:0;display:flex;flex-direction:column;gap:16px;flex:1}
.pricing-features li{color:#94a3b8;font-size:15px;padding-left:32px;position:relative;line-height:1.5}
.pricing-features li::before{content:'✓';position:absolute;left:0;width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:rgba(34,197,94,.12);color:#22c55e;font-weight:700;font-size:13px;border-radius:50%;top:0}
.pricing-card-pro .pricing-header{border-bottom-color:rgba(99,102,241,.15)}
.pricing-card-pro .pricing-price{background:linear-gradient(135deg,#c4b5fd 0%,#a5b4fc 50%,#818cf8 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.pricing-card-pro .pricing-features li{color:#cbd5e1}
.pricing-card-pro .pricing-features li::before{background:rgba(99,102,241,.15);color:#a5b4fc}
.pricing-features li.pricing-includes{padding-left:0;color:#64748b;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.8px}
.pricing-features li.pricing-includes::before{display:none}
.pricing-cta{margin-top:32px;text-align:center}
.btn-pricing{width:100%;justify-content:center;padding:16px 24px;font-size:16px}

/* ============================================
   CTA Section
   ============================================ */
.cta-section{padding:100px 24px;text-align:center}
.cta-box{background:linear-gradient(135deg,rgba(99,102,241,.15) 0%,rgba(139,92,246,.1) 100%);border:1px solid rgba(99,102,241,.2);border-radius:32px;padding:64px;max-width:700px;margin:0 auto}
.cta-box h2{font-size:36px;font-weight:700;margin-bottom:16px}
.cta-box p{color:#94a3b8;font-size:18px;margin-bottom:32px}

/* ============================================
   Footer
   ============================================ */
footer{padding:40px 24px;text-align:center;border-top:1px solid rgba(255,255,255,.05)}
.footer-content{max-width:600px;margin:0 auto}
.footer-logo{font-size:24px;font-weight:700;margin-bottom:16px;background:linear-gradient(135deg,#6366f1,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.footer-links{display:flex;justify-content:center;gap:32px;margin-bottom:24px;flex-wrap:wrap}
.footer-links a{color:#64748b;text-decoration:none;font-size:14px;transition:color .2s}
.footer-links a:hover{color:#a5b4fc}
.copyright{color:#475569;font-size:13px}
.copyright a{color:#64748b;text-decoration:none}
.copyright a:hover{color:#a5b4fc}

/* ============================================
   Legal Pages (Privacy, Terms)
   ============================================ */
.legal-page{padding-top:100px;padding-bottom:60px;min-height:100vh}
.legal-content{max-width:800px;margin:0 auto;padding:0 24px}
.legal-content .page-badge{display:inline-block;background:rgba(99,102,241,.15);border:1px solid rgba(99,102,241,.3);color:#a5b4fc;padding:8px 20px;border-radius:100px;font-size:13px;font-weight:600;margin-bottom:24px;letter-spacing:.5px}
.legal-content h1{font-size:40px;font-weight:800;margin-bottom:8px;line-height:1.2}
.legal-content .legal-subtitle{color:#64748b;font-size:15px;margin-bottom:48px}
.legal-content h2{font-size:24px;font-weight:700;color:#e2e8f0;margin:48px 0 16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.06)}
.legal-content h3{font-size:18px;font-weight:600;color:#cbd5e1;margin:24px 0 12px}
.legal-content p{color:#94a3b8;line-height:1.8;font-size:16px;margin-bottom:16px}
.legal-content ul,.legal-content ol{color:#94a3b8;line-height:1.8;font-size:16px;margin-bottom:16px;padding-left:24px}
.legal-content li{margin-bottom:8px}
.legal-content a{color:#a5b4fc;text-decoration:none;transition:color .2s}
.legal-content a:hover{color:#c4b5fd;text-decoration:underline}
.legal-content strong{color:#e2e8f0}

/* ============================================
   Contact Page
   ============================================ */
.contact-header{text-align:center;margin-bottom:48px}
.contact-header p{color:#94a3b8;font-size:18px;margin-top:12px}
.contact-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:48px}
.contact-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:24px;padding:32px;transition:all .3s ease}
.contact-card:hover{border-color:rgba(99,102,241,.2)}
.contact-card h2{font-size:20px;font-weight:700;margin-bottom:24px;color:#e2e8f0;border:none;padding:0}
.contact-card .info-row{display:flex;flex-direction:column;gap:4px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.contact-card .info-row:last-child{border-bottom:none}
.contact-card .info-label{font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:1px}
.contact-card .info-value{font-size:16px;color:#e2e8f0}
.contact-card .info-sub{font-size:13px;color:#64748b;font-style:italic}
.contact-card a{color:#a5b4fc;text-decoration:none;font-size:16px;transition:color .2s}
.contact-card a:hover{color:#c4b5fd}

.map-container{border-radius:24px;overflow:hidden;border:1px solid rgba(255,255,255,.06);height:300px}
.map-container iframe{width:100%;height:100%;border:none;filter:brightness(.8) contrast(1.1) saturate(.5)}

/* ============================================
   Responsive
   ============================================ */
@media(max-width:1024px){
    .phone-carousel{gap:20px}
    .phone-frame{width:220px}
}

@media(max-width:768px){
    h1{font-size:40px}
    .hero .subtitle{font-size:18px}
    .features-grid{grid-template-columns:repeat(2,1fr)}
    .pricing-cards{flex-direction:column;align-items:center}
    .pricing-card{max-width:400px;width:100%}
    .pricing-card-pro{transform:none}
    .pricing-card-pro:hover{transform:translateY(-6px)}
    .steps{flex-direction:column;align-items:center}
    .cta-buttons{flex-direction:column;width:100%;max-width:300px}
    .btn{justify-content:center}
    .contact-cards{grid-template-columns:1fr}

    /* Nav mobile */
    .nav-toggle{display:flex}
    .nav-links{position:fixed;top:0;right:-100%;width:280px;height:100vh;background:rgba(10,10,26,.98);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);flex-direction:column;padding:80px 32px 32px;gap:24px;transition:right .3s ease;border-left:1px solid rgba(255,255,255,.05)}
    .nav-links.active{right:0}
    .nav-links a{font-size:18px}

    /* Phone carousel mobile */
    .phone-carousel{flex-direction:column;gap:24px}
    .phone-frame,.phone-frame-center{transform:none;width:260px;max-width:80vw}
    .phone-frame-center{transform:scale(1.02)}

    /* Legal pages */
    .legal-content h1{font-size:32px}
    .legal-content h2{font-size:20px}
}

@media(max-width:480px){
    h1{font-size:32px}
    .hero{padding:80px 16px 40px}
    .features{padding:60px 16px}
    .features-grid{grid-template-columns:1fr}
    .how-it-works{padding:60px 16px}
    .cta-section{padding:60px 16px}
    .cta-box{padding:40px 24px}
    .pricing-section{padding:60px 16px}
    .legal-content h1{font-size:28px}
    .contact-card{padding:24px}
}

@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
