:root{
  --dark:#071021;
  --blue:#0b66b2;
  --gold:#d4af37;
  --bg:#0f1720;
  --muted:#6b7280;
  --card-bg:#0b1221;
}
*{box-sizing:border-box}
body{font-family:'Poppins',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;line-height:1.45;margin:0;color:#0b1221;background:linear-gradient(180deg,#0f1720 0%, #071021 100%);} 
.container{max-width:1140px;margin:0 auto;padding:2rem}
.site-header{background:rgba(7,16,33,0.96);padding:0.6rem 0;position:sticky;top:0;z-index:60;backdrop-filter:blur(6px);box-shadow:0 6px 20px rgba(2,6,23,0.6);transition:background .25s ease}
.header-inner{padding:0 1rem}
.header-inner{display:flex;align-items:center;justify-content:space-between}
.brand{font-weight:800;font-size:1.25rem;color:white;text-decoration:none}
.brand-logo{height:44px;width:auto;display:block}
.brand .gold{color:var(--gold);margin-left:4px}
.main-nav{display:flex;gap:1rem;align-items:center}
.main-nav a{color:#e6eef9;text-decoration:none;padding:0.25rem 0.5rem}
.main-nav .cta{background:var(--gold);color:#071021;padding:0.5rem 0.8rem;border-radius:8px;font-weight:700}
.nav-toggle{display:none;background:transparent;border:0;color:#fff;font-size:1.25rem}

.hero{padding:4rem 0;background:linear-gradient(180deg,#071021 0%, #081428 100%)}
.hero-grid{display:flex;gap:2rem;align-items:center}
.hero-text{flex:1;color:#fff;display:flex;flex-direction:column;justify-content:center;gap:1rem;min-height:320px}
.eyebrow{color:var(--muted);text-transform:uppercase;font-weight:600;margin-bottom:.25rem}
.eyebrow-list{display:flex;gap:0.75rem;list-style:none;padding:0;margin:0 0 1rem 0;flex-wrap:wrap}
.eyebrow-list li{display:flex;align-items:center;gap:.6rem;padding:.7rem 1rem;border-radius:12px;background:rgba(255,255,255,.03);font-weight:700;color:var(--muted);font-size:1.05rem;flex:1;min-width:200px;justify-content:center}
.eyebrow-list li img{width:22px;height:22px;display:block}
.eyebrow-list li{transition:transform .42s cubic-bezier(.2,.9,.2,1),opacity .42s ease,filter .42s ease}

/* Hide-on-scroll behaviour: when container has .hide-on-scroll, items slide up and fade */
.eyebrow-list.hide-on-scroll li{transform:translateY(-18px) scale(.985);opacity:0;pointer-events:none;filter:blur(.6px)}
.eyebrow-list.hide-on-scroll{pointer-events:none}

@media (max-width:780px){
  .eyebrow-list.hide-on-scroll li{transform:translateY(-12px)}
}
.eyebrow-list li.security{color:#fff}
.eyebrow-list li.tech{color:var(--blue)}
.eyebrow-list li.agri{color:var(--gold)}
.hero-text h1{font-size:clamp(2rem,5.5vw,3.6rem);margin:0;color:var(--blue);line-height:1.02}
.lead{color:#dbeafe;max-width:65ch;font-size:clamp(1rem,1.6vw,1.125rem);line-height:1.6}
.hero-actions{margin:1rem 0;display:flex;gap:0.75rem;flex-wrap:wrap}
.btn{display:inline-block;text-decoration:none;padding:1rem 1.4rem;border-radius:12px;font-weight:700}
.btn.primary{background:var(--blue);color:white}
.btn.outline{border:2px solid rgba(255,255,255,.12);color:white;background:transparent}
.btn.primary, .btn.outline{min-width:175px;text-align:center}
.badges{list-style:none;padding:0;display:flex;gap:1rem;margin-top:1rem;flex-wrap:wrap}
.badges li{flex:1;min-width:160px;background:rgba(255,255,255,.03);padding:1rem;border-radius:12px;color:#dbeafe;text-align:center;font-weight:700}
.hero-media{width:360px;display:flex;justify-content:center}
.phone-mock img{width:100%;height:auto;border-radius:24px;box-shadow:0 20px 40px rgba(0,0,0,.45)}

.section{padding:4rem 0}
.section.light{background:#fff}
.section.dark{background:#071021;color:#fff}
.muted{color:var(--muted)}

/* Features grid */
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-top:1.5rem}
.feature-card{background:#f8fafc;padding:1.25rem;border-radius:12px;display:flex;flex-direction:column;gap:.6rem;min-height:140px}
.feature-card h3{margin:0 0 .25rem;color:var(--dark);font-size:1.05rem}
.feature-top{display:flex;align-items:center;gap:.75rem;margin-bottom:.4rem}
.feature-icon{width:36px;height:36px;flex:0 0 36px}

/* Usimamizi identity styling */
#usimamizi{background:linear-gradient(180deg,#f7fbff,#eef6ff);padding:3.5rem 0;border-top:1px solid rgba(11,18,33,.04)}
.usimamizi-text h2, .usimamizi-text .usim-logo{display:block}
.usim-actions{margin:1rem 0}

/* reveal animations for scroll */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease, transform .6s cubic-bezier(.2,.9,.2,1)}
.reveal.visible{opacity:1;transform:none}

/* Dramatic hero title animation: entrance + glowing pulse while visible */
.hero-head{opacity:0;transform:translateY(24px) scale(.98);will-change:transform,opacity,text-shadow,color;display:inline-block}
.hero-head.visible{
  opacity:1;
  animation: heroPop .72s cubic-bezier(.2,.9,.2,1) both, heroGlow 2.8s ease-in-out .45s infinite alternate;
  color:#0ea5ff;
  text-shadow:0 10px 40px rgba(14,165,255,0.18), 0 3px 12px rgba(2,6,23,0.25);
}

@keyframes heroPop{
  0%{opacity:0;transform:translateY(36px) scale(.94) skewX(-6deg);filter:blur(6px)}
  60%{transform:translateY(-10px) scale(1.08) skewX(2deg);filter:blur(0)}
  100%{opacity:1;transform:none;filter:none}
}

@keyframes heroGlow{
  0%{text-shadow:0 0 0 rgba(14,165,255,0)}
  50%{text-shadow:0 12px 36px rgba(2,132,199,0.38), 0 4px 12px rgba(0,0,0,0.28)}
  100%{text-shadow:0 26px 90px rgba(2,132,199,0.6), 0 6px 18px rgba(0,0,0,0.44)}
}

/* Respect reduced motion preferences */
@media (prefers-reduced-motion: reduce){
  .hero-head, .hero-head.visible{animation:none!important;transition:none!important;text-shadow:none!important}
}

/* Staggered reveal container: children animate sequentially when the container gets .visible */
.reveal-stagger > *{opacity:0;transform:translateY(18px);transition:opacity .58s ease, transform .58s cubic-bezier(.2,.9,.2,1)}
.reveal-stagger.visible > *{opacity:1;transform:none}
.reveal-stagger > *:nth-child(1){transition-delay:60ms}
.reveal-stagger > *:nth-child(2){transition-delay:180ms}
.reveal-stagger > *:nth-child(3){transition-delay:320ms}
.reveal-stagger > *:nth-child(4){transition-delay:460ms}
.reveal-stagger > *:nth-child(5){transition-delay:600ms}

/* Small adjustments so buttons look smoother as they appear */
.hero-actions{display:flex;gap:0.75rem;justify-content:center}
.hero-actions .btn{transform-origin:center;transition:transform .36s cubic-bezier(.2,.9,.2,1),opacity .36s}
.reveal-stagger.visible .hero-actions .btn{transform:none;opacity:1}

@media(max-width:780px){
  .reveal-stagger > *:nth-child(1){transition-delay:40ms}
  .reveal-stagger > *:nth-child(2){transition-delay:120ms}
  .reveal-stagger > *:nth-child(3){transition-delay:220ms}
}
.laptop-alone{width:100%;max-width:420px;height:auto;border-radius:8px;display:block;box-shadow:none;border:0;transition:transform .6s ease,opacity .6s ease}
.laptop-alone.reveal{transform:translateX(24px);opacity:0}
.laptop-alone.reveal.visible{transform:none;opacity:1}

/* Usimamizi section layout */
.usimamizi-row{display:flex;gap:2rem;align-items:stretch}
.usimamizi-text{flex:1}
.usimamizi-mock{width:420px;display:flex;flex-direction:column;align-items:center;justify-content:center}
.laptop-alone{width:100%;max-width:420px;height:auto;border-radius:8px;display:block;box-shadow:none;border:0}
.usimamizi-mock img{display:block}
.caption{font-size:.9rem;margin-top:.6rem}

/* Usimamizi logo */
.usim-logo{max-width:320px;height:auto;display:block;margin-bottom:0.6rem}

.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}
.stat-card{background:rgba(255,255,255,.06);padding:2.5rem;border-radius:20px;display:flex;flex-direction:column;justify-content:center;align-items:flex-end;font-weight:800;color:#fff}
.stat-card.big{font-size:3rem;padding:3rem}
.stat-card.blue{background:var(--blue)}
.stat-card.gold{background:var(--gold);color:#071021}
.stat-label{font-weight:400;font-size:.9rem;margin-top:.5rem}

.product-row{display:flex;gap:1rem;margin-top:1rem}
.product-card{flex:1;background:linear-gradient(180deg,#ffefe6,#ffd9ca);padding:2.5rem;border-radius:22px;text-align:center;color:var(--dark);font-weight:700}

/* Shop grid (image-only cards with title) */
.shop-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem;margin-top:1rem}
.shop-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 8px 20px rgba(2,6,23,0.06);display:flex;flex-direction:column;align-items:stretch}
.shop-media img{width:100%;height:160px;object-fit:cover;display:block;transition:opacity .6s ease}
.shop-title{padding:0.9rem 1rem;text-align:center;font-weight:800;color:var(--dark);background:#fff}

@media(max-width:780px){
  .shop-media img{height:140px}
}

.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem;margin-top:1.25rem}
.service-card{background:#ffffff;padding:0;border-radius:12px;display:flex;flex-direction:column;gap:0.75rem;min-height:260px;color:var(--dark);box-shadow:0 8px 20px rgba(2,6,23,0.12);overflow:hidden}
.service-media img{width:100%;height:140px;object-fit:cover;display:block}
.service-media img{transition:opacity .6s ease}
.service-card h3{margin:0 0 .25rem;color:var(--dark);font-size:1.05rem}
.service-top{display:flex;align-items:center;gap:.75rem;margin-top:-32px;margin-bottom:.25rem;justify-content:center}
.icon-circle{width:64px;height:64px;border-radius:50%;background:#ecfdf5;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(2,6,23,0.08);margin-bottom:6px}
.service-icon{width:28px;height:28px;display:block}
.service-card p{padding:0 1rem;color:#555;margin-top:0}
.service-link{display:inline-block;margin:0 1rem 1rem 1rem;color:#16a34a;font-weight:700;text-decoration:none}

/* Drone pulverização section */
.drone-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem;margin-top:1rem}
.drone-card{background:#fff;padding:1.25rem;border-radius:12px;display:flex;flex-direction:column;gap:.6rem;align-items:center;text-align:center;box-shadow:0 8px 20px rgba(2,6,23,0.08);color:var(--dark)}
.drone-media img{width:120px;height:120px;object-fit:contain;display:block;margin-top:6px}
.drone-media-large img{width:100%;height:220px;object-fit:cover;border-radius:8px;display:block}
.drone-media-gif img{width:100%;height:220px;object-fit:cover;border-radius:8px;display:block}
.drone-card h3{margin:0;color:var(--dark)}
.drone-card p{color:#374151}
.drone-card .service-link{margin-top:auto;background:var(--blue);color:#fff;padding:.6rem .9rem;border-radius:10px}

/* Drone hero (video background) */
.drone-hero{position:relative;overflow:hidden;border-radius:12px}
.drone-hero{min-height:380px}
.drone-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;filter:brightness(.72)}
.drone-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,16,33,0.25),rgba(7,16,33,0.55));z-index:1}
.drone-hero-content{position:relative;z-index:2;padding:2.5rem 1rem;color:#fff;display:flex;flex-direction:column;align-items:center}
.drone-hero-content h2{color:#fff;margin:0;font-size:clamp(1.4rem,3.2vw,2.4rem)}
.drone-hero-content .muted{color:rgba(255,255,255,0.85);max-width:70ch;text-align:center}
.drone-hero .drone-grid{width:100%;max-width:980px;margin-top:1.25rem}
.drone-hero .drone-card{background:rgba(255,255,255,0.80);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,0.25);box-shadow:0 10px 30px rgba(2,6,23,0.18)}

@media(max-width:900px){
  .drone-hero{min-height:260px}
  .drone-hero-content{padding:1.25rem}
}

/* Carousel for services: show 3 cards in a horizontal sliding track */
.services-carousel{margin-top:1.25rem;overflow:hidden}
.services-carousel .carousel-track{display:flex;gap:1.25rem;transition:transform .6s ease;will-change:transform}
.services-carousel .service-card{flex:0 0 calc((100% - 2.5rem) / 3);} 

@media(max-width:1000px){
  .services-carousel .service-card{flex:0 0 calc((100% - 1.25rem) / 2);} /* show 2 on medium screens */
}

@media(max-width:780px){
  .services-carousel .service-card{flex:0 0 100%;} /* show 1 on small screens */
}

/* Generic carousel used for development section: show one card full-width and slide */
.carousel-wrapper{position:relative;overflow:hidden}
.carousel-track{display:flex;transition:transform .8s cubic-bezier(.2,.9,.2,1);will-change:transform}
.carousel-track .drone-card{flex:0 0 100%;max-width:100%;box-sizing:border-box}
.carousel-track .drone-card .drone-media img{height:220px;object-fit:cover}
.carousel-dots{display:flex;gap:.6rem;justify-content:center;margin-top:.85rem}
.carousel-dot{
  width:34px;
  height:8px;
  border-radius:6px;
  background:rgba(11,18,33,0.06);
  border:1px solid rgba(11,18,33,0.06);
  cursor:pointer;
  transition:transform .28s cubic-bezier(.2,.9,.2,1), box-shadow .28s ease, background .28s ease, border-color .28s ease;
  box-shadow:0 2px 6px rgba(2,6,23,0.06);
  outline:none;
}
.carousel-dot:focus{box-shadow:0 0 0 4px rgba(11,102,178,0.10)}
.carousel-dot:hover{transform:translateY(-3px);}
.carousel-dot.active{
  background:var(--blue);
  border-color:var(--blue);
  transform:scale(1.05);
  box-shadow:0 8px 22px rgba(11,102,178,0.12);
}

@media(max-width:780px){
  .carousel-track .drone-card .drone-media img{height:160px}
}


@media(max-width:780px){
  .services-grid{grid-template-columns:1fr}
}

.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}
.contact-form input,.contact-form textarea{width:100%;padding:.75rem;margin:.35rem 0;border-radius:8px;border:1px solid #ddd}
.contact-form .btn{width:100%}

/* Contact form specific styling to match provided mock */
.contact-form{background:transparent;padding:0}
.contact-form label{display:block;font-weight:600;margin-top:0.75rem;color:var(--dark)}
.contact-form input,.contact-form select,.contact-form textarea{background:#fff;border:1px solid rgba(11,18,33,0.06);box-shadow:none;border-radius:8px;padding:14px;color:#111}
.contact-form select{appearance:none}
.contact-form textarea{resize:vertical}
.btn-submit{background:#0b1221;color:white;padding:14px 22px;border-radius:10px;border:0;font-weight:800;letter-spacing:1px;display:inline-block;margin-top:1rem;box-shadow:6px 6px 0 rgba(244,114,72,0.18)}
.btn-submit:hover{transform:translateY(-2px)}

@media(max-width:780px){
  .contact-grid{grid-template-columns:1fr}
  .contact-grid aside{order:2}
}

/* Contact panel styling */
.contact-panel{background:linear-gradient(180deg, rgba(255,255,255,0.95), rgba(245,249,255,0.95));padding:28px;border-radius:16px;box-shadow:0 20px 60px rgba(2,6,23,0.12);border:1px solid rgba(11,18,33,0.04);position:relative;overflow:visible}
.contact-panel .form-success{background:linear-gradient(90deg,#16a34a,#10b981);color:#fff;padding:.85rem 1rem;border-radius:8px;margin-bottom:10px;font-weight:700;text-align:center}

.contact-panel .field{position:relative;margin-top:0.65rem}
.contact-panel input,.contact-panel select,.contact-panel textarea{width:100%;padding:16px;border-radius:10px;border:1px solid rgba(11,18,33,0.06);background:#fff;font-size:1rem}
.contact-panel label{position:absolute;left:14px;top:12px;color:#6b7280;pointer-events:none;transition:transform .22s ease, font-size .22s ease, top .22s ease}
.contact-panel .field.has-value label,
.contact-panel .field input:focus + label,
.contact-panel .field textarea:focus + label,
.contact-panel .field select:focus + label{transform:translateY(-10px);font-size:.78rem;top:6px;color:#0b66b2}

.contact-panel .two-cols{display:flex;gap:1rem}
.contact-panel .charcount{position:absolute;right:12px;bottom:8px;font-size:.82rem;color:#6b7280}
.submit-status{color:var(--muted);font-weight:700}

/* small screens adjustments */
@media(max-width:780px){
  .contact-panel{padding:18px}
  .contact-panel .two-cols{flex-direction:column}
}

/* Direct contact card mascot */
.direct-contact-card{position:relative;overflow:visible}
.direct-contact-card .contact-mascot{position:absolute;right:-18px;bottom:-24px;width:96px;height:96px;pointer-events:none;transform-origin:center center;animation:mascotBob 3.6s ease-in-out infinite}
.direct-contact-card .contact-mascot svg{display:block;width:100%;height:100%}
.direct-contact-card .contact-mascot .gear{transform-origin:50% 50%;animation:gearSpin 6s linear infinite}

@keyframes mascotBob{
  0%{transform:translateY(0) rotate(0deg)}
  25%{transform:translateY(-6px) rotate(-1deg)}
  50%{transform:translateY(-10px) rotate(1deg)}
  75%{transform:translateY(-6px) rotate(-1deg)}
  100%{transform:translateY(0) rotate(0deg)}
}

@keyframes gearSpin{
  from{transform:rotate(0deg)}
  to{transform:rotate(360deg)}
}

@media(max-width:780px){
  .direct-contact-card .contact-mascot{display:none}
}

/* Viewport debug overlay */
#viewport-debug{position:fixed;right:10px;top:10px;z-index:99999;background:rgba(2,6,23,0.9);color:#dbeafe;padding:8px 10px;border-radius:8px;font-family:Inter, system-ui, sans-serif;font-size:13px;line-height:1.2;box-shadow:0 6px 20px rgba(2,6,23,0.6);backdrop-filter:blur(6px)}

/* Tech mascot styling */
.tech-mascot{position:absolute;right:18px;top:-36px;width:140px;height:140px;pointer-events:auto;transition:transform .36s ease}
.tech-mascot svg{display:block;width:100%;height:100%}
.tech-mascot .eye{transform-origin:center;animation:blink 4s infinite ease-in-out}
.tech-mascot .pupil{transform-origin:center;animation:pupilMove 6s infinite ease-in-out}

@keyframes blink{
  0%,90%,100%{transform:scaleY(1)}
  92%,96%{transform:scaleY(0.06)}
}

@keyframes pupilMove{
  0%{transform:translateX(0)}
  25%{transform:translateX(-1px)}
  50%{transform:translateX(1px)}
  75%{transform:translateX(-1px)}
  100%{transform:translateX(0)}
}

.tech-mascot:hover{transform:translateY(-8px) scale(1.03)}

/* optional waving class toggled by JS */
.tech-mascot.wave{animation:float 3.8s ease-in-out infinite}
@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-6px)}100%{transform:translateY(0)}}

@media(max-width:780px){
  .tech-mascot{display:none}
}

.site-footer{background:#f8fafc;color:#111;padding:2.5rem 0;margin-top:2rem;border-top-left-radius:24px;border-top-right-radius:24px}
.footer-top{padding:3rem 0}
.footer-columns{display:grid;grid-template-columns:1fr 1fr 1fr 1.4fr;gap:2rem;align-items:start}
.footer-col h4{margin:0 0 .75rem;font-size:1.125rem;color:var(--dark);font-weight:700}
.footer-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem}
.footer-links a{color:#374151;text-decoration:none;font-size:1rem}
.footer-brand{display:flex;flex-direction:column;gap:0.75rem}
.footer-logo{width:140px;height:auto}
.social-row{display:flex;gap:.5rem;margin-top:.5rem}
.social-btn{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:rgba(2,6,23,0.04);color:var(--dark);text-decoration:none;font-weight:700}
.social-btn img{width:20px;height:20px;display:block}
.footer-bottom{border-top:1px solid rgba(11,18,33,0.04);padding:1rem 0;margin-top:1rem;color:var(--muted)}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;gap:1rem}
.footer-links-inline{display:flex;gap:1rem}
.footer-links-inline a{color:var(--muted);text-decoration:none}

@media(max-width:780px){
  .hero-grid{flex-direction:column}
  .hero-media{width:90%}
  .nav-toggle{display:block}
  .main-nav{display:none;position:absolute;right:1rem;top:64px;background:rgba(0,0,0,.6);padding:1rem;border-radius:8px}
  .contact-grid{grid-template-columns:1fr}
  .product-row{flex-direction:column}
  .eyebrow-list{justify-content:center}
  .usimamizi-row{flex-direction:column}
  .usimamizi-mock{width:100%}
  .laptop-alone{max-width:100%;}
  .footer-columns{grid-template-columns:1fr;gap:1.25rem}
  .footer-bottom-inner{flex-direction:column;align-items:flex-start}
  .brand-logo{height:36px}
  .footer-logo{width:120px}
}

/* Clients strip (logos carousel overlapping section boundary) */
.clients-wrapper{display:flex;justify-content:center}
.clients-strip{width:calc(100% - 80px);max-width:1140px;height:120px;background:#ffffff;border-radius:12px;box-shadow:0 12px 30px rgba(2,6,23,0.12);overflow:hidden;display:flex;align-items:center;margin-top:-70px;position:relative;z-index:30}
.clients-wrapper--top .clients-strip{transform:translateY(40%)}
.clients-track{display:flex;align-items:center;gap:48px;padding:0 30px;white-space:nowrap;animation:marquee 20s linear infinite}
.clients-track img{width:150px;height:auto;display:block;filter:grayscale(0);object-fit:contain}

/* Animate client logos on reveal: start hidden and slide up with stagger */
.clients-track.reveal img{opacity:0;transform:translateY(18px);transition:opacity .6s ease, transform .6s cubic-bezier(.2,.9,.2,1)}
.clients-track.reveal.visible img{opacity:1;transform:none}
.clients-track.reveal.visible img:nth-child(1){transition-delay:60ms}
.clients-track.reveal.visible img:nth-child(2){transition-delay:160ms}
.clients-track.reveal.visible img:nth-child(3){transition-delay:260ms}
.clients-track.reveal.visible img:nth-child(4){transition-delay:360ms}
.clients-track.reveal.visible img:nth-child(5){transition-delay:460ms}
.clients-track.reveal.visible img:nth-child(6){transition-delay:560ms}
.clients-track.reveal.visible img:nth-child(7){transition-delay:660ms}
.clients-track.reveal.visible img:nth-child(8){transition-delay:760ms}
.clients-strip:hover .clients-track{animation-play-state:paused}

@keyframes marquee{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

@media(max-width:780px){
  .clients_strip{height:100px;margin-top:-50px}
  .clients-wrapper--top .clients-strip{transform:translateY(80%)}
  .clients-track img{width:110px}
  .clients-track.reveal img{transform:translateY(12px)}
}

/* (Large-desktop scaling removed to match reference proportions) */

/* Mascot + Speech bubble styles for about page (rectangular, horizontal layout) */
.mascot-row{display:flex;gap:1rem;align-items:center;justify-content:flex-start;margin:2rem 0}
.mascot{flex:0 0 auto;display:flex;align-items:center;justify-content:center;width:96px}
.mascot-figure svg,.mascot img{width:88px;height:auto;display:block}
.mascot .speech-bubble{position:relative;margin-left:1rem;max-width:calc(100% - 140px);background:#fff;padding:1rem 1.1rem;border-radius:10px;border:1px solid rgba(11,18,33,0.06);box-shadow:0 12px 30px rgba(2,6,23,0.08);color:var(--dark);text-align:left}
.speech-bubble h3{margin:0 0 .35rem;font-size:1.05rem}
.speech-bubble p{margin:0;color:#374151}

/* smaller variation for secondary bubbles */
.mascot-row.small .mascot{width:76px}
.mascot-row.small .mascot .speech-bubble{max-width:calc(100% - 120px);padding:.85rem;border-radius:10px}

/* mascot idle animation (only transform, do not reset sizing) */
.mascot .mascot-figure{transition:transform .36s ease}
.mascot:hover .mascot-figure{transform:translateY(-6px) scale(1.02)}

@media(max-width:900px){
  .mascot-row{flex-direction:column;align-items:center}
  .mascot{width:100%;flex:0 0 auto}
  .mascot .speech-bubble{position:relative;margin-left:0;max-width:100%;margin-bottom:.65rem}
}

/* WhatsApp floating button */
.whatsapp-btn{
  position:fixed;
  right:20px;
  bottom:20px;
  width:56px;
  height:56px;
  border-radius:50%;
  background:#25D366;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 10px 30px rgba(37,211,102,0.16);
  z-index:1100;
  text-decoration:none;
}
.whatsapp-btn svg{width:22px;height:22px;display:block}
.whatsapp-btn:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(37,211,102,0.22)}
@media(max-width:480px){.whatsapp-btn{right:14px;bottom:14px;width:50px;height:50px}}

/* ====== Interactive services & chat styles ====== */
.services-grid{gap:1rem}
.service-card{background:linear-gradient(180deg,rgba(255,255,255,0.03),rgba(255,255,255,0.02));border-radius:14px;padding:1rem;display:flex;flex-direction:column;min-height:300px;position:relative;overflow:hidden}
.service-card .service-media{height:64px;display:flex;align-items:center;justify-content:center;margin-bottom:.4rem}
.service-card .mascot-container{width:78px;height:78px;pointer-events:none}
.service-card h3{margin:0.4rem 0 0.25rem}
.service-desc{font-size:.95rem;line-height:1.45}
.ask-btn{background:transparent;border:2px solid rgba(255,255,255,0.08);padding:.5rem .75rem;border-radius:10px;color:#fff;font-weight:700;cursor:pointer}
.ask-btn:hover{border-color:rgba(14,165,255,0.9);transform:translateY(-3px)}

/* Chat modal */
.chat-modal{position:fixed;right:24px;bottom:24px;width:360px;max-width:calc(100% - 32px);background:linear-gradient(180deg,#0b1221,#071021);color:#fff;border-radius:12px;box-shadow:0 20px 60px rgba(2,6,23,0.6);overflow:hidden;z-index:9999;border:1px solid rgba(255,255,255,0.04)}
.chat-header{display:flex;align-items:center;justify-content:space-between;padding:.8rem 1rem;border-bottom:1px solid rgba(255,255,255,0.03);font-weight:800}
.chat-header button{background:transparent;border:0;color:#fff;font-size:1.25rem;cursor:pointer}
.chat-messages{padding:1rem;max-height:260px;overflow:auto;display:flex;flex-direction:column;gap:.6rem}
.chat-messages .msg{background:rgba(255,255,255,0.04);padding:.6rem .75rem;border-radius:8px;max-width:85%;font-size:.95rem}
.chat-messages .msg.user{align-self:flex-end;background:linear-gradient(90deg,#0ea5ff,#06b6d4);color:#071021}
.chat-form{display:flex;border-top:1px solid rgba(255,255,255,0.03);padding:.6rem}
.chat-form input{flex:1;padding:.6rem .7rem;border-radius:8px;border:1px solid rgba(255,255,255,0.06);background:rgba(255,255,255,0.02);color:#fff;margin-right:.5rem}
.chat-form button{background:#06b6d4;border:0;color:#071021;padding:.55rem .85rem;border-radius:8px;cursor:pointer;font-weight:800}

/* Mascot animation helpers (simple follow & bob) */
.mascot{transition:transform .18s cubic-bezier(.2,.9,.2,1)}
.mascot.wave{animation:mascotBob 3.2s ease-in-out infinite}

@keyframes mascotBob{0%{transform:translateY(0)}50%{transform:translateY(-6px)}100%{transform:translateY(0)}}

@media(max-width:780px){
  .chat-modal{right:12px;left:12px;bottom:12px;height:auto}
  .services-grid{grid-template-columns:1fr}
}

/* Styles for the new detailed services gallery */
#servicos-detalhados .services-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;margin-top:1rem}
#servicos-detalhados .service-card{min-height:260px;padding:0;border-radius:12px;background:#fff;color:var(--dark);box-shadow:0 8px 24px rgba(2,6,23,0.06);overflow:hidden}
#servicos-detalhados .service-card h3{padding:1rem 1rem 0;margin:0}
#servicos-detalhados .service-card .service-desc{padding:0 1rem 1rem;color:#374151}
#servicos-detalhados .service-media img{display:block}


/* Quick ask input inside service card */
.quick-ask{margin-top:.75rem}
.quick-ask-input{border:1px solid rgba(255,255,255,0.06);background:transparent;color:#fff;border-radius:8px;padding:.55rem .6rem}
.open-chat-btn{background:#06b6d4;color:#071021;border-radius:8px;padding:.5rem .75rem;border:0;font-weight:800;cursor:pointer}
.open-chat-btn:hover{filter:brightness(.95)}


