/* ==========================================================================
   VIZU — Widgets de Elementor (marca + responsivo)
   Roxo · Magenta · Amarelo · Creme · Preto
   ========================================================================== */
:root{
  --vizu-purple:#9B2FE0; --vizu-purple-dark:#6B21D6; --vizu-magenta:#E91E9C;
  --vizu-pink:#FF4FD8; --vizu-yellow:#FFD60A; --vizu-cream:#F3F0E7; --vizu-ink:#121212;
}
.vizu-w{ --vp:var(--vizu-purple); --vpd:var(--vizu-purple-dark); --vm:var(--vizu-magenta);
  --vy:var(--vizu-yellow); --vpk:var(--vizu-pink); --cream:var(--vizu-cream); --ink:var(--vizu-ink);
  font-family:inherit; box-sizing:border-box; }
.vizu-w *,.vizu-w *::before,.vizu-w *::after{ box-sizing:border-box; }
.vizu-w img{ max-width:100%; height:auto; display:block; }
.vizu-grad-text{ background:linear-gradient(95deg,var(--vp),var(--vm)); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:var(--vm); }
.vizu-underline{ position:relative; display:inline-block; color:var(--vm); }
.vizu-underline::after{ content:""; position:absolute; left:0; right:0; bottom:-2px; height:7px; border-radius:6px;
  background:linear-gradient(90deg,var(--vp),var(--vm)); opacity:.55; z-index:-1; }

/* ---------- Botões ---------- */
.vizu-btn{ display:inline-flex; align-items:center; gap:8px; font-weight:700; font-size:15px; line-height:1;
  padding:15px 26px; border-radius:50px; text-decoration:none; cursor:pointer; border:2px solid transparent;
  transition:transform .2s ease, filter .2s ease, background .2s ease, color .2s ease; }
.vizu-btn:hover{ transform:translateY(-2px); }
.vizu-btn--primary{ background:linear-gradient(95deg,var(--vp),var(--vm)); color:#fff; }
.vizu-btn--primary:hover{ filter:brightness(1.06); color:#fff; }
.vizu-btn--ghost{ background:transparent; color:var(--vp); border-color:var(--vp); }
.vizu-btn--ghost:hover{ background:var(--vp); color:#fff; }

/* ---------- Eyebrow / pill ---------- */
.vizu-eyebrow{ display:inline-block; font-size:12px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase;
  color:var(--vp); background:rgba(155,47,224,.10); border:1px solid rgba(155,47,224,.30);
  padding:7px 16px; border-radius:50px; margin-bottom:18px; }

/* ---------- Section heading ---------- */
.vizu-heading{ max-width:760px; }
.vizu-heading.is-center{ margin-left:auto; margin-right:auto; text-align:center; }
.vizu-heading__title{ font-size:38px; line-height:1.15; font-weight:800; margin:0; color:inherit; }
.vizu-heading__desc{ margin:14px 0 0; font-size:16px; line-height:1.6; opacity:.8; }

/* ==========================================================================
   HERO
   ========================================================================== */
.vizu-hero{ display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; }
.vizu-hero__title{ font-size:54px; line-height:1.05; font-weight:800; margin:0 0 18px; letter-spacing:-1px; }
.vizu-hero__subtitle{ font-size:17px; line-height:1.6; opacity:.82; margin:0 0 28px; max-width:480px; }
.vizu-hero__actions{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:30px; }
.vizu-hero__features{ display:flex; flex-wrap:wrap; gap:22px; }
.vizu-hero__feature{ display:inline-flex; align-items:center; gap:9px; font-size:14px; font-weight:600; }
.vizu-hero__feature i,.vizu-hero__feature svg{ color:var(--vp); font-size:18px; width:18px; height:18px; }
/* card colagem */
.vizu-hero__visual{ position:relative; }
.vizu-collage{ position:relative; background:#fff; border:2px solid var(--ink); border-radius:20px; padding:26px;
  box-shadow:14px 16px 0 rgba(155,47,224,.18); }
.vizu-collage__bar{ display:flex; gap:7px; margin-bottom:18px; }
.vizu-collage__bar span{ width:12px; height:12px; border-radius:50%; background:#d9d4c6; }
.vizu-collage__bar span:nth-child(1){ background:var(--vm); }
.vizu-collage__bar span:nth-child(2){ background:var(--vy); }
.vizu-collage__bar span:nth-child(3){ background:var(--vp); }
.vizu-collage__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.vizu-collage__item{ background:var(--cream); border:1.5px solid rgba(18,18,18,.12); border-radius:14px;
  padding:16px 8px; text-align:center; transition:transform .2s ease; }
.vizu-collage__item:hover{ transform:translateY(-4px); }
.vizu-collage__item i,.vizu-collage__item svg{ font-size:26px; color:var(--vp); }
.vizu-collage__item span{ display:block; margin-top:8px; font-size:11.5px; font-weight:700; color:var(--ink); }
.vizu-sticker{ position:absolute; right:-18px; bottom:-22px; background:var(--vy); color:var(--ink);
  font-weight:800; font-size:18px; line-height:1.1; padding:14px 18px; border:2px solid var(--ink);
  border-radius:10px; transform:rotate(-5deg); box-shadow:5px 5px 0 rgba(18,18,18,.85); text-align:center; }
.vizu-shape{ position:absolute; z-index:-1; }
.vizu-shape--star{ top:-22px; right:30px; color:var(--vy); font-size:34px; }
.vizu-shape--tri{ bottom:40px; left:-26px; width:0; height:0; border-left:18px solid transparent;
  border-right:18px solid transparent; border-bottom:30px solid var(--vm); transform:rotate(18deg); }

/* ==========================================================================
   SERVICES GRID
   ========================================================================== */
.vizu-services{ display:grid; grid-template-columns:repeat(var(--cols,4),1fr); gap:22px; }
.vizu-card{ background:#fff; border:1px solid rgba(18,18,18,.08); border-radius:18px; padding:28px 24px;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease; height:100%; }
.vizu-card:hover{ transform:translateY(-6px); box-shadow:0 18px 40px rgba(18,18,18,.10); border-color:rgba(155,47,224,.35); }
.vizu-card__icon{ width:56px; height:56px; border-radius:14px; display:flex; align-items:center; justify-content:center;
  background:rgba(155,47,224,.10); margin-bottom:18px; }
.vizu-card__icon i,.vizu-card__icon svg{ font-size:28px; color:var(--vp); width:28px; height:28px; }
.vizu-card__title{ font-size:19px; font-weight:800; margin:0 0 10px; }
.vizu-card__desc{ font-size:14.5px; line-height:1.6; opacity:.78; margin:0 0 16px; }
.vizu-card__link{ display:inline-flex; width:40px; height:40px; align-items:center; justify-content:center;
  border-radius:10px; background:var(--cream); color:var(--vp); text-decoration:none; transition:.2s; }
.vizu-card__link:hover{ background:var(--vp); color:#fff; }

/* ==========================================================================
   PILLARS (não há pacotes fechados)
   ========================================================================== */
.vizu-pillars{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start; }
.vizu-pillars__title{ font-size:40px; line-height:1.12; font-weight:800; margin:0; }
.vizu-pillars__intro{ font-size:16px; line-height:1.65; opacity:.82; margin:0 0 24px; }
.vizu-checklist{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:18px; }
.vizu-checklist li{ display:flex; gap:14px; align-items:flex-start; }
.vizu-checklist__ic{ flex:0 0 auto; width:36px; height:36px; border-radius:50%; display:flex; align-items:center;
  justify-content:center; background:rgba(155,47,224,.12); color:var(--vp); }
.vizu-checklist__ic i,.vizu-checklist__ic svg{ font-size:18px; }
.vizu-checklist__tx{ font-size:14.5px; font-weight:600; line-height:1.5; text-transform:uppercase; letter-spacing:.3px; padding-top:6px; }

/* ==========================================================================
   PROCESS STEPS
   ========================================================================== */
.vizu-process{ display:grid; grid-template-columns:repeat(var(--steps,4),1fr); gap:18px; align-items:start; }
.vizu-step{ position:relative; }
.vizu-step__num{ display:inline-block; font-size:30px; font-weight:800; color:var(--ink);
  background:var(--vy); padding:6px 16px; border-radius:6px; transform:rotate(-3deg);
  box-shadow:3px 3px 0 rgba(18,18,18,.8); margin-bottom:18px; }
.vizu-step:nth-child(even) .vizu-step__num{ background:#e5d9ff; transform:rotate(2deg); }
.vizu-step__title{ font-size:19px; font-weight:800; margin:0 0 8px; }
.vizu-step__desc{ font-size:14px; line-height:1.55; opacity:.78; margin:0; }
.vizu-step__arrow{ position:absolute; top:14px; right:-13px; color:var(--ink); font-size:20px; z-index:2; }
.vizu-step:last-child .vizu-step__arrow{ display:none; }

/* ==========================================================================
   PROJECTS
   ========================================================================== */
.vizu-projects{ display:grid; grid-template-columns:repeat(var(--pcols,3),1fr); gap:20px; }
.vizu-project{ position:relative; border-radius:16px; overflow:hidden; display:block; text-decoration:none;
  color:#fff; background:#1a1a22; aspect-ratio:4/3; }
.vizu-project img{ width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }
.vizu-project:hover img{ transform:scale(1.06); }
.vizu-project__body{ position:absolute; left:0; right:0; bottom:0; padding:18px 18px 16px;
  background:linear-gradient(to top,rgba(10,10,14,.85),transparent); }
.vizu-project__title{ font-size:16px; font-weight:800; margin:0; color:#fff; }
.vizu-project__cat{ font-size:12.5px; font-weight:600; color:var(--vy); }

/* ==========================================================================
   TEAM
   ========================================================================== */
.vizu-team{ display:grid; grid-template-columns:repeat(var(--tcols,2),1fr); gap:24px; }
.vizu-member{ display:flex; gap:18px; align-items:center; background:#fff; border:1px solid rgba(18,18,18,.08);
  border-radius:18px; padding:22px; }
.vizu-member__photo{ flex:0 0 auto; width:96px; height:96px; border-radius:14px; overflow:hidden;
  border:2px solid var(--vp); }
.vizu-member__photo img{ width:100%; height:100%; object-fit:cover; }
.vizu-member__name{ font-size:19px; font-weight:800; margin:0; }
.vizu-member__role{ font-size:12px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--vm); margin:2px 0 8px; }
.vizu-member__bio{ font-size:13.5px; line-height:1.55; opacity:.8; margin:0 0 12px; }
.vizu-member__social{ display:flex; gap:10px; }
.vizu-member__social a{ width:34px; height:34px; border-radius:9px; display:flex; align-items:center;
  justify-content:center; background:var(--cream); color:var(--vp); text-decoration:none; transition:.2s; }
.vizu-member__social a:hover{ background:var(--vp); color:#fff; }

/* ==========================================================================
   FAQ
   ========================================================================== */
.vizu-faq{ max-width:760px; margin:0 auto; display:flex; flex-direction:column; gap:12px; }
.vizu-faq__item{ background:#fff; border:1px solid rgba(18,18,18,.10); border-radius:12px; overflow:hidden; }
.vizu-faq__item[open]{ border-color:var(--vp); }
.vizu-faq__q{ list-style:none; cursor:pointer; padding:18px 22px; font-size:15.5px; font-weight:700;
  display:flex; justify-content:space-between; align-items:center; gap:16px; }
.vizu-faq__q::-webkit-details-marker{ display:none; }
.vizu-faq__q::after{ content:"+"; font-size:24px; font-weight:400; color:var(--vp); transition:transform .2s ease; line-height:1; }
.vizu-faq__item[open] .vizu-faq__q::after{ content:"–"; }
.vizu-faq__a{ padding:0 22px 20px; font-size:14.5px; line-height:1.65; opacity:.82; }

/* ==========================================================================
   CTA BANNER
   ========================================================================== */
.vizu-cta{ position:relative; overflow:hidden; background:linear-gradient(95deg,var(--vp),var(--vpd));
  border-radius:20px; padding:40px 44px; display:flex; align-items:center; justify-content:space-between;
  gap:26px; flex-wrap:wrap; }
.vizu-cta__title{ font-size:28px; font-weight:800; color:#fff; margin:0; max-width:640px; line-height:1.2; }
.vizu-cta__title .vizu-underline{ color:var(--vy); }
.vizu-cta__title .vizu-underline::after{ background:var(--vy); opacity:.6; }
.vizu-cta .vizu-btn--primary{ background:#fff; color:var(--vp); }
.vizu-cta .vizu-btn--primary:hover{ background:var(--vy); color:var(--ink); }

/* ==========================================================================
   DARK MODE (acompanha o tema)
   ========================================================================== */
.active-dark-mode .vizu-card,
.active-dark-mode .vizu-member,
.active-dark-mode .vizu-faq__item,
.active-dark-mode .vizu-collage{ background:#1a1a22; border-color:#2c2c36; color:#f2f0ea; }
.active-dark-mode .vizu-collage__item{ background:#23232d; border-color:#34343f; }
.active-dark-mode .vizu-collage__item span,
.active-dark-mode .vizu-card__title,
.active-dark-mode .vizu-member__name,
.active-dark-mode .vizu-faq__q{ color:#f2f0ea; }
.active-dark-mode .vizu-card__link,
.active-dark-mode .vizu-member__social a{ background:#23232d; }
.active-dark-mode .vizu-collage{ box-shadow:14px 16px 0 rgba(155,47,224,.30); }

/* ==========================================================================
   RESPONSIVO
   ========================================================================== */
@media (max-width:1024px){
  .vizu-hero__title{ font-size:44px; }
  .vizu-services{ grid-template-columns:repeat(2,1fr); }
  .vizu-process{ grid-template-columns:repeat(2,1fr); }
  .vizu-step__arrow{ display:none; }
  .vizu-projects{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:767px){
  .vizu-hero{ grid-template-columns:1fr; gap:40px; }
  .vizu-hero__title{ font-size:36px; }
  .vizu-heading__title,.vizu-pillars__title{ font-size:30px; }
  .vizu-pillars{ grid-template-columns:1fr; gap:28px; }
  .vizu-services{ grid-template-columns:1fr; }
  .vizu-process{ grid-template-columns:1fr; }
  .vizu-projects{ grid-template-columns:1fr; }
  .vizu-team{ grid-template-columns:1fr; }
  .vizu-member{ flex-direction:column; text-align:center; align-items:center; }
  .vizu-member__social{ justify-content:center; }
  .vizu-cta{ flex-direction:column; text-align:center; padding:32px 24px; }
  .vizu-cta__title{ font-size:23px; }
}
@media (prefers-reduced-motion:reduce){
  .vizu-w *{ transition:none !important; }
}
