/* ===== Diretiva TI — landing ===== */
:root{
  --bg:#0B0F14;          /* bgBase */
  --canvas:#0F141B;
  --surface:#131A22;
  --surface2:#18212B;
  --elevated:#1D2733;
  --brand:#019BEF;       /* brandPrimary */
  --brand-2:#27345A;     /* secondaryBrand */
  --orange:#FF7A1A;
  --text:#F3F6F8;
  --text-2:#A4B0BE;
  --text-3:#738091;
  --border:#24303D;
  --border-soft:rgba(255,255,255,.06);
  --green:#22C55E;
  --amber:#F59E0B;
  --maxw:1200px;
  --r:16px;
  --ease:cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
strong{color:var(--text);font-weight:600}
em{font-style:normal;color:var(--brand)}

.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---- Typography helpers ---- */
.kicker{
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--brand);font-weight:600;margin-bottom:14px;
}
.section__title{
  font-family:'Sora',sans-serif;font-weight:700;
  font-size:clamp(1.9rem,4.4vw,3.2rem);line-height:1.08;
  letter-spacing:-.02em;margin-bottom:22px;
}
.lead{font-size:clamp(1rem,1.5vw,1.18rem);color:var(--text-2);max-width:60ch}
.grad{
  background:linear-gradient(100deg,var(--brand),#5ec8ff);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-weight:600;font-size:.95rem;line-height:1;
  padding:13px 24px;border-radius:100px;cursor:pointer;
  border:1px solid transparent;transition:transform .25s var(--ease),background .25s,border-color .25s,box-shadow .25s;
  white-space:nowrap;
}
.btn--lg{padding:16px 30px;font-size:1.02rem}
.btn--primary{background:var(--brand);color:#03121d;box-shadow:0 8px 30px rgba(1,155,239,.28)}
.btn--primary:hover{transform:translateY(-2px);background:#1aa9f6;box-shadow:0 12px 38px rgba(1,155,239,.42)}
.btn--ghost{background:rgba(255,255,255,.04);color:var(--text);border-color:var(--border)}
.btn--ghost:hover{transform:translateY(-2px);border-color:var(--brand);background:rgba(1,155,239,.08)}

/* ===== NAV ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;gap:24px;
  padding:16px 24px;
  transition:background .3s,backdrop-filter .3s,border-color .3s;
  border-bottom:1px solid transparent;
}
.nav.is-stuck{
  background:rgba(11,15,20,.72);backdrop-filter:blur(18px);
  border-bottom-color:var(--border-soft);
}
.nav__brand{display:flex;align-items:center;gap:10px}
.nav__mark{width:22px;height:24px}
.nav__wordmark{font-family:'Sora',sans-serif;font-weight:700;letter-spacing:.04em;font-size:1.02rem}
.nav__ti{color:var(--brand);margin-left:5px}
.nav__links{display:flex;gap:28px;margin-left:auto}
.nav__links a{color:var(--text-2);font-size:.92rem;font-weight:500;transition:color .2s}
.nav__links a:hover{color:var(--text)}
.nav__cta{margin-left:8px;padding:10px 20px}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px;margin-left:auto}
.nav__burger span{width:24px;height:2px;background:var(--text);border-radius:2px;transition:.3s var(--ease)}
.nav__burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__burger.is-open span:nth-child(2){opacity:0}
.nav__burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== HERO ===== */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden}
.hero__bg{
  position:absolute;inset:0;background-size:cover;background-position:center 35%;
  transform:scale(1.08);will-change:transform;
}
.hero__veil{
  position:absolute;inset:0;
  background:
    radial-gradient(120% 90% at 20% 10%,rgba(1,155,239,.12),transparent 55%),
    linear-gradient(180deg,rgba(11,15,20,.55) 0%,rgba(11,15,20,.78) 45%,var(--bg) 100%),
    linear-gradient(90deg,rgba(11,15,20,.85) 0%,rgba(11,15,20,.35) 60%,rgba(11,15,20,.55) 100%);
}
.hero__content{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;width:100%;padding:0 24px}
.hero__eyebrow{
  font-family:'Sora',sans-serif;letter-spacing:.22em;text-transform:uppercase;
  font-size:.82rem;color:var(--text-2);margin-bottom:18px;font-weight:600;
}
.hero__title{
  font-family:'Sora',sans-serif;font-weight:800;
  font-size:clamp(2.8rem,8vw,6rem);line-height:.98;letter-spacing:-.03em;
  margin-bottom:26px;
}
.hero__sub{font-size:clamp(1.05rem,1.8vw,1.3rem);color:var(--text-2);max-width:52ch;margin-bottom:38px}
.hero__actions{display:flex;gap:14px;flex-wrap:wrap}
.hero__scroll{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:2;
  width:26px;height:42px;border:2px solid rgba(255,255,255,.4);border-radius:14px;
}
.hero__scroll span{
  position:absolute;top:8px;left:50%;width:4px;height:8px;margin-left:-2px;
  background:var(--text);border-radius:2px;animation:scrolldot 1.8s var(--ease) infinite;
}
@keyframes scrolldot{0%{opacity:0;transform:translateY(0)}40%{opacity:1}80%,100%{opacity:0;transform:translateY(14px)}}

/* ===== SECTIONS ===== */
.section{padding:clamp(70px,11vw,140px) 0;position:relative}
.sobre .lead{font-size:clamp(1.15rem,2.2vw,1.6rem);line-height:1.5;color:var(--text-2);max-width:34ch;}
.sobre .lead{max-width:none;max-width:62ch}

/* ---- Pillars ---- */
.pillars{background:var(--canvas);border-top:1px solid var(--border-soft);border-bottom:1px solid var(--border-soft)}
.pillar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:48px}
.pillar{
  background:linear-gradient(180deg,var(--surface),var(--canvas));
  border:1px solid var(--border);border-radius:var(--r);padding:30px 26px;
  transition:transform .35s var(--ease),border-color .35s,box-shadow .35s;
}
.pillar:hover{transform:translateY(-6px);border-color:var(--brand);box-shadow:0 18px 50px rgba(0,0,0,.45)}
.pillar h3{font-family:'Sora',sans-serif;font-size:1.2rem;margin:18px 0 10px}
.pillar p{color:var(--text-2);font-size:.95rem}
.pillar__icon{width:46px;height:46px;border-radius:12px;background:rgba(1,155,239,.12);position:relative}
.pillar__icon::before{content:"";position:absolute;inset:0;background:var(--brand);mask-size:24px;mask-position:center;mask-repeat:no-repeat;-webkit-mask-size:24px;-webkit-mask-position:center;-webkit-mask-repeat:no-repeat}
.pillar__icon[data-icon="hardware"]::before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M9 3v2H7a2 2 0 0 0-2 2v2H3v2h2v2H3v2h2v2a2 2 0 0 0 2 2h2v2h2v-2h2v2h2v-2h2a2 2 0 0 0 2-2v-2h2v-2h-2v-2h2V9h-2V7a2 2 0 0 0-2-2h-2V3h-2v2h-2V3H9Zm-2 4h10v10H7V7Zm3 3v4h4v-4h-4Z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M9 3v2H7a2 2 0 0 0-2 2v2H3v2h2v2H3v2h2v2a2 2 0 0 0 2 2h2v2h2v-2h2v2h2v-2h2a2 2 0 0 0 2-2v-2h2v-2h-2v-2h2V9h-2V7a2 2 0 0 0-2-2h-2V3h-2v2h-2V3H9Zm-2 4h10v10H7V7Zm3 3v4h4v-4h-4Z'/%3E%3C/svg%3E")}
.pillar__icon[data-icon="software"]::before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='m8 6-6 6 6 6 1.4-1.4L4.8 12l4.6-4.6L8 6Zm8 0-1.4 1.4 4.6 4.6-4.6 4.6L16 18l6-6-6-6Z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='m8 6-6 6 6 6 1.4-1.4L4.8 12l4.6-4.6L8 6Zm8 0-1.4 1.4 4.6 4.6-4.6 4.6L16 18l6-6-6-6Z'/%3E%3C/svg%3E")}
.pillar__icon[data-icon="ia"]::before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M12 2a4 4 0 0 0-4 4v1a4 4 0 0 0 0 7v1a4 4 0 1 0 8 0v-1a4 4 0 0 0 0-7V6a4 4 0 0 0-4-4Zm-1 4a1 1 0 1 1 2 0v12a1 1 0 1 1-2 0V6Z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M12 2a4 4 0 0 0-4 4v1a4 4 0 0 0 0 7v1a4 4 0 1 0 8 0v-1a4 4 0 0 0 0-7V6a4 4 0 0 0-4-4Zm-1 4a1 1 0 1 1 2 0v12a1 1 0 1 1-2 0V6Z'/%3E%3C/svg%3E")}
.pillar__icon[data-icon="gestao"]::before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M4 13h6v7H4v-7Zm5-9h6v16H9V4Zm5 5h6v11h-6V9Z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M4 13h6v7H4v-7Zm5-9h6v16H9V4Zm5 5h6v11h-6V9Z'/%3E%3C/svg%3E")}

/* ===== PRODUCT ===== */
.product__grid{display:grid;grid-template-columns:1fr 1.05fr;gap:60px;align-items:center}
.badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(34,197,94,.12);color:#7ee2a8;border:1px solid rgba(34,197,94,.3);
  padding:6px 14px;border-radius:100px;font-size:.78rem;font-weight:600;
  letter-spacing:.04em;margin-bottom:20px;
}
.badge--muted{background:rgba(255,255,255,.05);color:var(--text-3);border-color:var(--border)}
.badge__dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(34,197,94,.6);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(34,197,94,.5)}70%{box-shadow:0 0 0 8px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}
.feature-list{list-style:none;margin:28px 0 34px}
.feature-list li{position:relative;padding-left:30px;margin-bottom:13px;color:var(--text-2)}
.feature-list li::before{
  content:"";position:absolute;left:0;top:3px;width:18px;height:18px;border-radius:50%;
  background:rgba(1,155,239,.16);
}
.feature-list li::after{content:"";position:absolute;left:6px;top:8px;width:6px;height:3px;border-left:2px solid var(--brand);border-bottom:2px solid var(--brand);transform:rotate(-45deg)}

/* ---- Visual / mockups ---- */
.product__visual{position:relative;perspective:1600px}
.mock-window{
  background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;
  box-shadow:0 40px 90px rgba(0,0,0,.55);
  transform:rotateY(-9deg) rotateX(4deg);transform-style:preserve-3d;
  transition:transform .6s var(--ease);
}
.product__visual:hover .mock-window{transform:rotateY(-4deg) rotateX(2deg)}
.mock-window__bar{display:flex;align-items:center;gap:7px;padding:11px 14px;background:var(--canvas);border-bottom:1px solid var(--border)}
.mock-window__bar .dot{width:11px;height:11px;border-radius:50%;background:var(--border-strong,#334253)}
.mock-window__bar .dot:nth-child(1){background:#ff5f57}.mock-window__bar .dot:nth-child(2){background:#febc2e}.mock-window__bar .dot:nth-child(3){background:#28c840}
.mock-window__url{margin-left:14px;font-size:.74rem;color:var(--text-3);background:var(--bg);padding:4px 14px;border-radius:8px;border:1px solid var(--border)}
.mock-window__body{display:flex;height:340px}
.mock-side{width:64px;background:var(--canvas);border-right:1px solid var(--border);padding:18px 0;display:flex;flex-direction:column;align-items:center;gap:14px}
.mock-side__brand{width:26px;height:26px;border-radius:8px;background:var(--brand);margin-bottom:8px}
.mock-side__item{width:30px;height:30px;border-radius:9px;background:rgba(255,255,255,.05)}
.mock-side__item.is-active{background:rgba(1,155,239,.2);border:1px solid rgba(1,155,239,.4)}
.mock-map{position:relative;flex:1;background:
  radial-gradient(80% 80% at 70% 20%,#16202b,transparent),
  linear-gradient(160deg,#10161e,#0c1117);overflow:hidden}
.mock-map__roads path{fill:none;stroke:#2a3744;stroke-width:6;stroke-linecap:round}
.mock-map__roads{position:absolute;inset:0;width:100%;height:100%;opacity:.9}
.mock-map__route{position:absolute;inset:0;width:100%;height:100%}
.mock-map__route path{fill:none;stroke:var(--brand);stroke-width:3.5;stroke-linecap:round;stroke-dasharray:6 9;filter:drop-shadow(0 0 6px rgba(1,155,239,.6));animation:dash 22s linear infinite}
@keyframes dash{to{stroke-dashoffset:-300}}
.vmark{position:absolute;width:14px;height:14px;border-radius:50% 50% 50% 0;transform:rotate(-45deg) translate(-4px,-4px);box-shadow:0 4px 10px rgba(0,0,0,.5)}
.vmark::after{content:"";position:absolute;inset:3px;background:#fff;border-radius:50%}
.vmark--blue{background:var(--brand)}.vmark--green{background:var(--green)}.vmark--amber{background:var(--amber)}
.mock-card{position:absolute;left:16px;bottom:16px;width:190px;background:rgba(19,26,34,.92);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:12px;padding:14px}
.mock-card__row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.mock-card__title{width:80px;height:10px;border-radius:5px;background:rgba(255,255,255,.22)}
.mock-card__line{height:8px;border-radius:5px;background:rgba(255,255,255,.09);margin-bottom:8px}
.mock-card__line.short{width:60%}
.chip{font-size:.62rem;font-weight:700;padding:3px 9px;border-radius:100px;letter-spacing:.04em}
.chip--on{background:rgba(34,197,94,.16);color:#7ee2a8}

.mock-phone{
  position:absolute;right:-14px;bottom:-44px;width:180px;height:368px;
  background:#05080c;border:7px solid #1b242f;border-radius:34px;
  box-shadow:0 34px 70px rgba(0,0,0,.6);overflow:hidden;
  transform:rotate(4deg);transition:transform .6s var(--ease);
}
.product__visual:hover .mock-phone{transform:rotate(1deg) translateY(-6px)}
.mock-phone__notch{position:absolute;top:0;left:50%;transform:translateX(-50%);width:90px;height:20px;background:#05080c;border-radius:0 0 14px 14px;z-index:3}
.mock-phone__screen{position:relative;height:100%;background:var(--bg);display:flex;flex-direction:column}
.mock-phone__top{height:46px;background:var(--surface);border-bottom:1px solid var(--border)}
.mock-phone__map{position:relative;flex:1;background:linear-gradient(160deg,#10161e,#0c1117);overflow:hidden}
.mock-phone__map svg{position:absolute;inset:0;width:100%;height:100%}
.mock-phone__map path{fill:none;stroke:#2a3744;stroke-width:7;stroke-linecap:round}
.mock-phone__sheet{background:var(--surface);border-top:1px solid var(--border);border-radius:18px 18px 0 0;padding:14px 12px 18px;display:flex;gap:8px;justify-content:space-around;position:relative}
.mock-phone__grab{position:absolute;top:7px;left:50%;transform:translateX(-50%);width:36px;height:4px;border-radius:3px;background:var(--border-strong,#334253)}
.mock-stat{text-align:center;margin-top:8px}
.mock-stat b{display:block;font-family:'Sora',sans-serif;font-size:1.1rem;color:var(--text)}
.mock-stat small{color:var(--text-3);font-size:.66rem}

/* ===== STATS ===== */
.stats{background:var(--canvas);border-top:1px solid var(--border-soft);border-bottom:1px solid var(--border-soft)}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat b{font-family:'Sora',sans-serif;font-size:clamp(2.4rem,5vw,3.4rem);font-weight:800;color:var(--text);display:block;letter-spacing:-.02em;background:linear-gradient(180deg,var(--text),var(--brand));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat span{color:var(--text-3);font-size:.92rem;text-transform:uppercase;letter-spacing:.08em}

/* ===== CASES ===== */
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:48px}
.case{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:30px;transition:transform .35s var(--ease),border-color .35s}
.case:hover{transform:translateY(-6px);border-color:var(--brand)}
.case--live{background:linear-gradient(160deg,rgba(1,155,239,.1),var(--surface))}
.case h3{font-family:'Sora',sans-serif;font-size:1.3rem;margin-bottom:10px}
.case p{color:var(--text-2);font-size:.95rem}

/* ===== CONTACT ===== */
.contact{background:radial-gradient(80% 120% at 50% 0%,rgba(1,155,239,.1),transparent 60%),var(--bg);text-align:center}
.contact__inner{max-width:760px;margin:0 auto}
.contact .lead{margin:0 auto}
.contact__actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin:36px 0 16px}
.contact__hint{color:var(--text-3);font-size:.88rem}

/* ===== FOOTER ===== */
.footer{background:var(--canvas);border-top:1px solid var(--border-soft);padding:64px 0 30px}
.footer__inner{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;padding-bottom:40px;border-bottom:1px solid var(--border-soft)}
.footer__logo{height:34px;width:auto;opacity:.92;margin-bottom:12px}
.footer__brand p{color:var(--text-3);font-size:.9rem}
.footer__cols{display:flex;gap:64px;flex-wrap:wrap}
.footer__cols h4{font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);margin-bottom:14px}
.footer__cols a{display:block;color:var(--text-2);font-size:.92rem;margin-bottom:9px;transition:color .2s}
.footer__cols a:hover{color:var(--brand)}
.footer__bottom{display:flex;justify-content:space-between;padding-top:24px;color:var(--text-3);font-size:.82rem;flex-wrap:wrap;gap:8px}

/* ===== Reveal anim ===== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.is-in{opacity:1;transform:none}

/* ===== Responsive ===== */
@media (max-width:900px){
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:flex}
  .nav.menu-open{background:rgba(11,15,20,.96);backdrop-filter:blur(18px)}
  .nav.menu-open .nav__links{
    display:flex;position:fixed;inset:64px 0 auto 0;flex-direction:column;gap:0;
    background:var(--bg);border-bottom:1px solid var(--border);padding:8px 0;margin:0;
  }
  .nav.menu-open .nav__links a{padding:16px 24px;font-size:1.05rem;border-bottom:1px solid var(--border-soft)}
  .pillar-grid{grid-template-columns:repeat(2,1fr)}
  .product__grid{grid-template-columns:1fr;gap:40px}
  .product__visual{margin-top:10px}
  .mock-phone{right:0;width:150px;height:310px}
  .case-grid{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:repeat(2,1fr);gap:36px 16px}
}
@media (max-width:520px){
  .pillar-grid{grid-template-columns:1fr}
  .mock-phone{display:none}
  .mock-window{transform:none}
  .hero__actions .btn,.contact__actions .btn{flex:1 1 auto;justify-content:center}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}

/* ===================================================================
   Rastreamento — estilos específicos (mocks fiéis + planos)
   =================================================================== */
:root{--red:#F2545B;--yellow:#F59E0B}

/* ---- App mockups (telefones fiéis ao app) ---- */
.appshots{display:flex;gap:34px;justify-content:center;align-items:flex-end;flex-wrap:wrap;margin-top:54px;perspective:2000px}
.appshot{
  width:280px;flex:0 0 auto;background:#05080c;border:9px solid #161e27;border-radius:42px;
  box-shadow:0 40px 90px rgba(0,0,0,.6);overflow:hidden;position:relative;
  transition:transform .6s var(--ease);
}
.appshot--tilt-l{transform:rotateY(11deg) translateY(10px)}
.appshot--tilt-r{transform:rotateY(-11deg) translateY(10px)}
.appshots:hover .appshot{transform:rotateY(0) translateY(0)}
.appshot__notch{position:absolute;top:0;left:50%;transform:translateX(-50%);width:120px;height:24px;background:#05080c;border-radius:0 0 16px 16px;z-index:6}
.appshot__screen{height:580px;display:flex;flex-direction:column;background:var(--bg)}
.appshot__status{height:30px;display:flex;align-items:center;justify-content:space-between;padding:0 22px 0 24px;font-size:.66rem;color:var(--text-2);padding-top:6px}
.appshot__status b{font-weight:600;color:var(--text)}
.appshot__status .sb{display:inline-flex;gap:5px;align-items:center}
.appshot__status .sb i{width:14px;height:9px;border:1px solid var(--text-2);border-radius:2px;display:inline-block;position:relative}
.appshot__status .sb i::after{content:"";position:absolute;inset:1px;width:60%;background:var(--text-2);border-radius:1px}

/* nav inferior */
.appshot__nav{height:58px;background:var(--surface);border-top:1px solid var(--border);display:flex;justify-content:space-around;align-items:center}
.appnav{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:.62rem;color:var(--text-3)}
.appnav i{width:20px;height:20px;border-radius:5px;background:currentColor;opacity:.6;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center}
.appnav.is-on{color:var(--brand)}.appnav.is-on i{opacity:1}
.appnav.is-off{opacity:.4}

/* mapa */
.appmap{position:relative;flex:1;overflow:hidden;background:
  radial-gradient(70% 60% at 60% 25%,#1b2a23,transparent),
  radial-gradient(60% 50% at 20% 80%,#202a18,transparent),
  linear-gradient(160deg,#11181a,#0c1114)}
.appmap svg{position:absolute;inset:0;width:100%;height:100%}
.appmap .road{fill:none;stroke:#2c3a31;stroke-width:9;stroke-linecap:round}
.appmap .road.minor{stroke-width:5;stroke:#27332b}
.appmap__btns{position:absolute;right:12px;top:14px;display:flex;flex-direction:column;gap:8px}
.appmap__btns span{width:34px;height:34px;border-radius:9px;background:rgba(19,26,34,.92);border:1px solid var(--border);display:grid;place-items:center}
.appmap__btns span::before{content:"";width:15px;height:15px;background:var(--text-2);-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center}
.appmap__btns .loc::before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M12 8a4 4 0 1 0 0 8 4 4 0 0 0 0-8Zm0-6a1 1 0 0 1 1 1v1.06A8 8 0 0 1 19.94 11H21a1 1 0 1 1 0 2h-1.06A8 8 0 0 1 13 19.94V21a1 1 0 1 1-2 0v-1.06A8 8 0 0 1 4.06 13H3a1 1 0 1 1 0-2h1.06A8 8 0 0 1 11 4.06V3a1 1 0 0 1 1-1Zm0 4a6 6 0 1 0 0 12A6 6 0 0 0 12 6Z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M12 8a4 4 0 1 0 0 8 4 4 0 0 0 0-8Zm0-6a1 1 0 0 1 1 1v1.06A8 8 0 0 1 19.94 11H21a1 1 0 1 1 0 2h-1.06A8 8 0 0 1 13 19.94V21a1 1 0 1 1-2 0v-1.06A8 8 0 0 1 4.06 13H3a1 1 0 1 1 0-2h1.06A8 8 0 0 1 11 4.06V3a1 1 0 0 1 1-1Z'/%3E%3C/svg%3E")}
.appmap__btns .comp::before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M12 2a10 10 0 1 0 0 20 10 10 0 0 0 0-20Zm3.5 6.5-2 5-5 2 2-5 5-2Z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M12 2a10 10 0 1 0 0 20 10 10 0 0 0 0-20Zm3.5 6.5-2 5-5 2 2-5 5-2Z'/%3E%3C/svg%3E")}

/* marcadores teardrop verde/vermelho como no app */
.pin{position:absolute;width:26px;height:26px;transform:translate(-50%,-100%);filter:drop-shadow(0 6px 8px rgba(0,0,0,.5))}
.pin::before{content:"";position:absolute;inset:0;border-radius:50% 50% 50% 0;transform:rotate(-45deg);background:var(--green)}
.pin::after{content:"";position:absolute;left:50%;top:42%;width:9px;height:9px;background:#0b1410;border-radius:50%;transform:translate(-50%,-50%);z-index:2}
.pin--off::before{background:var(--red)}
.pin--sel{width:32px;height:32px;z-index:3}
.pin--sel::before{box-shadow:0 0 0 4px rgba(34,197,94,.25)}

/* bottom sheet do dispositivo */
.sheet{position:absolute;left:0;right:0;bottom:0;background:#16181d;border-radius:20px 20px 0 0;border-top:1px solid var(--border);padding:10px 14px 16px;box-shadow:0 -16px 40px rgba(0,0,0,.5)}
.sheet__grab{display:block;width:42px;height:5px;border-radius:3px;background:#3a4654;margin:2px auto 12px}
.dcard{background:#1f2228;border:1px solid var(--border);border-radius:14px;padding:14px}
.dcard+.dcard{margin-top:10px}
.dcard__head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}
.dcard__head b{font-family:'Sora',sans-serif;font-size:.98rem;display:block}
.dcard__head small{color:var(--text-3);font-size:.74rem}
.dcard__ic{width:34px;height:34px;border-radius:9px;background:rgba(1,155,239,.14);display:grid;place-items:center}
.dcard__ic::before{content:"";width:18px;height:18px;background:var(--brand);-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-image:var(--ic);mask-image:var(--ic)}
.drow{display:flex;align-items:center;justify-content:space-between;padding:7px 0;border-top:1px solid rgba(255,255,255,.05);font-size:.82rem}
.drow span{color:var(--text-3)}
.drow b{font-weight:600}
.drow .ok{color:var(--green)}
.dbtns{display:flex;gap:8px;margin-top:13px}
.db{flex:1;text-align:center;padding:10px;border-radius:10px;font-size:.78rem;font-weight:600;border:1px solid transparent}
.db--ghost{background:rgba(1,155,239,.12);color:var(--brand);border-color:rgba(1,155,239,.3)}
.db--danger{background:rgba(242,84,91,.14);color:#ff8a8f;border-color:rgba(242,84,91,.35)}
.dchip{font-size:.66rem;font-weight:700;padding:3px 9px;border-radius:100px}
.dchip.ok{background:rgba(34,197,94,.16);color:#7ee2a8}

/* lista "Meus dispositivos" */
.applist{flex:1;overflow:hidden;padding:18px 16px 8px}
.applist h4{font-family:'Sora',sans-serif;font-size:1.15rem;margin-bottom:16px}
.lvitem{display:flex;align-items:center;gap:12px;background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:13px;margin-bottom:11px}
.lvitem__ic{width:40px;height:40px;border-radius:10px;background:rgba(1,155,239,.13);display:grid;place-items:center;flex:0 0 auto}
.lvitem__ic::before{content:"";width:22px;height:22px;background:var(--brand);-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M5 11l1.5-4.5A2 2 0 0 1 8.4 5h7.2a2 2 0 0 1 1.9 1.5L19 11h.5a1.5 1.5 0 0 1 1.5 1.5V17a1 1 0 0 1-1 1h-1a1 1 0 0 1-1-1v-1H6v1a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1v-4.5A1.5 1.5 0 0 1 4.5 11H5Zm2.1 0h9.8l-1-3H8.1l-1 3ZM6.5 13.5a1 1 0 1 0 0 2 1 1 0 0 0 0-2Zm11 0a1 1 0 1 0 0 2 1 1 0 0 0 0-2Z'/%3E%3C/svg%3E") center/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M5 11l1.5-4.5A2 2 0 0 1 8.4 5h7.2a2 2 0 0 1 1.9 1.5L19 11h.5a1.5 1.5 0 0 1 1.5 1.5V17a1 1 0 0 1-1 1h-1a1 1 0 0 1-1-1v-1H6v1a1 1 0 0 1-1 1H4a1 1 0 0 1-1-1v-4.5A1.5 1.5 0 0 1 4.5 11H5Zm2.1 0h9.8l-1-3H8.1l-1 3ZM6.5 13.5a1 1 0 1 0 0 2 1 1 0 0 0 0-2Zm11 0a1 1 0 1 0 0 2 1 1 0 0 0 0-2Z'/%3E%3C/svg%3E") center/contain no-repeat}
.lvitem__main{flex:1;min-width:0}
.lvitem__main b{font-size:.9rem;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lvitem__main small{color:var(--text-3);font-size:.72rem;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lvbadge{font-size:.66rem;font-weight:700;padding:4px 10px;border-radius:100px;white-space:nowrap}
.lvbadge.on{background:rgba(34,197,94,.16);color:#7ee2a8}
.lvbadge.off{background:rgba(242,84,91,.16);color:#ff8a8f}
.lvbadge.unk{background:rgba(245,158,11,.16);color:#fbcd77}

/* card flutuante de veículo (callout) */
.callout{
  position:absolute;background:rgba(22,24,29,.96);backdrop-filter:blur(10px);
  border:1px solid var(--border);border-radius:14px;padding:14px 16px;width:230px;
  box-shadow:0 24px 60px rgba(0,0,0,.55);
}
.callout h5{font-family:'Sora',sans-serif;font-size:.82rem;color:var(--text-3);margin-bottom:10px;text-transform:uppercase;letter-spacing:.08em}
.callout .drow{font-size:.84rem}
.callout--veh{left:-82px;top:44%}
@media (max-width:1180px){.callout--veh{left:-44px;top:6%}}
@media (max-width:900px){.callout{display:none}}

/* ---- Planos ---- */
.plans-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:48px;max-width:900px;margin-left:auto;margin-right:auto}
.plan{
  background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:36px 32px;
  display:flex;flex-direction:column;transition:transform .35s var(--ease),border-color .35s,box-shadow .35s;
}
.plan:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(0,0,0,.45)}
.plan--featured{border-color:var(--brand);background:linear-gradient(180deg,rgba(1,155,239,.1),var(--surface));position:relative}
.plan--featured::after{content:"Mais popular";position:absolute;top:18px;right:18px;background:var(--brand);color:#03121d;font-size:.68rem;font-weight:700;padding:4px 12px;border-radius:100px;letter-spacing:.03em}
.plan__name{font-family:'Sora',sans-serif;font-size:1.35rem;font-weight:700;margin-bottom:6px}
.plan__desc{color:var(--text-2);font-size:.92rem;margin-bottom:24px;min-height:42px}
.plan__price{display:flex;align-items:baseline;gap:6px;margin-bottom:4px}
.plan__price .cur{font-size:1.1rem;color:var(--text-2);font-weight:600}
.plan__price .val{font-family:'Sora',sans-serif;font-size:3rem;font-weight:800;letter-spacing:-.02em;line-height:1}
.plan__price .per{color:var(--text-3);font-size:.9rem}
.plan__price--quote .val{font-size:2rem}
.plan__note{color:var(--text-3);font-size:.84rem;margin-bottom:26px}
.plan__feats{list-style:none;margin:0 0 30px}
.plan__feats li{position:relative;padding-left:28px;margin-bottom:12px;color:var(--text-2);font-size:.92rem}
.plan__feats li::before{content:"";position:absolute;left:0;top:2px;width:18px;height:18px;border-radius:50%;background:rgba(1,155,239,.16)}
.plan__feats li::after{content:"";position:absolute;left:6px;top:7px;width:6px;height:3px;border-left:2px solid var(--brand);border-bottom:2px solid var(--brand);transform:rotate(-45deg)}
.plan .btn{margin-top:auto;justify-content:center}

/* ---- Como funciona ---- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px;counter-reset:step}
.step{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:30px 26px;position:relative}
.step::before{counter-increment:step;content:"0" counter(step);font-family:'Sora',sans-serif;font-size:2.4rem;font-weight:800;color:rgba(1,155,239,.28);line-height:1;display:block;margin-bottom:14px}
.step h3{font-family:'Sora',sans-serif;font-size:1.12rem;margin-bottom:8px}
.step p{color:var(--text-2);font-size:.93rem}

@media (max-width:900px){
  .plans-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .appshots{gap:20px}
  .appshot{width:260px}
}

/* ---- Ícones dos recursos ---- */
.pillar__icon[data-icon="map"]::before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='m15 4-6 2-4.6-1.5A1 1 0 0 0 3 5.4v13a1 1 0 0 0 1.3 1L9 18l6 2 4.6-1.5A1 1 0 0 0 21 17.6v-13a1 1 0 0 0-1.3-1L15 4Zm0 2.1 4-1.3v11.8l-4 1.3V6.1ZM9 6.3l4 1.3v11.8l-4-1.3V6.3ZM5 5.4l2-.6v11.8l-2 .6V5.4Z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='m15 4-6 2-4.6-1.5A1 1 0 0 0 3 5.4v13a1 1 0 0 0 1.3 1L9 18l6 2 4.6-1.5A1 1 0 0 0 21 17.6v-13a1 1 0 0 0-1.3-1L15 4Zm0 2.1 4-1.3v11.8l-4 1.3V6.1ZM9 6.3l4 1.3v11.8l-4-1.3V6.3ZM5 5.4l2-.6v11.8l-2 .6V5.4Z'/%3E%3C/svg%3E")}
.pillar__icon[data-icon="lock"]::before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M12 2a5 5 0 0 0-5 5v3H6a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-8a2 2 0 0 0-2-2h-1V7a5 5 0 0 0-5-5Zm-3 8V7a3 3 0 1 1 6 0v3H9Zm3 4a1.5 1.5 0 0 1 .8 2.8V19a.8.8 0 0 1-1.6 0v-2.2A1.5 1.5 0 0 1 12 14Z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M12 2a5 5 0 0 0-5 5v3H6a2 2 0 0 0-2 2v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-8a2 2 0 0 0-2-2h-1V7a5 5 0 0 0-5-5Zm-3 8V7a3 3 0 1 1 6 0v3H9Zm3 4a1.5 1.5 0 0 1 .8 2.8V19a.8.8 0 0 1-1.6 0v-2.2A1.5 1.5 0 0 1 12 14Z'/%3E%3C/svg%3E")}
.pillar__icon[data-icon="speed"]::before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M12 4a9 9 0 0 0-7.8 13.5 1 1 0 0 0 .87.5h13.86a1 1 0 0 0 .87-.5A9 9 0 0 0 12 4Zm0 2a7 7 0 0 1 6.33 10H5.67A7 7 0 0 1 12 6Zm4 3-3.3 3.3a1.5 1.5 0 1 0 1 1l2.3-4.3Z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M12 4a9 9 0 0 0-7.8 13.5 1 1 0 0 0 .87.5h13.86a1 1 0 0 0 .87-.5A9 9 0 0 0 12 4Zm0 2a7 7 0 0 1 6.33 10H5.67A7 7 0 0 1 12 6Zm4 3-3.3 3.3a1.5 1.5 0 1 0 1 1l2.3-4.3Z'/%3E%3C/svg%3E")}
.pillar__icon[data-icon="pin"]::before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M12 2a7 7 0 0 0-7 7c0 5 7 13 7 13s7-8 7-13a7 7 0 0 0-7-7Zm0 9.5A2.5 2.5 0 1 1 12 6a2.5 2.5 0 0 1 0 5.5Z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M12 2a7 7 0 0 0-7 7c0 5 7 13 7 13s7-8 7-13a7 7 0 0 0-7-7Zm0 9.5A2.5 2.5 0 1 1 12 6a2.5 2.5 0 0 1 0 5.5Z'/%3E%3C/svg%3E")}
.pillar__icon[data-icon="devices"]::before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M3 5h13a1 1 0 0 1 1 1v2h-2V7H4v8h6v2H3a1 1 0 0 1-1-1V6a1 1 0 0 1 1-1Zm10 5h7a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1h-7a1 1 0 0 1-1-1v-8a1 1 0 0 1 1-1Zm1 2v6h5v-6h-5Z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M3 5h13a1 1 0 0 1 1 1v2h-2V7H4v8h6v2H3a1 1 0 0 1-1-1V6a1 1 0 0 1 1-1Zm10 5h7a1 1 0 0 1 1 1v8a1 1 0 0 1-1 1h-7a1 1 0 0 1-1-1v-8a1 1 0 0 1 1-1Zm1 2v6h5v-6h-5Z'/%3E%3C/svg%3E")}
.pillar__icon[data-icon="phone"]::before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M7 2h10a2 2 0 0 1 2 2v16a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2Zm0 3v13h10V5H7Zm5 14.5a1 1 0 1 0 0 2 1 1 0 0 0 0-2Z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M7 2h10a2 2 0 0 1 2 2v16a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2Zm0 3v13h10V5H7Zm5 14.5a1 1 0 1 0 0 2 1 1 0 0 0 0-2Z'/%3E%3C/svg%3E")}

/* ===================================================================
   Multiplataforma — computador, celular e TV
   =================================================================== */
.map-pill{position:absolute;top:14px;left:14px;background:rgba(19,26,34,.92);border:1px solid var(--border);border-radius:100px;padding:6px 13px;font-size:.7rem;color:var(--text-2);font-weight:600;display:flex;align-items:center;gap:7px}
.map-pill::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green)}
.map-pill b{color:var(--text);font-weight:700}

/* mapa genérico reutilizável (web) */
.gmap{position:relative;overflow:hidden;background:
  radial-gradient(70% 60% at 60% 25%,#1b2a23,transparent),
  radial-gradient(60% 50% at 18% 82%,#202a18,transparent),
  linear-gradient(160deg,#11181a,#0c1114)}
.gmap svg{position:absolute;inset:0;width:100%;height:100%}
.gmap .road{fill:none;stroke:#2c3a31;stroke-width:2.6;stroke-linecap:round}
.gmap .road.minor{stroke:#27332b;stroke-width:1.5}
.gmap .pin{transform:translate(-50%,-100%) scale(.62)}
.gmap__card{position:absolute;left:14px;bottom:14px;background:rgba(19,26,34,.94);border:1px solid var(--border);border-radius:11px;padding:11px 13px;min-width:140px}
.gmap__card .t{font-family:'Sora',sans-serif;font-size:.8rem;display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:7px}
.gmap__card .t .dchip{font-size:.6rem}
.gmap__card .l{height:7px;border-radius:4px;background:rgba(255,255,255,.1);margin-top:6px}
.gmap__card .l.s{width:60%}

/* dashboard web (sidebar + topbar + mapa) */
.webui{display:flex;height:100%;background:var(--bg)}
.webui__side{width:46px;background:var(--canvas);border-right:1px solid var(--border);display:flex;flex-direction:column;align-items:center;gap:11px;padding:13px 0}
.webui__brand{width:24px;height:24px;border-radius:7px;background:var(--brand)}
.webui__nav{width:26px;height:26px;border-radius:8px;background:rgba(255,255,255,.05)}
.webui__nav.on{background:rgba(1,155,239,.2);border:1px solid rgba(1,155,239,.4)}
.webui__main{flex:1;display:flex;flex-direction:column;min-width:0}
.webui__top{height:34px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 14px;gap:8px}
.webui__top::before{content:"";width:30%;height:9px;border-radius:5px;background:rgba(255,255,255,.13)}
.webui__top::after{content:"";margin-left:auto;width:24px;height:24px;border-radius:50%;background:rgba(1,155,239,.25)}
.webui .gmap{flex:1}

/* devices row */
.devices{display:flex;justify-content:center;align-items:flex-end;gap:42px;flex-wrap:wrap;margin-top:56px}
.device-fig{margin:0;text-align:center}
.device-fig figcaption{margin-top:20px;color:var(--text-3);font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;font-weight:600}

/* laptop */
.laptop{width:470px;max-width:84vw}
.laptop__lid{background:#161e27;border-radius:16px 16px 0 0;padding:11px 11px 0;box-shadow:inset 0 0 0 1px rgba(255,255,255,.03)}
.laptop__screen{aspect-ratio:16/10;border-radius:6px;overflow:hidden;border:1px solid #0a0e12;background:var(--bg)}
.laptop__base{height:15px;width:118%;margin-left:-9%;background:linear-gradient(#222b34,#0e131a);border-radius:0 0 12px 12px;position:relative;box-shadow:0 22px 36px rgba(0,0,0,.55)}
.laptop__base::after{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:92px;height:6px;background:#0a0e12;border-radius:0 0 7px 7px}

/* tv */
.tv{width:510px;max-width:86vw}
.tv__screen{aspect-ratio:16/9;background:#05080c;border:9px solid #0c1116;border-radius:14px;overflow:hidden;box-shadow:0 32px 64px rgba(0,0,0,.55)}
.tv__neck{width:12px;height:22px;background:linear-gradient(#1b242e,#11161c);margin:2px auto 0}
.tv__stand{width:160px;height:9px;background:linear-gradient(#1b242e,#11161c);border-radius:0 0 10px 10px;margin:0 auto}

/* celular compacto (reaproveita o frame do app) */
.appshot--sm{width:208px;border-width:8px;border-radius:34px}
.appshot--sm .appshot__screen{height:430px}
.appshot--sm .appshot__notch{width:96px;height:20px}
.appshot--sm .appshot__nav{height:48px}
.appshot--sm .appnav{font-size:.56rem}
.appshot--sm .appnav i{width:17px;height:17px}

/* center phone nas telas do app */
.appshot--center{transform:translateY(-16px);z-index:2}
.appshots:hover .appshot--center{transform:translateY(-16px)}

@media (max-width:560px){
  .laptop{max-width:94vw}
  .tv{max-width:94vw}
}

/* botão Entrar visível também no mobile (login é prioritário) */
@media (max-width:900px){
  .nav__login{display:inline-flex;margin-left:auto;padding:9px 18px}
  .nav__login + .nav__burger{margin-left:6px}
}

/* marca compacta em telas estreitas para caber Entrar + menu */
@media (max-width:600px){
  .nav{gap:12px}
  .nav__wordmark{font-size:.82rem;letter-spacing:.02em}
  .nav__ti{margin-left:4px}
}
@media (max-width:430px){
  .nav__wordmark .nav__ti{display:none}
  .nav__wordmark{font-size:.9rem}
}

/* ===== Hero em vídeo ===== */
.hero__video{display:block;width:100%;height:100%;object-fit:cover}

/* ===== Foto de fundo na 2ª seção (Recursos) ===== */
.section--photo{
  background-color:var(--bg);
  background-image:
    linear-gradient(180deg,rgba(11,15,20,.80),rgba(11,15,20,.62) 45%,rgba(11,15,20,.88)),
    url('assets/hero.png');
  background-size:cover;
  background-position:center 30%;
  border-top:1px solid var(--border-soft);
  border-bottom:1px solid var(--border-soft);
}
