/* ================================================================
   MEU PMOC — Base CSS compartilhado
   Referenciado por: site-meu-pmoc.html, lp-index.html
   Não editar diretamente nos HTMLs — editar aqui.
   ================================================================ */

:root {
  --primary:#2b45fb; --primary-dark:#1e35e8; --secondary:#018cfb; --accent:#00b0e4;
  --green:#10b981; --orange:#f97316; --red:#ef4444;
  --bg:#f0f4ff; --glass:rgba(255,255,255,0.78); --glass-border:rgba(43,69,251,0.1);
  --text:#0f1540; --muted:rgba(15,21,64,0.52); --muted2:rgba(15,21,64,0.32);
  --shadow:0 2px 20px rgba(43,69,251,0.08); --shadow-md:0 8px 40px rgba(43,69,251,0.13);
  --fd:'Montserrat',sans-serif; --fb:'Sora',sans-serif; --fm:'JetBrains Mono',monospace;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden;scroll-padding-top:88px}
body{background:var(--bg);color:var(--text);font-family:var(--fb);font-size:16px;line-height:1.6;overflow-x:hidden;padding-bottom:env(safe-area-inset-bottom)}

/* Reset responsivo universal */
img,svg,video,iframe{max-width:100%}
img,video{height:auto}
iframe{display:block}
/* Elimina delay de 300ms em tap no mobile */
a,button{touch-action:manipulation}

/* Tap targets mínimos (44px Apple / 48px Google) */
.nav-burger,.btn-primary,.btn-ghost,.nav-cta,.mobile-menu-login,.mobile-menu-link,.pricing-btn{min-height:44px}

/* Âncoras não ficam atrás da nav fixa */
section[id]{scroll-margin-top:88px}


/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:200;padding:14px 20px;padding-left:max(20px,env(safe-area-inset-left));padding-right:max(20px,env(safe-area-inset-right));display:flex;align-items:center;justify-content:space-between;background:rgba(240,244,255,0);backdrop-filter:blur(0px);border-bottom:1px solid transparent;box-shadow:none;transition:background .3s ease,backdrop-filter .3s ease,border-color .3s ease,box-shadow .3s ease}
nav.nav-scrolled{background:rgba(240,244,255,.92);backdrop-filter:blur(24px);border-bottom-color:var(--glass-border);box-shadow:0 1px 20px rgba(43,69,251,.06)}
.nav-logo{display:flex;align-items:flex-end;gap:8px;text-decoration:none}
.nav-logo-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center}
.nav-logo-icon img{width:28px;height:28px;object-fit:contain}
.nav-logo-img{height:22px;object-fit:contain}
.nav-links{display:none;align-items:center;gap:28px;list-style:none}
.nav-links a{color:var(--muted);text-decoration:none;font-size:13px;font-weight:500;transition:color .2s}
.nav-links a:hover{color:var(--primary)}
.nav-right{display:none;align-items:center;gap:12px}
.nav-login{color:var(--muted);text-decoration:none;font-size:13px;font-weight:500;transition:color .2s}
.nav-login:hover{color:var(--primary)}
.nav-cta{background:linear-gradient(135deg,#00c896,#00a878);color:#fff;padding:10px 22px;border-radius:9px;font-weight:700;font-size:13px;text-decoration:none;transition:all .2s;box-shadow:0 4px 14px rgba(0,168,120,0.35)}
.nav-cta:hover{background:linear-gradient(135deg,#00b386,#009668);transform:translateY(-1px);box-shadow:0 8px 24px rgba(0,168,120,0.45)}

/* HAMBURGER */
.nav-burger{display:flex;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:6px;border-radius:8px;transition:background .2s}
.nav-burger:hover{background:rgba(43,69,251,.08)}
.nav-burger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all .3s}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* MOBILE MENU */
.mobile-menu{position:fixed;top:54px;right:16px;left:auto;width:min(280px,calc(100vw - 32px));z-index:199;background:rgba(248,250,255,.98);backdrop-filter:blur(24px);border:1px solid var(--glass-border);border-radius:16px;box-shadow:0 8px 40px rgba(43,69,251,.15);transform:translateY(-8px) scale(.97);transform-origin:top right;opacity:0;transition:transform .25s cubic-bezier(.4,0,.2,1),opacity .2s;pointer-events:none}
.mobile-menu.open{transform:translateY(0) scale(1);opacity:1;pointer-events:all}
.mobile-menu-inner{padding:16px;display:flex;flex-direction:column;gap:4px}
.mobile-menu-links{display:flex;flex-direction:column;gap:2px}
.mobile-menu-link{display:block;padding:11px 14px;color:var(--text);text-decoration:none;font-size:14px;font-weight:600;border-radius:10px;transition:all .2s}
.mobile-menu-link:hover{background:rgba(43,69,251,.07);color:var(--primary)}
.mobile-menu-actions{display:flex;flex-direction:column;gap:8px;padding-top:12px;margin-top:8px;border-top:1px solid var(--glass-border)}
.mobile-menu-login{display:block;text-align:center;padding:10px;color:var(--muted);text-decoration:none;font-size:13px;font-weight:500;border-radius:10px;border:1.5px solid var(--glass-border);transition:all .2s}
.mobile-menu-login:hover{border-color:var(--primary);color:var(--primary)}

/* SHARED */
section{position:relative;z-index:1}
.container{max-width:1100px;margin:0 auto;padding:0 max(20px,env(safe-area-inset-left))}
.section-label{font-family:var(--fm);font-size:11px;color:var(--primary);letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.section-label::before{content:'';display:block;width:20px;height:1px;background:var(--primary)}
.section-label.center{justify-content:center}.section-label.center::before{display:none}
.section-title{font-family:var(--fd);font-size:clamp(28px,4vw,46px);font-weight:900;letter-spacing:-.03em;line-height:1.1;margin-bottom:16px;color:var(--text)}
.section-sub{color:var(--muted);font-size:16px;line-height:1.7;max-width:560px}
.section-sub.center{margin:0 auto;text-align:center}
.btn-primary{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#00c896,#00a878);color:#fff;padding:16px 32px;border-radius:10px;font-weight:700;font-size:15px;text-decoration:none;border:none;cursor:pointer;transition:all .25s;font-family:var(--fb);box-shadow:0 6px 28px rgba(0,168,120,0.35)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(0,168,120,0.45)}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;background:var(--glass);color:var(--primary);padding:16px 32px;border-radius:10px;font-weight:600;font-size:15px;text-decoration:none;border:1.5px solid rgba(43,69,251,0.2);cursor:pointer;transition:all .25s;font-family:var(--fb);backdrop-filter:blur(10px)}
.btn-ghost:hover{background:rgba(43,69,251,0.06);border-color:var(--primary);transform:translateY(-2px)}
.reveal{opacity:0;transform:translateY(16px);transition:opacity .3s ease,transform .3s ease}
.reveal.visible{opacity:1;transform:none}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}
@keyframes floatBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* HERO */
.hero{min-height:100svh;display:flex;align-items:center;padding:120px 20px 56px;position:relative;overflow:hidden}
.hero-glow{position:absolute;top:-120px;left:50%;transform:translateX(-50%);width:1000px;height:800px;background:radial-gradient(ellipse,rgba(43,69,251,0.1) 0%,rgba(1,140,251,0.06) 40%,transparent 70%);pointer-events:none}
.hero-inner{max-width:1100px;width:100%;margin:0 auto;display:grid;grid-template-columns:1fr;align-items:center;gap:40px}
.hero-badge{display:inline-flex;align-items:center;gap:12px;margin-bottom:28px;animation:fadeUp .35s ease both;position:relative}
.hero-badge-inner{display:inline-flex;align-items:center;gap:10px;padding:10px 22px;border-radius:100px;background:linear-gradient(135deg,var(--primary),var(--secondary),var(--accent));box-shadow:0 6px 32px rgba(43,69,251,.35),0 0 0 1px rgba(43,69,251,.2);position:relative;overflow:hidden}
.hero-badge-inner::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.22) 50%,transparent 100%);transform:translateX(-100%);animation:badgeShimmer 2.8s ease-in-out infinite}
@keyframes badgeShimmer{0%{transform:translateX(-100%)}60%,100%{transform:translateX(100%)}}
.hero-badge-dot{width:8px;height:8px;background:#fff;border-radius:50%;flex-shrink:0;box-shadow:0 0 0 3px rgba(255,255,255,.3);animation:pulse 2s infinite}
.hero-badge-text{font-family:var(--fd);font-size:13px;font-weight:800;color:#fff;letter-spacing:.06em;text-transform:uppercase}
.hero-badge-dot{width:6px;height:6px;background:var(--primary);border-radius:50%;animation:pulse 2s infinite}
.hero h1{font-family:var(--fd);font-size:clamp(26px,6vw,52px);font-weight:900;line-height:1.05;letter-spacing:-.03em;margin-bottom:16px;color:var(--text);animation:fadeUp .35s .05s ease both}
.hero h1 em{font-style:normal;color:var(--primary)}
.hero h1 .line2{color:var(--secondary);display:block}
.hero-desc{font-size:14px;color:var(--muted);line-height:1.65;margin-bottom:24px;animation:fadeUp .35s .1s ease both}
.hero-actions{display:flex;flex-direction:column;gap:14px;animation:fadeUp .35s .15s ease both}
.hero-actions .btn-primary,.hero-actions .btn-ghost{width:100%;justify-content:center;white-space:nowrap}
.hero-trust{display:flex;align-items:flex-start;flex-direction:column;gap:10px;margin-top:28px;animation:fadeUp .35s .2s ease both}
.trust-dots{display:flex}
.trust-dot{width:28px;height:28px;border-radius:50%;border:2px solid var(--bg);margin-left:-8px;font-size:10px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(43,69,251,0.15)}
.trust-dot:nth-child(1){background:#dbeafe}.trust-dot:nth-child(2){background:#e0e7ff}.trust-dot:nth-child(3){background:#fce7f3}.trust-dot:nth-child(4){background:#d1fae5}
.hero-trust-text{font-size:12px;color:var(--muted2);font-family:var(--fm)}

/* PHONE MOCKUP */
.hero-visual{display:flex;justify-content:center;align-items:center;animation:fadeUp .35s .07s ease both;position:relative;order:-1}
.phone-wrap{position:relative;width:min(200px,calc(100vw - 48px));margin:0 auto 0 auto;padding:16px 8px}
.phone-frame{width:100%;aspect-ratio:9/18;background:linear-gradient(160deg,rgba(255,255,255,.95) 0%,rgba(240,244,255,.9) 100%);border:1px solid rgba(43,69,251,.15);border-radius:32px;padding:10px;position:relative;box-shadow:0 0 0 1px rgba(43,69,251,.06),0 24px 60px rgba(43,69,251,.16),inset 0 1px 0 rgba(255,255,255,.9)}
.phone-screen{background:#f8faff;border-radius:28px;height:100%;overflow:hidden;position:relative;display:flex;flex-direction:column}
.phone-notch{width:80px;height:22px;background:#fff;border-radius:0 0 14px 14px;position:absolute;top:0;left:50%;transform:translateX(-50%);z-index:10}
.phone-content{padding:34px 14px 12px;flex:1;display:flex;flex-direction:column;gap:10px;overflow:hidden}
.phone-topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}
.phone-logo{display:flex;align-items:center;gap:5px}
.phone-logo img.ico{width:16px;height:16px;object-fit:contain}
.phone-logo img.txt{height:13px;object-fit:contain}
.phone-live{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.25);border-radius:100px;padding:2px 8px;font-family:var(--fm);font-size:7px;color:var(--green);display:flex;align-items:center;gap:4px}
.phone-live::before{content:'';width:5px;height:5px;background:var(--green);border-radius:50%;animation:pulse 2s infinite}
.phone-stats{display:flex;gap:6px}
.phone-stat{flex:1;background:rgba(255,255,255,.9);border:1px solid rgba(43,69,251,.09);border-radius:10px;padding:7px 6px;text-align:center}
.phone-stat-num{font-family:var(--fd);font-size:13px;font-weight:900;line-height:1;margin-bottom:3px}
.phone-stat-num.blue{color:var(--primary)}.phone-stat-num.teal{color:var(--secondary)}.phone-stat-num.green{color:var(--green)}
.phone-stat-label{font-size:6px;color:var(--muted);font-family:var(--fm);text-transform:uppercase}
.phone-os-card{background:rgba(255,255,255,.95);border:1px solid rgba(43,69,251,.1);border-radius:12px;padding:10px 12px;box-shadow:0 2px 10px rgba(43,69,251,.06)}
.phone-os-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.phone-os-num{font-family:var(--fm);font-size:7.5px;color:var(--muted)}
.phone-os-status{border-radius:100px;padding:2px 7px;font-size:7px;font-weight:600}
.phone-os-status.green{background:rgba(16,185,129,.1);color:var(--green)}
.phone-os-status.orange{background:rgba(249,115,22,.1);color:var(--orange)}
.phone-os-client{font-size:10.5px;font-weight:700;color:var(--text);margin-bottom:2px}
.phone-os-sub{font-size:7.5px;color:var(--muted)}
.phone-os-divider{height:1px;background:rgba(43,69,251,.07);margin:7px 0}
.phone-os-row{display:flex;justify-content:space-between}
.phone-os-info strong{display:block;font-size:8.5px;color:var(--text);margin-bottom:1px}
.phone-os-info span{font-size:7px;color:var(--muted)}
.phone-pmoc-row{background:rgba(43,69,251,.04);border:1px solid rgba(43,69,251,.1);border-radius:10px;padding:9px 10px;display:flex;align-items:center;gap:8px}
.phone-pmoc-icon{width:26px;height:26px;background:rgba(43,69,251,.1);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:11px;flex-shrink:0}
.phone-pmoc-name{font-size:9px;font-weight:700;color:var(--text)}
.phone-pmoc-sub{font-size:7px;color:var(--muted)}
.phone-pmoc-badge{margin-left:auto;background:rgba(1,140,251,.1);color:var(--secondary);border-radius:100px;padding:2px 6px;font-size:6.5px;font-family:var(--fm);white-space:nowrap}
.phone-nav{margin-top:auto;display:flex;justify-content:space-around;border-top:1px solid rgba(43,69,251,.08);padding-top:7px;padding-bottom:3px}
.phone-nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:6px;color:var(--muted);font-family:var(--fm)}
.phone-nav-item.active{color:var(--primary)}
.phone-nav-item i{font-size:12px}
.float-badge{display:block;position:absolute;background:rgba(255,255,255,.94);backdrop-filter:blur(14px);border:1px solid rgba(43,69,251,.12);border-radius:10px;padding:8px 12px;white-space:nowrap;box-shadow:0 4px 20px rgba(43,69,251,.1);animation:floatBob 3s ease-in-out infinite}
.float-badge-icon{font-size:13px;margin-bottom:1px}.float-badge-text{font-family:var(--fm);font-size:8px;color:var(--muted)}.float-badge-val{font-weight:700;font-size:11px;color:var(--text)}

/* PROOF BAR */
.proof-bar{border-top:1px solid var(--glass-border);border-bottom:1px solid var(--glass-border);background:rgba(255,255,255,.55);overflow:hidden}
.proof-bar .lqd-throwable-element-rot{opacity:1}
.proof-bar-inner{display:grid;grid-template-columns:1fr;gap:12px;max-width:360px;margin:0 auto;padding:0 24px}
.proof-item{text-align:center;background:var(--glass);border:1px solid var(--glass-border);border-radius:14px;padding:16px 12px}
.proof-item.proof-pair{display:contents}
.proof-pair-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.proof-num{font-family:var(--fd);font-size:28px;font-weight:900;letter-spacing:-.03em;color:var(--primary);line-height:1;display:block}
.proof-label{font-size:11px;color:var(--muted);margin-top:4px;font-family:var(--fm)}
.proof-divider{display:none}

/* PAIN */
.pain{padding:48px 0;background:#ffffff}
.pain-inner{display:grid;grid-template-columns:1fr;gap:32px;align-items:start}
.pain-label-bad{font-family:var(--fm);font-size:11px;color:var(--red);letter-spacing:.12em;text-transform:uppercase;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.pain-label-bad::before{content:'';display:block;width:20px;height:1px;background:var(--red)}
.pain-cards{display:flex;flex-direction:column;gap:8px;margin-top:12px}
.pain-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:14px;padding:12px 16px;display:flex;align-items:flex-start;gap:12px;transition:all .3s;backdrop-filter:blur(10px);box-shadow:var(--shadow)}
.pain-card:hover{border-color:rgba(239,68,68,.15);transform:translateX(4px)}
.pain-card-icon{width:36px;height:36px;border-radius:10px;background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.15);display:flex;align-items:center;justify-content:center;color:rgba(239,68,68,.7);font-size:14px;flex-shrink:0}
.pain-card-text{font-size:14px;color:var(--muted);line-height:1.6}
.pain-card-text strong{color:var(--text);font-weight:600;display:block;margin-bottom:2px}
.chaos-wrap{display:flex;flex-direction:column;gap:18px;padding-top:20px}

/* Nota base */
.chaos-note{
  position:relative;
  background:rgba(255,255,255,.96);
  border:1px solid rgba(15,21,64,.09);
  border-radius:4px;
  padding:16px 18px 14px;
  font-size:13px;
  color:var(--muted);
  box-shadow:0 3px 14px rgba(15,21,64,.08),0 1px 3px rgba(15,21,64,.05);
  transform:rotate(var(--r,0deg));
  transform-origin:var(--origin,50% 0%);
  transition:transform .35s cubic-bezier(.25,.46,.45,.94),box-shadow .3s;
}

/* Fita adesiva */
.chaos-note::before{
  content:'';
  position:absolute;
  top:-10px;
  left:var(--tape-x,50%);
  transform:translateX(-50%) rotate(var(--tape-r,0deg));
  width:48px;height:20px;
  background:rgba(255,220,80,.55);
  border-radius:2px;
  box-shadow:inset 0 0 0 0.5px rgba(200,160,0,.25);
  backdrop-filter:blur(1px);
  z-index:2;
}

/* Hover — endireita */
.chaos-note:hover{
  transform:rotate(0deg) translateY(-2px);
  box-shadow:0 8px 32px rgba(15,21,64,.14),0 2px 6px rgba(15,21,64,.07);
}

/* Balanço nos que estão "quase caindo" */
@keyframes sway{
  0%,100%{transform:rotate(var(--r,0deg))}
  40%{transform:rotate(calc(var(--r,0deg) + 1.2deg)) translateY(1px)}
  70%{transform:rotate(calc(var(--r,0deg) - 0.8deg))}
}
.chaos-note.sway{
  animation:sway 4s ease-in-out infinite;
  animation-delay:var(--delay,0s);
}
.chaos-note.sway:hover{animation:none;transform:rotate(0deg) translateY(-2px)}

.chaos-note strong{color:var(--text);font-weight:700;display:flex;align-items:center;gap:6px;font-size:11px;font-family:var(--fm);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
.chaos-note.chaos-alert{background:rgba(239,68,68,.04);border-color:rgba(239,68,68,.22)}

/* HOW */
.how{padding:60px 0;background:#eef2ff}
.how-grid{display:grid;grid-template-columns:1fr;gap:40px;align-items:start;margin-top:0}
.steps-list{display:flex;flex-direction:column;gap:0}
.step{display:flex;gap:18px;padding:10px 0;border-bottom:1px solid var(--glass-border);transition:all .25s}
.step:last-child{border-bottom:none}
.step:hover .step-num{background:var(--primary);color:#fff;border-color:var(--primary)}
.step-num{width:38px;height:38px;background:rgba(43,69,251,.07);border:1.5px solid rgba(43,69,251,.18);border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:13px;font-weight:900;color:var(--primary);flex-shrink:0;transition:all .25s}
.step-content h3{font-family:var(--fd);font-size:15px;font-weight:800;margin-bottom:4px;letter-spacing:-.02em;color:var(--text)}
.step-content p{font-size:14px;color:var(--muted);line-height:1.65}
.how-visual{display:flex;flex-direction:column;gap:8px;align-self:start}
.how-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:14px;padding:14px 18px;position:relative;overflow:hidden;transition:all .3s;box-shadow:var(--shadow);backdrop-filter:blur(10px)}
.how-card:hover{border-color:rgba(43,69,251,.22);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.how-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--primary),transparent);opacity:0;transition:opacity .3s}
.how-card:hover::before{opacity:1}
.how-card-header{display:flex;align-items:center;gap:10px;margin-bottom:7px}
.how-card-icon{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:14px}
.how-card-title{font-weight:700;font-size:14px;color:var(--text)}.how-card-sub{font-size:12px;color:var(--muted)}
.how-card-list{display:flex;flex-direction:column;gap:3px}
.how-card-item{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--muted)}
.how-card-item::before{content:'';width:4px;height:4px;background:var(--primary);border-radius:50%;flex-shrink:0}

/* FEATURES */
.features{padding:48px 0;background:#ffffff}
.features-header{text-align:center;margin-bottom:16px}
.features-grid{display:grid;grid-template-columns:1fr;gap:16px}
.feat-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:20px;padding:32px;position:relative;overflow:hidden;transition:all .3s;cursor:default;box-shadow:var(--shadow);backdrop-filter:blur(10px)}
.feat-card:hover{transform:translateY(-4px);border-color:rgba(43,69,251,.2);box-shadow:var(--shadow-md)}
.feat-glow{position:absolute;top:-60px;right:-60px;width:160px;height:160px;border-radius:50%;opacity:0;transition:opacity .4s;filter:blur(40px);background:var(--primary)}
.feat-card:hover .feat-glow{opacity:.35}
.feat-card.c2 .feat-glow{background:var(--secondary)}.feat-card.c3 .feat-glow{background:var(--green)}.feat-card.c4 .feat-glow{background:var(--accent)}.feat-card.c5 .feat-glow{background:var(--orange)}
.feat-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:20px;background:rgba(43,69,251,.08);border:1px solid rgba(43,69,251,.15);color:var(--primary)}
.feat-card.c2 .feat-icon{background:rgba(1,140,251,.08);border-color:rgba(1,140,251,.18);color:var(--secondary)}
.feat-card.c3 .feat-icon{background:rgba(16,185,129,.08);border-color:rgba(16,185,129,.18);color:var(--green)}
.feat-card.c4 .feat-icon{background:rgba(0,176,228,.08);border-color:rgba(0,176,228,.18);color:var(--accent)}
.feat-card.c5 .feat-icon{background:rgba(249,115,22,.08);border-color:rgba(249,115,22,.18);color:var(--orange)}
.feat-title{font-family:var(--fd);font-size:16px;font-weight:800;margin-bottom:10px;letter-spacing:-.02em;color:var(--text)}
.feat-desc{font-size:13px;color:var(--muted);line-height:1.7}
.feat-tag{display:inline-block;margin-top:16px;font-family:var(--fm);font-size:10px;padding:4px 10px;border-radius:100px;background:rgba(43,69,251,.07);color:var(--primary);border:1px solid rgba(43,69,251,.15)}
.feat-card.c2 .feat-tag{background:rgba(1,140,251,.07);color:var(--secondary);border-color:rgba(1,140,251,.18)}
.feat-card.c3 .feat-tag{background:rgba(16,185,129,.07);color:var(--green);border-color:rgba(16,185,129,.18)}
.feat-card.c4 .feat-tag{background:rgba(0,176,228,.07);color:var(--accent);border-color:rgba(0,176,228,.18)}
.feat-card.c5 .feat-tag{background:rgba(249,115,22,.07);color:var(--orange);border-color:rgba(249,115,22,.18)}
.feat-card.wide{grid-column:span 1;display:grid;grid-template-columns:1fr;gap:20px;align-items:start}
.feat-wide-right{background:rgba(43,69,251,.04);border:1px solid rgba(43,69,251,.08);border-radius:14px;padding:20px}
.feat-checklist{display:flex;flex-direction:column;gap:10px}
.feat-check{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--text);line-height:1.5}
.feat-check-icon{width:18px;height:18px;background:rgba(43,69,251,.1);color:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;flex-shrink:0;margin-top:1px}

/* STATS */
.stats{display:none}

.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;border:1px solid var(--glass-border);border-radius:24px;overflow:hidden;background:var(--glass-border);box-shadow:var(--shadow-md)}
.stat-box{background:#fff;padding:20px 16px;text-align:center;transition:background .3s}
.stat-box:hover{background:rgba(43,69,251,.04)}
.stat-num{font-family:var(--fd);font-size:34px;font-weight:900;letter-spacing:-.04em;line-height:1;margin-bottom:8px;min-width:3ch;display:inline-block}
.stat-box:nth-child(1) .stat-num{color:var(--primary)}.stat-box:nth-child(2) .stat-num{color:var(--secondary)}.stat-box:nth-child(3) .stat-num{color:var(--green)}.stat-box:nth-child(4) .stat-num{color:var(--accent)}
.stat-lbl{font-size:13px;color:var(--muted);line-height:1.5}

/* COMPARE */
.compare{padding:72px 0;background:#eef2ff}
.compare-inner{display:grid;grid-template-columns:1fr;gap:24px;margin-top:40px}
.compare-col{border-radius:20px;overflow:hidden;border:1px solid var(--glass-border);box-shadow:var(--shadow);background:var(--glass);backdrop-filter:blur(10px)}
.compare-col.old{border-color:rgba(239,68,68,.18);background:rgba(255,250,250,.95)}
.compare-col.new{border-color:rgba(43,69,251,.18)}
.compare-col-header{padding:24px 28px;font-family:var(--fd);font-size:15px;font-weight:800;display:flex;align-items:center;gap:10px}
.compare-col.old .compare-col-header{background:rgba(239,68,68,.07);color:rgba(220,38,38,.85);border-bottom:1px solid rgba(239,68,68,.14)}
.compare-col.new .compare-col-header{background:rgba(43,69,251,.08);color:var(--primary);border-bottom:1px solid rgba(43,69,251,.14)}
.compare-items{padding:8px 0}
.compare-item{display:flex;align-items:center;gap:14px;padding:16px 28px;font-size:14px;border-bottom:1px solid rgba(15,21,64,.06);transition:background .2s;line-height:1.5}
.compare-item:last-child{border-bottom:none}
.compare-col.old .compare-item{color:var(--muted)}
.compare-col.new .compare-item{color:var(--text)}
.compare-col.new .compare-item:hover{background:rgba(43,69,251,.04)}
.compare-icon{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0}
.compare-col.old .compare-icon{background:rgba(239,68,68,.1);color:rgba(220,38,38,.75)}
.compare-col.new .compare-icon{background:rgba(43,69,251,.12);color:var(--primary)}

/* TESTIMONIALS */
.testimonials{padding:48px 0;background:transparent}
.testimonials-header{text-align:center;margin-bottom:18px}
.test-grid{display:grid;grid-template-columns:1fr;gap:16px}
.test-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:16px;padding:16px;transition:all .3s;box-shadow:var(--shadow);backdrop-filter:blur(10px);display:flex;flex-direction:column}
.test-card:hover{border-color:rgba(43,69,251,.2);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.test-stars{color:#f59e0b;margin-bottom:14px;letter-spacing:2px}
.test-stars i{font-size:12px}
.test-text{font-size:13px;color:var(--muted);line-height:1.65;margin-bottom:14px}
.test-author{display:flex;align-items:center;gap:12px}
.test-avatar{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;font-family:var(--fd);flex-shrink:0;overflow:hidden;border:2px solid rgba(43,69,251,.12)}
.test-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.test-name{font-size:13px;font-weight:600;margin-bottom:2px;color:var(--text)}.test-role{font-size:11px;color:var(--muted);font-family:var(--fm)}

/* BENEFITS */
.benefits{padding:72px 0;background:#ffffff}
.benefits-header{text-align:center;margin-bottom:70px}
.benefits-grid{display:grid;grid-template-columns:1fr;gap:16px}
.benefit-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:20px;padding:32px;text-align:center;transition:all .3s;box-shadow:var(--shadow);backdrop-filter:blur(10px)}
.benefit-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.benefit-icon{width:64px;height:64px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 20px}
.benefit-title{font-family:var(--fd);font-size:17px;font-weight:800;margin-bottom:10px;letter-spacing:-.02em;color:var(--text)}
.benefit-desc{font-size:13px;color:var(--muted);line-height:1.7}

/* INDUSTRIES */
.industries{padding:40px 0 0;background:#eef2ff;border-top:none;border-bottom:none}
.industries-label{text-align:center;font-family:var(--fm);font-size:11px;color:var(--muted2);letter-spacing:.12em;text-transform:uppercase;margin-bottom:32px}

/* THROWABLE ARENA */
.throwable-arena{position:relative;width:100%;overflow:hidden;border-radius:0;background:radial-gradient(circle at center,#00b0e4 0%,#018cfb 40%,#2b45fb 100%)}
.throwable-arena::before{content:'';position:absolute;inset:0;

background-image: url('../images/site/plataforma-meupmoc-ar-condicionado-industrial-multiplas-condensadoras-telhado-cidade-pmoc.webp');

background-size:cover;background-position:center;opacity:.08;pointer-events:none;z-index:0}
.throwable-arena .lqd-throwable-scene{position:relative;z-index:1}
.lqd-throwable-scene{position:relative;overflow:hidden}

/* Utility classes required by playground_words.js */
.pos-rel{position:relative}
.pos-abs{position:absolute}
.pos-tl{top:0;left:0}
.d-inline-block{display:inline-block}
.ws-nowrap{white-space:nowrap}
.m-0{margin:0}
.pointer-events-none{pointer-events:none}
.pointer-events-auto{pointer-events:auto}
.user-select-none{user-select:none}
.overflow-hidden{overflow:hidden}
.lqd-throwable-element{position:absolute;top:0;left:0;margin:0;white-space:nowrap;display:inline-block}
.lqd-throwable-element-rot{border-radius:7em;padding:.45em .80em;font-size:14px;font-weight:700;line-height:1.5em;display:inline-block;transform-origin:center center}
.b001 .lqd-throwable-element-rot,.b003 .lqd-throwable-element-rot,.b005 .lqd-throwable-element-rot,.b007 .lqd-throwable-element-rot,.b009 .lqd-throwable-element-rot,.b011 .lqd-throwable-element-rot,.b013 .lqd-throwable-element-rot,.b015 .lqd-throwable-element-rot{background-color:var(--primary);color:#fff}
.b002 .lqd-throwable-element-rot,.b004 .lqd-throwable-element-rot,.b006 .lqd-throwable-element-rot,.b008 .lqd-throwable-element-rot,.b010 .lqd-throwable-element-rot,.b012 .lqd-throwable-element-rot,.b014 .lqd-throwable-element-rot,.b016 .lqd-throwable-element-rot{background-color:#fff;color:var(--secondary)}
.b001 .lqd-throwable-element-rot{border:2px solid var(--primary)}
.b004 .lqd-throwable-element-rot{box-shadow:0 0 12px 3px var(--accent)}
.b007 .lqd-throwable-element-rot{box-shadow:3px 3px 8px rgba(74,80,92,.5)}
.b010 .lqd-throwable-element-rot{box-shadow:4px 6px 12px rgba(1,140,251,.4)}
.b013 .lqd-throwable-element-rot{border:3px double var(--primary)}
.b002 .lqd-throwable-element-rot{box-shadow:2px 4px 6px rgba(1,140,251,.3)}
.b005 .lqd-throwable-element-rot{box-shadow:0 0 10px var(--accent)}
.b008 .lqd-throwable-element-rot{box-shadow:3px 3px 8px rgba(74,80,92,.5)}
.b011 .lqd-throwable-element-rot{box-shadow:inset 0 0 8px var(--primary)}
.b014 .lqd-throwable-element-rot{box-shadow:4px 6px 12px rgba(1,140,251,.4)}
.b016 .lqd-throwable-element-rot{box-shadow:0 0 12px 3px var(--accent)}

/* GOV SECTION */
.gov-section{padding:72px 0;background:#ffffff;position:relative;overflow:hidden}

.gov-inner{display:grid;grid-template-columns:1fr;gap:56px;align-items:start}
.gov-licitacao-card{background:var(--glass);border:1.5px solid rgba(43,69,251,.18);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-md);backdrop-filter:blur(12px)}
.gov-lic-header{background:linear-gradient(135deg,rgba(43,69,251,.08),rgba(1,140,251,.06));border-bottom:1px solid rgba(43,69,251,.12);padding:16px 24px;display:flex;align-items:center;gap:12px}
.gov-lic-badge{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;border-radius:7px;padding:5px 12px;font-family:var(--fm);font-size:10px;font-weight:700;letter-spacing:.06em;white-space:nowrap}
.gov-lic-title{font-size:13px;font-weight:600;color:var(--text);line-height:1.3}
.gov-lic-sub{font-size:11px;color:var(--muted);font-family:var(--fm)}
.gov-lic-body{padding:20px 24px;display:flex;flex-direction:column;gap:14px}
.gov-lic-highlight{background:rgba(43,69,251,.05);border:1px solid rgba(43,69,251,.1);border-left:3px solid var(--primary);border-radius:0 10px 10px 0;padding:12px 16px}
.gov-lic-highlight-label{font-family:var(--fm);font-size:10px;color:var(--primary);letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px}
.gov-lic-highlight-text{font-size:13px;color:var(--text);font-weight:600;line-height:1.5}
.gov-lic-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.gov-lic-item{background:rgba(255,255,255,.7);border:1px solid var(--glass-border);border-radius:12px;padding:12px 14px}
.gov-lic-item-label{font-family:var(--fm);font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:3px}
.gov-lic-item-val{font-size:13px;font-weight:700;color:var(--text)}
.gov-lic-item-val.green{color:var(--green)}
.gov-lic-item-val.primary{color:var(--primary)}
.gov-lic-match{display:flex;align-items:center;gap:10px;background:rgba(16,185,129,.07);border:1px solid rgba(16,185,129,.2);border-radius:12px;padding:12px 16px;margin-top:2px}
.gov-lic-match-icon{width:32px;height:32px;border-radius:9px;background:rgba(16,185,129,.15);color:var(--green);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.gov-lic-match-text{font-size:12px;color:var(--text);line-height:1.5}
.gov-lic-match-text strong{color:var(--green);font-weight:700}
.gov-cards-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:8px}
.gov-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:16px;padding:24px;transition:all .3s;box-shadow:var(--shadow);backdrop-filter:blur(10px);position:relative;overflow:hidden}
.gov-card:hover{border-color:rgba(43,69,251,.2);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.gov-card-icon{width:44px;height:44px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:14px}
.gov-card-title{font-family:var(--fd);font-size:14px;font-weight:800;margin-bottom:7px;letter-spacing:-.02em;color:var(--text)}
.gov-card-desc{font-size:13px;color:var(--muted);line-height:1.65}
.gov-cta-box{background:linear-gradient(135deg,rgba(43,69,251,.06),rgba(1,140,251,.04));border:1.5px solid rgba(43,69,251,.15);border-radius:20px;padding:28px 28px;margin-top:8px;text-align:center}
.gov-cta-label{font-family:var(--fm);font-size:10px;color:var(--primary);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px}
.gov-cta-title{font-family:var(--fd);font-size:18px;font-weight:900;letter-spacing:-.02em;color:var(--text);margin-bottom:8px;line-height:1.2}
.gov-cta-sub{font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:20px}
.gov-cta-btn{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;padding:13px 28px;border-radius:10px;font-weight:700;font-size:13px;text-decoration:none;transition:all .25s;box-shadow:0 6px 24px rgba(43,69,251,.3)}
.gov-cta-btn:hover{transform:translateY(-2px);box-shadow:0 10px 32px rgba(43,69,251,.4)}
.gov-trend-chip{display:inline-flex;align-items:center;gap:6px;background:rgba(249,115,22,.08);border:1px solid rgba(249,115,22,.2);border-radius:100px;padding:4px 12px;font-family:var(--fm);font-size:10px;color:var(--orange);margin-bottom:20px}
.gov-trend-dot{width:5px;height:5px;background:var(--orange);border-radius:50%;animation:pulse 2s infinite}

/* FAQ */
.faq{padding:72px 0;background:transparent}
.faq-header{text-align:center;margin-bottom:28px}
.faq-grid{display:grid;grid-template-columns:1fr;gap:10px;max-width:900px;margin:0 auto}
.faq-item{background:var(--glass);border:1px solid var(--glass-border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);backdrop-filter:blur(10px);transition:all .3s}
.faq-item:hover{border-color:rgba(43,69,251,.18);box-shadow:var(--shadow-md)}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;cursor:pointer;gap:16px}
.faq-q-text{font-weight:700;font-size:14px;color:var(--text);line-height:1.4}
.faq-q-icon{width:24px;height:24px;border-radius:50%;background:rgba(43,69,251,.08);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:11px;flex-shrink:0;transition:all .3s}
.faq-item.open .faq-q-icon{background:var(--primary);color:#fff;transform:rotate(45deg)}
.faq-a{padding:0 24px;max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease;font-size:14px;color:var(--muted);line-height:1.7}
.faq-item.open .faq-a{max-height:200px;padding-bottom:20px}

/* PRICING */
.pricing{padding:72px 0;background:#ffffff}
.pricing-header{text-align:center;margin-bottom:60px}
.pricing-grid{display:grid;grid-template-columns:1fr;gap:16px}
.pricing-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:24px;padding:36px 32px;position:relative;transition:all .3s;box-shadow:var(--shadow);backdrop-filter:blur(10px)}
.pricing-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.pricing-card.featured{border-color:rgba(43,69,251,.3);box-shadow:0 8px 40px rgba(43,69,251,.16);background:linear-gradient(160deg,rgba(255,255,255,.92) 0%,rgba(240,244,255,.88) 100%)}
.pricing-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;padding:4px 16px;border-radius:100px;font-size:10px;font-weight:700;font-family:var(--fm);letter-spacing:.08em;white-space:nowrap;box-shadow:0 4px 14px rgba(43,69,251,.3)}
.pricing-plan{font-family:var(--fd);font-size:13px;font-weight:700;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px}
.pricing-price{font-family:var(--fd);font-size:44px;font-weight:900;letter-spacing:-.04em;color:var(--text);line-height:1;margin-bottom:4px}
.pricing-price sup{font-size:18px;vertical-align:super;margin-right:2px;color:var(--muted);font-weight:400}
.pricing-price-free{font-family:var(--fd);font-size:34px;font-weight:900;color:var(--green);letter-spacing:-.03em}
.pricing-period{font-size:12px;color:var(--muted);font-family:var(--fm);margin-bottom:24px}
.pricing-divider{height:1px;background:var(--glass-border);margin:24px 0}
.pricing-feats{display:flex;flex-direction:column;gap:10px;margin-bottom:28px}
.pricing-feat{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text)}
.pricing-feat i{color:var(--primary);font-size:12px;width:16px;flex-shrink:0}
.pricing-feat.dim{color:var(--muted)}.pricing-feat.dim i{color:var(--muted2)}
.pricing-btn{display:block;text-align:center;padding:14px;border-radius:10px;font-weight:700;font-size:14px;text-decoration:none;transition:all .25s;font-family:var(--fb)}
.pricing-btn-primary{background:linear-gradient(135deg,#00c896,#00a878);color:#fff;box-shadow:0 6px 24px rgba(0,168,120,.35)}
.pricing-btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 36px rgba(0,168,120,.45)}
.pricing-btn-ghost{background:transparent;color:var(--primary);border:1.5px solid rgba(43,69,251,.2)}
.pricing-btn-ghost:hover{background:rgba(43,69,251,.05);border-color:var(--primary)}

/* CTA */
.cta{padding:72px 0;background:#ffffff}
.cta-box{background:linear-gradient(135deg,rgba(43,69,251,.07) 0%,rgba(1,140,251,.04) 100%);border:1.5px solid rgba(43,69,251,.18);border-radius:20px;padding:44px 24px;text-align:center;position:relative;overflow:hidden;box-shadow:0 20px 80px rgba(43,69,251,.1)}
.cta-box::before{content:'';position:absolute;top:-80px;left:50%;transform:translateX(-50%);width:500px;height:400px;background:radial-gradient(circle,rgba(43,69,251,.1) 0%,transparent 70%);pointer-events:none}
.cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:36px}
.cta-note{margin-top:24px;font-size:12px;color:var(--muted2);font-family:var(--fm);letter-spacing:.04em}

/* FOOTER */
footer{border-top:1px solid var(--glass-border);padding:60px 0 40px;position:relative;z-index:1;background:rgba(255,255,255,.6);backdrop-filter:blur(10px)}
.footer-inner{display:grid;grid-template-columns:1fr;gap:32px;margin-bottom:48px}
.footer-brand p{font-size:13px;color:var(--muted);line-height:1.7;margin-top:14px;max-width:260px}
.footer-slogan{font-size:11px;color:var(--muted2);font-family:var(--fm);margin-top:20px;letter-spacing:.04em}
.footer-col h4{font-family:var(--fd);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted2);margin-bottom:16px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col a{color:var(--muted);text-decoration:none;font-size:13px;transition:color .2s}
.footer-col a:hover{color:var(--primary)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:24px;border-top:1px solid var(--glass-border);font-size:12px;color:var(--muted2);font-family:var(--fm)}
.footer-bottom a{color:var(--primary);text-decoration:none;opacity:.7}
.footer-bottom a:hover{opacity:1}

/* ══════════════════════════════════════════
   MOBILE-FIRST RESPONSIVE
   Base = mobile. Desktop overrides via min-width.
   ══════════════════════════════════════════ */







/* ── 480px+ : telefones grandes ── */
@media(min-width:480px){
  .stats-grid{grid-template-columns:1fr 1fr}
  .benefits-grid{grid-template-columns:1fr 1fr}
  .chaos-wrap{display:flex;flex-direction:column;gap:10px}
  .footer-inner{grid-template-columns:1fr 1fr}
  .hero-actions{flex-direction:column;gap:14px;max-width:500px}
}

/* ── 680px+ : tablets menores ── */
@media(min-width:680px){
  .features-grid{grid-template-columns:1fr 1fr}
  .feat-card.wide{grid-column:span 2;grid-template-columns:1fr 1fr}
  .test-grid{grid-template-columns:1fr 1fr}
  .pricing-grid{grid-template-columns:1fr 1fr}
  .faq-grid{grid-template-columns:1fr 1fr}
  .compare-inner{grid-template-columns:1fr 1fr}
  .pain-inner{grid-template-columns:1fr 1fr}
  .gov-cards-grid{grid-template-columns:1fr 1fr}
}

/* ── 900px+ : desktop ── */
@media(min-width:900px){
  nav{padding:16px 40px}
  .container{padding:0 40px}
  .nav-logo-img{height:22px}
  .nav-burger{display:none}
  .nav-links{display:flex}
  .nav-right{display:flex}
  .hero{min-height:100svh;height:100svh;padding:120px 40px 40px;display:flex;align-items:center;box-sizing:border-box}
  .hero-inner{grid-template-columns:1.6fr 0.4fr;gap:40px;align-items:center}
  .hero-visual{order:0;justify-content:flex-end}
  .hero-actions{flex-direction:column;gap:14px;max-width:500px}
  .hero-trust{flex-direction:row;align-items:center}
  .pain{padding:120px 0;background:#ffffff}
  .pain-inner{grid-template-columns:1fr 1fr;gap:48px}
  .how{padding:120px 0;background:#eef2ff}
  .how-grid{grid-template-columns:1fr 1fr;gap:80px;margin-top:0;align-items:start}
  .how-visual{display:flex;margin-top:0 !important;padding-top:0 !important;align-self:start !important}
  .features{padding:120px 0;background:#ffffff}
  .features-grid{grid-template-columns:repeat(3,1fr);gap:20px}
  .feat-card.wide{grid-column:span 2;grid-template-columns:1fr 1fr;gap:32px;align-items:center}
  .stats-hidden{display:none}
  .stats-grid{grid-template-columns:repeat(4,1fr)}
  .stat-box{padding:22px 24px}
  .stat-num{font-size:38px}
  .compare{padding:120px 0;background:#eef2ff}
  .compare-inner{grid-template-columns:1fr 1fr;gap:24px;margin-top:60px}
  .testimonials{padding:120px 0;background:#eef2ff}
  .test-grid{grid-template-columns:repeat(3,1fr);gap:14px}
  .benefits{padding:120px 0;background:#ffffff}
  .benefits-grid{grid-template-columns:repeat(3,1fr);gap:20px}
  .faq{padding:120px 0;background:#eef2ff}
  .faq-grid{grid-template-columns:1fr 1fr;gap:16px}
  .pricing{padding:120px 0;background:#ffffff}
  .pricing-grid{grid-template-columns:repeat(3,1fr);gap:20px}
  .gov-section{padding:120px 0;background:#ffffff}
  .gov-inner{grid-template-columns:1fr 1fr;gap:80px}
  .gov-cards-grid{grid-template-columns:1fr 1fr 1fr !important}
  .cta{padding:120px 0;background:#ffffff}
  .cta-box{padding:80px 60px;border-radius:28px}
  .gov-section{padding:120px 0}
  .gov-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
  .gov-cards-grid{grid-template-columns:repeat(3,1fr) !important}
  .footer-inner{grid-template-columns:2fr 1fr 1fr 1fr;gap:40px}
  .footer-bottom{flex-direction:row}
  .proof-bar{padding:5px 0}
  .proof-bar-inner{display:flex;align-items:center;justify-content:center;gap:0;max-width:100%;padding:0 40px}
  .proof-pair-row{display:contents}
  .proof-item{background:none;border:none;border-radius:0;padding:0 40px;flex:1;min-width:0;text-align:center}
  .proof-num{font-size:32px;display:inline-block}
  .proof-divider{display:block;width:1px;height:40px;background:var(--glass-border);flex-shrink:0}
  .device-stage{min-height:420px}
  .iphone-wrap{transform:rotateX(7deg) rotateY(-14deg) rotateZ(-1deg)}
  .iphone-shadow{width:210px;height:46px}
  .float-badge:nth-child(2){top:70px !important;left:-20px !important;bottom:auto !important;right:auto !important}
  .float-badge:nth-child(3){top:25% !important;right:-20px !important;bottom:auto !important;left:auto !important}
  .float-badge:nth-child(4){bottom:40px !important;right:-20px !important;top:auto !important;left:auto !important}
  .shift{transform:translateX(20px)}
}
@media(min-width:900px){
  /* Hero botões desktop — compactos como LP */
  .hero-actions .btn-primary,
  .hero-actions .btn-ghost{
    padding:14px 28px;
    font-size:14px;
  }
}

/* VIDEO SECTION */
.video-section{padding:72px 0 0;background:radial-gradient(circle at 60% 40%,#00b0e4 0%,#018cfb 40%,#2b45fb 100%);position:relative;overflow:hidden;min-height:auto}
.video-section::before{content:'';position:absolute;inset:0;background-image:url('images/site/plataforma-meupmoc-ar-condicionado-industrial-multiplas-condensadoras-telhado-cidade-pmoc.webp');background-size:cover;background-position:center;opacity:.05;pointer-events:none;z-index:0}
.video-section > .container{position:relative;z-index:2;padding-bottom:72px;pointer-events:none}
.video-section > .container *{pointer-events:auto}
.video-inner{display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
.video-copy{}
.video-copy .section-label{margin-bottom:14px;color:rgba(255,255,255,.7)}
.video-copy .section-label::before{background:rgba(255,255,255,.5)}
.video-copy .section-title{color:#fff}
.video-copy .section-sub{color:rgba(255,255,255,.75)}
.video-quote{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:20px 24px;margin-top:24px;position:relative;box-shadow:0 4px 24px rgba(0,0,0,.15);backdrop-filter:blur(12px)}
.video-quote::before{content:'"';font-family:var(--fd);font-size:48px;color:rgba(255,255,255,.25);position:absolute;top:8px;left:16px;line-height:1}
.video-quote-text{font-size:14px;color:rgba(255,255,255,.85);line-height:1.7;padding-left:20px}
.video-quote-author{display:flex;align-items:center;gap:10px;margin-top:14px;padding-left:20px}
.video-quote-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.3)}
.video-quote-name{font-size:13px;font-weight:600;color:#fff}
.video-quote-role{font-size:11px;color:rgba(255,255,255,.6);font-family:var(--fm)}
.video-embed-wrap{position:relative;border-radius:20px;overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.15)}
.video-embed-wrap iframe{display:block;width:100%;aspect-ratio:16/9;border:none}
.video-thumb{position:relative;width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,#0f1540 0%,#1e35e8 100%);border-radius:20px;overflow:hidden;cursor:pointer;box-shadow:0 24px 64px rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.12)}
.video-thumb-img{width:100%;height:100%;object-fit:cover;opacity:.6}
.video-play-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:72px;height:72px;background:rgba(255,255,255,.95);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s;box-shadow:0 8px 32px rgba(0,0,0,.3)}
.video-thumb:hover .video-play-btn{transform:translate(-50%,-50%) scale(1.1);box-shadow:0 12px 40px rgba(0,0,0,.4)}
.video-play-btn i{color:var(--primary);font-size:24px;margin-left:4px}
.video-badge-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}
.video-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);border-radius:100px;padding:6px 14px;font-size:12px;color:rgba(255,255,255,.85);backdrop-filter:blur(10px)}
.video-badge i{color:rgba(255,255,255,.9);font-size:12px}
/* arena ocupa toda a section como background interativo */
.video-section .throwable-arena{background:transparent;pointer-events:none}
.video-section .throwable-arena .lqd-throwable-element{pointer-events:auto}
.video-section .throwable-arena::before{opacity:.04}

/* PHOTOS / SOCIAL PROOF VISUAL */
.photos-section{padding:72px 0;overflow:hidden;background:#ffffff}
.photos-section .section-label.center::before{display:none}
.photo-strip-old{display:none}
.photo-card-old{display:none}
.photo-card-old img{display:none}

.photo-card-caption{position:absolute;bottom:0;left:0;right:0;padding:16px 14px;background:linear-gradient(transparent,rgba(15,21,64,.75));color:#fff}
.photo-card-caption-title{font-size:13px;font-weight:700;font-family:var(--fd)}
.photo-card-caption-sub{font-size:11px;opacity:.75;font-family:var(--fm)}

/* ART / TRT SECTION */
.art-section{padding:72px 0;background:#eef2ff}
.art-inner{display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
.art-doc-mockup{background:rgba(255,255,255,.95);border:1px solid rgba(43,69,251,.15);border-radius:16px;padding:28px;box-shadow:var(--shadow-md);position:relative;overflow:hidden}
.art-doc-mockup::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary),var(--secondary))}
.art-doc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgba(43,69,251,.08)}
.art-doc-logo-area{display:flex;align-items:center;gap:10px}
.art-doc-logo-box{width:40px;height:40px;background:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center}
.art-doc-logo-box i{color:#fff;font-size:16px}
.art-doc-company{font-size:12px;font-weight:700;color:var(--text);font-family:var(--fd)}
.art-doc-cnpj{font-size:10px;color:var(--muted);font-family:var(--fm)}
.art-doc-badge{background:rgba(43,69,251,.1);color:var(--primary);border-radius:8px;padding:6px 12px;font-size:10px;font-weight:700;font-family:var(--fm);letter-spacing:.06em}
.art-doc-title{font-family:var(--fd);font-size:15px;font-weight:900;color:var(--text);text-align:center;margin-bottom:16px;letter-spacing:-.01em}
.art-doc-fields{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
.art-doc-field{background:rgba(43,69,251,.04);border:1px solid rgba(43,69,251,.08);border-radius:8px;padding:10px 12px}
.art-doc-field-label{font-family:var(--fm);font-size:8.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:3px}
.art-doc-field-val{font-size:12px;font-weight:600;color:var(--text)}
.art-doc-field.full{grid-column:span 2}
.art-doc-sign-row{display:flex;align-items:center;justify-content:space-between;background:rgba(16,185,129,.06);border:1px solid rgba(16,185,129,.2);border-radius:10px;padding:12px 16px;margin-top:8px}
.art-doc-sign-label{font-family:var(--fm);font-size:9px;color:var(--green);text-transform:uppercase;letter-spacing:.08em}
.art-doc-sign-val{font-size:11px;font-weight:700;color:var(--text)}
.art-doc-sign-icon{width:28px;height:28px;background:rgba(16,185,129,.1);border-radius:7px;display:flex;align-items:center;justify-content:center;color:var(--green);font-size:12px}
.art-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
.art-chip{display:inline-flex;align-items:center;gap:6px;background:var(--glass);border:1px solid var(--glass-border);border-radius:100px;padding:6px 14px;font-size:12px;color:var(--muted);box-shadow:var(--shadow)}
.art-chip i{font-size:12px;color:var(--primary)}

/* AI SECTION */
.ai-section{padding:72px 0;background:#eef2ff;position:relative;overflow:hidden}
.ai-section::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:800px;height:600px;background:radial-gradient(ellipse,rgba(43,69,251,.06) 0%,transparent 65%);pointer-events:none}
.ai-header{text-align:center;margin-bottom:60px}
.ai-header .section-label{justify-content:center}
.ai-header .section-label::before{display:none}
.ai-cards{display:grid;grid-template-columns:1fr;gap:16px}
.ai-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:20px;padding:28px;position:relative;overflow:hidden;transition:all .3s;box-shadow:var(--shadow);backdrop-filter:blur(10px)}
.ai-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:rgba(43,69,251,.2)}
.ai-card-glow{position:absolute;top:-60px;right:-60px;width:180px;height:180px;border-radius:50%;opacity:0;transition:opacity .4s;filter:blur(50px);background:var(--primary)}
.ai-card:hover .ai-card-glow{opacity:.3}
.ai-card-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:18px;background:linear-gradient(135deg,rgba(43,69,251,.12),rgba(1,140,251,.08));border:1px solid rgba(43,69,251,.15);color:var(--primary)}
.ai-card-title{font-family:var(--fd);font-size:16px;font-weight:800;margin-bottom:8px;letter-spacing:-.02em;color:var(--text)}
.ai-card-desc{font-size:13px;color:var(--muted);line-height:1.7;margin-bottom:16px}
.ai-card-demo{background:rgba(43,69,251,.04);border:1px solid rgba(43,69,251,.08);border-radius:12px;padding:14px 16px}
.ai-card-demo-label{font-family:var(--fm);font-size:9px;color:var(--primary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.ai-card-demo-label::before{content:'';width:5px;height:5px;background:var(--green);border-radius:50%;animation:pulse 2s infinite}
.ai-card-demo-text{font-size:12px;color:var(--text);line-height:1.6;font-style:italic}
.ai-card-demo-cursor{display:inline-block;width:2px;height:14px;background:var(--primary);margin-left:2px;animation:blink 1s step-end infinite;vertical-align:middle}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.ai-badge{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,rgba(43,69,251,.1),rgba(1,140,251,.07));border:1px solid rgba(43,69,251,.2);border-radius:100px;padding:4px 12px;font-size:10px;font-family:var(--fm);color:var(--primary);letter-spacing:.06em;margin-bottom:28px}
.ai-disclaimer{text-align:center;margin-top:48px;font-size:13px;color:var(--muted);max-width:480px;margin-left:auto;margin-right:auto;line-height:1.7}
.ai-disclaimer strong{color:var(--text)}


/* ── 680px+ : new sections ── */
@media(min-width:680px){
  .video-inner{grid-template-columns:1fr 1fr}
  .art-inner{grid-template-columns:1fr 1fr}
  .ai-cards{grid-template-columns:1fr 1fr 1fr}
  .photo-card{flex:0 0 300px}
}
@media(min-width:900px){
  .video-section{padding:120px 0 0}
  .photos-section{padding:120px 0;background:#ffffff}
  .art-section{padding:120px 0;background:#eef2ff}
  .ai-section{padding:120px 0;background:#eef2ff}
  .photo-strip-wrap{margin:40px -40px 0}
  .photo-card{flex:0 0 320px}
}


/* QR PHONE MOCKUP (from QR Live) */
.qr-phone{position:relative;width:100%}
.qr-phone-frame{
  width:100%;
  aspect-ratio:9/19.5;
  background:#0a0a0a;
  border-radius:34px;
  padding:3px;
  position:relative;
  box-shadow:
    0 0 0 0.5px rgba(255,255,255,0.08),
    0 0 0 1px rgba(255,255,255,0.04),
    0 50px 100px rgba(0,0,0,0.6),
    0 20px 60px rgba(43,69,251,0.18);
}
.qr-phone-frame::before{
  content:'';
  position:absolute;
  left:-2px;top:100px;
  width:2px;height:32px;
  background:#1a1a1a;
  border-radius:2px 0 0 2px;
  box-shadow:0 42px 0 #1a1a1a;
}
.qr-phone-frame::after{
  content:'';
  position:absolute;
  right:-2px;top:120px;
  width:2px;height:48px;
  background:#1a1a1a;
  border-radius:0 2px 2px 0;
}
.qr-phone-screen{
  background:#f8faff;
  border-radius:32px;
  height:100%;
  overflow:hidden;
  position:relative;
  display:flex;
  flex-direction:column;
  box-shadow:inset 0 0 0 0.5px rgba(0,0,0,0.15);
}
.qr-phone-notch{
  position:absolute;
  top:13px;left:50%;
  transform:translateX(-50%);
  width:9px;height:9px;
  background:#0a0a0a;
  border-radius:50%;
  z-index:20;
  box-shadow:0 0 0 1px rgba(255,255,255,0.04);
}
.qr-scan-area{background:rgba(43,69,251,.04);border:1px solid rgba(43,69,251,.1);border-radius:10px;padding:8px;position:relative;flex:1;min-height:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:6px;overflow:hidden}
.qr-scan-line{position:absolute;left:16px;right:16px;height:2px;background:linear-gradient(90deg,transparent,var(--primary),var(--secondary),transparent);border-radius:2px;animation:qrScanLine 2.4s ease-in-out infinite;box-shadow:0 0 12px rgba(43,69,251,.5),0 0 6px rgba(1,140,251,.4)}
@keyframes qrScanLine{0%{top:16px;opacity:0}8%{opacity:1}48%{top:calc(100% - 16px);opacity:1}52%{top:calc(100% - 16px);opacity:1}92%{top:16px;opacity:1}100%{top:16px;opacity:0}}
.qr-code-svg{width:72px;height:72px;opacity:.8}
.qr-info-row{display:flex;gap:8px}
.qr-info-chip{flex:1;background:rgba(255,255,255,.9);border:1px solid rgba(43,69,251,.1);border-radius:6px;padding:5px 6px;font-size:8px}
.qr-info-chip-label{color:var(--muted);font-family:var(--fm);font-size:7px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:3px}
.qr-info-chip-val{color:var(--text);font-weight:600;font-size:9px}
.qr-status-bar{background:rgba(1,140,251,.08);border:1px solid rgba(1,140,251,.2);border-radius:6px;padding:5px 8px;display:flex;align-items:center;gap:6px}
.qr-status-dot{width:6px;height:6px;background:var(--secondary);border-radius:50%;animation:pulse 2s infinite}
.qr-status-text{color:var(--secondary);font-family:var(--fm);font-size:7px}
.qr-btn-row{display:flex;gap:6px}
.qr-mini-btn{flex:1;background:var(--primary);color:#fff;border:none;border-radius:6px;padding:6px 4px;font-size:7px;font-weight:700;font-family:var(--fb);cursor:pointer;text-align:center}
.qr-mini-btn-ghost{background:rgba(43,69,251,.06);color:var(--primary)}


/* ── iPhone 17 Pro Max Mockup ── */
.iphone17{
  position:relative;
  width:100%;
  aspect-ratio:390/844;
  border-radius:62px;
  background:linear-gradient(145deg,#6d6d72 0%,#2f2f33 28%,#18181a 60%,#66666c 100%);
  padding:10px;
  box-shadow:
    0 60px 120px rgba(0,0,0,.5),
    0 25px 45px rgba(0,0,0,.3),
    inset 0 1px 0 rgba(255,255,255,.18),
    inset 0 -2px 8px rgba(0,0,0,.45),
    0 20px 60px rgba(43,69,251,.2);
}
.iphone17::before{
  content:'';position:absolute;inset:3px;
  border-radius:58px;border:1px solid rgba(255,255,255,.08);pointer-events:none;
}
.iphone17::after{
  content:'';position:absolute;top:14px;left:16px;right:16px;height:80px;
  border-radius:40px;
  background:linear-gradient(to bottom,rgba(255,255,255,.08),rgba(255,255,255,0));
  pointer-events:none;filter:blur(2px);
}
.iphone17-side{position:absolute;background:linear-gradient(180deg,#7f7f84,#2f2f33);box-shadow:inset 0 1px 0 rgba(255,255,255,.18);border-radius:4px}
.btn-power{width:4px;height:14%;right:-3px;top:21%;border-radius:4px}
.btn-vol-up{width:4px;height:9%;left:-3px;top:20%;border-radius:4px}
.btn-vol-down{width:4px;height:9%;left:-3px;top:31%}
.btn-action{width:4px;height:5%;left:-3px;top:14%}
.iphone17-screen{
  position:relative;width:100%;height:100%;overflow:hidden;
  border-radius:52px;
  background:#f8faff;
  box-shadow:inset 0 0 0 2px #000,inset 0 0 40px rgba(255,255,255,.04);
}
.iphone17-bezel{position:absolute;inset:0;border-radius:52px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.04);pointer-events:none;z-index:5}
.iphone17-island{
  position:absolute;top:2.2%;left:50%;transform:translateX(-50%);
  width:32%;height:4%;
  background:#000;border-radius:999px;z-index:6;
  box-shadow:inset 0 1px 1px rgba(255,255,255,.06),0 2px 8px rgba(0,0,0,.45);
}
.iphone17-statusbar{
  position:absolute;top:1.5%;left:6%;right:6%;
  display:flex;justify-content:space-between;align-items:center;
  color:#0f1540;font-size:11px;font-weight:600;z-index:4;pointer-events:none;
  letter-spacing:.2px;
}
.iphone17-battery{width:20px;height:10px;border:1.5px solid #0f1540;border-radius:3px;position:relative}
.iphone17-battery::before{content:'';position:absolute;top:2px;bottom:2px;left:2px;width:12px;background:#0f1540;border-radius:1px}
.iphone17-battery::after{content:'';position:absolute;right:-3px;top:3px;width:2px;height:4px;background:#0f1540;border-radius:1px}
.iphone17-content{
  position:absolute;
  top:10%;left:4%;right:4%;bottom:4%;
  display:flex;flex-direction:column;gap:6px;
  overflow:hidden;
}
.iphone17-home{
  position:absolute;left:50%;bottom:1.2%;
  transform:translateX(-50%);
  width:36%;height:1%;min-height:4px;
  border-radius:999px;background:rgba(15,21,64,.35);z-index:6;
}





/* ══ MOCKUP QR LIVE ══ */
/* DEVICE STAGE */
.hero-visual {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  animation: fadeUp .35s .1s ease both;
  position: relative;
  order: -1;
}

.device-stage {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  perspective: 1800px;
  padding: 40px 60px;
}

.device-glow {
  position: absolute;
  width: 480px; height: 480px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(43,69,251,0.15) 0%, rgba(1,140,251,0.08) 38%, transparent 72%);
  filter: blur(10px);
  pointer-events: none;
}

/* iPhone shell */
.iphone-wrap {
  position: relative;
  transform: rotateX(4deg) rotateY(-10deg) rotateZ(-1deg) scale(0.9);
  z-index: 1;
}

.iphone-shadow {
  position: absolute;
  left: 50%; bottom: -28px;
  width: 240px; height: 50px;
  transform: translateX(-50%) rotateX(72deg);
  background: rgba(14,20,35,0.18);
  filter: blur(22px);
  border-radius: 999px;
}

.iphone {
  position: relative;
  width: 300px; height: 640px;
  border-radius: 52px;
  padding: 5px;
  background: linear-gradient(145deg, #171b20 0%, #404854 34%, #14181d 72%, #2b3139 100%);
  box-shadow:
    0 24px 60px rgba(12,16,26,0.28),
    0 8px 22px rgba(12,16,26,0.14),
    inset 0 1px 0 rgba(255,255,255,0.15),
    inset 0 -1px 0 rgba(255,255,255,0.04);
  user-select: none;
  -webkit-user-select: none;
}

.iphone::before {
  content: '';
  position: absolute;
  inset: 2px;
  border-radius: 50px;
  border: 1px solid rgba(255,255,255,0.06);
  pointer-events: none;
}

/* Botões laterais */
.side-btn {
  position: absolute;
  background: linear-gradient(180deg,#3a4150,#23282f);
  border-radius: 3px;
}
.side-btn-power  { right:-3px; top:130px; width:3px; height:70px; }
.side-btn-vol1   { left:-3px;  top:130px; width:3px; height:38px; }
.side-btn-vol2   { left:-3px;  top:178px; width:3px; height:60px; }
.side-btn-mute   { left:-3px;  top:100px; width:3px; height:28px; }

/* Tela */
.iphone-screen {
  width: 100%; height: 100%;
  border-radius: 47px;
  overflow: hidden;
  background: #0e1220;
  position: relative;
  display: flex;
  flex-direction: column;
}

/* Dynamic island */
.dynamic-island {
  position: absolute;
  top: 12px; left: 50%;
  transform: translateX(-50%);
  width: 110px; height: 32px;
  background: #000;
  border-radius: 20px;
  z-index: 20;
}

/* Status bar */
.iphone-status {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 22px 0;
  font-size: 12px;
  font-weight: 700;
  color: #fff;
  position: relative;
  z-index: 10;
  flex-shrink: 0;
}
.iphone-status-right { display: flex; align-items: center; gap: 6px; font-size: 11px; }
.iphone-battery {
  width: 22px; height: 11px;
  border: 1.5px solid rgba(255,255,255,0.6);
  border-radius: 3px;
  position: relative;
}
.iphone-battery::after {
  content: '';
  position: absolute;
  right: -4px; top: 50%;
  transform: translateY(-50%);
  width: 2px; height: 5px;
  background: rgba(255,255,255,0.6);
  border-radius: 0 1px 1px 0;
}
.iphone-battery::before {
  content: '';
  position: absolute;
  inset: 2px 4px 2px 2px;
  background: #fff;
  border-radius: 1px;
}

/* Slides */
.phone-slides {
  flex: 1;
  position: relative;
  overflow: hidden;
}

.phone-step {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 0.5s ease;
  pointer-events: none;
}
.phone-step.is-active {
  opacity: 1;
  pointer-events: all;
}

.phone-step[data-step="4"].is-active {
  animation: slideLastFadeIn 1.2s ease forwards;
}

@keyframes slideLastFadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* ── STEP 0: câmera ── */
.step-camera {
  display: flex;
  flex-direction: column;
  height: 100%;
  background: #0e1220;
  overflow: hidden;
}

.camera-topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 16px;
  flex-shrink: 0;
  z-index: 2;
}
.camera-pill {
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 100px;
  padding: 4px 10px;
  font-size: 9px;
  color: rgba(255,255,255,0.7);
  font-family: var(--font-mono);
  letter-spacing: 0.06em;
}
.camera-pill.active {
  background: rgba(43,69,251,0.25);
  border-color: rgba(43,69,251,0.5);
  color: #a5b4fc;
}

.camera-viewfinder {
  flex: 1;
  position: relative;
  overflow: hidden;
  min-height: 0;
}

.camera-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 52% 20%;
  display: block;
}

/* Scanner sobre o QR no celular da foto */
.cam-scan-frame {
  position: absolute;
  width: 90px;
  height: 90px;
  left: 50%;
  top: 52%;
  transform: translate(-50%, -50%);
  border-radius: 16px;
  pointer-events: none;
  z-index: 50;
}

.cam-scan-frame {
  left: 50%;
  top: 34%;   /* ← sobe/desce */
  transform: translate(-50%, -50%);
}

.cam-scan-focus-glow {
  position: absolute;
  inset: -10px;
  border-radius: 22px;
  background: radial-gradient(circle, rgba(43,69,251,.22), rgba(0,176,228,.14), transparent 70%);
  filter: blur(10px);
  animation: focusPulse 1.4s ease-in-out infinite;
  z-index: 0;
}

@keyframes focusPulse {
  0%, 100% { transform: scale(.96); opacity: .65; }
  50%       { transform: scale(1.04); opacity: 1; }
}

.cam-scan-corner {
  position: absolute;
  width: 20px;
  height: 20px;
  border-color: #2b45fb;
  border-style: solid;
  z-index: 2;
  filter: drop-shadow(0 0 6px rgba(43,69,251,.6));
}
.cam-scan-corner.tl { left:0;   top:0;    border-width: 3.5px 0 0 3.5px; border-radius: 10px 0 0 0; }
.cam-scan-corner.tr { right:0;  top:0;    border-width: 3.5px 3.5px 0 0; border-radius: 0 10px 0 0; }
.cam-scan-corner.bl { left:0;   bottom:0; border-width: 0 0 3.5px 3.5px; border-radius: 0 0 0 10px; }
.cam-scan-corner.br { right:0;  bottom:0; border-width: 0 3.5px 3.5px 0; border-radius: 0 0 10px 0; }

.slide1-scan .cam-scan-corner { width: 12px; height: 12px; }

.slide1-scan .cam-scan-corner.tl { border-width: 2px 0 0 2px; border-radius: 7px 0 0 0;}
.slide1-scan .cam-scan-corner.tr { border-width: 2px 2px 0 0; border-radius: 0 7px 0 0; }
.slide1-scan .cam-scan-corner.bl { border-width: 0 0 2px 2px; border-radius: 0 0 0 7px; }
.slide1-scan .cam-scan-corner.br { border-width: 0 2px 2px 0; border-radius: 0 0 7px 0; }


.cam-scan-beam {
  position: absolute;
  left: 8px; right: 8px;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, #2b45fb, #00b0e4, transparent);
  box-shadow: 0 0 14px rgba(43,69,251,.6);
  animation: scanMove 1.6s ease-in-out infinite;
  z-index: 2;
}

@keyframes scanMove {
  0%   { top: 10px; opacity: 0; }
  8%   { opacity: 1; }
  48%  { top: calc(100% - 10px); opacity: 1; }
  52%  { top: calc(100% - 10px); opacity: 1; }
  92%  { top: 10px; opacity: 1; }
  100% { top: 10px; opacity: 0; }
}

.camera-label {
  padding: 10px 16px;
  flex-shrink: 0;
  text-align: center;
  font-size: 10px;
  color: rgba(255,255,255,0.5);
  font-family: var(--font-mono);
  letter-spacing: 0.08em;
  background: #0e1220;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ── STEP 1: identificado ── */
.step-identified {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  background: linear-gradient(160deg, #f8faff 0%, #eef4ff 100%);
  padding: 24px 20px;
  gap: 16px;
}

.id-ring {
  width: 72px; height: 72px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--primary), var(--secondary));
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; color: #fff;
  box-shadow:
    0 0 0 8px rgba(43,69,251,0.1),
    0 0 0 16px rgba(43,69,251,0.05),
    0 12px 40px rgba(43,69,251,0.35);
  animation: idRingPop 0.4s cubic-bezier(0.34,1.56,0.64,1) both;
}

@keyframes idRingPop {
  from { transform: scale(0); opacity: 0; }
  to   { transform: scale(1); opacity: 1; }
}

.id-title {
  font-family: var(--font-display);
  font-size: 17px; font-weight: 900;
  color: var(--text);
  letter-spacing: -0.02em;
  text-align: center;
}
.id-sub {
  font-size: 11px;
  color: var(--muted);
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-top: -8px;
}

.id-card {
  width: 100%;
  background: #fff;
  border: 1px solid rgba(43,69,251,0.1);
  border-radius: 14px;
  padding: 14px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  box-shadow: 0 4px 16px rgba(43,69,251,0.08);
}
.id-card-icon {
  width: 36px; height: 36px;
  border-radius: 10px;
  background: rgba(43,69,251,0.08);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
}
.id-card-info small {
  display: block;
  font-size: 9px;
  color: var(--muted);
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 3px;
}
.id-card-info strong {
  display: block;
  font-size: 13px;
  color: var(--text);
  font-weight: 700;
}
.id-card-info span {
  display: block;
  font-size: 10px;
  color: var(--muted);
  margin-top: 2px;
}

.id-progress {
  width: 100%;
  height: 3px;
  background: rgba(43,69,251,0.1);
  border-radius: 3px;
  overflow: hidden;
}
.id-progress-bar {
  height: 100%;
  background: linear-gradient(90deg, var(--primary), var(--secondary));
  border-radius: 3px;
  animation: progressFill 3s ease forwards;
}
@keyframes progressFill {
  from { width: 0; }
  to   { width: 100%; }
}

/* ── STEP 2: passaporte ── */
.step-passport {
  display: flex;
  flex-direction: column;
  height: 100%;
  background: #f4f7ff;
  overflow-y: auto;
  overflow-x: hidden;
}

.passport-topbar {
  background: linear-gradient(135deg, var(--primary), var(--secondary));
  padding: 14px 16px 18px;
  flex-shrink: 0;
}
.passport-topbar-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.passport-badge {
  background: rgba(255,255,255,0.2);
  border-radius: 100px;
  padding: 3px 10px;
  font-size: 9px;
  color: rgba(255,255,255,0.9);
  font-family: var(--font-mono);
  letter-spacing: 0.06em;
}
.passport-id {
  font-size: 9px;
  color: rgba(255,255,255,0.6);
  font-family: var(--font-mono);
}
.passport-equip-row {
  display: flex;
  align-items: center;
  gap: 10px;
}
.passport-equip-icon {
  width: 38px; height: 38px;
  background: rgba(255,255,255,0.2);
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
}
.passport-equip-name {
  font-family: var(--font-display);
  font-size: 14px; font-weight: 900;
  color: #fff;
  letter-spacing: -0.02em;
}
.passport-equip-sub {
  font-size: 10px;
  color: rgba(255,255,255,0.65);
  margin-top: 2px;
}

.passport-kpis {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 6px;
  padding: 12px 12px 0;
  flex-shrink: 0;
}
.passport-kpi {
  background: #fff;
  border: 1px solid rgba(43,69,251,0.08);
  border-radius: 10px;
  padding: 8px 6px;
  text-align: center;
}
.passport-kpi small {
  display: block;
  font-size: 8px;
  color: var(--muted);
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 3px;
}
.passport-kpi strong {
  display: block;
  font-size: 12px;
  font-weight: 800;
  color: var(--text);
}
.passport-kpi.ok strong { color: #16a34a; }

.passport-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  padding: 10px 12px 12px;
}
.passport-action {
  background: #fff;
  border: 1px solid rgba(43,69,251,0.08);
  border-radius: 12px;
  padding: 12px 10px;
  cursor: pointer;
  transition: all 0.2s;
}
.passport-action:first-child {
  grid-column: span 2;
  background: linear-gradient(135deg, var(--primary), var(--secondary));
  border-color: transparent;
}
.passport-action:first-child .pa-title { color: #fff; }
.passport-action:first-child .pa-sub   { color: rgba(255,255,255,0.65); }
.pa-icon { font-size: 16px; margin-bottom: 6px; }
.pa-title { font-size: 11px; font-weight: 700; color: var(--text); }
.pa-sub   { font-size: 9px; color: var(--muted); margin-top: 2px; }

/* Dots */
.demo-dots {
  display: flex;
  justify-content: center;
  gap: 6px;
  padding: 10px 0 14px;
  background: transparent;
  position: absolute;
  bottom: 0; left: 0; right: 0;
  pointer-events: none;
}
.demo-dot {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: rgba(255,255,255,0.25);
  transition: all 0.3s;
}
.demo-dot.is-active {
  background: #fff;
  width: 16px;
  border-radius: 3px;
}

/* Step screenshot */
.step-screenshot {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #000;
  overflow: hidden;
}
.screenshot-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}

.step-iframe-wrap {
  height: 100%;
  display: flex;
  flex-direction: column;
  background: #fff;
  position: relative;
  overflow: hidden;
  touch-action: pan-y;
}

/* Slide com duas camadas: base fixa + mãos com fade-in */
.step-layered {
  position: relative;
}
.layer-base {
  position: absolute;
  inset: 0;
  animation: baseBlur 0.6s 0.4s ease forwards;
}
@keyframes baseBlur {
  from { filter: blur(0px); }
  to   { filter: blur(4px); }
}
.layer-hands {
  position: absolute;
  inset: 0;
  opacity: 0;
  animation: handsAppear 0.8s 0.3s cubic-bezier(0.22,1,0.36,1) forwards;
}
@keyframes handsAppear {
  from { opacity: 0; transform: translateY(60px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Scanner slide 1 — sobre QR no celular da foto das mãos */
.slide1-scan {
  left: 50%;
  width: 50px;
  height: 50px;
  opacity: 0;
  animation: none;
}
.slide1-scan {
  top: 46%;   /* ← sobe/desce */
  left: 50%;
  transform: translate(-50%, -50%);
}

.phone-step[data-step="1"].is-active .slide1-scan {
  animation: scanAppear 0.4s 1.2s ease forwards;
}
@keyframes scanAppear {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.demo-dots {
  pointer-events: all !important;
}
.demo-dot {
  cursor: pointer;
  pointer-events: all !important;
  transition: all 0.3s;
}
.demo-dot:hover {
  background: rgba(255,255,255,0.6) !important;
}

/* ── STEP 5: página pública scrollável ── */
.step-qrpage {
  height: 100%;
  overflow-y: auto;
  overflow-x: hidden;
  background: #f0f4ff;
  -webkit-overflow-scrolling: touch;
}
.step-qrpage::-webkit-scrollbar { display: none; }

.qrp-hero {
  background: linear-gradient(135deg, #2b45fb, #018cfb);
  padding: 16px 14px 18px;
  color: #fff;
  flex-shrink: 0;
}
.qrp-hero-title { font-size: 14px; font-weight: 700; margin-bottom: 3px; }
.qrp-hero-sub   { font-size: 9px; opacity: .85; font-style: italic; margin-bottom: 12px; }
.qrp-hero-stats { display: flex; justify-content: space-between; text-align: center; }
.qrp-stat-n { display: block; font-size: 15px; font-weight: 700; }
.qrp-stat-l { display: block; font-size: 8px; opacity: .8; margin-top: 2px; line-height: 1.2; }

.qrp-section-title {
  font-size: 11px; font-weight: 700; color: #1f2937;
  padding: 10px 10px 4px; letter-spacing: -0.01em;
}

.qrp-card {
  margin: 0 8px 8px;
  background: #fff;
  border-radius: 12px;
  border: 1px solid #e5e7eb;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}
.qrp-responsible {
  padding: 12px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 6px;
}
.qrp-resp-icon {
  width: 34px; height: 34px; border-radius: 50%;
  background: linear-gradient(135deg, #2b45fb, #018cfb);
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 14px;
}
.qrp-resp-name { font-size: 12px; font-weight: 700; color: #1f2937; }
.qrp-resp-doc  { font-size: 9px; color: #6b7280; }

.qrp-list {
  margin: 0 8px 8px;
  background: #fff;
  border-radius: 12px;
  border: 1px solid #e5e7eb;
  overflow: hidden;
}
.qrp-list-item {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 12px;
  border-bottom: 1px solid #f3f4f6;
}
.qrp-list-item:last-child { border-bottom: none; }
.qrp-list-icon {
  width: 26px; height: 26px; border-radius: 50%;
  background: linear-gradient(135deg, #2b45fb, #018cfb);
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 11px; flex-shrink: 0;
}
.qrp-list-t { font-size: 11px; font-weight: 500; color: #1f2937; }
.qrp-list-s { font-size: 9px; color: #6b7280; margin-top: 1px; }

.qrp-stats-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 6px;
  margin: 0 8px 8px;
}
.qrp-stat-card {
  background: #fff; border-radius: 10px; border: 1px solid #e5e7eb;
  padding: 10px 8px; text-align: center;
}
.qrp-sc-n { display: block; font-size: 18px; font-weight: 700; color: #2b45fb; }
.qrp-sc-l { display: block; font-size: 9px; color: #6b7280; margin-top: 2px; }

.qrp-actions-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 6px;
  margin: 0 8px 8px;
}
.qrp-action {
  background: #fff; border-radius: 10px; border: 1px solid #e5e7eb;
  padding: 12px 8px; text-align: center;
}
.qrp-act-icon {
  width: 32px; height: 32px; border-radius: 8px;
  background: linear-gradient(135deg, #2b45fb, #018cfb);
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 14px; margin: 0 auto 6px;
}
.qrp-act-t { font-size: 11px; font-weight: 600; color: #1f2937; }
.qrp-act-s { font-size: 9px; color: #6b7280; margin-top: 2px; line-height: 1.2; }

.qrp-footer {
  margin: 4px 8px 20px;
  background: linear-gradient(135deg, #2b45fb, #018cfb);
  border-radius: 12px; padding: 14px;
  text-align: center; color: #fff;
}
/* ── STEP 5: página Meu Pmoc simulada ── */
.mp-page {
  height: 100%;
  overflow-y: scroll;
  overflow-x: hidden;
  background: linear-gradient(135deg, #f5f8fa 0%, #eff6ff 100%);
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  touch-action: pan-y;
  font-family: -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  padding-bottom: 80px;
}
.mp-page::-webkit-scrollbar { display: none; }

.mp-hero {
  background: linear-gradient(135deg, #2b45fb, #018cfb);
  padding: 18px 14px 16px;
  color: #fff;
  margin-bottom: 0;
}
.mp-hero-title { font-size: 15px; font-weight: 700; margin-bottom: 4px; text-align: center; }
.mp-hero-sub   { font-size: 9px; opacity: .88; line-height: 1.4; text-align: center; }

.mp-stats-hero {
  display: flex;
  justify-content: space-between;
  text-align: center;
  padding: 12px 14px;
  margin-bottom: 0;
}
.mp-hstat { flex: 1; }
.mp-hsn { display: block; font-size: 16px; font-weight: 700; }
.mp-hsl { display: block; font-size: 8px; opacity: .8; margin-top: 2px; line-height: 1.2; }

.mp-sec-title {
  font-size: 14px; font-weight: 700;
  color: #1f2937; padding: 12px 12px 6px;
}

.mp-card {
  margin: 0 10px 10px;
  background: #fff;
  border-radius: 14px;
  border: 1px solid #e5e7eb;
  box-shadow: 0 4px 12px rgba(0,0,0,0.06);
}
.mp-resp-card {
  padding: 16px 12px 14px;
  display: flex; flex-direction: column;
  align-items: center; text-align: center; gap: 5px;
  position: relative; overflow: hidden;
}
.mp-ribbon {
  position: absolute; top: 0; left: 0;
  overflow: hidden; width: 80px; height: 80px;
  pointer-events: none;
}
.mp-ribbon span {
  position: absolute;
  top: 16px; left: -22px;
  width: 90px;
  background: linear-gradient(135deg,#ffd700,#b8860b,#ffd700);
  color: #fff; font-size: 7px; font-weight: 700;
  text-align: center; padding: 3px 0;
  transform: rotate(-45deg);
  box-shadow: 0 2px 6px rgba(0,0,0,0.3);
  letter-spacing: 0.5px;
}
.mp-resp-icon {
  width: 36px; height: 36px; border-radius: 50%;
  background: linear-gradient(135deg,#2b45fb,#018cfb);
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 15px;
  box-shadow: 0 4px 12px rgba(43,69,251,0.3);
}
.mp-resp-role { font-size: 9px; color: #6b7280; font-weight: 500; letter-spacing: 0.5px; }
.mp-resp-name { font-size: 13px; font-weight: 700; color: #1f2937; line-height: 1.2; }
.mp-resp-doc  { font-size: 9px; color: #6b7280; }
.mp-logo-bg {
  width: 100px; height: 28px; margin-top: 8px;
  background: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTYuNTYiPjx0ZXh0IHg9IjAiIHk9IjEzIiBmb250LXNpemU9IjEyIiBmb250LWZhbWlseT0iQXJpYWwiIGZpbGw9IiMyYjQ1ZmIiIGZvbnQtd2VpZ2h0PSJib2xkIj5NZXUgUG1vYzwvdGV4dD48L3N2Zz4=') center/contain no-repeat;
}

.mp-list {
  margin: 0 10px 10px;
  background: #fff; border-radius: 14px;
  border: 1px solid #e5e7eb; overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}
.mp-list-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px;
  border-bottom: 1px solid #f3f4f6;
  text-decoration: none; color: #1f2937;
}
.mp-list-item:last-child { border-bottom: none; }
.mp-list-icon {
  width: 28px; height: 28px; border-radius: 50%;
  background: linear-gradient(135deg,#2b45fb,#018cfb);
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 12px; flex-shrink: 0;
}
.mp-li-t { font-size: 11px; font-weight: 500; }
.mp-li-s { font-size: 9px; color: #6b7280; margin-top: 1px; }

.mp-hr { border: none; border-top: 1px solid #e5e7eb; margin: 4px 10px 4px; }

.mp-stats-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
  margin: 0 10px 10px;
}
.mp-stat-card {
  background: #fff; border-radius: 12px; border: 1px solid #e5e7eb;
  padding: 12px 8px; text-align: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}
.mp-stat-link { cursor: pointer; }
.mp-scn { display: block; font-size: 20px; font-weight: 700; color: #2b45fb; }
.mp-scl { display: block; font-size: 9px; color: #6b7280; margin-top: 2px; line-height: 1.3; }

.mp-actions-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
  margin: 0 10px 60px;
}
.mp-action {
  background: #fff; border-radius: 12px; border: 1px solid #e5e7eb;
  padding: 14px 8px; text-align: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.05);
}
.mp-act-icon {
  width: 34px; height: 34px; border-radius: 10px;
  background: linear-gradient(135deg,#2b45fb,#018cfb);
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 14px; margin: 0 auto 8px;
  box-shadow: 0 4px 10px rgba(43,69,251,0.3);
}
.mp-act-t { font-size: 11px; font-weight: 600; color: #1f2937; }
.mp-act-s { font-size: 9px; color: #6b7280; margin-top: 2px; line-height: 1.2; }

.mp-login-section {
  text-align: center; padding: 8px 10px 14px;
}
.mp-login-btn {
  display: inline-flex; align-items: center; gap: 6px;
  background: linear-gradient(135deg,#2b45fb,#0ea5e9);
  color: #fff; padding: 10px 22px; border-radius: 12px;
  font-weight: 600; font-size: 12px;
  box-shadow: 0 6px 16px rgba(43,69,251,0.35);
}

.mp-footer {
  margin: 4px 10px 16px;
  background: linear-gradient(135deg,#2b45fb,#018cfb);
  border-radius: 14px; padding: 16px 12px;
  text-align: center; color: #fff;
}
.mp-footer-logo {
  width: 40px; height: 40px; border-radius: 10px;
  margin-bottom: 8px; display: block; margin: 0 auto 8px;
}
.mp-footer-title { font-size: 11px; font-weight: 700; margin-bottom: 4px; }
.mp-footer-info  { font-size: 9px; opacity: .85; line-height: 1.6; }

.mp-fabs {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  display: flex; gap: 8px; padding: 10px 10px 30px;
  background: linear-gradient(to top, rgba(245,248,250,0.98) 70%, transparent);
  pointer-events: none;
  z-index: 20;
}
.mp-fab {
  flex: 1; display: flex; align-items: center; justify-content: center;
  gap: 6px; padding: 12px 8px; border-radius: 10px;
  font-size: 13px; font-weight: 700; color: #fff;
  text-align: center; line-height: 1.3;
  box-shadow: 0 6px 20px rgba(0,0,0,0.2);
  pointer-events: all;
}
.mp-fab-red  { background: linear-gradient(135deg,#e8394a,#c9253a); cursor:pointer; box-shadow: 0 4px 16px rgba(201,37,58,0.4); animation: fabBeat 1.4s ease-in-out infinite; }
.mp-fab-teal { background: rgba(255,255,255,0.92); border: 1px solid #2b45fb; color: #2b45fb; backdrop-filter: blur(8px); }
@keyframes fabBeat {
  0%,100% { transform: scale(1); box-shadow: 0 4px 16px rgba(201,37,58,0.4); }
  14%     { transform: scale(1.07); box-shadow: 0 6px 22px rgba(201,37,58,0.55); }
  28%     { transform: scale(1); box-shadow: 0 4px 16px rgba(201,37,58,0.4); }
  42%     { transform: scale(1.05); box-shadow: 0 6px 20px rgba(201,37,58,0.50); }
  56%     { transform: scale(1); box-shadow: 0 4px 16px rgba(201,37,58,0.4); }
}

/* TELA DE CHAMADO — dentro do mockup */
.mp-chamado-screen {
  display: none;
  position: absolute;
  inset: 0;
  background: #f4f6ff;
  overflow-y: auto;
  z-index: 25;
  flex-direction: column;
}
.mp-chamado-screen::-webkit-scrollbar { display: none; }

/* TOAST de sucesso dentro do mockup */
.mp-toast-mockup {
  position: absolute;
  bottom: 16px; left: 10px; right: 10px;
  z-index: 30;
  background: #fff;
  border-radius: 12px;
  padding: 10px 12px;
  display: flex;
  align-items: center;
  gap: 10px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.18);
  border-left: 3px solid #10b981;
  transform: translateY(80px);
  opacity: 0;
  transition: transform 0.4s cubic-bezier(0.34,1.56,0.64,1), opacity 0.3s ease;
  pointer-events: none;
}
.mp-toast-mockup.mp-toast-show {
  transform: translateY(0);
  opacity: 1;
}
.mp-toast-icon {
  width: 28px; height: 28px; border-radius: 50%;
  background: rgba(16,185,129,0.12);
  display: flex; align-items: center; justify-content: center;
  color: #10b981; font-size: 13px; flex-shrink: 0;
}
.mp-toast-text { flex: 1; }
.mp-toast-title { font-size: 10px; font-weight: 700; color: #1f2937; }
.mp-toast-sub   { font-size: 8px; color: #6b7280; margin-top: 2px; line-height: 1.3; }

/* TOAST de aviso (sem manutenções) */
.mp-toast-warn {
  border-left-color: #f97316;
}
.mp-toast-warn .mp-toast-icon {
  background: rgba(249,115,22,0.12);
  color: #f97316;
}

/* MÃO ANIMADA acima do FAB de assistência */
#mpFabHand {
  position: absolute;
  bottom: 100px;
  left: 40px;
  display: none;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  z-index: 22;
}
#mpFabHandIcon {
  font-size: 32px;
  color: #2b45fb;
  filter: drop-shadow(0 2px 8px rgba(43,69,251,0.45));
  opacity: 0;
}

  height: 100%;
  display: flex;
  flex-direction: column;
  background: #fff;
  position: relative;
}

.iframe-addressbar {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 7px 10px;
  background: #f3f4f6;
  border-bottom: 1px solid #e5e7eb;
  flex-shrink: 0;
}
.iframe-addr-dot {
  width: 7px; height: 7px; border-radius: 50%;
}
.iframe-addr-dot.red    { background: #ef4444; }
.iframe-addr-dot.yellow { background: #f59e0b; }
.iframe-addr-dot.green  { background: #10b981; }

.iframe-addr-url {
  flex: 1;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 5px;
  padding: 3px 8px;
  font-size: 9px;
  color: #374151;
  font-family: var(--font-mono);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-left: 4px;
}

.iframe-site {
  width: 100%;
  flex: 1;
  border: none;
  display: block;
  background: #fff;
}

/* Overlay de toques */
.touch-overlay {
  position: absolute;
  top: 30px; /* abaixo da address bar */
  left: 0; right: 0; bottom: 0;
  pointer-events: none;
  z-index: 99;
  overflow: hidden;
}

/* Cursor/dedo */
.touch-cursor {
  position: absolute;
  width: 32px; height: 32px;
  transform: translate(-50%, -50%);
  pointer-events: none;
  opacity: 0;
  transition: left 0.6s cubic-bezier(0.4,0,0.2,1), top 0.6s cubic-bezier(0.4,0,0.2,1), opacity 0.3s;
}
.touch-cursor.visible { opacity: 1; }

.touch-ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 2px solid rgba(43,69,251,0.6);
  background: rgba(43,69,251,0.08);
}
.touch-dot {
  position: absolute;
  top: 50%; left: 50%;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: rgba(43,69,251,0.8);
  transform: translate(-50%, -50%);
}

/* Ripple ao tocar */
.touch-ripple {
  position: absolute;
  width: 0; height: 0;
  border-radius: 50%;
  background: rgba(43,69,251,0.25);
  transform: translate(-50%, -50%);
  pointer-events: none;
}
.touch-ripple.tapping {
  animation: touchRipple 0.5s ease-out forwards;
}
.touch-ripple.hidden { display: none; }

@keyframes touchRipple {
  0%   { width: 0;    height: 0;    opacity: 0.6; }
  100% { width: 60px; height: 60px; opacity: 0; }
}

  height: 20px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding-bottom: 6px;
  background: transparent;
  flex-shrink: 0;
}
.home-indicator::after {
  content: '';
  width: 100px; height: 4px;
  background: rgba(255,255,255,0.3);
  border-radius: 2px;
}

/* Floating badges fora do iPhone */
.device-float {
  position: absolute;
  background: rgba(255,255,255,0.96);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(43,69,251,0.12);
  border-radius: 14px;
  padding: 10px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  box-shadow: 0 4px 24px rgba(43,69,251,0.13);
  white-space: nowrap;
  z-index: 10;
}
.device-float.f1 {
  top: 20px; right: -10px;
  animation: floatBob 3s ease-in-out infinite;
}
.device-float.f2 {
  bottom: 80px; left: -10px;
  animation: floatBob 3s ease-in-out infinite;
  animation-delay: 1.5s;
}
.df-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #22c55e;
  box-shadow: 0 0 0 3px rgba(34,197,94,0.2);
  flex-shrink: 0;
  animation: pulse 2s infinite;
}
.df-content small {
  display: block;
  font-size: 9px;
  color: var(--muted);
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.df-content strong {
  display: block;
  font-size: 12px;
  font-weight: 700;
  color: var(--text);
}

@media(min-width:900px) {
  .hero-visual { order: 0; }
}

section { position: relative; z-index: 1; }

.container { max-width: 1100px; margin: 0 auto; padding: 0 20px; }

.section-label {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--primary);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.section-label::before {
  content: '';
  display: block;
  width: 20px; height: 1px;
  background: var(--primary);
}

.section-title {
  font-family: var(--font-display);
  font-size: clamp(28px, 4vw, 46px);
  font-weight: 900;
  letter-spacing: -0.03em;
  line-height: 1.1;
  margin-bottom: 16px;
  color: var(--text);
}

.section-sub { color: var(--muted); font-size: 16px; line-height: 1.7; max-width: 560px; }

/* INDUSTRIES */
.industries {
  padding: 60px 0;
  border-top: 1px solid var(--glass-border);
  border-bottom: 1px solid var(--glass-border);
  background: rgba(255,255,255,0.5);
}

.industries-label {
  text-align: center;
  font-family: var(--font-mono);
  font-size: 11px;
  color: rgba(15,21,64,0.3);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 36px;
}

.industries-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
}

.industry-chip {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 100px;
  padding: 10px 20px;
  font-size: 13px;
  color: var(--muted);
  transition: all .25s;
  cursor: default;
  box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
}
.industry-chip:hover {
  background: rgba(43,69,251,0.07);
  border-color: rgba(43,69,251,0.25);
  color: var(--primary);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(43,69,251,0.12);
}
.industry-chip-icon {
  font-size: 15px;
  width: 20px;
  text-align: center;
  color: var(--primary);
}
.how-card-icon i { font-size: 15px; }
.feature-icon i   { font-size: 20px; }
.float-badge-icon i { font-size: 15px; }
.test-stars i { font-size: 12px; letter-spacing: 1px; }

/* HOW IT WORKS */
.how { padding: 72px 0; background: linear-gradient(180deg, transparent, rgba(43,69,251,0.02) 50%, transparent); }

.how-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
  align-items: start;
  margin-top: 0;
}

.steps-list { display: flex; flex-direction: column; gap: 0; }

.step {
  display: flex;
  gap: 24px;
  padding: 28px 0;
  border-bottom: 1px solid var(--glass-border);
  position: relative;
  transition: all .25s;
}
.step:last-child { border-bottom: none; }
.step:hover .step-num { background: var(--primary); color: #fff; border-color: var(--primary); }

.step-num {
  width: 44px; height: 44px;
  background: rgba(43,69,251,0.07);
  border: 1.5px solid rgba(43,69,251,0.18);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 900;
  color: var(--primary);
  flex-shrink: 0;
  transition: all .25s;
}
.step-content h3 { font-family: var(--font-display); font-size: 16px; font-weight: 700; margin-bottom: 8px; letter-spacing: -0.02em; color: var(--text); }
.step-content p  { font-size: 14px; color: var(--muted); line-height: 1.65; }

.how-visual { position: relative; display: flex; flex-direction: column; gap: 8px; margin-top: 0 !important; padding-top: 0 !important; align-self: start !important; }

.how-card {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  padding: 20px 24px;
  position: relative;
  overflow: hidden;
  transition: all .3s;
  box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
}
.how-card:hover { border-color: rgba(43,69,251,0.22); box-shadow: var(--shadow-md); transform: translateY(-2px); }
.how-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--primary), transparent);
  opacity: 0;
  transition: opacity .3s;
}
.how-card:hover::before { opacity: 1; }

.how-card-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.how-card-icon {
  width: 36px; height: 36px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
}
.how-card-title { font-weight: 600; font-size: 14px; color: var(--text); }
.how-card-sub   { font-size: 12px; color: var(--muted); }

.how-card-list  { display: flex; flex-direction: column; gap: 4px; }
.how-card-item  { display: flex; align-items: center; gap: 10px; font-size: 12px; color: var(--muted); }
.how-card-item::before {
  content: '';
  width: 4px; height: 4px;
  background: var(--primary);
  border-radius: 50%;
  flex-shrink: 0;
}

.how-card-big { transform: translateX(20px); border-color: rgba(1,140,251,0.18); }

/* FEATURES */
.features { padding: 72px 0; }

.features-header { text-align: center; margin-bottom: 70px; }
.features-header .section-label { justify-content: center; }
.features-header .section-label::before { display: none; }
.features-header .section-sub { margin: 0 auto; }

.features-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}

.feature-card {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  padding: 32px;
  position: relative;
  overflow: hidden;
  transition: all .3s;
  cursor: default;
  box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
}
.feature-card:hover {
  transform: translateY(-4px);
  border-color: rgba(43,69,251,0.2);
  box-shadow: var(--shadow-md);
}
.feature-card.accent-blue2:hover { border-color: rgba(1,140,251,0.22); }
.feature-card.accent-accent:hover { border-color: rgba(0,176,228,0.22); }

.feature-card-glow {
  position: absolute;
  top: -60px; right: -60px;
  width: 160px; height: 160px;
  border-radius: 50%;
  opacity: 0;
  transition: opacity .4s;
  filter: blur(40px);
}
.feature-card:hover .feature-card-glow { opacity: 0.4; }
.feature-card:not(.accent-blue2):not(.accent-accent) .feature-card-glow { background: var(--primary); }
.accent-blue2 .feature-card-glow  { background: var(--secondary); }
.accent-accent .feature-card-glow { background: var(--accent); }

.feature-icon {
  width: 52px; height: 52px;
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px;
  margin-bottom: 20px;
  background: rgba(43,69,251,0.08);
  border: 1px solid rgba(43,69,251,0.15);
  color: var(--primary);
}
.accent-blue2 .feature-icon  { background: rgba(1,140,251,0.08);  border-color: rgba(1,140,251,0.18);  color: var(--secondary); }
.accent-accent .feature-icon { background: rgba(0,176,228,0.08);  border-color: rgba(0,176,228,0.18);  color: var(--accent);    }

.feature-title { font-family: var(--font-display); font-size: 16px; font-weight: 700; margin-bottom: 10px; letter-spacing: -0.02em; color: var(--text); }
.feature-desc  { font-size: 13px; color: var(--muted); line-height: 1.7; }

.feature-tag {
  display: inline-block;
  margin-top: 16px;
  font-family: var(--font-mono);
  font-size: 10px;
  padding: 4px 10px;
  border-radius: 100px;
  background: rgba(43,69,251,0.07);
  color: var(--primary);
  border: 1px solid rgba(43,69,251,0.15);
}
.accent-blue2 .feature-tag  { background: rgba(1,140,251,0.07);  color: var(--secondary); border-color: rgba(1,140,251,0.18); }
.accent-accent .feature-tag { background: rgba(0,176,228,0.07);  color: var(--accent);    border-color: rgba(0,176,228,0.18); }

.feature-card-wide {
  grid-column: span 1;
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  align-items: center;
}
.feature-card-wide .feature-icon { margin-bottom: 0; }
.feature-wide-left  { display: flex; flex-direction: column; }
.feature-wide-right {
  background: rgba(43,69,251,0.04);
  border: 1px solid rgba(43,69,251,0.08);
  border-radius: 14px;
  padding: 20px;
}

.feature-timeline { display: flex; flex-direction: column; gap: 12px; }
.timeline-item { display: flex; gap: 12px; align-items: flex-start; }
.timeline-dot  { width: 8px; height: 8px; border-radius: 50%; margin-top: 5px; flex-shrink: 0; }
.timeline-item:nth-child(1) .timeline-dot { background: var(--secondary); }
.timeline-item:nth-child(2) .timeline-dot { background: var(--primary); }
.timeline-item:nth-child(3) .timeline-dot { background: var(--accent); }
.timeline-item:nth-child(4) .timeline-dot { background: rgba(15,21,64,0.15); }

.timeline-text { font-size: 12px; color: var(--muted); }
.timeline-date { font-family: var(--font-mono); font-size: 10px; color: rgba(15,21,64,0.3); margin-top: 2px; }

/* STATS */
.stats { padding: 64px 0; position: relative; background: linear-gradient(135deg, rgba(43,69,251,0.04) 0%, rgba(1,140,251,0.03) 100%); }
.stats::before {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 600px; height: 400px;
  background: radial-gradient(ellipse, rgba(43,69,251,0.07) 0%, transparent 70%);
  pointer-events: none;
}

.stats-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2px;
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  overflow: hidden;
  background: var(--glass-border);
  box-shadow: var(--shadow-md);
}

.stat-box {
  background: #fff;
  padding: 28px 20px;
  text-align: center;
  transition: background .3s;
}
.stat-box:hover { background: rgba(43,69,251,0.04); }

.stat-number {
  font-family: var(--font-display);
  font-size: 34px;
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: 1;
  margin-bottom: 8px;
}
.stat-box:nth-child(1) .stat-number { color: var(--primary); }
.stat-box:nth-child(2) .stat-number { color: var(--secondary); }
.stat-box:nth-child(3) .stat-number { color: var(--accent); }
.stat-box:nth-child(4) .stat-number { color: var(--primary); }

.stat-label { font-size: 13px; color: var(--muted); line-height: 1.5; }

/* COMPARE */
.compare { padding: 72px 0; }

.compare-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 40px;
}

.compare-col {
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid var(--glass-border);
  box-shadow: var(--shadow);
  background: var(--glass);
  backdrop-filter: blur(10px);
}

.compare-col-header {
  padding: 24px 28px;
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.01em;
  display: flex;
  align-items: center;
  gap: 10px;
}
.compare-col.old .compare-col-header { background: rgba(239,68,68,.07); color: rgba(220,38,38,.85); border-bottom: 1px solid rgba(239,68,68,.14); }
.compare-col.new .compare-col-header { background: rgba(43,69,251,.08); color: var(--primary); border-bottom: 1px solid rgba(43,69,251,.14); }

.compare-items { padding: 8px 0; }

.compare-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 28px;
  font-size: 14px;
  border-bottom: 1px solid var(--glass-border);
  transition: background .2s;
}
.compare-item:last-child { border-bottom: none; }
.compare-col.old .compare-item { color: rgba(15,21,64,0.3); }
.compare-col.new .compare-item { color: var(--text); }
.compare-col.new .compare-item:hover { background: rgba(43,69,251,0.04); }

.compare-icon {
  width: 22px; height: 22px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  flex-shrink: 0;
}
.compare-col.old .compare-icon { background: rgba(15,21,64,0.06); color: rgba(15,21,64,0.25); }
.compare-col.new .compare-icon { background: rgba(43,69,251,0.1);  color: var(--primary); }

/* TESTIMONIALS */
.testimonials { padding: 72px 0; background: linear-gradient(180deg, transparent, rgba(1,140,251,0.03) 50%, transparent); }

.testimonials-header { text-align: center; margin-bottom: 60px; }
.testimonials-header .section-label { justify-content: center; }
.testimonials-header .section-label::before { display: none; }

.test-grid { display: grid; grid-template-columns: 1fr; gap: 16px; }

.test-card {
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  padding: 28px;
  transition: all .3s;
  box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
}
.test-card:hover { border-color: rgba(43,69,251,0.2); transform: translateY(-3px); box-shadow: var(--shadow-md); }

.test-stars { color: #f59e0b; font-size: 13px; letter-spacing: 2px; margin-bottom: 14px; }
.test-text  { font-size: 14px; color: var(--muted); line-height: 1.75; margin-bottom: 20px; }

.test-author { display: flex; align-items: center; gap: 12px; }
.test-avatar {
  width: 38px; height: 38px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  font-weight: 700;
  font-family: var(--font-display);
  flex-shrink: 0;
}
.test-name { font-size: 13px; font-weight: 600; margin-bottom: 2px; color: var(--text); }
.test-role { font-size: 11px; color: var(--muted); font-family: var(--font-mono); }

/* CTA */
.cta { padding: 72px 0; }

.cta-box {
  background: linear-gradient(135deg, rgba(43,69,251,0.06) 0%, rgba(1,140,251,0.04) 100%);
  border: 1.5px solid rgba(43,69,251,0.18);
  border-radius: 28px;
  padding: 44px 24px;
  text-align: center;
  position: relative;
  overflow: hidden;
  box-shadow: 0 20px 80px rgba(43,69,251,0.1);
}
.cta-box::before {
  content: '';
  position: absolute;
  top: -80px; left: 50%;
  transform: translateX(-50%);
  width: 500px; height: 400px;
  background: radial-gradient(circle, rgba(43,69,251,0.1) 0%, transparent 70%);
  pointer-events: none;
}
.cta-box .section-label { justify-content: center; }
.cta-box .section-label::before { display: none; }
.cta-box .section-title { font-size: clamp(32px, 4vw, 52px); }
.cta-box .section-sub { margin: 0 auto 40px; }

.cta-actions { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }
.cta-note { margin-top: 24px; font-size: 12px; color: rgba(15,21,64,0.25); font-family: var(--font-mono); letter-spacing: 0.04em; }

/* FOOTER */
footer {
  border-top: 1px solid var(--glass-border);
  padding: 60px 0 40px;
  position: relative;
  z-index: 1;
  background: rgba(255,255,255,0.6);
  backdrop-filter: blur(10px);
}

.footer-inner { display: grid; grid-template-columns: 1fr; gap: 32px; margin-bottom: 48px; }

.footer-brand p { font-size: 13px; color: var(--muted); line-height: 1.7; margin-top: 14px; max-width: 260px; }

.footer-col h4 {
  font-family: var(--font-display);
  font-size: 12px; font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(15,21,64,0.35);
  margin-bottom: 16px;
}
.footer-col ul  { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.footer-col a   { color: var(--muted); text-decoration: none; font-size: 13px; transition: color .2s; }
.footer-col a:hover { color: var(--primary); }

.footer-bottom {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 24px;
  border-top: 1px solid var(--glass-border);
  font-size: 12px;
  color: rgba(15,21,64,0.25);
  font-family: var(--font-mono);
}
.footer-bottom-powered { display: flex; align-items: center; gap: 8px; }
.footer-bottom-powered a { color: var(--primary); text-decoration: none; opacity: 0.7; transition: opacity .2s; }
.footer-bottom-powered a:hover { opacity: 1; }

/* BOTÃO PLAY */
.hero-play-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  padding: 20px 0 4px;
}

.hero-play-badge {
  display: none;
  align-items: center;
  gap: 8px;
  background: rgba(43,69,251,0.07);
  border: 1px solid rgba(43,69,251,0.18);
  border-radius: 100px;
  padding: 8px 18px;
  font-size: 12px;
  font-family: var(--font-mono);
  color: var(--primary);
  letter-spacing: 0.04em;
  white-space: nowrap;
  animation: fadeUp 0.5s ease both;
}

.hero-play-badge i {
  animation: bounceDown 1.2s ease-in-out infinite;
}

@keyframes bounceDown {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(4px); }
}

.hero-play-btn {
  display: none;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  background: linear-gradient(135deg, var(--primary), var(--secondary));
  border: none;
  border-radius: 50%;
  color: #fff;
  font-size: 18px;
  cursor: pointer;
  box-shadow: 0 6px 24px rgba(43,69,251,0.35);
  transition: all 0.25s;
  animation: fadeUp 0.5s 0.15s ease both;
  padding-left: 3px; /* compensa visual do play */
}

.hero-play-btn:hover {
  transform: scale(1.1);
  box-shadow: 0 10px 36px rgba(43,69,251,0.45);
}

.hero-play-btn:active {
  transform: scale(0.96);
}

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

.reveal { opacity: 0; transform: translateY(16px); transition: opacity .3s ease, transform .3s ease; }
.reveal.visible { opacity: 1; transform: none; }

/* ── 480px+ ── */
@media(min-width:480px){
  .features-grid{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:1fr 1fr;border-radius:20px}
  .hero-actions{flex-direction:column;gap:14px;max-width:500px}
  .footer-inner{grid-template-columns:1fr 1fr}
}

/* ── 680px+ ── */
@media(min-width:680px){
  .compare-inner{grid-template-columns:1fr 1fr}
  .test-grid{grid-template-columns:1fr 1fr}
  .features-grid{grid-template-columns:repeat(3,1fr)}
  .feature-card-wide{grid-column:span 2;grid-template-columns:1fr 1fr}
}

/* ── 900px+ : desktop ── */
@media(min-width:900px){
  nav{padding:18px 40px}
  .container{padding:0 40px}
  .nav-burger{display:none}
  .nav-links{display:flex}
  .hero{padding:120px 40px 60px}
  .hero-inner{grid-template-columns:1.6fr 0.4fr;gap:40px}
  .hero-visual{order:0;justify-content:flex-end}
  .hero-actions{flex-direction:column;gap:14px;max-width:500px}
  .how{padding:120px 0}
  .how-grid{grid-template-columns:1fr 1fr;gap:80px;margin-top:0;align-items:start}
  .how-visual{display:flex;margin-top:0 !important;padding-top:0 !important;align-self:start !important}
  .features{padding:120px 0}
  .features-grid{grid-template-columns:repeat(3,1fr);gap:20px}
  .feature-card-wide{grid-column:span 2;grid-template-columns:1fr 1fr}
  .stats{padding:100px 0}
  .stats-grid{grid-template-columns:repeat(4,1fr);border-radius:24px}
  .stat-box{padding:22px 24px}
  .stat-number{font-size:48px}
  .compare{padding:120px 0}
  .compare-inner{grid-template-columns:1fr 1fr;gap:24px;margin-top:60px}
  .testimonials{padding:120px 0}
  .test-grid{grid-template-columns:repeat(3,1fr);gap:14px}
  .cta{padding:120px 0}
  .cta-box{padding:80px 60px;border-radius:28px}
  .footer-inner{grid-template-columns:2fr 1fr 1fr 1fr;gap:40px}
  .footer-bottom{flex-direction:row}
  .qr-phone-frame{width:280px;height:560px}
}

/* DEDO ANIMADO (último slide) */
.finger-overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 99;
  overflow: hidden;
}
.finger-cursor {
  position: absolute;
  width: 36px; height: 36px;
  transform: translate(-50%, -50%);
  opacity: 0;
  pointer-events: none;
  transition: top 0.6s cubic-bezier(0.4,0,0.2,1), opacity 0.3s;
}
.finger-ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 2px solid rgba(43,69,251,0.5);
  background: rgba(43,69,251,0.08);
}
.finger-dot {
  position: absolute;
  top: 50%; left: 50%;
  width: 10px; height: 10px;
  border-radius: 50%;
  background: rgba(43,69,251,0.75);
  transform: translate(-50%, -50%);
  box-shadow: 0 0 8px rgba(43,69,251,0.5);
}

.slide-float {
  position: absolute;
  background: rgba(255,255,255,0.96);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(43,69,251,0.12);
  border-radius: 14px;
  padding: 10px 14px;
  display: none;
  align-items: center;
  gap: 10px;
  box-shadow: 0 4px 24px rgba(43,69,251,0.13);
  white-space: nowrap;
  z-index: 10;
}
.slide-float.visible {
  display: flex;
  animation: slideFloatIn 0.5s cubic-bezier(0.34,1.56,0.64,1) both, floatBob 3s ease-in-out 0.5s infinite;
}
#sf0 { top: 240px;    right: 100px; }
#sf1 { bottom: 180px; left: 8px; }
#sf2 { top: 260px;    right: 8px; }
#sf3 { bottom: 120px; left: 8px; }
#sf4 { bottom: 130px; left: 8px; }
#sf5 { top: 260px; right: 8px; max-width: 180px; }
@keyframes slideFloatIn {
  from { opacity:0; transform:scale(0.7) translateY(10px); }
  to   { opacity:1; transform:scale(1)   translateY(0); }
}
/* BOTÃO PLAY */
.hero-play-wrap { display:flex; flex-direction:column; align-items:center; padding:16px 0 4px; }
.hero-play-btn {
  display:none; align-items:center; justify-content:center;
  width:52px; height:52px;
  background:linear-gradient(135deg,#2b45fb,#018cfb);
  border:none; border-radius:50%; color:#fff; font-size:18px;
  cursor:pointer; box-shadow:0 6px 24px rgba(43,69,251,0.35);
  transition:all 0.25s; padding-left:3px;
}
.hero-play-btn:hover { transform:scale(1.1); }



/* ═══════════════════════════════════════════════════════════
   14B · SCROLL SNAP — BLOCOS TRAVADOS
   Cada seção principal = 100vh + snap.
   Seções densas têm snap no topo mas crescem livremente.
   Tiras accent (stats, industries) ficam fora do snap
   para não quebrar o ritmo de navegação.
   ═══════════════════════════════════════════════════════════ */

html {
  scroll-snap-type: y mandatory;
}

/* ── Seções com snap + altura mínima de tela ── */
.hero {
  scroll-snap-align: start;
  /* min-height já definido como 100svh */
}
.video-section {
  scroll-snap-align: start;
  padding-top: 120px;
}
.how {
  scroll-snap-align: start;
  min-height: 100vh;
  padding-top: 100px;
  padding-bottom: 80px;
}
.art-section {
  scroll-snap-align: start;
  min-height: 100vh;
  padding-top: 120px;
  padding-bottom: 80px;
}
.ai-section {
  scroll-snap-align: start;
  min-height: 100vh;
  padding-top: 120px;
  padding-bottom: 80px;
}
.gov-section {
  scroll-snap-align: start;
  min-height: 100vh;
  padding-top: 100px;
  padding-bottom: 80px;
}
.testimonials {
  scroll-snap-align: start;
  min-height: 100vh;
  padding-top: 100px;
  padding-bottom: 80px;
}
.cta {
  scroll-snap-align: start;
  min-height: 70vh;
}
footer {
  scroll-snap-align: start;
}

/* ── Seções densas: snap no topo, altura natural ── */
.pain      { scroll-snap-align: start; padding-top: 100px; padding-bottom: 100px; }
.features  { scroll-snap-align: start; padding-top: 100px; padding-bottom: 100px; }
.compare   { scroll-snap-align: start; padding-top: 100px; padding-bottom: 100px; }
.benefits  { scroll-snap-align: start; padding-top: 100px; padding-bottom: 100px; }
.pricing   { scroll-snap-align: start; padding-top: 100px; padding-bottom: 100px; }
.faq       { scroll-snap-align: start; padding-top: 100px; padding-bottom: 100px; }
.photos-section { scroll-snap-align: start; padding-top: 100px; padding-bottom: 100px; }

/* ── Tiras accent: SEM snap — fluem entre seções ── */
.stats       { scroll-snap-align: none; padding-top: 80px; padding-bottom: 80px; }


/* ── Indicador de scroll no hero ── */
.b14-scroll-hint {
  position: absolute;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 7px;
  z-index: 20;
  pointer-events: none;
  animation: b14HintFloat 2.2s ease-in-out infinite;
}
.b14-scroll-hint-label {
  font-family: var(--fm);
  font-size: 10px;
  color: var(--primary);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  opacity: 0.55;
}
.b14-scroll-hint-arrow {
  width: 32px;
  height: 32px;
  border: 1.5px solid rgba(43,69,251,0.25);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(43,69,251,0.05);
  backdrop-filter: blur(8px);
}
.b14-scroll-hint-arrow i {
  color: var(--primary);
  font-size: 11px;
  opacity: 0.7;
}
@keyframes b14HintFloat {
  0%, 100% { opacity: 0.6; transform: translateX(-50%) translateY(0);   }
  50%       { opacity: 1;   transform: translateX(-50%) translateY(10px); }
}

/* ── Dots de progresso lateral ── */
.b14-progress {
  position: fixed;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  gap: 8px;
  z-index: 900;
  pointer-events: none;
}
.b14-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: rgba(43,69,251,0.18);
  transition: background 0.3s, transform 0.3s;
}
.b14-dot.active {
  background: var(--primary);
  transform: scale(1.7);
}
/* ── Landscape mobile: desativa snap e 100vh ── */
@media (max-height:500px) and (orientation:landscape) {
  html { scroll-snap-type: none; }
  section { min-height: unset !important; height: auto !important; scroll-snap-align: none !important; }
  .hero { min-height: 100svh; padding-top: 120px; }
  .b14-progress, .b14-scroll-hint { display: none; }
}

/* ── Respeita preferência do sistema por menos animação ── */
@media (prefers-reduced-motion:reduce) {
  *, *::before, *::after { animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; scroll-behavior:auto !important; }
  html { scroll-snap-type: none; }
}

/* ── Focus visible — navegação por teclado ── */
:focus-visible { outline:2px solid var(--primary); outline-offset:3px; border-radius:4px; }

/* ── iPhone mockup: escalar em telas muito pequenas ── */
@media (max-width:480px) {
  /* hero: sem overflow que esconde o phone */
  .hero { overflow:visible; padding-top:120px; }
  .hero-inner { overflow:visible; }
  .hero-visual {
    order: 1;
    width: 100%;
    max-width: 100%;
    overflow: visible;
  }
  .device-stage {
    padding: 10px 0;
    width: 100%;
    max-width: 100%;
    overflow: visible;
    justify-content: center;
  }
  .iphone-wrap {
    transform: scale(0.72);
    transform-origin: center top;
  }
  /* balões e glow somem — eram eles que causavam o scroll */
  .device-float { display:none !important; }
  .device-glow  { display:none; }

  /* texto hero não corta */
  .hero-copy { min-width:0; word-break:break-word; }
  .hero h1   { font-size:clamp(28px,3.6vw,52px); margin-bottom:16px }
  .hero-desc { font-size:14px; }
}
@media (max-width:380px) {
  .iphone { width:240px; height:512px; }
  .iphone-wrap { transform:scale(0.95); transform-origin:center top; }
}

/* Divisória sutil entre seções via ::after */
.how::after,.pain::after,.features::after,
.art-section::after,.compare::after,.benefits::after,.testimonials::after,
.pricing::after,.faq::after,.gov-section::after,.ai-section::after{
  content:'';
  position:absolute;
  left:40px;right:40px;bottom:0;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(43,69,251,.12),transparent);
  pointer-events:none;
}


/* Real photo badge */
.photo-real-badge{position:absolute;top:12px;left:12px;z-index:2;display:inline-flex;align-items:center;gap:6px;background:rgba(15,21,64,.55);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);border-radius:100px;padding:5px 11px;font-family:var(--fm);font-size:10px;font-weight:700;letter-spacing:.06em;color:#fff;text-transform:uppercase}
.photo-real-badge::before{content:'';width:6px;height:6px;background:#10b981;border-radius:50%;flex-shrink:0;box-shadow:0 0 6px rgba(16,185,129,.7)}


/* GALLERY SECTION */
.gallery-tabs{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:24px 0 0}
.gallery-tab{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:100px;font-size:12px;font-weight:700;font-family:var(--fm);letter-spacing:.04em;cursor:pointer;border:1.5px solid var(--glass-border);background:var(--glass);color:var(--muted);transition:all .2s}
.gallery-tab.active,.gallery-tab:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.gallery-tab i{font-size:12px}
.photo-strip-wrap{position:relative;overflow:hidden;margin:40px 0 0}
@keyframes carousel{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.photo-strip{display:flex;gap:16px;width:max-content;animation:carousel 40s linear infinite}
.photo-strip:hover{animation-play-state:paused}
.photo-card{flex:0 0 220px;border-radius:16px;overflow:hidden;position:relative;box-shadow:var(--shadow-md)}
.photo-card img{width:100%;aspect-ratio:3/4;object-fit:cover;display:block;transition:transform .4s}
.photo-card:hover img{transform:scale(1.05)}
.photo-card-caption{position:absolute;bottom:0;left:0;right:0;padding:16px 14px;background:linear-gradient(transparent,rgba(15,21,64,.82));color:#fff}
.photo-card-caption-title{font-size:13px;font-weight:700;font-family:var(--fd);margin-bottom:2px}
.photo-card-caption-sub{font-size:10px;opacity:.8;font-family:var(--fm);line-height:1.4}
.photo-tag{position:absolute;top:10px;right:10px;z-index:2;padding:4px 10px;border-radius:100px;font-size:9px;font-weight:700;font-family:var(--fm);letter-spacing:.06em;text-transform:uppercase;backdrop-filter:blur(10px)}
.photo-tag-problem{background:rgba(239,68,68,.75);color:#fff}
.photo-tag-ok{background:rgba(16,185,129,.75);color:#fff}
.photo-tag-real{background:rgba(43,69,251,.75);color:#fff}


/* QR CODE SECTION */
.qr-section{padding:72px 0;background:#ffffff}
.qr-section-inner{display:grid;grid-template-columns:1fr;gap:56px;align-items:center}
.qr-benefits{display:flex;flex-direction:column;gap:20px;margin-top:8px}
.qr-benefit{display:flex;align-items:flex-start;gap:16px}
.qr-benefit-icon{width:44px;height:44px;border-radius:12px;background:rgba(43,69,251,.08);border:1px solid rgba(43,69,251,.15);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.qr-benefit-title{font-family:var(--fd);font-size:15px;font-weight:800;color:var(--text);margin-bottom:4px;letter-spacing:-.02em}
.qr-benefit-desc{font-size:13px;color:var(--muted);line-height:1.6}
.qr-section-visual{position:relative;display:flex;justify-content:center}
.qr-visual-card{background:#fff;border:1px solid rgba(43,69,251,.15);border-radius:24px;padding:24px;box-shadow:0 20px 60px rgba(43,69,251,.14);width:100%;max-width:340px}
.qr-visual-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px;padding-bottom:16px;border-bottom:1px solid rgba(43,69,251,.08)}
.qr-visual-code{display:flex;flex-direction:column;align-items:center;background:rgba(43,69,251,.03);border:1px solid rgba(43,69,251,.08);border-radius:16px;padding:20px;margin-bottom:14px}
.qr-stat-row{display:flex;gap:8px}
.qr-stat-chip{flex:1;background:rgba(43,69,251,.04);border:1px solid rgba(43,69,251,.08);border-radius:10px;padding:8px 10px;text-align:center}
.qr-stat-label{font-family:var(--fm);font-size:8px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}
.qr-stat-val{font-family:var(--fd);font-size:13px;font-weight:800;color:var(--text)}
@media(min-width:680px){.qr-section-inner{grid-template-columns:1fr 1fr;gap:80px}.qr-section{padding:120px 0}}



/* ── COOKIE BANNER ── */
.lp-cookie-banner{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(120px);z-index:9999;width:min(680px,calc(100vw - 32px));background:rgba(255,255,255,.94);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:16px;box-shadow:0 8px 40px rgba(43,69,251,.14);padding:16px 20px;opacity:0;pointer-events:none;transition:transform .4s cubic-bezier(.16,1,.3,1),opacity .35s ease}
.lp-cookie-banner.lp-cookie-show{transform:translateX(-50%) translateY(0);opacity:1;pointer-events:all}
.lp-cookie-inner{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.lp-cookie-icon{font-size:20px;color:var(--primary);flex-shrink:0}
.lp-cookie-text{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--muted);line-height:1.5;flex:1;min-width:200px}
.lp-cookie-link{color:var(--primary);font-weight:600;text-decoration:none}
.lp-cookie-link:hover{text-decoration:underline}
.lp-cookie-actions{display:flex;gap:8px;flex-shrink:0}
.lp-cookie-btn{border:none;cursor:pointer;font-family:var(--fb);font-size:13px;font-weight:700;padding:9px 18px;border-radius:9px;transition:all .2s;white-space:nowrap}
.lp-cookie-btn--outline{background:transparent;color:var(--muted);border:1.5px solid var(--glass-border)}
.lp-cookie-btn--outline:hover{border-color:var(--muted);color:var(--text)}
.lp-cookie-btn--primary{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;box-shadow:0 4px 14px rgba(43,69,251,.28)}
.lp-cookie-btn--primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(43,69,251,.35)}
@media(max-width:480px){.lp-cookie-inner{flex-direction:column;align-items:flex-start}.lp-cookie-actions{width:100%}.lp-cookie-btn{flex:1;text-align:center}}

/* Desktop section tightenings (ported from LP) */
@media(min-width:900px){
  #como-funciona .features-header{ margin-bottom:12px }
  #como-funciona .section-sub{ margin-bottom:8px; font-size:14px }
  #como-funciona .step{ padding:8px 0 }
  #como-funciona .step-content h3{ margin-bottom:2px }
  #como-funciona .step-content p{ font-size:13px }
  .testimonials{ padding:48px 0 !important }
  .testimonials-header{ margin-bottom:16px !important }
  .test-grid{ gap:12px !important }
  .test-card{ padding:14px 16px }
  .stats-grid{ margin-top:16px }
  .stat-box{ padding:18px 16px !important }
  .stat-num{ font-size:38px !important }
  .pain-cards{ margin-top:16px }
}

/* ── TYPING ANIMATION ── */
.hero-typing-line{
  font-family:var(--fd);
  font-size:clamp(18px,2.5vw,36px);
  font-weight:900;
  line-height:1.15;
  letter-spacing:-.03em;
  margin-bottom:20px;
  animation:fadeUp .35s .12s ease both;
}
.hero-typing-static{ color:var(--text) }
#hero-typed-text{ color:var(--secondary) }
.hero-cursor{
  display:inline-block;
  width:3px;
  height:1em;
  background:var(--secondary);
  margin-left:2px;
  vertical-align:middle;
  border-radius:2px;
  animation:heroBlink .7s step-end infinite;
}
@keyframes heroBlink{0%,100%{opacity:1}50%{opacity:0}}

/* ── DESKTOP SCALE 1024px+ — fontes + blocos ── */
@media(min-width:1024px){

  /* Container mais largo */
  .container{max-width:1240px;padding:0 56px}

  /* Seções — mais respiro vertical */
  .pain,.how,.features,.compare,.testimonials,.benefits,
  .faq,.pricing,.gov-section,.cta,.video-section,
  .art-section,.ai-section,.qr-section,.lp-custo-section{
    padding-top:80px;
    padding-bottom:80px;
  }

  /* Títulos de seção */
  .section-title{font-size:clamp(32px,3.2vw,52px)}
  .section-sub{font-size:16px;max-width:640px}
  .section-label{font-size:12px}

  /* Nav */
  .nav-links a,.nav-login{font-size:14px}
  .nav-cta{font-size:14px;padding:11px 26px}

  /* Hero */
  .hero-desc{font-size:16px;line-height:1.75}
  .hero h1{font-size:clamp(32px,3.8vw,60px)}

  /* Proof bar */
  .proof-num{font-size:38px}
  .proof-label{font-size:12px}
  .proof-item{padding:0 52px}

  /* Stats */
  .stat-num{font-size:52px}
  .stat-lbl{font-size:14px}
  .stat-box{padding:28px 32px}
  .stats-grid{gap:24px}

  /* Grids — mais espaçamento entre cards */
  .features-grid{gap:28px}
  .benefits-grid{gap:28px}
  .test-grid{gap:20px}
  .pricing-grid{gap:28px}
  .faq-grid{gap:20px}
  .compare-inner{gap:32px}
  .how-grid{gap:96px}

  /* Cards de features */
  .feat-card{padding:40px;border-radius:24px}
  .feat-icon{width:64px;height:64px;font-size:26px;border-radius:18px;margin-bottom:24px}
  .feat-title{font-size:18px;margin-bottom:12px}
  .feat-desc{font-size:14px}
  .feat-tag{font-size:11px;padding:5px 13px;margin-top:20px}
  .feat-check{font-size:14px}
  .feat-card.wide{gap:48px}

  /* Cards de benefícios */
  .benefit-card{padding:40px;border-radius:24px}
  .benefit-icon{width:76px;height:76px;font-size:30px;border-radius:22px;margin-bottom:24px}
  .benefit-title{font-size:18px;margin-bottom:12px}
  .benefit-desc{font-size:14px}

  /* Cards de IA */
  .ai-card{padding:36px;border-radius:24px}
  .ai-card-icon{width:60px;height:60px;font-size:24px;border-radius:16px;margin-bottom:22px}
  .ai-card-title{font-size:17px}
  .ai-card-desc{font-size:14px}
  .ai-disclaimer{font-size:14px;max-width:560px}

  /* Comparativo */
  .compare-col-header{padding:28px 36px;font-size:17px}
  .compare-item{padding:18px 36px;font-size:15px}
  .compare-icon{width:26px;height:26px;font-size:12px}

  /* Depoimentos */
  .test-card{padding:24px}
  .test-text{font-size:14px}
  .test-name{font-size:14px}
  .test-role{font-size:12px}

  /* Pain cards */
  .pain-card{padding:16px 20px;border-radius:16px}
  .pain-card-icon{width:42px;height:42px;font-size:16px;border-radius:12px}
  .pain-card-text{font-size:15px}

  /* Steps */
  .step-num{width:46px;height:46px;font-size:15px}
  .step-content h3{font-size:17px}
  .step-content p{font-size:15px}

  /* How cards */
  .how-card-title{font-size:16px}
  .how-card-sub{font-size:13px}
  .how-card-item{font-size:13px}
  .how-card-icon{width:40px;height:40px;font-size:16px}

  /* FAQ */
  .faq-q-text{font-size:15px}
  .faq-a{font-size:15px}

  /* Pricing */
  .pricing-feat{font-size:14px}
  .pricing-btn{font-size:15px;padding:16px}
  .pricing-period{font-size:13px}

  /* Gov / licença */
  .gov-card{padding:32px;border-radius:20px}
  .gov-card-icon{width:52px;height:52px;font-size:22px;border-radius:16px;margin-bottom:18px}
  .gov-card-title{font-size:16px}
  .gov-card-desc{font-size:14px}
  .gov-lic-title{font-size:14px}
  .gov-lic-sub{font-size:12px}
  .gov-lic-highlight-text{font-size:14px}
  .gov-lic-match-text{font-size:13px}
  .gov-cta-sub{font-size:14px}

  /* Labels e rótulos pequenos */
  .gov-cta-label,.gov-trend-chip,.gov-lic-item-label,.feat-tag{font-size:11px}

  /* Footer */
  .footer-col a{font-size:14px}
  .footer-brand p{font-size:14px;max-width:300px}
  .footer-bottom,.footer-slogan{font-size:13px}
  .footer-col h4{font-size:13px}

  /* CTA box */
  .cta-box{padding:100px 80px}
}

/* ============================================================
   PADRÃO VISUAL NOVO — sobrescreve estilos de seção
   Aplicado sobre HTML existente sem alterar estrutura
   ============================================================ */

/* Variáveis adicionais */
:root {
  --surface: rgba(255,255,255,0.82);
  --border:  rgba(43,69,251,0.12);
  --muted-2: rgba(15,21,64,0.42);
  --shadow-sm: 0 8px 28px rgba(43,69,251,0.08);
}

/* Glass — classe utilitária para qualquer card */
.glass {
  background: var(--surface);
  border: 1px solid var(--border);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

/* ── TIPOGRAFIA DE SEÇÃO ─────────────────────────────────── */
.section-label {
  font-family: var(--fm);
  font-size: 11px;
  color: var(--primary);
  letter-spacing: .14em;
  text-transform: uppercase;
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.section-label::before {
  content: '';
  display: block;
  width: 20px;
  height: 1px;
  background: var(--primary);
  flex-shrink: 0;
}
.section-label.center {
  justify-content: center;
}
.section-label.center::before { display: none; }

.section-title {
  font-family: var(--fd);
  font-size: clamp(28px, 4.5vw, 54px);
  font-weight: 900;
  letter-spacing: -.035em;
  line-height: 1.07;
  color: var(--text);
  margin-bottom: 18px;
}
.section-title em {
  font-style: normal;
  color: var(--primary);
}
.section-title span[style*="color:var(--primary)"],
.section-title span[style*="color:var(--secondary)"] {
  font-style: normal;
}

.section-sub {
  color: var(--muted);
  font-size: 16px;
  line-height: 1.75;
  max-width: 560px;
}
.section-sub.center {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

/* ── PADDING PADRÃO DAS SEÇÕES ───────────────────────────── */
.pain, .features, .how, .photos-section,
.testimonials, .benefits, .compare,
.faq, .art-section, .qr-section,
.gov-section, .ai-section { 
  padding: 80px 0; 
}

/* ── PAIN CARDS ──────────────────────────────────────────── */
.pain-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin-top: 28px;
}
.pain-card {
  background: var(--surface);
  border: 1px solid var(--border);
  backdrop-filter: blur(18px);
  border-radius: 18px;
  padding: 18px 20px;
  display: flex;
  gap: 14px;
  align-items: flex-start;
  box-shadow: var(--shadow-sm);
}
.pain-card-icon {
  width: 38px;
  height: 38px;
  flex-shrink: 0;
  border-radius: 12px;
  background: rgba(239,68,68,0.1);
  color: var(--red);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
}
.pain-card-text {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.65;
}
.pain-card-text strong {
  display: block;
  font-size: 15px;
  color: var(--text);
  font-family: var(--fd);
  margin-bottom: 4px;
}

/* ── FEAT CARDS ──────────────────────────────────────────── */
.feat-card {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  backdrop-filter: blur(18px);
  border-radius: 22px !important;
  box-shadow: var(--shadow-sm) !important;
}

/* ── HOW CARDS ───────────────────────────────────────────── */
.how-card {
  background: var(--surface);
  border: 1px solid var(--border);
  backdrop-filter: blur(18px);
  border-radius: 20px;
  box-shadow: var(--shadow-sm);
}

/* ── TESTIMONIALS ────────────────────────────────────────── */
.test-card {
  background: var(--surface);
  border: 1px solid var(--border);
  backdrop-filter: blur(18px);
  border-radius: 22px;
  padding: 28px 24px;
  box-shadow: var(--shadow-sm);
}
.test-stars {
  color: #f59e0b;
  font-size: 13px;
  letter-spacing: 2px;
  margin-bottom: 14px;
}
.test-text {
  font-size: 14px !important;
  color: var(--muted) !important;
  line-height: 1.8 !important;
  margin-bottom: 18px !important;
}
.test-avatar {
  border: 2px solid var(--border);
}
.test-name {
  font-size: 14px;
  font-weight: 700;
}
.test-role {
  font-size: 11px;
  color: var(--muted-2);
  font-family: var(--fm);
}

/* Stats grid */
.stats-grid {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  backdrop-filter: blur(18px) !important;
  border-radius: 22px !important;
  box-shadow: var(--shadow-sm) !important;
}

/* ── BENEFIT CARDS ───────────────────────────────────────── */
.benefit-card {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  backdrop-filter: blur(18px) !important;
  border-radius: 22px !important;
  box-shadow: var(--shadow-sm) !important;
  position: relative;
  overflow: hidden;
}
.benefit-card::after {
  content: '';
  position: absolute;
  inset: auto -40px -40px auto;
  width: 140px; height: 140px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(43,69,251,0.1), transparent 70%);
  pointer-events: none;
}

/* ── COMPARE ─────────────────────────────────────────────── */
.compare-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 36px;
}
.compare-col {
  border-radius: 24px !important;
  overflow: hidden;
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  box-shadow: var(--shadow-sm) !important;
  backdrop-filter: blur(18px) !important;
}
.compare-col-header {
  padding: 18px 22px !important;
  font-family: var(--fd);
  font-size: 16px !important;
  font-weight: 800;
  display: flex !important;
  align-items: center;
  gap: 10px;
  border-bottom: 1px solid var(--border) !important;
}
.compare-col.old .compare-col-header {
  background: rgba(239,68,68,0.08) !important;
  color: #c73737 !important;
}
.compare-col.new .compare-col-header {
  background: rgba(43,69,251,0.08) !important;
  color: var(--primary) !important;
}
.compare-items { padding: 10px 0 !important; }
.compare-item {
  padding: 13px 22px !important;
  border-bottom: 1px solid rgba(15,21,64,0.06) !important;
  font-size: 14px;
  display: flex;
  align-items: flex-start;
  gap: 12px;
}
.compare-item:last-child { border-bottom: 0 !important; }
.compare-icon {
  width: 22px !important; height: 22px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 10px !important;
  flex-shrink: 0;
  margin-top: 2px;
}
.compare-col.old .compare-icon { background: rgba(239,68,68,0.12) !important; color: var(--red) !important; }
.compare-col.new .compare-icon { background: rgba(43,69,251,0.12) !important; color: var(--primary) !important; }

/* ── FAQ ─────────────────────────────────────────────────── */
.faq-item {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 18px !important;
  backdrop-filter: blur(18px) !important;
  overflow: hidden;
}

/* ── QR BENEFITS ─────────────────────────────────────────── */
.qr-benefit {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 16px 18px;
  box-shadow: var(--shadow-sm);
}
.qr-benefit-icon {
  background: rgba(43,69,251,0.09) !important;
  color: var(--primary) !important;
  border-radius: 12px !important;
}

/* ── GOV CARDS ───────────────────────────────────────────── */
.gov-card {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 20px !important;
  box-shadow: var(--shadow-sm) !important;
}

/* ── AI CARDS ────────────────────────────────────────────── */
.ai-card {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 22px !important;
  box-shadow: var(--shadow-sm) !important;
}

/* ── CTA FINAL ───────────────────────────────────────────── */
.cta-box {
  border-radius: 30px !important;
  padding: 56px 40px !important;
  text-align: center;
  background: linear-gradient(135deg, rgba(43,69,251,0.08), rgba(1,140,251,0.05)) !important;
  border: 1px solid rgba(43,69,251,0.14) !important;
  box-shadow: var(--shadow-md) !important;
  position: relative;
  overflow: hidden;
}
.cta-box::before {
  content: '';
  position: absolute;
  top: -120px; left: 50%;
  transform: translateX(-50%);
  width: 420px; height: 320px;
  background: radial-gradient(circle, rgba(43,69,251,0.12), transparent 70%);
  pointer-events: none;
}
.cta-box > * { position: relative; z-index: 1; }
.cta-note {
  margin-top: 18px;
  font-size: 11px;
  color: var(--muted-2);
  font-family: var(--fm);
  letter-spacing: .08em;
}

/* ── RESPONSIVO ──────────────────────────────────────────── */
@media (min-width: 640px) {
  .pain-cards { grid-template-columns: 1fr 1fr; }
  .compare-inner { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 900px) {
  .pain-cards { grid-template-columns: repeat(3, 1fr); }
  .pain, .features, .how, .photos-section,
  .testimonials, .benefits, .compare,
  .faq, .art-section, .qr-section,
  .gov-section, .ai-section { padding: 96px 0; }
}

/* ═══════════════════════════════════════════════════════════════
   COMPONENTES COMPARTILHADOS GPT-STYLE
   Usados em: site, lp, blog, planos
   Não editar aqui isoladamente — alterar reflete em todos os projetos
════════════════════════════════════════════════════════════════ */

/* ── CONTAINER UNIFICADO ── */
.mpgm-container {
  width: min(1120px, calc(100% - 40px));
  margin: 0 auto;
}

/* ── GLASS CARD ── */
.mpgm-glass {
  background: var(--surface);
  border: 1px solid var(--border);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  box-shadow: var(--shadow-sm);
}

/* ── SEÇÃO GENÉRICA ── */
.mpgm-section {
  padding: 108px 0;
  position: relative;
  z-index: 1;
}

/* ── LABEL ── */
.mpgm-label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--fm);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--primary);
  margin-bottom: 18px;
}
.mpgm-label::before { content:''; width:22px; height:1px; background:currentColor; opacity:.8; }
.mpgm-label.center { justify-content:center; width:100%; }
.mpgm-label.center::before { display:none; }

/* ── TITLE ── */
.mpgm-title {
  font-family: var(--fd);
  font-weight: 900;
  line-height: 1.06;
  letter-spacing: -0.04em;
  font-size: clamp(30px, 4vw, 56px);
  margin-bottom: 16px;
  color: var(--text);
}
.mpgm-title .accent  { color: var(--primary); }
.mpgm-title .accent-2{ color: var(--secondary); }

/* ── SUB ── */
.mpgm-sub {
  color: var(--muted);
  font-size: 16px;
  max-width: 640px;
  line-height: 1.75;
  font-family: var(--fb);
}
.mpgm-sub.center { text-align:center; margin-inline:auto; }

/* ── BTNS ── */
.mpgm-btn {
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 24px;
  border-radius: 12px;
  text-decoration: none;
  font-weight: 700;
  font-size: 14px;
  transition: transform .2s ease, box-shadow .2s ease;
  border: 1px solid transparent;
  cursor: pointer;
}
.mpgm-btn:hover { transform: translateY(-2px); }
.mpgm-btn-primary {
  color: #fff;
  background: linear-gradient(135deg, #00c896, #00a878);
  box-shadow: 0 10px 28px rgba(0,168,120,0.34);
}
.mpgm-btn-primary:hover { box-shadow: 0 16px 38px rgba(0,168,120,0.42); }
.mpgm-btn-secondary {
  color: var(--primary);
  background: rgba(255,255,255,0.84);
  border-color: rgba(43,69,251,0.18);
  box-shadow: var(--shadow-sm);
}
.mpgm-btn-row { display:flex; gap:14px; flex-wrap:wrap; }

/* ── REVEAL ── */
.mpgm-reveal { opacity:0; transform:translateY(22px); transition:opacity .55s ease, transform .55s ease; }
.mpgm-reveal.visible { opacity:1; transform:translateY(0); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   MÉTRICAS
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.mpgm-metrics { padding: 14px 0 0; }
.mpgm-metrics-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
.mpgm-metric {
  padding: 22px 16px;
  border-radius: 18px;
  text-align: center;
}
.mpgm-metric strong {
  display: block;
  font-family: var(--fd);
  font-size: clamp(26px, 5vw, 38px);
  line-height: 1;
  color: var(--primary);
  margin-bottom: 6px;
  letter-spacing: -0.04em;
}
.mpgm-metric span {
  display: block;
  font-size: 11px;
  color: var(--muted);
  font-family: var(--fm);
  line-height: 1.6;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   DOR / PROBLEMA
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.mpgm-pain-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  margin-top: 34px;
}
.mpgm-pain-card {
  border-radius: 18px;
  padding: 20px;
  display: flex;
  gap: 14px;
  align-items: flex-start;
}
.mpgm-pain-card i {
  width: 38px;
  height: 38px;
  flex-shrink: 0;
  border-radius: 12px;
  background: rgba(239,68,68,0.1);
  color: var(--red);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
}
.mpgm-pain-card h3 { font-size:15px; line-height:1.35; margin-bottom:6px; font-family:var(--fd); color:var(--text); }
.mpgm-pain-card p  { font-size:14px; color:var(--muted); font-family:var(--fb); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   COMO FUNCIONA — FLOW GRID
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.mpgm-flow-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 36px;
}
.mpgm-flow-card {
  padding: 36px 28px;
  border-radius: 20px;
  position: relative;
  overflow: hidden;
}
.mpgm-flow-step {
  width: 40px; height: 40px;
  border-radius: 12px;
  background: rgba(43,69,251,0.09);
  color: var(--primary);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--fd);
  font-weight: 900;
  font-size: 15px;
  margin-bottom: 16px;
}
.mpgm-flow-card h3 { font-family:var(--fd); font-size:18px; margin-bottom:8px; color:var(--text); }
.mpgm-flow-card p  { color:var(--muted); font-size:14px; line-height:1.75; font-family:var(--fb); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   BENEFÍCIOS
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.mpgm-benefits-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 36px;
}
.mpgm-benefit {
  padding: 28px 24px;
  border-radius: 22px;
  position: relative;
  overflow: hidden;
}
.mpgm-benefit::after {
  content:'';
  position:absolute;
  inset: auto -40px -40px auto;
  width:140px; height:140px;
  border-radius:50%;
  background: radial-gradient(circle, rgba(43,69,251,0.12), transparent 70%);
  pointer-events:none;
}
.mpgm-benefit i {
  width:54px; height:54px;
  border-radius:16px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(43,69,251,0.09);
  color: var(--primary);
  font-size:20px;
  margin-bottom:18px;
  position:relative; z-index:1;
}
.mpgm-benefit h3 { font-size:18px; font-family:var(--fd); margin-bottom:10px; position:relative; z-index:1; color:var(--text); }
.mpgm-benefit p  { font-size:14px; color:var(--muted); position:relative; z-index:1; font-family:var(--fb); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   PROVAS VISUAIS
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.mpgm-proof-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 36px;
}
.mpgm-proof-shot {
  overflow:hidden;
  border-radius: 22px;
  position: relative;
  min-height: 220px;
}
.mpgm-proof-shot img { width:100%; height:100%; object-fit:cover; }
.mpgm-proof-shot::after {
  content:'';
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, transparent 35%, rgba(15,21,64,0.78) 100%);
}
.mpgm-proof-caption {
  position:absolute;
  left:18px; right:18px; bottom:18px;
  z-index:1;
  color:#fff;
}
.mpgm-proof-caption strong { display:block; font-size:16px; line-height:1.3; margin-bottom:5px; font-family:var(--fd); }
.mpgm-proof-caption span   { display:block; font-size:12px; line-height:1.5; opacity:.9; font-family:var(--fb); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   DEPOIMENTOS
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.mpgm-testimonial-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 36px;
}
.mpgm-testimonial { padding:24px 22px; border-radius:22px; }
.mpgm-stars { color:#f59e0b; font-size:12px; letter-spacing:2px; margin-bottom:14px; }
.mpgm-testimonial p  { font-size:14px; color:var(--muted); line-height:1.75; margin-bottom:16px; font-family:var(--fb); }
.mpgm-author { display:flex; gap:12px; align-items:center; }
.mpgm-author-avatar {
  width:48px; height:48px;
  border-radius:50%; overflow:hidden;
  border: 2px solid rgba(43,69,251,0.12);
  flex-shrink:0; background:#fff;
}
.mpgm-author-avatar img { width:100%; height:100%; object-fit:cover; }
.mpgm-author strong { display:block; font-size:14px; margin-bottom:2px; color:var(--text); font-family:var(--fd); }
.mpgm-author span   { display:block; font-size:11px; color:var(--muted-2); font-family:var(--fm); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   COMPARATIVO
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.mpgm-compare-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 36px;
}
.mpgm-compare-box { border-radius:24px; overflow:hidden; }
.mpgm-compare-head {
  padding:22px 28px;
  font-family:var(--fd); font-size:17px; font-weight:800;
  display:flex; align-items:center; gap:10px;
  border-bottom: 1px solid rgba(43,69,251,0.08);
}
.mpgm-compare-box.bad  .mpgm-compare-head { background:rgba(239,68,68,0.08); color:#c73737; }
.mpgm-compare-box.good .mpgm-compare-head { background:rgba(43,69,251,0.08); color:var(--primary); }
.mpgm-compare-list { padding:10px 0; }
.mpgm-compare-item {
  display:flex; gap:14px; align-items:flex-start;
  padding:17px 28px;
  border-bottom: 1px solid rgba(15,21,64,0.06);
  font-size:15px; color:var(--text);
  font-family:var(--fb);
}
.mpgm-compare-item:last-child { border-bottom:0; }
.mpgm-compare-item i {
  width:22px; height:22px;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:10px; flex-shrink:0; margin-top:2px;
}
.mpgm-compare-box.bad  .mpgm-compare-item i { background:rgba(239,68,68,0.12); color:var(--red); }
.mpgm-compare-box.good .mpgm-compare-item i { background:rgba(43,69,251,0.12); color:var(--primary); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   CTA FINAL
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.mpgm-cta-box {
  border-radius:30px;
  padding:56px 32px;
  text-align:center;
  background: linear-gradient(135deg, rgba(43,69,251,0.08), rgba(1,140,251,0.05));
  border: 1px solid rgba(43,69,251,0.14);
  box-shadow: var(--shadow-md);
  position:relative;
  overflow:hidden;
}
.mpgm-cta-box::before {
  content:'';
  position:absolute;
  top:-120px; left:50%;
  transform:translateX(-50%);
  width:420px; height:320px;
  background: radial-gradient(circle, rgba(43,69,251,0.12), transparent 70%);
  pointer-events:none;
}
.mpgm-cta-box > * { position:relative; z-index:1; }
.mpgm-cta-note { margin-top:16px; font-size:12px; color:var(--muted-2); font-family:var(--fm); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   FAQ
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.mpgm-faq-grid { display:grid; gap:12px; margin-top:36px; }
.mpgm-faq-item { border-radius:18px; overflow:hidden; }
.mpgm-faq-q {
  width:100%;
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:18px 20px;
  background:transparent; border:0;
  cursor:pointer; font:inherit; color:inherit; text-align:left;
}
.mpgm-faq-q strong { font-size:15px; line-height:1.45; color:var(--text); font-family:var(--fb); }
.mpgm-faq-q i {
  width:28px; height:28px;
  border-radius:50%;
  background:rgba(43,69,251,0.08);
  display:flex; align-items:center; justify-content:center;
  color:var(--primary);
  transition:transform .2s ease, background .2s ease, color .2s ease;
  flex-shrink:0;
}
.mpgm-faq-item.active .mpgm-faq-q i { transform:rotate(45deg); background:var(--primary); color:#fff; }
.mpgm-faq-a {
  max-height:0; overflow:hidden;
  transition:max-height .26s ease, padding .26s ease;
  padding:0 20px;
}
.mpgm-faq-item.active .mpgm-faq-a { padding:0 20px 18px; max-height:300px; }
.mpgm-faq-a p { color:var(--muted); font-size:14px; line-height:1.75; font-family:var(--fb); }
.mpgm-faq-a a { color:var(--primary); font-weight:600; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   FOOTER GPT
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.mpgm-footer {
  padding:42px 0 50px;
  border-top:1px solid rgba(43,69,251,0.08);
  background:rgba(255,255,255,0.58);
  backdrop-filter:blur(14px);
}
.mpgm-footer-inner { display:grid; grid-template-columns:1fr; gap:28px; }
.mpgm-footer-brand p { margin-top:14px; max-width:440px; color:var(--muted); font-size:14px; line-height:1.8; font-family:var(--fb); }
.mpgm-footer-nav { display:flex; flex-wrap:wrap; gap:12px 18px; }
.mpgm-footer-nav a, .mpgm-footer-bottom a { color:var(--muted); text-decoration:none; font-size:13px; font-family:var(--fb); }
.mpgm-footer-nav a:hover, .mpgm-footer-bottom a:hover { color:var(--primary); }
.mpgm-footer-bottom {
  margin-top:22px; padding-top:18px;
  border-top:1px solid rgba(43,69,251,0.08);
  display:flex; flex-direction:column; gap:8px;
  color:var(--muted-2); font-size:12px; font-family:var(--fm);
}
.mpgm-footer-slogan {
  font-family:var(--fm); font-size:10px; text-transform:uppercase;
  letter-spacing:.12em; color:var(--primary); opacity:.7; margin-top:6px;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   RESPONSIVO
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@media (min-width:640px) {
  .mpgm-metrics-grid      { grid-template-columns: repeat(4, 1fr); }
  .mpgm-pain-grid         { grid-template-columns: 1fr 1fr; }
  .mpgm-benefits-grid     { grid-template-columns: 1fr 1fr; }
  .mpgm-testimonial-grid  { grid-template-columns: 1fr 1fr; }
  .mpgm-proof-grid        { grid-template-columns: 1fr 1fr; }
  .mpgm-proof-shot:nth-child(1) { grid-column:span 2; min-height:300px; }
  .mpgm-faq-grid          { grid-template-columns: 1fr 1fr; }
  .mpgm-compare-grid      { grid-template-columns: 1fr 1fr; }
}
@media (min-width:900px) {
  .mpgm-flow-grid         { grid-template-columns: repeat(4, 1fr); }
  .mpgm-benefits-grid     { grid-template-columns: repeat(3, 1fr); }
  .mpgm-testimonial-grid  { grid-template-columns: repeat(3, 1fr); }
  .mpgm-proof-grid        { grid-template-columns: 1.2fr 1fr 1fr; }
  .mpgm-proof-shot:nth-child(1) { grid-column:auto; grid-row:span 2; min-height:100%; }
  .mpgm-footer-inner      { grid-template-columns: 1.5fr 1fr; align-items:end; }
  .mpgm-footer-bottom     { flex-direction:row; justify-content:space-between; align-items:center; }
}
@media (max-width:639px) {
  .mpgm-btn-row .mpgm-btn { width:100%; }
  .mpgm-section { padding:64px 0; }

  /* Carrossel — scroll horizontal no mobile, sem animação */
  .photo-strip-wrap { overflow-x:auto !important; overflow-y:hidden !important; -webkit-overflow-scrolling:touch; scrollbar-width:none; }
  .photo-strip-wrap::-webkit-scrollbar { display:none; }
  .photo-strip { animation:none !important; width:max-content; }
  .photo-card { flex:0 0 200px !important; }

  /* Pain cards — 1 coluna */
  .mpgm-pain-grid { grid-template-columns:1fr !important; }

  /* Setor público — steps 1 coluna */
  #setor-publico .container > div[style*="max-width:560px"] { max-width:100% !important; margin-left:0 !important; }
  #setor-publico { padding:64px 0 !important; }

  /* ART/TRT */
  #art-trt { padding:64px 0 !important; }
  #art-trt .container > div { margin-left:0 !important; max-width:100% !important; }

  /* QR section */
  .qr-section-inner { grid-template-columns:1fr !important; gap:32px !important; }
  .qr-section-visual { display:none; }

  /* Vídeo lp */
  .lp-yt-section { padding:48px 0 32px !important; }

  /* Gov steps — remover fundo branco e simplificar */
  #setor-publico [style*="display:flex;gap:20px"] { padding:16px !important; }

  /* CTA final */
  .mpgm-cta-box { padding:40px 20px !important; }

  /* Comparativo */
  .mpgm-compare-grid { grid-template-columns:1fr !important; }

  /* FAQ */
  .mpgm-faq-grid { grid-template-columns:1fr !important; }

  /* Proof grid */
  .mpgm-proof-grid { grid-template-columns:1fr !important; }
  .mpgm-proof-shot:nth-child(1) { grid-column:auto !important; }

  /* Benefícios */
  .mpgm-benefits-grid { grid-template-columns:1fr !important; }

  /* Testimonials */
  .mpgm-testimonial-grid { grid-template-columns:1fr !important; }

  /* Footer */
  .mpgm-footer-inner { grid-template-columns:1fr !important; }
  .mpgm-footer-bottom { flex-direction:column !important; gap:6px !important; text-align:center; }
  .mpgm-footer-nav { justify-content:center; }
}