/* ============================================================
   ZAPLYX — Section styles (phone, problem, solution, demo, results, security)
   ============================================================ */

/* ---- HERO phone + 3D flow ------------------------------------ */
.hero-badges{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:26px; }
.hbadge{ display:inline-flex; align-items:center; gap:7px; padding:7px 13px; border-radius:var(--pill);
  background:var(--glass); border:1px solid var(--line); font-size:12.5px; font-weight:600; color:var(--ink-dim); backdrop-filter:blur(6px); }
.hbadge svg{ width:14px; height:14px; color:var(--mint); }

.hero-stage{ position:relative; perspective:1600px; height:560px; display:flex; align-items:center; justify-content:center; }
.hero-stage .phone{ width:272px; height:552px; }
.ai-core-glow{ position:absolute; width:420px; height:420px; border-radius:50%;
  background:radial-gradient(circle, rgba(37,211,102,.28), rgba(110,108,242,.12) 50%, transparent 72%); filter:blur(20px); z-index:0; }

/* phone */
.phone{ position:relative; z-index:3; width:288px; height:580px; border-radius:46px; padding:13px;
  background:linear-gradient(160deg,#1a2820,#0b1410); border:1px solid rgba(255,255,255,.1);
  box-shadow:0 50px 110px -30px rgba(0,0,0,.85), inset 0 1px 0 rgba(255,255,255,.1), 0 0 0 1px rgba(0,0,0,.4);
  transform:rotateY(-15deg) rotateX(6deg) rotateZ(1deg); transform-style:preserve-3d;
  transition:transform .8s var(--ease-out); }
.hero-stage:hover .phone{ transform:rotateY(-9deg) rotateX(3deg); }
.phone-notch{ position:absolute; top:20px; left:50%; transform:translateX(-50%); width:96px; height:26px; background:#05090a; border-radius:0 0 16px 16px; z-index:5; }
.phone-screen{ width:100%; height:100%; border-radius:34px; overflow:hidden; background:#0a130e; display:flex; flex-direction:column; position:relative; }
.wa-top{ display:flex; align-items:center; gap:10px; padding:34px 14px 12px; background:rgba(37,211,102,.1); border-bottom:1px solid var(--line); }
.wa-top .ava{ width:36px; height:36px; border-radius:50%; background:var(--grad); display:grid; place-items:center; }
.wa-top .ava img{ width:22px; height:22px; }
.wa-top .nm{ font-family:var(--display); font-weight:700; font-size:14px; }
.wa-top .st{ font-size:11px; color:var(--mint); }
.wa-top .ico{ margin-left:auto; display:flex; gap:14px; color:var(--ink-faint); }
.wa-top .ico svg{ width:18px; height:18px; }
.wa-msgs{ flex:1; padding:16px 12px; display:flex; flex-direction:column; gap:9px; overflow-y:auto;
  background-image:radial-gradient(rgba(255,255,255,.02) 1px, transparent 1px); background-size:16px 16px; }
.wa-msgs::-webkit-scrollbar{ width:0; height:0; }
.wa-msgs{ scrollbar-width:none; }
.wa-day{ align-self:center; font-size:10px; color:var(--ink-faint); background:var(--glass); padding:3px 11px; border-radius:var(--pill); margin-bottom:2px; }
.wmsg{ max-width:82%; padding:9px 12px; font-size:13px; line-height:1.4; border-radius:13px; opacity:0; transform:translateY(8px) scale(.96); animation:msgpop .45s var(--ease-out) forwards; }
.wmsg .tm{ font-size:9px; opacity:.5; display:block; text-align:right; margin-top:3px; }
.wmsg.in{ align-self:flex-start; background:var(--elev-2); border-bottom-left-radius:4px; }
.wmsg.out{ align-self:flex-end; background:linear-gradient(135deg,#1FAE58,#13876a); color:#eafbf0; border-bottom-right-radius:4px; }
.wmsg.bot{ align-self:flex-start; background:linear-gradient(135deg, rgba(110,108,242,.2), rgba(18,183,166,.16)); border:1px solid var(--line); border-bottom-left-radius:4px; }
.wmsg.bot .bt{ font-size:9px; font-weight:700; color:var(--mint); text-transform:uppercase; letter-spacing:.06em; display:flex; align-items:center; gap:4px; margin-bottom:3px; }
@keyframes msgpop{ to{ opacity:1; transform:none; } }
.wa-bar{ display:flex; align-items:center; gap:8px; padding:10px 12px; border-top:1px solid var(--line); background:rgba(0,0,0,.25); }
.wa-bar .inp{ flex:1; color:var(--ink-faint); font-size:12px; }
.wa-bar .snd{ width:30px; height:30px; border-radius:50%; background:var(--grad); display:grid; place-items:center; }
.wa-bar .snd svg{ width:14px; height:14px; }
.wa-typing{ display:inline-flex; gap:3px; padding:10px 13px; align-self:flex-start; background:var(--elev-2); border-radius:13px; border-bottom-left-radius:4px; }
.wa-typing i{ width:6px; height:6px; border-radius:50%; background:var(--ink-faint); animation:typing 1.3s infinite; }
.wa-typing i:nth-child(2){ animation-delay:.2s;} .wa-typing i:nth-child(3){ animation-delay:.4s;}

/* floating flow cards */
.flow-card{ position:absolute; z-index:4; display:flex; align-items:center; gap:10px; padding:11px 14px;
  background:rgba(11,21,16,.85); border:1px solid var(--line-strong); border-radius:15px; backdrop-filter:blur(14px);
  box-shadow:0 20px 50px -18px rgba(0,0,0,.8); white-space:nowrap; }
.flow-card .ic{ width:30px; height:30px; border-radius:9px; display:grid; place-items:center; flex-shrink:0; }
.flow-card .ic svg{ width:16px; height:16px; }
.flow-card .ti{ font-family:var(--display); font-weight:700; font-size:13px; line-height:1.1; }
.flow-card .su{ font-size:10.5px; color:var(--ink-dim); }
.flow-card .ic.g{ background:rgba(37,211,102,.16); color:var(--mint); }
.flow-card .ic.t{ background:rgba(18,183,166,.16); color:var(--teal); }
.flow-card .ic.i{ background:rgba(110,108,242,.18); color:#a5a4f7; }
.fl-1{ top:-14px; left:-22px; animation:floaty 6s ease-in-out infinite; }
.fl-2{ top:96px; right:-38px; animation:floaty 7s ease-in-out infinite .9s; }
.fl-3{ bottom:96px; left:-34px; animation:floaty 6.5s ease-in-out infinite .4s; }
.fl-4{ bottom:-6px; right:-26px; animation:floaty 7.5s ease-in-out infinite 1.3s; }

.hero-trust{ margin-top:18px; display:flex; align-items:center; gap:10px; color:var(--ink-faint); font-size:13px; }
.hero-trust svg{ width:16px; height:16px; color:var(--mint); }

/* =============================================================
   PROBLEM
   ============================================================= */
.problem-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:48px; align-items:center; }
.pain-list{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.pain{ display:flex; gap:12px; align-items:flex-start; padding:16px; border-radius:var(--r-sm); border:1px solid var(--line);
  background:linear-gradient(170deg, rgba(255,80,80,.05), rgba(255,255,255,.012)); }
.pain .x{ width:26px; height:26px; border-radius:8px; flex-shrink:0; display:grid; place-items:center;
  background:rgba(255,90,90,.12); color:#ff8a8a; }
.pain .x svg{ width:15px; height:15px; }
.pain span{ font-size:14px; color:var(--ink); line-height:1.4; }

/* accumulating messages visual */
.pile{ position:relative; height:380px; display:flex; flex-direction:column; justify-content:flex-end; gap:8px; padding:24px;
  border-radius:var(--r-lg); border:1px solid var(--line); background:linear-gradient(180deg, rgba(255,90,90,.06), var(--glass)); overflow:hidden; }
.pile::before{ content:'7 não respondidas'; position:absolute; top:18px; right:18px; font-size:11px; font-weight:700; color:#ff8a8a;
  background:rgba(255,90,90,.14); padding:5px 11px; border-radius:var(--pill); }
.pile-msg{ max-width:80%; padding:10px 13px; font-size:13px; border-radius:13px; border-bottom-left-radius:4px; background:var(--elev-2);
  align-self:flex-start; border:1px solid var(--line); opacity:.5; }
.pile-msg .tm{ display:block; font-size:10px; color:#ff8a8a; margin-top:3px; }
.pile-msg:nth-child(1){ opacity:.3; } .pile-msg:nth-child(2){ opacity:.45; } .pile-msg:nth-child(3){ opacity:.62; } .pile-msg:nth-child(4){ opacity:.85; }

/* =============================================================
   SOLUTION dashboard
   ============================================================= */
.solution-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:48px; align-items:center; }
.sol-list{ display:flex; flex-direction:column; gap:14px; margin-top:28px; }
.sol-item{ display:flex; gap:13px; align-items:flex-start; }
.sol-item .ck{ width:24px; height:24px; border-radius:50%; flex-shrink:0; background:linear-gradient(135deg,var(--green),var(--teal)); display:grid; place-items:center; margin-top:1px; }
.sol-item .ck svg{ width:13px; height:13px; color:#04140B; }
.sol-item p{ font-size:15px; color:var(--ink); }
.sol-item p b{ font-weight:700; }

.dash{ border-radius:var(--r-lg); border:1px solid var(--line-strong); overflow:hidden; position:relative;
  background:linear-gradient(170deg,#0e1b14,#0a130e); box-shadow:0 40px 90px -30px rgba(0,0,0,.8); }
.dash-top{ display:flex; align-items:center; gap:8px; padding:14px 18px; border-bottom:1px solid var(--line); background:rgba(255,255,255,.02); }
.dash-top .dot{ width:11px; height:11px; border-radius:50%; }
.dash-top .dot:nth-child(1){ background:#ff5f57; } .dash-top .dot:nth-child(2){ background:#febc2e; } .dash-top .dot:nth-child(3){ background:#28c840; }
.dash-top .ttl{ margin-left:12px; font-family:var(--display); font-size:13px; font-weight:600; color:var(--ink-dim); display:flex; align-items:center; gap:8px; }
.dash-top .ttl img{ width:18px; height:18px; }
.dash-body{ padding:20px; display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.dash-tile{ padding:16px; border-radius:var(--r-sm); border:1px solid var(--line); background:var(--glass); }
.dash-tile.wide{ grid-column:1/-1; }
.dash-tile .lab{ font-size:11px; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-dim); margin-bottom:8px; display:flex; align-items:center; gap:7px; }
.dash-tile .lab svg{ width:14px; height:14px; color:var(--mint); }
.dash-tile .big{ font-family:var(--display); font-weight:800; font-size:30px; letter-spacing:-.02em; }
.dash-tile .sub{ font-size:12px; color:var(--mint); margin-top:3px; }
.minibars{ display:flex; align-items:flex-end; gap:6px; height:54px; margin-top:6px; }
.minibars i{ flex:1; border-radius:4px 4px 0 0; background:var(--grad); opacity:.85; transform-origin:bottom; }
.donut{ width:64px; height:64px; border-radius:50%; background:conic-gradient(var(--green) 0 var(--p,75%), rgba(255,255,255,.08) 0); display:grid; place-items:center; position:relative; }
.donut::after{ content:''; position:absolute; inset:9px; border-radius:50%; background:#0c1611; }
.donut span{ position:relative; z-index:2; font-family:var(--display); font-weight:700; font-size:14px; }
.dash-row{ display:flex; align-items:center; gap:12px; }
.pill-tag{ font-size:11px; font-weight:700; padding:4px 10px; border-radius:var(--pill); }
.pill-tag.g{ background:rgba(37,211,102,.16); color:var(--mint); }
.pill-tag.i{ background:rgba(110,108,242,.18); color:#a5a4f7; }

/* =============================================================
   DEMO 3-part
   ============================================================= */
.demo3{ display:grid; grid-template-columns:300px 1fr; gap:24px; align-items:stretch; }
.demo3-right{ display:grid; grid-template-rows:auto 1fr; gap:18px; }
.demo-phone{ position:relative; }
/* reuse .phone styles but flat for demo */
.demo-phone .phone{ transform:none; width:300px; height:600px; margin-inline:auto; }
.hero-stage .demo-phone .phone{ transform:none; }

.ia-card{ border-radius:var(--r-lg); border:1px solid var(--line-strong); padding:22px; position:relative; overflow:hidden;
  background:linear-gradient(135deg, rgba(110,108,242,.1), rgba(18,183,166,.07)); }
.ia-card .ia-head{ display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.ia-card .brain{ width:46px; height:46px; border-radius:13px; background:var(--grad); display:grid; place-items:center; position:relative; }
.ia-card .brain svg{ width:24px; height:24px; color:#04140B; }
.ia-card .brain::after{ content:''; position:absolute; inset:-4px; border-radius:16px; border:1px solid var(--mint); opacity:0; animation:iapulse 2s infinite; }
@keyframes iapulse{ 0%{ transform:scale(.9); opacity:.6; } 100%{ transform:scale(1.25); opacity:0; } }
.ia-card h4{ font-size:16px; } .ia-card .ia-head small{ display:block; font-size:11.5px; color:var(--mint); }
.ia-rows{ display:flex; flex-direction:column; gap:11px; }
.ia-row{ display:flex; justify-content:space-between; align-items:center; gap:12px; padding:11px 14px; border-radius:11px;
  background:var(--glass); border:1px solid var(--line); opacity:.35; transform:translateX(-6px); transition:.5s var(--ease); }
.ia-row.on{ opacity:1; transform:none; border-color:var(--line-strong); }
.ia-row .k{ font-size:12.5px; color:var(--ink-dim); display:flex; align-items:center; gap:8px; }
.ia-row .k svg{ width:15px; height:15px; color:var(--mint); }
.ia-row .v{ font-family:var(--display); font-weight:600; font-size:13px; color:var(--ink); }

.demo-dash{ border-radius:var(--r-lg); border:1px solid var(--line-strong); padding:22px; background:linear-gradient(170deg,#0e1b14,#0a130e); }
.demo-dash .dh{ display:flex; align-items:center; gap:9px; margin-bottom:16px; font-family:var(--display); font-weight:600; font-size:14px; }
.demo-dash .dh .live{ margin-left:auto; font-size:11px; color:var(--mint); display:flex; align-items:center; gap:6px; }
.demo-dash .dh .live::before{ content:''; width:7px; height:7px; border-radius:50%; background:var(--green); box-shadow:0 0 8px var(--green); animation:blink 1.4s infinite; }
@keyframes blink{ 50%{ opacity:.3; } }
.status-list{ display:flex; flex-direction:column; gap:10px; }
.status-item{ display:flex; align-items:center; gap:12px; padding:12px 14px; border-radius:11px; border:1px solid var(--line); background:var(--glass);
  opacity:.3; transform:translateY(6px); transition:.5s var(--ease); }
.status-item.on{ opacity:1; transform:none; }
.status-item .si{ width:30px; height:30px; border-radius:9px; flex-shrink:0; display:grid; place-items:center; background:linear-gradient(135deg,var(--green),var(--teal)); }
.status-item .si svg{ width:15px; height:15px; color:#04140B; }
.status-item .sl{ font-size:11px; color:var(--ink-dim); } .status-item .sv{ font-family:var(--display); font-weight:600; font-size:13.5px; }
.status-item .chk{ margin-left:auto; color:var(--mint); opacity:0; transition:.3s .2s; }
.status-item.on .chk{ opacity:1; } .status-item .chk svg{ width:18px; height:18px; }

/* =============================================================
   RESULTS metrics
   ============================================================= */
.metric-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:16px; }
.metric{ padding:26px 22px; border-radius:var(--r-lg); border:1px solid var(--line); position:relative; overflow:hidden;
  background:linear-gradient(170deg, var(--glass-2), rgba(255,255,255,.015)); text-align:left; }
.metric .num{ font-family:var(--display); font-weight:800; font-size:clamp(30px,3.4vw,42px); letter-spacing:-.03em; line-height:1; }
.metric .num .grad-text{ display:inline; }
.metric .lab{ font-size:13px; color:var(--ink-dim); margin-top:10px; line-height:1.4; }
.metric .spark{ display:flex; align-items:flex-end; gap:3px; height:30px; margin-top:14px; }
.metric .spark i{ flex:1; border-radius:2px; background:linear-gradient(180deg,var(--mint),transparent); opacity:.7; }

/* =============================================================
   SECURITY / LGPD
   ============================================================= */
.security-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:52px; align-items:center; }
.shield-wrap{ position:relative; display:grid; place-items:center; height:420px; }
.shield-glow{ position:absolute; width:340px; height:340px; border-radius:50%; background:radial-gradient(circle, rgba(37,211,102,.22), transparent 70%); filter:blur(10px); }
.shield{ position:relative; width:200px; height:236px; z-index:2;
  clip-path:polygon(50% 0, 100% 16%, 100% 56%, 50% 100%, 0 56%, 0 16%);
  background:linear-gradient(160deg, rgba(37,211,102,.22), rgba(110,108,242,.18)); border:1px solid var(--line-strong);
  display:grid; place-items:center; backdrop-filter:blur(8px); }
.shield::before{ content:''; position:absolute; inset:0; clip-path:inherit; padding:1.5px; background:var(--grad);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite:xor; mask-composite:exclude; }
.shield svg{ width:74px; height:74px; color:var(--mint); filter:drop-shadow(0 6px 20px rgba(37,211,102,.5)); }
.shield-ring{ position:absolute; border:1px solid var(--line); border-radius:50%; }
.shield-ring.r1{ width:300px; height:300px; animation:spin 26s linear infinite; }
.shield-ring.r2{ width:380px; height:380px; animation:spin 40s linear infinite reverse; border-style:dashed; }
@keyframes spin{ to{ transform:rotate(360deg); } }
.orbit-seal{ position:absolute; padding:7px 13px; border-radius:var(--pill); background:rgba(11,21,16,.9); border:1px solid var(--line-strong);
  font-size:11px; font-weight:700; color:var(--mint); backdrop-filter:blur(8px); display:flex; align-items:center; gap:6px; box-shadow:0 12px 30px -12px rgba(0,0,0,.7); }
.orbit-seal svg{ width:13px; height:13px; }
.os-1{ top:30px; right:0; } .os-2{ bottom:60px; left:-10px; } .os-3{ bottom:20px; right:30px; }

.sec-checklist{ display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:30px; }
.sec-check{ display:flex; gap:11px; align-items:flex-start; padding:14px; border-radius:var(--r-sm); border:1px solid var(--line); background:var(--glass); }
.sec-check svg{ width:19px; height:19px; flex-shrink:0; color:var(--mint); margin-top:1px; }
.sec-check span{ font-size:13.5px; color:var(--ink); line-height:1.4; }

@media (max-width:1024px){
  .problem-grid,.solution-grid,.security-grid{ grid-template-columns:1fr; gap:40px; }
  .demo3{ grid-template-columns:1fr; } .demo-phone .phone{ margin-inline:auto; }
  .metric-grid{ grid-template-columns:repeat(3,1fr); }
  .hero-stage{ height:500px; }
  .pain-list,.sec-checklist{ grid-template-columns:1fr 1fr; }
}
@media (max-width:680px){
  .pain-list,.sec-checklist,.dash-body{ grid-template-columns:1fr; }
  .metric-grid{ grid-template-columns:1fr 1fr; }
  .hero-stage{ height:auto; padding:40px 0; }
  .phone{ transform:none !important; }
  .flow-card{ display:none; }
  .demo-phone .phone{ width:280px; height:560px; }
}
