/* VIDEO-STYLE HERO BG */
.hero-bg{position:absolute;inset:0;overflow:hidden}
.hero-bg-layer{position:absolute;inset:-10%;background:radial-gradient(ellipse 80% 60% at 60% 40%,rgba(107,144,188,.22) 0%,transparent 55%),radial-gradient(ellipse 40% 50% at 20% 70%,rgba(221,81,74,.14) 0%,transparent 50%),radial-gradient(ellipse 50% 40% at 80% 80%,rgba(29,53,85,.9) 0%,transparent 60%);animation:bgShift 12s ease-in-out infinite alternate}
@keyframes bgShift{0%{transform:translate(0,0) scale(1)}50%{transform:translate(-2%,3%) scale(1.04)}100%{transform:translate(2%,-2%) scale(1.02)}}
.hero-particles{position:absolute;inset:0;pointer-events:none}
.particle{position:absolute;width:2px;height:2px;border-radius:50%;background:rgba(107,144,188,.5);animation:particleFloat var(--dur,8s) var(--delay,0s) linear infinite}
@keyframes particleFloat{0%{transform:translateY(100vh) translateX(0);opacity:0}10%{opacity:1}90%{opacity:.4}100%{transform:translateY(-100px) translateX(var(--drift,30px));opacity:0}}
.hero-grid{position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(rgba(107,144,188,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(107,144,188,.06) 1px,transparent 1px);background-size:60px 60px;animation:gridPulse 4s ease-in-out infinite}
@keyframes gridPulse{0%,100%{opacity:.6}50%{opacity:1}}

/* HERO */
.hero{min-height:100vh;background:var(--navy);display:grid;grid-template-columns:1fr 1fr;align-items:center;padding:130px 5% 80px;position:relative;overflow:hidden}
.hero-content{position:relative;z-index:2}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(107,144,188,.15);border:1px solid rgba(107,144,188,.35);color:#a8c4e0;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:8px 18px;border-radius:50px;margin-bottom:28px;animation:fadeUp .6s ease both;backdrop-filter:blur(8px)}
.hero-badge-dot{width:7px;height:7px;background:var(--red);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.5)}}
.hero h1{font-size:clamp(2.8rem,5.5vw,5rem);font-weight:900;line-height:1.06;color:var(--white);margin-bottom:24px;animation:fadeUp .6s .1s ease both}
.hero h1 em{font-style:normal;color:var(--red);position:relative}
.hero h1 em::after{content:'';position:absolute;left:0;bottom:-4px;right:0;height:3px;background:linear-gradient(90deg,var(--red),transparent);border-radius:2px;transform:scaleX(0);transform-origin:left;animation:lineIn .5s .9s ease forwards}
@keyframes lineIn{to{transform:scaleX(1)}}
.hero p{font-size:1.05rem;font-weight:400;line-height:1.8;color:rgba(254,254,254,.62);max-width:500px;margin-bottom:40px;animation:fadeUp .6s .2s ease both}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;animation:fadeUp .6s .3s ease both}
.btn-store{display:flex;align-items:center;gap:12px;padding:14px 28px;border-radius:14px;text-decoration:none;transition:transform .25s,box-shadow .25s;border:2px solid transparent}
.btn-store:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(0,0,0,.35)}
.btn-appstore{background:var(--white);color:var(--navy)}
.btn-playstore{background:transparent;color:var(--white);border-color:rgba(254,254,254,.28)}
.btn-playstore:hover{border-color:rgba(254,254,254,.7)}
.btn-store-text small{font-size:.62rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;opacity:.65}
.btn-store-text strong{font-size:1rem;font-weight:800;line-height:1.2;display:block}
.hero-stats{display:flex;gap:40px;margin-top:56px;animation:fadeUp .6s .4s ease both}
.stat-item{border-left:2px solid var(--red);padding-left:16px;cursor:default}
.stat-num{font-size:1.9rem;font-weight:900;color:var(--white);line-height:1}
.stat-label{font-size:.7rem;font-weight:600;color:rgba(254,254,254,.45);letter-spacing:.09em;text-transform:uppercase;margin-top:4px}
.hero-visual{position:relative;z-index:2;display:flex;justify-content:center;align-items:center;animation:fadeUp .7s .15s ease both}
.phone-wrap{position:relative;width:1111px;animation:float 4s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-18px)}}
.phone-shadow{position:absolute;bottom:-28px;left:50%;transform:translateX(-50%);width:220px;height:18px;background:rgba(0,0,0,.35);border-radius:50%;filter:blur(14px);animation:shadowFloat 4s ease-in-out infinite}
.hero-bus-img{width:100%;display:block;filter:drop-shadow(0 24px 48px rgba(0,0,0,.5))}
@keyframes shadowFloat{0%,100%{transform:translateX(-50%) scaleX(1);opacity:.35}50%{transform:translateX(-50%) scaleX(.65);opacity:.18}}
.phone-frame{width:100%;aspect-ratio:9/19;background:#0d1f33;border-radius:44px;border:3px solid rgba(107,144,188,.35);box-shadow:0 0 0 1px rgba(107,144,188,.12),0 50px 100px rgba(0,0,0,.6),inset 0 1px 0 rgba(255,255,255,.07);overflow:hidden;position:relative}
.phone-notch{position:absolute;top:14px;left:50%;transform:translateX(-50%);width:68px;height:7px;background:rgba(0,0,0,.55);border-radius:10px;z-index:5}
.phone-screen{width:100%;height:100%;background:var(--navy);display:flex;flex-direction:column;padding:30px 14px 18px}
.app-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.app-logo-sm{font-size:.88rem;font-weight:900;color:var(--white);display:flex;align-items:center;gap:5px}
.app-map-card{background:var(--navy-light);border-radius:14px;overflow:hidden;flex:1;position:relative;margin-bottom:12px;min-height:120px}
.map-bg{width:100%;height:100%;background:linear-gradient(135deg,#1a3a5c,#1f4a6e,#1a3a5c);position:relative}
.map-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(107,144,188,.12) 1px,transparent 1px),linear-gradient(90deg,rgba(107,144,188,.12) 1px,transparent 1px);background-size:20px 20px}
.map-pin{position:absolute;top:35%;left:48%;transform:translate(-50%,-50%);animation:pinBounce 2.5s ease-in-out infinite}
@keyframes pinBounce{0%,100%{transform:translate(-50%,-50%)}50%{transform:translate(-50%,-75%)}}
.map-pin-ripple{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:36px;height:36px;border-radius:50%;background:rgba(221,81,74,.2);animation:ripple 2.5s infinite}
@keyframes ripple{0%{transform:translate(-50%,-50%) scale(0);opacity:.8}100%{transform:translate(-50%,-50%) scale(2.2);opacity:0}}
.app-route-card{background:rgba(254,254,254,.07);border:1px solid rgba(107,144,188,.22);border-radius:11px;padding:9px 11px;display:flex;align-items:center;justify-content:space-between;margin-bottom:9px}
.route-dot-line{display:flex;flex-direction:column;align-items:center;gap:2px;margin-right:9px}
.rdot{width:7px;height:7px;border-radius:50%}
.rdot.origin{background:var(--blue)}
.rdot.dest{background:var(--red)}
.rline{width:1px;height:12px;background:rgba(107,144,188,.35)}
.route-loc{font-size:.58rem;font-weight:600;color:rgba(254,254,254,.75)}
.route-loc span{display:block;font-size:.52rem;color:rgba(254,254,254,.38);font-weight:400}
.btn-book-now{background:var(--red);color:var(--white);border:none;border-radius:11px;padding:12px;width:100%;font-family:'Montserrat',sans-serif;font-size:.82rem;font-weight:800;cursor:pointer;letter-spacing:.04em}
.app-bottom-bar{display:flex;justify-content:space-around;align-items:center;padding:8px 0;border-top:1px solid rgba(107,144,188,.13);margin-top:10px}
.tab-icon{display:flex;flex-direction:column;align-items:center;gap:3px}
.tab-icon svg{width:17px;height:17px;color:rgba(254,254,254,.3)}
.tab-icon span{font-size:.42rem;font-weight:600;color:rgba(254,254,254,.35);letter-spacing:.05em;text-transform:uppercase}
.tab-icon.active svg{color:var(--red)}
.tab-icon.active span{color:var(--red)}
.orbit{position:absolute;border-radius:50%;border:1px solid rgba(107,144,188,.1);pointer-events:none;top:50%;left:50%;transform:translate(-50%,-50%)}

/* TRUST BAR */
.trust-bar{background:var(--navy-dark);padding:28px 5%;display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;border-top:1px solid rgba(107,144,188,.12)}
.trust-bar p{color:rgba(254,254,254,.35);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-right:16px}
.trust-partner{background:rgba(107,144,188,.1);border:1px solid rgba(107,144,188,.18);color:rgba(254,254,254,.45);font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:9px 20px;border-radius:8px;transition:all .2s;cursor:default}
.trust-partner:hover{background:rgba(107,144,188,.2);color:rgba(254,254,254,.75)}

/* FEATURES */
.features-section{background:#f4f7fb}
.features-header{text-align:center;margin-bottom:70px}
.features-header .section-sub{max-width:520px;margin:14px auto 0}
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px}
.feature-card{background:var(--white);border-radius:24px;padding:38px 30px;border:1px solid rgba(29,53,85,.07);box-shadow:0 4px 24px rgba(29,53,85,.05);transition:transform .35s cubic-bezier(.4,0,.2,1),box-shadow .35s;position:relative;overflow:hidden;cursor:default}
.feature-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--red),var(--blue));transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.feature-card:hover{transform:translateY(-8px);box-shadow:0 24px 60px rgba(29,53,85,.14)}
.feature-card:hover::before{transform:scaleX(1)}
.feature-icon{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:22px;background:rgba(29,53,85,.07);transition:background .3s,transform .3s}
.feature-card:hover .feature-icon{background:rgba(29,53,85,.12);transform:scale(1.08) rotate(-4deg)}
.feature-icon svg{width:26px;height:26px;color:var(--navy)}
.feature-card h3{font-size:1.1rem;font-weight:800;margin-bottom:10px;color:var(--navy)}
.feature-card p{font-size:.86rem;font-weight:400;line-height:1.72;color:rgba(29,53,85,.58)}
.feature-card.accent{background:var(--navy)}
.feature-card.accent .feature-icon{background:rgba(254,254,254,.1)}
.feature-card.accent .feature-icon svg{color:var(--white)}
.feature-card.accent h3{color:var(--white)}
.feature-card.accent p{color:rgba(254,254,254,.58)}

/* HOW IT WORKS */
.how-section{background:var(--white)}
.how-layout{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.steps{display:flex;flex-direction:column}
.step{display:flex;gap:22px;position:relative;padding-bottom:38px}
.step:last-child{padding-bottom:0}
.step-line-wrap{display:flex;flex-direction:column;align-items:center;flex-shrink:0}
.step-num{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:900;flex-shrink:0;border:2px solid var(--navy);color:var(--navy);background:var(--white);z-index:1;transition:background .3s,color .3s,transform .3s,box-shadow .3s}
.step:hover .step-num{background:var(--navy);color:var(--white);transform:scale(1.1);box-shadow:0 8px 24px rgba(29,53,85,.3)}
.step-connector{flex:1;width:2px;background:linear-gradient(var(--blue),transparent);margin-top:4px}
.step:last-child .step-connector{display:none}
.step-body{padding-top:10px}
.step-body h3{font-size:1.08rem;font-weight:800;color:var(--navy);margin-bottom:8px}
.step-body p{font-size:.86rem;line-height:1.72;color:rgba(29,53,85,.58)}
.how-visual{position:relative;display:flex;justify-content:center;align-items:center}
.how-phone{width:255px;aspect-ratio:9/19;background:var(--navy);border-radius:40px;border:3px solid rgba(107,144,188,.3);box-shadow:0 30px 80px rgba(29,53,85,.28);overflow:hidden;position:relative;display:flex;flex-direction:column}
.how-screen-content{flex:1;display:flex;flex-direction:column;padding:32px 16px 18px}
.fare-card{background:rgba(107,144,188,.14);border:1px solid rgba(107,144,188,.28);border-radius:14px;padding:14px;margin-bottom:11px}
.fare-row{display:flex;justify-content:space-between;align-items:center}
.fare-label{font-size:.58rem;font-weight:700;color:rgba(254,254,254,.45);text-transform:uppercase;letter-spacing:.08em}
.fare-value{font-size:1.35rem;font-weight:900;color:var(--white)}
.fare-route{font-size:.58rem;color:rgba(254,254,254,.45);margin-top:7px;display:flex;align-items:center;gap:5px}
.fare-route-dot{width:5px;height:5px;background:var(--red);border-radius:50%}
.driver-row{display:flex;align-items:center;gap:10px;background:rgba(254,254,254,.06);border-radius:11px;padding:9px 11px;margin-top:10px}
.driver-avatar{width:34px;height:34px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:800;color:var(--white)}
.driver-name{font-size:.63rem;font-weight:700;color:var(--white)}
.driver-rating{font-size:.53rem;color:rgba(254,254,254,.45)}
.driver-eta{font-size:.63rem;font-weight:800;color:var(--red);text-align:right}
.how-decoration{position:absolute;border-radius:50%;pointer-events:none}
.how-circle-lg{width:420px;height:420px;border:1px dashed rgba(107,144,188,.15);top:50%;left:50%;transform:translate(-50%,-50%);animation:rotateRing 30s linear infinite}
.how-circle-sm{width:300px;height:300px;border:1px dashed rgba(221,81,74,.12);top:50%;left:50%;transform:translate(-50%,-50%);animation:rotateRing 20s linear infinite reverse}
@keyframes rotateRing{to{transform:translate(-50%,-50%) rotate(360deg)}}

/* ROUTES */
.routes-section{background:var(--navy);position:relative;overflow:hidden}
.routes-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 80% 50%,rgba(107,144,188,.15),transparent 65%)}
.routes-header{text-align:center;margin-bottom:60px;position:relative}
.routes-header .section-title{color:var(--white)}
.routes-header .section-sub{color:rgba(254,254,254,.5);max-width:500px;margin:14px auto 0}
.routes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;position:relative}
.route-card{background:rgba(254,254,254,.05);border:1px solid var(--glass-border);border-radius:20px;padding:28px;transition:background .3s,transform .3s,box-shadow .3s;cursor:pointer;position:relative;overflow:hidden}
.route-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--red);transform:scaleY(0);transform-origin:bottom;transition:transform .35s ease}
.route-card:hover{background:rgba(254,254,254,.09);transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.3)}
.route-card:hover::before{transform:scaleY(1)}
.route-top{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:16px}
.route-cities{display:flex;align-items:center;gap:10px}
.route-city{font-size:.95rem;font-weight:800;color:var(--white)}
.route-arrow{color:var(--red);font-size:1rem}
.route-meta{display:flex;gap:10px;flex-wrap:wrap}
.route-tag{background:rgba(107,144,188,.15);border:1px solid rgba(107,144,188,.25);color:rgba(254,254,254,.65);font-size:.65rem;font-weight:700;padding:5px 12px;border-radius:20px;letter-spacing:.05em;text-transform:uppercase}
.route-tag.red{background:rgba(221,81,74,.15);border-color:rgba(221,81,74,.3);color:rgba(221,81,74,.9)}
.route-price{font-size:1rem;font-weight:900;color:var(--white);text-align:right;flex-shrink:0}
.route-price small{font-size:.6rem;font-weight:600;color:rgba(254,254,254,.45);display:block;text-align:right}
.route-card-soon{border-style:dashed;border-color:rgba(107,144,188,.3);cursor:default;pointer-events:none}
.route-card-soon:hover{background:rgba(254,254,254,.05);transform:none;box-shadow:none}
.route-card-soon::before{display:none}
.soon-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(107,144,188,.12);border:1px solid rgba(107,144,188,.3);color:var(--blue);font-size:.62rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:4px 12px;border-radius:20px;margin-bottom:16px}
.map-visual{margin-top:60px;border-radius:24px;overflow:hidden;border:1px solid var(--glass-border);position:relative;height:300px;background:linear-gradient(135deg,#162843,#1e3d60)}
.map-visual-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(107,144,188,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(107,144,188,.1) 1px,transparent 1px);background-size:40px 40px}
.map-dot{position:absolute;width:12px;height:12px;border-radius:50%;background:var(--red);border:2px solid rgba(221,81,74,.4);box-shadow:0 0 0 6px rgba(221,81,74,.1),0 0 20px rgba(221,81,74,.4);animation:dotPulse 2s ease-in-out infinite}
@keyframes dotPulse{0%,100%{box-shadow:0 0 0 4px rgba(221,81,74,.15),0 0 16px rgba(221,81,74,.3)}50%{box-shadow:0 0 0 8px rgba(221,81,74,.05),0 0 30px rgba(221,81,74,.5)}}
.map-line-svg{position:absolute;inset:0;width:100%;height:100%}
.map-animated-line{stroke:rgba(107,144,188,.4);stroke-width:1.5;stroke-dasharray:8 5;fill:none;animation:dashMove 3s linear infinite}
@keyframes dashMove{to{stroke-dashoffset:-52}}
.map-label{position:absolute;background:rgba(29,53,85,.85);border:1px solid var(--glass-border);border-radius:8px;padding:6px 12px;font-size:.65rem;font-weight:700;color:var(--white);backdrop-filter:blur(8px);white-space:nowrap}

/* PRICING */
.pricing-section{background:#f4f7fb}
.pricing-header{text-align:center;margin-bottom:60px}
.pricing-header .section-sub{max-width:480px;margin:14px auto 0}
.pricing-toggle{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:24px}
.pricing-toggle span{font-size:.82rem;font-weight:700;color:rgba(29,53,85,.45)}
.pricing-toggle span.active{color:var(--navy)}
.toggle-track{width:48px;height:26px;background:var(--navy);border-radius:50px;position:relative;cursor:pointer;transition:background .3s}
.toggle-thumb{position:absolute;top:3px;left:3px;width:20px;height:20px;background:var(--white);border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px rgba(0,0,0,.25)}
.toggle-track.yearly .toggle-thumb{transform:translateX(22px)}
.save-badge{background:rgba(221,81,74,.12);border:1px solid rgba(221,81,74,.3);color:var(--red);font-size:.65rem;font-weight:800;letter-spacing:.06em;padding:3px 10px;border-radius:20px}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
.price-card{background:var(--white);border-radius:24px;padding:40px 32px;border:1px solid rgba(29,53,85,.08);box-shadow:0 4px 24px rgba(29,53,85,.06);transition:transform .3s,box-shadow .3s;position:relative;overflow:hidden;display:flex;flex-direction:column}
.price-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(29,53,85,.12)}
.price-card.popular{background:var(--navy);border:none;box-shadow:0 20px 60px rgba(29,53,85,.35);transform:scale(1.04)}
.price-card.popular:hover{transform:scale(1.04) translateY(-4px)}
.popular-badge{position:absolute;top:20px;right:20px;background:var(--red);color:var(--white);font-size:.62rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:5px 12px;border-radius:20px}
.price-plan{font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);margin-bottom:12px}
.price-card.popular .price-plan{color:rgba(107,144,188,.8)}
.price-num{font-size:2.6rem;font-weight:900;color:var(--navy);line-height:1;margin-bottom:4px}
.price-card.popular .price-num{color:var(--white)}
.price-period{font-size:.78rem;color:rgba(29,53,85,.4);font-weight:600;margin-bottom:10px}
.price-card.popular .price-period{color:rgba(254,254,254,.4)}
.price-desc{font-size:.82rem;color:rgba(29,53,85,.55);margin-bottom:28px;line-height:1.6}
.price-card.popular .price-desc{color:rgba(254,254,254,.55)}
.price-features{list-style:none;display:flex;flex-direction:column;gap:12px;flex:1;margin-bottom:32px}
.price-features li{display:flex;align-items:center;gap:10px;font-size:.84rem;font-weight:500;color:rgba(29,53,85,.75)}
.price-card.popular .price-features li{color:rgba(254,254,254,.75)}
.price-features li svg{width:16px;height:16px;flex-shrink:0}
.check{color:var(--red)}
.price-card.popular .check{color:#7ec8a0}
.btn-price{display:block;text-align:center;padding:14px;border-radius:12px;font-weight:800;font-size:.88rem;letter-spacing:.04em;text-decoration:none;transition:all .25s;border:2px solid var(--navy);color:var(--navy)}
.btn-price:hover{background:var(--navy);color:var(--white)}
.btn-price.primary{background:var(--red);color:var(--white);border-color:var(--red)}
.btn-price.primary:hover{background:#c94440;border-color:#c94440;box-shadow:0 8px 30px rgba(221,81,74,.4)}

/* TESTIMONIALS */
.testimonials-section{background:var(--navy);position:relative;overflow:hidden}
.testimonials-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 70% at 80% 20%,rgba(107,144,188,.1),transparent 60%)}
.testimonials-header{text-align:center;margin-bottom:56px;position:relative}
.testimonials-header .section-label{color:var(--blue)}
.testimonials-header .section-title{color:var(--white)}
.testimonials-track-wrap{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,black 8%,black 92%,transparent);mask-image:linear-gradient(90deg,transparent,black 8%,black 92%,transparent)}
.testimonials-track{display:flex;gap:22px;animation:scrollLeft 32s linear infinite;width:max-content}
.testimonials-track:hover{animation-play-state:paused}
@keyframes scrollLeft{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.tcard{background:rgba(254,254,254,.05);border:1px solid rgba(107,144,188,.18);border-radius:20px;padding:28px;width:310px;flex-shrink:0;transition:background .3s,transform .3s}
.tcard:hover{background:rgba(254,254,254,.09);transform:translateY(-4px)}
.tcard-stars{font-size:14px;margin-bottom:14px;letter-spacing:2px;color:#f5a623}
.tcard-text{font-size:.86rem;font-weight:400;line-height:1.75;color:rgba(254,254,254,.68);margin-bottom:18px;font-style:italic}
.tcard-author{display:flex;align-items:center;gap:11px}
.tcard-avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.88rem;font-weight:800;color:var(--white);flex-shrink:0}
.tcard-name{font-size:.8rem;font-weight:700;color:var(--white)}
.tcard-role{font-size:.7rem;color:rgba(254,254,254,.38);margin-top:2px}

/* FAQ */
.faq-section{background:var(--white)}
.faq-layout{display:grid;grid-template-columns:1fr 1.6fr;gap:80px;align-items:start}
.faq-cta{display:inline-flex;align-items:center;gap:10px;background:var(--navy);color:var(--white);padding:14px 28px;border-radius:12px;text-decoration:none;font-weight:800;font-size:.88rem;letter-spacing:.04em;transition:transform .25s,box-shadow .25s;margin-top:32px}
.faq-cta:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(29,53,85,.3)}
.faq-list{display:flex;flex-direction:column;gap:12px}
.faq-item{border:1px solid rgba(29,53,85,.1);border-radius:16px;overflow:hidden;transition:border-color .25s,box-shadow .25s}
.faq-item.open{border-color:var(--navy);box-shadow:0 4px 20px rgba(29,53,85,.08)}
.faq-question{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;cursor:pointer;user-select:none;font-size:.92rem;font-weight:700;color:var(--navy);transition:color .2s;gap:16px}
.faq-question:hover{color:var(--red)}
.faq-icon{width:28px;height:28px;border-radius:50%;border:2px solid rgba(29,53,85,.2);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .25s,border-color .25s,transform .3s}
.faq-item.open .faq-icon{background:var(--navy);border-color:var(--navy);transform:rotate(45deg)}
.faq-icon svg{width:14px;height:14px;color:var(--navy);transition:color .25s}
.faq-item.open .faq-icon svg{color:var(--white)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .45s cubic-bezier(.4,0,.2,1),padding .3s;font-size:.88rem;line-height:1.75;color:rgba(29,53,85,.6);padding:0 24px}
.faq-item.open .faq-answer{max-height:200px;padding:0 24px 20px}

/* DOWNLOAD */
.download-section{background:#f4f7fb;text-align:center;position:relative;overflow:hidden}
.download-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 50% 80% at 50% 0%,rgba(29,53,85,.06),transparent 70%)}
.download-inner{position:relative;max-width:680px;margin:0 auto}
.download-section .section-sub{margin:0 auto 48px;text-align:center;max-width:480px}
.download-actions{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
.btn-dl{display:flex;align-items:center;gap:14px;padding:16px 32px;border-radius:16px;text-decoration:none;transition:transform .25s,box-shadow .25s;min-width:200px}
.btn-dl:hover{transform:translateY(-5px)}
.btn-dl-primary{background:var(--navy);color:var(--white)}
.btn-dl-primary:hover{box-shadow:0 20px 50px rgba(29,53,85,.3)}
.btn-dl-secondary{background:var(--red);color:var(--white)}
.btn-dl-secondary:hover{box-shadow:0 20px 50px rgba(221,81,74,.4)}
.btn-dl-text small{display:block;font-size:.62rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;opacity:.7}
.btn-dl-text strong{display:block;font-size:1.05rem;font-weight:800;line-height:1.2}
.download-note{margin-top:22px;font-size:.76rem;color:rgba(29,53,85,.38);font-weight:500}

/* WHATSAPP — index.html pairs the WA button with a back-to-top button and
   tooltip markup that no other page has, so it overrides base.css's default
   bottom-right placement/size to sit above .back-top and adds the entrance animation */
.wa-btn{position:fixed;bottom:90px;right:28px;width:56px;height:56px;box-shadow:0 8px 30px rgba(37,211,102,.4);transition:transform .25s,box-shadow .25s;animation:fadeUp .5s 1.5s ease both}
.wa-btn:hover{transform:scale(1.1) translateY(-2px);box-shadow:0 14px 40px rgba(37,211,102,.5)}
.wa-btn svg{width:28px;height:28px}
.back-top{position:fixed;bottom:28px;right:28px;z-index:99;width:44px;height:44px;border-radius:50%;background:var(--navy);color:white;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.25);cursor:pointer;transition:all .25s;opacity:0;transform:translateY(20px);border:1px solid rgba(107,144,188,.25)}
.back-top.visible{opacity:1;transform:translateY(0)}
.back-top:hover{background:var(--red);box-shadow:0 8px 24px rgba(221,81,74,.4);transform:translateY(-3px)}
.back-top svg{width:18px;height:18px}

/* RESPONSIVE */
@media(max-width:1024px){.pricing-grid{grid-template-columns:1fr 1fr}.price-card.popular{transform:scale(1);grid-column:span 2}}
@media(max-width:900px){
  .hero{grid-template-columns:1fr;text-align:center;padding-top:100px}
  .hero-content{order:1}.hero-visual{order:0;margin-bottom:40px}
  .hero p,.hero-actions,.hero-stats{justify-content:center}
  .hero p{margin:0 auto 40px}
  .hero-badge{justify-content:center}
  .phone-wrap{width:min(1111px,75%)}
  .how-layout,.faq-layout{grid-template-columns:1fr}
  .how-visual{order:-1;margin-bottom:40px}
  .pricing-grid{grid-template-columns:1fr}.price-card.popular{transform:scale(1);grid-column:auto}
}
@media(max-width:600px){.features-grid,.routes-grid{grid-template-columns:1fr}.hero-stats{flex-direction:column;gap:20px}}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}