/* SITE INSTITUCIONAL NEURALLEX — CSS principal
   Identidade visual: sofisticada, tecnológica, jurídica.
   Paleta: azul profundo + grafite + ciano elétrico (acento) + off-white.
   Distinta do Portal (acadêmico) e do NeuralLex Fluxo (operacional). */

:root{
  /* Paleta NeuralLex Institucional */
  --ink-900:#0a1628;       /* azul-preto profundo */
  --ink-800:#0f1f3d;       /* azul-noite */
  --ink-700:#173264;       /* azul-marinho denso */
  --ink-600:#1f4180;       /* azul */
  --ink-500:#2756a5;       /* azul claro */
  --ink-400:#3d77c8;
  --ink-300:#6b9bd9;
  --ink-200:#a8c5e8;
  --ink-100:#dbe7f4;
  --ink-50:#f0f5fb;

  --accent-cyan:#00d4ff;   /* ciano elétrico — acento tecnológico */
  --accent-cyan-soft:#7be8fa;
  --accent-violet:#6366f1; /* violeta sutil — Direito moderno */
  --accent-emerald:#10b981;

  --graphite-900:#1a1f2e;
  --graphite-700:#2d3447;
  --graphite-500:#5b6478;
  --graphite-400:#7e8699;
  --graphite-300:#a8aebd;
  --graphite-200:#cdd2de;
  --graphite-100:#e7eaf0;
  --off-white:#fafbfd;
  --white:#ffffff;

  --grad-hero:linear-gradient(135deg, #0a1628 0%, #173264 50%, #1f4180 100%);
  --grad-cyan:linear-gradient(135deg, #173264 0%, #2756a5 50%, #00d4ff 100%);
  --grad-deep:linear-gradient(180deg, #0a1628 0%, #0f1f3d 100%);
  --grad-soft:linear-gradient(135deg, #f0f5fb 0%, #ffffff 60%, #e7eaf0 100%);

  --shadow-sm:0 1px 2px rgba(10,22,40,.06);
  --shadow-md:0 6px 18px rgba(10,22,40,.10), 0 2px 4px rgba(10,22,40,.06);
  --shadow-lg:0 18px 40px rgba(10,22,40,.14), 0 4px 8px rgba(10,22,40,.08);
  --shadow-xl:0 28px 60px rgba(23,50,100,.22), 0 8px 16px rgba(10,22,40,.10);

  --r-xs:4px;
  --r-sm:8px;
  --r-md:12px;
  --r-lg:16px;
  --r-xl:24px;
  --r-pill:999px;

  --font-display:"Inter","Helvetica Neue",Arial,sans-serif;
  --font-body:"Inter","Helvetica Neue",Arial,sans-serif;
  --font-mono:ui-monospace,"SF Mono",Menlo,Consolas,monospace;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;scroll-behavior:smooth}
body{font-family:var(--font-body);font-size:16px;line-height:1.6;color:var(--graphite-900);background:var(--off-white);-webkit-font-smoothing:antialiased;overflow-x:hidden}

a{color:var(--ink-500);text-decoration:none;transition:color .15s}
a:hover{color:var(--ink-700)}

h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--ink-900);margin:0;line-height:1.15;letter-spacing:-0.022em;font-weight:700}
h1{font-size:clamp(36px,5.2vw,64px);font-weight:800;letter-spacing:-0.036em}
h2{font-size:clamp(28px,3.6vw,42px);font-weight:800;letter-spacing:-0.028em}
h3{font-size:22px;font-weight:700}
h4{font-size:18px;font-weight:700}
p{margin:0;color:var(--graphite-700)}

::selection{background:var(--accent-cyan);color:var(--ink-900)}

/* ===== NAVBAR ===== */
.nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(18px);border-bottom:1px solid var(--graphite-100)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;max-width:1280px;margin:0 auto;padding:16px 28px;gap:24px}
.brand{display:flex;align-items:center;gap:12px;color:var(--ink-900);text-decoration:none;flex-shrink:0}
.brand img{width:40px;height:40px;border-radius:8px;background:rgba(0,0,0,.04);padding:4px}
.brand-text{display:flex;flex-direction:column;line-height:1.2}
.brand-text strong{font-size:18px;font-weight:800;letter-spacing:-0.025em;color:var(--ink-900)}
.brand-text small{font-size:11px;font-weight:500;color:var(--graphite-500);letter-spacing:0.08em;text-transform:uppercase}

.nav-menu{display:flex;align-items:center;gap:4px;list-style:none;padding:0;margin:0;height:42px}
.nav-menu li{position:relative;display:flex;align-items:center;height:100%;list-style:none}
.nav-menu > li > a{
  display:inline-flex;align-items:center;justify-content:center;
  height:100%;padding:0 14px;
  font-size:14px;font-weight:500;line-height:1;
  color:var(--graphite-700);
  border-radius:var(--r-sm);
  transition:background .15s,color .15s;
  text-decoration:none;
  white-space:nowrap;
}
.nav-menu > li > a:hover{background:var(--ink-50);color:var(--ink-700)}
.nav-menu > li > a.active{color:var(--ink-700);font-weight:600}
.nav-menu .has-sub > a::after{content:"▾";font-size:9px;color:var(--graphite-400);margin-left:6px}
.nav-menu .has-sub{position:relative}
.nav-menu .has-sub::after{content:"";position:absolute;left:0;right:0;top:100%;height:14px;display:none}
.nav-menu .has-sub:hover::after,.nav-menu .has-sub:focus-within::after{display:block}
.nav-menu .submenu{position:absolute;top:calc(100% + 8px);left:0;background:#fff;border:1px solid var(--graphite-100);border-radius:var(--r-md);box-shadow:var(--shadow-lg);padding:8px;min-width:240px;display:none;list-style:none;margin:0;opacity:0;transform:translateY(-4px);transition:opacity .18s ease,transform .18s ease;pointer-events:none}
.nav-menu .has-sub:hover .submenu,.nav-menu .has-sub:focus-within .submenu{display:block;opacity:1;transform:translateY(0);pointer-events:auto}
.nav-menu .submenu li{display:block;height:auto}
.nav-menu .submenu a{display:block;padding:10px 14px;border-radius:var(--r-sm);font-size:14px;line-height:1.3}

.nav-cta{display:flex;align-items:center;gap:10px}
.menu-toggle{display:none;background:rgba(255,255,255,.95);border:1px solid var(--graphite-200,#cdd2de);border-radius:10px;cursor:pointer;padding:8px;color:var(--ink-900);transition:background .15s,border-color .15s,transform .15s;width:42px;height:42px;align-items:center;justify-content:center}
.menu-toggle:hover{background:var(--ink-50,#f0f5fb);border-color:var(--ink-500)}
.menu-toggle:active{transform:scale(.95)}
.menu-toggle[aria-expanded="true"]{background:var(--ink-900);border-color:var(--ink-900);color:#fff}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 22px;font-family:inherit;font-size:14.5px;font-weight:600;border-radius:var(--r-pill);text-decoration:none;cursor:pointer;border:none;transition:all .18s;white-space:nowrap}
.btn--primary{background:var(--ink-700);color:#fff}
.btn--primary:hover{background:var(--ink-800);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn--cyan{background:var(--accent-cyan);color:var(--ink-900)}
.btn--cyan:hover{background:var(--accent-cyan-soft);color:var(--ink-900);transform:translateY(-1px);box-shadow:0 8px 24px rgba(0,212,255,.32)}
.btn--ghost{background:transparent;color:var(--ink-700);border:1.5px solid var(--graphite-200)}
.btn--ghost:hover{border-color:var(--ink-500);color:var(--ink-700);background:var(--ink-50)}
.btn--white{background:#fff;color:var(--ink-900)}
.btn--white:hover{background:var(--graphite-100);color:var(--ink-900)}
.btn--lg{padding:16px 30px;font-size:16px}
.btn svg{width:18px;height:18px}

/* ===== CONTAINERS ===== */
.container{max-width:1240px;margin:0 auto;padding:0 28px}
.container--narrow{max-width:920px}
.section{padding:88px 0}
.section--tight{padding:56px 0}
.section--dark{background:var(--grad-deep);color:#fff}
.section--dark h1,.section--dark h2,.section--dark h3{color:#fff}
.section--dark p{color:rgba(255,255,255,.78)}

/* ===== HERO ===== */
.hero{position:relative;padding:100px 0 80px;background:var(--grad-hero);color:#fff;overflow:hidden}
.hero::before{content:"";position:absolute;top:-200px;right:-200px;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(0,212,255,.22) 0%,transparent 70%);filter:blur(60px)}
.hero::after{content:"";position:absolute;bottom:-150px;left:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(99,102,241,.20) 0%,transparent 70%);filter:blur(60px)}
.hero-inner{position:relative;z-index:2;max-width:920px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;padding:6px 16px;background:rgba(0,212,255,.14);color:var(--accent-cyan);border:1px solid rgba(0,212,255,.32);border-radius:var(--r-pill);font-size:12.5px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;margin-bottom:24px}
.hero-eyebrow .dot{width:6px;height:6px;background:var(--accent-cyan);border-radius:50%;box-shadow:0 0 0 4px rgba(0,212,255,.22)}
.hero h1{color:#fff;margin-bottom:24px}
.hero h1 .grad{background:linear-gradient(120deg,#fff 0%,var(--accent-cyan-soft) 60%,var(--accent-cyan) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero-sub{font-size:clamp(17px,1.6vw,20px);color:rgba(255,255,255,.82);max-width:720px;margin-bottom:36px;line-height:1.55}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}

.page-hero{padding:72px 0 56px;background:var(--grad-deep);color:#fff;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;top:-100px;right:-80px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(0,212,255,.18),transparent 70%);filter:blur(40px)}
.page-hero-inner{position:relative;z-index:2;max-width:880px}
.page-hero h1{color:#fff;font-size:clamp(32px,4.2vw,48px);margin-bottom:16px}
.page-hero p{color:rgba(255,255,255,.82);font-size:18px;line-height:1.6;max-width:680px}
.breadcrumb{font-size:13px;color:rgba(255,255,255,.6);margin-bottom:20px;display:flex;gap:8px;align-items:center}
.breadcrumb a{color:rgba(255,255,255,.78)}
.breadcrumb a:hover{color:var(--accent-cyan)}

/* ===== CARDS ===== */
.grid{display:grid;gap:22px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:980px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

.card{background:#fff;border:1px solid var(--graphite-100);border-radius:var(--r-lg);padding:32px 28px;transition:all .22s;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow-sm)}
.card:hover{border-color:var(--ink-300);box-shadow:var(--shadow-lg);transform:translateY(-3px)}
.card-icon{width:48px;height:48px;border-radius:12px;background:var(--ink-50);color:var(--ink-700);display:grid;place-items:center;margin-bottom:8px}
.card-icon svg{width:24px;height:24px}
.card.accent .card-icon{background:linear-gradient(135deg,var(--ink-700),var(--accent-cyan));color:#fff}
.card h3{font-size:19px;font-weight:700;color:var(--ink-900);letter-spacing:-0.018em}
.card p{font-size:15px;color:var(--graphite-700);line-height:1.6;margin:0;flex:1}
.card-link{margin-top:6px;color:var(--ink-700);font-weight:600;font-size:14px;display:inline-flex;align-items:center;gap:6px}
.card-link::after{content:"→";transition:transform .2s}
.card:hover .card-link::after{transform:translateX(4px)}

.card-clickable{cursor:pointer;text-decoration:none;color:inherit}

/* ===== SECTION HEADERS ===== */
.section-eyebrow{display:inline-block;font-size:12.5px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-600);margin-bottom:14px}
.section-title{font-size:clamp(28px,3.4vw,40px);margin-bottom:14px}
.section-lead{font-size:18px;color:var(--graphite-700);max-width:720px;margin:0 0 40px;line-height:1.55}

/* ===== FEATURES LIST ===== */
.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;margin-top:36px}
.feature{display:flex;gap:14px;align-items:flex-start}
.feature-icon{flex-shrink:0;width:32px;height:32px;background:var(--ink-50);color:var(--ink-700);border-radius:8px;display:grid;place-items:center}
.feature h4{font-size:16px;color:var(--ink-900);margin:0 0 4px}
.feature p{font-size:14.5px;color:var(--graphite-500);margin:0;line-height:1.5}

/* ===== CTA BLOCK ===== */
.cta-block{background:var(--grad-hero);color:#fff;border-radius:var(--r-xl);padding:56px 48px;text-align:center;position:relative;overflow:hidden;margin:40px 0}
.cta-block::before{content:"";position:absolute;top:-100px;right:-100px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(0,212,255,.24),transparent 70%);filter:blur(40px)}
.cta-block > *{position:relative;z-index:2}
.cta-block h2{color:#fff;margin-bottom:14px;font-size:clamp(24px,3vw,34px)}
.cta-block p{color:rgba(255,255,255,.82);font-size:17px;max-width:600px;margin:0 auto 28px}
.cta-block .btn-group{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ===== CONTENT (páginas internas) ===== */
.content{padding:64px 0}
.content h2{font-size:32px;margin:48px 0 18px;color:var(--ink-900);position:relative;padding-bottom:14px}
.content h2::after{content:"";position:absolute;left:0;bottom:0;width:48px;height:3px;background:linear-gradient(90deg,var(--ink-700),var(--accent-cyan));border-radius:2px}
.content h3{font-size:22px;margin:32px 0 12px;color:var(--ink-800)}
.content p{margin:0 0 16px;font-size:16.5px;line-height:1.7;color:var(--graphite-700)}
.content ul,.content ol{margin:0 0 20px 22px;padding:0}
.content li{margin-bottom:8px;line-height:1.65;color:var(--graphite-700)}
.content strong{color:var(--ink-900);font-weight:600}
.content blockquote{border-left:3px solid var(--accent-cyan);background:var(--ink-50);padding:18px 24px;margin:24px 0;border-radius:0 var(--r-md) var(--r-md) 0;color:var(--ink-800);font-style:italic}

.note{background:var(--ink-50);border:1px solid var(--ink-200);border-left:4px solid var(--ink-500);padding:18px 22px;border-radius:var(--r-md);margin:24px 0;color:var(--ink-800);font-size:15px;line-height:1.6}
.note strong{color:var(--ink-900)}

/* ===== FOOTER ===== */
.site-footer{background:var(--grad-deep);color:rgba(255,255,255,.78);padding:64px 0 24px;margin-top:80px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;max-width:1240px;margin:0 auto;padding:0 28px}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:540px){.footer-grid{grid-template-columns:1fr}}
.footer-brand img{width:46px;height:46px;border-radius:10px;background:rgba(255,255,255,.06);padding:5px;margin-bottom:14px}
.footer-brand strong{display:block;color:#fff;font-size:18px;font-weight:800;letter-spacing:-0.02em;margin-bottom:6px}
.footer-brand p{color:rgba(255,255,255,.62);font-size:14px;line-height:1.55;max-width:300px}
.footer-col h5{color:#fff;font-size:13px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;margin:0 0 14px}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{margin-bottom:8px}
.footer-col a{color:rgba(255,255,255,.72);font-size:14px;transition:color .15s}
.footer-col a:hover{color:var(--accent-cyan)}
.footer-bottom{max-width:1240px;margin:48px auto 0;padding:24px 28px 0;border-top:1px solid rgba(255,255,255,.10);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;font-size:13px;color:rgba(255,255,255,.54)}
.footer-bottom a{color:rgba(255,255,255,.72);margin-left:18px}

/* ===== WHATSAPP FLOAT ===== */
.whatsapp-float{position:fixed;right:22px;bottom:22px;z-index:9999;display:inline-flex;align-items:center;gap:10px;padding:14px 18px;border-radius:var(--r-pill);text-decoration:none;font-weight:600;font-size:14.5px;color:#fff;background:linear-gradient(135deg,#25d366,#1da851);box-shadow:0 14px 36px rgba(37,211,102,.36),0 4px 10px rgba(0,0,0,.18);transition:all .25s}
.whatsapp-float:hover{transform:translateY(-2px) scale(1.02);color:#fff;box-shadow:0 18px 44px rgba(37,211,102,.46)}
.whatsapp-float svg{width:22px;height:22px;flex-shrink:0}
.whatsapp-float span{display:inline-block}
.whatsapp-float::before{content:"";position:absolute;inset:0;border-radius:inherit;background:#25d366;animation:wa-pulse 2.4s ease-out infinite;opacity:0;z-index:-1}
@keyframes wa-pulse{0%{transform:scale(1);opacity:.5}80%{transform:scale(1.4);opacity:0}100%{opacity:0}}

@media(max-width:768px){
  .whatsapp-float{right:14px;bottom:14px;padding:12px 14px;font-size:13.5px}
  .whatsapp-float span{display:none}
}

/* ===== TABLES (em conteúdo) ===== */
.table-wrap{overflow-x:auto;margin:24px 0}
table{width:100%;border-collapse:collapse;background:#fff;box-shadow:var(--shadow-sm);border-radius:var(--r-md);overflow:hidden}
th{background:var(--ink-700);color:#fff;padding:12px 16px;text-align:left;font-size:14px;font-weight:600;letter-spacing:0.02em}
td{padding:12px 16px;border-bottom:1px solid var(--graphite-100);font-size:14.5px;color:var(--graphite-700);vertical-align:top}
tr:last-child td{border-bottom:none}

/* ===== FORM (contato) ===== */
.form{display:grid;gap:18px;max-width:640px;margin-top:30px}
.form-field{display:flex;flex-direction:column;gap:6px}
.form-field label{font-size:14px;font-weight:600;color:var(--ink-900)}
.form-field input,.form-field textarea,.form-field select{padding:12px 16px;font-family:inherit;font-size:15px;color:var(--ink-900);background:#fff;border:1.5px solid var(--graphite-200);border-radius:var(--r-md);outline:none;transition:all .15s}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{border-color:var(--ink-500);box-shadow:0 0 0 3px rgba(39,86,165,.14)}
.form-field textarea{min-height:120px;resize:vertical;font-family:inherit}

/* ===== RESPONSIVE NAV ===== */
@media(max-width:960px){
  .nav-menu{
    display:none;
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;
    height:auto;max-height:calc(100vh - 80px);overflow-y:auto;
    background:#fff;
    border-top:1px solid var(--graphite-100);
    border-bottom:1px solid var(--graphite-100);
    box-shadow:var(--shadow-lg);
    padding:10px;
    align-items:stretch;
    gap:2px;
    list-style:none;margin:0;
  }
  .nav-menu.open{display:flex}
  .nav-menu li{
    display:block;
    height:auto;
    width:100%;
    position:relative;
  }
  .nav-menu > li > a{
    display:flex;align-items:center;justify-content:space-between;
    width:100%;height:auto;
    padding:13px 16px;
    font-size:15px;font-weight:500;
    color:var(--ink-900);
    border-radius:var(--r-sm);
    line-height:1.3;
  }
  .nav-menu > li > a:hover,
  .nav-menu > li > a.active{background:var(--ink-50,#f0f5fb);color:var(--ink-700)}
  .nav-menu .has-sub > a::after{
    content:"▾";
    font-size:12px;color:var(--graphite-500);
    margin-left:8px;
  }
  .nav-menu .has-sub::after{display:none !important}
  .nav-menu .submenu{
    position:static;
    background:transparent;
    border:none;box-shadow:none;
    padding:4px 0 8px 16px;
    margin:0;
    min-width:0;
    display:block;
    opacity:1;
    transform:none;
    pointer-events:auto;
    transition:none;
  }
  .nav-menu .submenu li{border-left:2px solid var(--graphite-100)}
  .nav-menu .submenu a{
    display:block;
    padding:10px 14px;
    font-size:14px;
    color:var(--graphite-700);
    border-radius:var(--r-sm);
    line-height:1.4;
  }
  .nav-menu .submenu a:hover{background:var(--ink-50,#f0f5fb);color:var(--ink-700)}
  .menu-toggle{display:inline-flex}
  .nav-cta .btn{display:none}
}

@media(max-width:540px){
  .container{padding:0 18px}
  .nav-inner{padding:14px 18px}
  .section{padding:60px 0}
  .hero{padding:72px 0 56px}
  .cta-block{padding:36px 24px}
  .card{padding:24px 20px}
  .footer-bottom{justify-content:flex-start}
}

/* ===== UTILS ===== */
.text-center{text-align:center}
.text-cyan{color:var(--accent-cyan)}
.mb-0{margin-bottom:0}
.mt-3{margin-top:24px}
.mt-4{margin-top:36px}

/* Scroll fade-in suave */
.fade-in{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.fade-in.is-visible{opacity:1;transform:translateY(0)}

/* ===== VERTICAIS (PROMPT 42) ===== */
.lead{font-size:18px;color:var(--ink-700);max-width:780px;margin:0 auto;text-align:center;line-height:1.55}

.cards-grid--verticais{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(290px,1fr));
  gap:22px;
  margin-top:20px;
}
.card-vertical{
  display:block;
  background:#fff;
  border-radius:18px;
  padding:30px 26px 26px;
  border:1px solid #e3eaf1;
  box-shadow:0 1px 0 rgba(10,22,40,.04);
  transition:transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s,border-color .25s;
  position:relative;
  overflow:hidden;
}
.card-vertical::before{
  content:"";
  position:absolute;left:0;top:0;height:3px;width:0;
  background:linear-gradient(90deg,var(--accent-cyan),#0a1628);
  transition:width .3s ease;
}
.card-vertical:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 44px rgba(10,22,40,.12);
  border-color:#cdd9e5;
}
.card-vertical:hover::before{width:100%}
.card-vertical .card-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:56px;height:56px;border-radius:14px;
  background:linear-gradient(135deg,#eef6fa,#dff2f9);
  font-size:28px;margin-bottom:18px;
}
.card-vertical h3{
  font-size:18px;font-weight:700;color:var(--ink-900);margin-bottom:10px;line-height:1.3
}
.card-vertical p{
  font-size:14.5px;color:var(--ink-600);line-height:1.55;margin-bottom:18px
}
.card-vertical .card-cta{
  font-size:14px;font-weight:600;color:var(--accent-cyan-dark,#006b8a);
}

/* FAQ */
.faq-block{margin-top:8px}
.faq-item{
  border:1px solid #e3eaf1;border-radius:12px;
  margin-bottom:10px;background:#fff;overflow:hidden;
  transition:border-color .2s,box-shadow .2s;
}
.faq-item[open]{border-color:#cfdbe6;box-shadow:0 4px 14px rgba(10,22,40,.06)}
.faq-item summary{
  list-style:none;cursor:pointer;
  padding:16px 22px;font-weight:600;color:var(--ink-900);font-size:15.5px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";font-size:24px;color:var(--accent-cyan-dark,#006b8a);
  font-weight:300;transition:transform .25s;line-height:1;
}
.faq-item[open] summary::after{content:"−"}
.faq-item p{
  padding:0 22px 18px;color:var(--ink-700);font-size:14.5px;line-height:1.65;margin:0;
}

/* CTA Block */
.cta-block{
  background:linear-gradient(135deg,#0a1628 0%,#1a2942 100%);
  padding:64px 24px;margin-top:60px;
  color:#fff;text-align:center;
}
.cta-inner h2{color:#fff;margin-bottom:14px;font-size:30px}
.cta-inner p{color:#c1cad6;margin-bottom:26px;max-width:620px;margin-left:auto;margin-right:auto;font-size:16.5px}
.cta-buttons{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-block .btn--ghost{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.2)}
.cta-block .btn--ghost:hover{background:rgba(255,255,255,.14)}

.grid-list{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:6px 18px;
  list-style:none;
  padding:0;
}
.grid-list li{
  position:relative;
  padding:6px 0 6px 18px;
  color:var(--ink-700);
  font-size:14.5px;
  line-height:1.5;
}
.grid-list li::before{
  content:"";
  position:absolute;
  left:0;top:13px;
  width:6px;height:6px;
  background:var(--accent-cyan);
  border-radius:50%;
}

.content--alt{background:linear-gradient(180deg,#fff 0%,#f5f7fa 100%);padding:60px 0 80px}

/* ===== CONTATO MINIMALISTA (PROMPT 43) ===== */
.contact-wa-card{
  max-width:560px;margin:30px auto 60px;
  background:#fff;border-radius:22px;padding:60px 48px 56px;
  text-align:center;
  border:1px solid #e3eaf1;
  box-shadow:0 24px 60px rgba(10,22,40,.10),0 2px 6px rgba(10,22,40,.04);
  position:relative;overflow:hidden;
}
.contact-wa-card::before{
  content:"";
  position:absolute;left:0;right:0;top:0;height:5px;
  background:linear-gradient(90deg,#25d366 0%,#1da851 100%);
}
.contact-wa-icon{
  width:96px;height:96px;border-radius:50%;
  background:linear-gradient(135deg,#25d366 0%,#1da851 100%);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 24px;color:#fff;
  box-shadow:0 12px 30px rgba(37,211,102,.32);
}
.contact-wa-icon svg{width:48px;height:48px}
.contact-wa-card h2{font-size:28px;color:var(--ink-900);margin-bottom:16px}
.contact-wa-card p{font-size:16px;color:var(--ink-700);line-height:1.65;max-width:440px;margin:0 auto 22px}
.contact-wa-number{
  font-size:22px;font-weight:700;color:var(--ink-900);
  letter-spacing:.3px;margin:8px 0 26px;
}
.btn--wa{
  background:linear-gradient(135deg,#25d366 0%,#1da851 100%);
  color:#fff;border:none;
  padding:16px 36px;font-size:16px;font-weight:700;
  display:inline-flex;align-items:center;gap:10px;
  border-radius:999px;cursor:pointer;
  box-shadow:0 8px 22px rgba(37,211,102,.36);
  transition:transform .2s,box-shadow .2s;
}
.btn--wa:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(37,211,102,.44)}
.btn--lg{padding:16px 36px;font-size:16px}

@media(max-width:540px){
  .contact-wa-card{padding:48px 28px 44px;margin:18px 14px 40px}
  .contact-wa-icon{width:80px;height:80px}
  .contact-wa-icon svg{width:40px;height:40px}
  .contact-wa-card h2{font-size:24px}
  .contact-wa-number{font-size:20px}
}

/* ===== LOCALIZAÇÃO COM MAPA ===== */
.contact-location{
  display:grid;
  grid-template-columns:minmax(280px,1fr) 1.4fr;
  gap:28px;
  align-items:stretch;
  max-width:1100px;
  margin:0 auto;
}
.contact-address{
  background:#fff;
  border:1px solid #e3eaf1;
  border-radius:18px;
  padding:32px 32px 28px;
  box-shadow:0 8px 24px rgba(10,22,40,.06);
  display:flex;flex-direction:column;gap:20px;
  position:relative;overflow:hidden;
}
.contact-address::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--accent-cyan,#00d4ff) 0%,var(--ink-500,#2756a5) 100%);
}
.contact-address-icon{
  width:54px;height:54px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,212,255,.10);
  border:1px solid rgba(0,212,255,.28);
  color:var(--accent-cyan-dark,#006b8a);
  flex-shrink:0;
}
.contact-address-icon svg{width:26px;height:26px}
.contact-address-content h3{
  font-size:18px;color:var(--ink-900);font-weight:700;
  margin:0 0 12px;letter-spacing:-0.005em;
}
.contact-address-line{
  font-size:15px;color:var(--ink-700);
  line-height:1.6;margin:0 0 4px;
}
.contact-address-line + .contact-address-line{margin-top:2px}
.contact-address-btn{
  margin-top:18px;
  align-self:flex-start;
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 18px;
  font-size:14px;font-weight:600;
  border:1px solid var(--ink-500,#2756a5);
  color:var(--ink-700);
  background:#fff;
  border-radius:999px;
  transition:background .2s,color .2s,transform .2s;
}
.contact-address-btn:hover{
  background:var(--ink-500,#2756a5);color:#fff;
  transform:translateY(-1px);
}
.contact-map{
  border-radius:18px;
  overflow:hidden;
  border:1px solid #e3eaf1;
  box-shadow:0 8px 24px rgba(10,22,40,.06);
  background:#eef2f7;
  min-height:360px;
  position:relative;
}
.contact-map iframe{display:block;width:100%;height:100%;min-height:360px;border:0}

@media(max-width:860px){
  .contact-location{grid-template-columns:1fr;gap:20px}
  .contact-address{padding:28px 24px 24px}
  .contact-map{min-height:300px}
  .contact-map iframe{min-height:300px}
}
@media(max-width:540px){
  .contact-address{padding:24px 20px 22px}
  .contact-address-content h3{font-size:16.5px}
  .contact-address-line{font-size:14.5px}
}

/* ===== PÁGINA SOLUÇÕES (PROMPT 44) ===== */
.section-header{text-align:center;max-width:780px;margin:0 auto 44px}
.section-eyebrow{
  display:inline-block;
  font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  color:var(--accent-cyan-dark,#006b8a);margin-bottom:14px;
}
.section-header h2{font-size:32px;color:var(--ink-900);line-height:1.25;margin-bottom:14px}
.section-sub{font-size:16.5px;color:var(--ink-700);line-height:1.6}

/* Desafios */
.desafios-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:20px;margin-top:40px;
}
.desafio-item{
  background:#fff;border-radius:16px;padding:28px 26px;
  border:1px solid #e3eaf1;
  transition:transform .25s,box-shadow .25s,border-color .25s;
}
.desafio-item:hover{
  transform:translateY(-3px);
  box-shadow:0 14px 38px rgba(10,22,40,.10);
  border-color:#cdd9e5;
}
.desafio-icon{
  font-size:32px;margin-bottom:14px;
  display:inline-flex;align-items:center;justify-content:center;
  width:54px;height:54px;border-radius:13px;
  background:linear-gradient(135deg,#fef3c7,#fde68a);
}
.desafio-item h3{font-size:17px;color:var(--ink-900);margin-bottom:8px;font-weight:700}
.desafio-item p{font-size:14.5px;color:var(--ink-700);line-height:1.55;margin:0}

/* Soluções grid */
.solucoes-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:24px;margin-top:40px;
}
.solucao-card{
  background:#fff;border-radius:18px;padding:32px 28px 24px;
  border:1px solid #e3eaf1;
  position:relative;
  transition:transform .25s,box-shadow .25s,border-color .25s;
}
.solucao-card:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 44px rgba(10,22,40,.12);
  border-color:#cdd9e5;
}
.solucao-num{
  position:absolute;top:18px;right:24px;
  font-size:38px;font-weight:800;
  background:linear-gradient(180deg,#00d4ff,#006b8a);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  opacity:.4;line-height:1;
}
.solucao-card h3{
  font-size:20px;color:var(--ink-900);font-weight:700;
  line-height:1.3;margin-bottom:18px;padding-right:50px;
}
.solucao-tag{
  display:inline-block;
  font-size:10.5px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--accent-cyan-dark,#006b8a);
  background:rgba(0,212,255,.08);
  padding:3px 9px;border-radius:6px;
  margin:10px 0 4px;
}
.solucao-text{
  font-size:14px;color:var(--ink-700);line-height:1.5;margin:0;
}
.solucao-link{
  display:inline-block;margin-top:18px;
  font-size:14px;font-weight:600;color:var(--accent-cyan-dark,#006b8a);
  transition:transform .2s;
}
.solucao-link:hover{transform:translateX(3px)}

/* Públicos */
.publicos-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:18px;margin-top:36px;
}
.publico-card{
  background:#fff;border-radius:14px;padding:24px 18px;
  text-align:center;border:1px solid #e3eaf1;
  transition:transform .25s,box-shadow .25s;
}
.publico-card:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(10,22,40,.10)}
.publico-icon{font-size:36px;display:block;margin-bottom:12px}
.publico-card h4{font-size:14.5px;color:var(--ink-900);font-weight:600;margin:0;line-height:1.4}

/* Passos */
.passos-list{
  list-style:none;padding:0;margin:40px 0 0;
}
.passos-list li{
  display:flex;gap:24px;align-items:flex-start;
  padding:24px 0;border-bottom:1px solid #e3eaf1;
}
.passos-list li:last-child{border-bottom:none}
.passo-num{
  flex-shrink:0;
  width:54px;height:54px;border-radius:50%;
  background:linear-gradient(135deg,#0a1628,#1a2942);
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:22px;font-weight:700;
  box-shadow:0 6px 18px rgba(10,22,40,.20);
}
.passos-list h4{font-size:18px;color:var(--ink-900);margin-bottom:6px;font-weight:700}
.passos-list p{font-size:15px;color:var(--ink-700);line-height:1.6;margin:0}

@media(max-width:540px){
  .section-header h2{font-size:26px}
  .solucao-card{padding:28px 22px 22px}
  .solucao-num{font-size:32px}
  .desafios-grid,.solucoes-grid{grid-template-columns:1fr}
  .passos-list li{gap:16px}
  .passo-num{width:44px;height:44px;font-size:18px}
}

/* ===== PÁGINA JAMILLE PORTO (PROMPT 48) ===== */
.jp-hero{padding-bottom:60px}
.jp-hero-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:60px;
  align-items:center;
  padding-top:30px;
}
.jp-hero-text h1{
  font-size:54px;line-height:1.1;
  margin-top:18px;margin-bottom:18px;
  color:#fff;font-weight:700;
}
.jp-tagline{
  font-size:18px;line-height:1.55;
  color:rgba(255,255,255,.86);
  max-width:520px;
}
.jp-hero-photo{
  position:relative;
}
.jp-hero-photo img{
  width:100%;max-width:380px;
  aspect-ratio:1/1;
  object-fit:cover;
  border-radius:24px;
  border:3px solid rgba(0,212,255,.3);
  box-shadow:0 24px 80px rgba(0,0,0,.5),
             0 0 0 1px rgba(0,212,255,.2);
  display:block;
  margin:0 auto;
}
.jp-hero-photo::before{
  content:"";
  position:absolute;
  inset:-20px;
  background:radial-gradient(circle at 30% 30%, rgba(0,212,255,.25), transparent 60%);
  z-index:-1;
  border-radius:50%;
}

.jp-text p{
  font-size:16.5px;line-height:1.75;
  color:var(--ink-700);
  margin-bottom:18px;
}
.jp-text p strong{color:var(--ink-900)}

/* Expertise grid */
.expertise-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:20px;margin-top:40px;
}
.expertise-card{
  background:#fff;border-radius:16px;padding:28px 24px;
  border:1px solid #e3eaf1;
  transition:transform .25s,box-shadow .25s,border-color .25s;
}
.expertise-card:hover{
  transform:translateY(-3px);
  box-shadow:0 14px 38px rgba(10,22,40,.10);
  border-color:#cdd9e5;
}
.expertise-icon{
  font-size:32px;display:block;margin-bottom:14px;
  width:54px;height:54px;border-radius:13px;
  background:linear-gradient(135deg,rgba(0,212,255,.10),rgba(0,212,255,.04));
  display:inline-flex;align-items:center;justify-content:center;
}
.expertise-card h3{font-size:17px;color:var(--ink-900);margin-bottom:8px;font-weight:700;line-height:1.3}
.expertise-card p{font-size:14.5px;color:var(--ink-700);line-height:1.55;margin:0}

/* Trajetória */
.trajetoria{margin-top:36px}
.traj-block{
  background:#fff;border-left:3px solid var(--accent-cyan);
  padding:22px 28px;margin-bottom:18px;
  border-radius:0 12px 12px 0;
  box-shadow:0 1px 0 rgba(10,22,40,.04);
}
.traj-block h3{
  font-size:18px;color:var(--ink-900);
  margin-bottom:10px;font-weight:700;
}
.traj-block p{font-size:15px;color:var(--ink-700);line-height:1.65;margin:0}

/* Publicações */
.publicacoes p{font-size:16.5px;color:var(--ink-700);line-height:1.65}
.publicacoes-lista{
  list-style:none;padding:0;margin-top:20px;
}
.publicacoes-lista li{
  padding:14px 20px;
  border-radius:10px;
  background:#fff;
  border:1px solid #e3eaf1;
  margin-bottom:10px;
  font-size:15.5px;color:var(--ink-700);
}
.publicacoes-lista li strong{color:var(--ink-900);font-weight:700}
.link-arrow{
  font-weight:600;color:var(--accent-cyan-dark,#006b8a);
  transition:transform .2s;display:inline-block;
}
.link-arrow:hover{transform:translateX(3px)}

/* Palestras grid */
.palestras-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:20px;margin-top:36px;
}
.palestra-card{
  background:#fff;border-radius:16px;padding:24px 22px;
  border:1px solid #e3eaf1;
}
.palestra-card h4{font-size:16.5px;color:var(--ink-900);margin-bottom:10px;font-weight:700;line-height:1.35}
.palestra-card p{font-size:14.5px;color:var(--ink-700);line-height:1.55;margin:0}

@media(max-width:960px){
  .jp-hero-grid{grid-template-columns:1fr;gap:36px;text-align:left}
  .jp-hero-text h1{font-size:42px}
  .jp-hero-photo{order:-1;display:flex;justify-content:center}
  .jp-hero-photo img{max-width:280px}
}
@media(max-width:540px){
  .jp-hero-text h1{font-size:32px}
  .jp-tagline{font-size:16px}
  .expertise-grid,.palestras-grid{grid-template-columns:1fr}
  .traj-block{padding:18px 20px}
}

/* ===== AJUSTES PROMPT 59 ===== */
/* Lista elegante para subpáginas de Soluções */
.lista-elegante{
  list-style:none;padding:0;margin:24px 0 8px;
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:10px 22px;
}
.lista-elegante li{
  position:relative;
  padding:8px 0 8px 22px;
  color:var(--ink-700);
  font-size:15px;
  line-height:1.55;
}
.lista-elegante li::before{
  content:"";
  position:absolute;left:0;top:14px;
  width:8px;height:8px;border-radius:2px;
  background:linear-gradient(135deg,var(--accent-cyan),#006b8a);
}

/* Card de solução sem mais rótulos — mais espaçamento na descrição */
.solucao-card .solucao-text{
  font-size:15px;color:var(--ink-700);
  line-height:1.65;margin:0 0 20px;
}
.solucao-card h3{margin-bottom:14px}

@media(max-width:540px){
  .cards-grid--verticais{grid-template-columns:1fr}
  .cta-buttons{flex-direction:column;align-items:stretch}
  .cta-buttons .btn{width:100%;justify-content:center}
}

/* Botão WhatsApp verde no header */
.btn--wa-green{
  display:inline-flex;align-items:center;
  background:linear-gradient(135deg,#25d366 0%,#1da851 100%);
  color:#fff;
  padding:10px 18px;border-radius:999px;
  font-weight:600;font-size:13.5px;
  text-decoration:none;
  box-shadow:0 4px 14px rgba(37,211,102,.32);
  transition:transform .2s,box-shadow .2s,background .25s;
  border:none;line-height:1;
}
.btn--wa-green:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 22px rgba(37,211,102,.42);
  background:linear-gradient(135deg,#2bd970 0%,#1eb555 100%);
}
.btn--wa-green svg{flex-shrink:0}

/* ============================================ */
/* PROMPT 60 — HUBS ARTIGOS, FAQ E COMPONENTES  */
/* ============================================ */

/* Hero específico para Fluxo (mantido) e Article hero escuro */
.hero-fluxo{
  position:relative;
  background:linear-gradient(135deg,#0a1628 0%,#1a2942 50%,#0f1f3a 100%);
  color:#fff;
  padding:80px 0 70px;
  overflow:hidden;
}
.hero-fluxo-bg{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 80% 20%, rgba(0,212,255,.18), transparent 60%),
             radial-gradient(circle at 10% 80%, rgba(0,107,138,.20), transparent 55%);
}
.hero-fluxo .container{position:relative;z-index:1}
.hero-fluxo-inner{max-width:780px}
.hero-fluxo h1{
  font-size:54px;font-weight:700;line-height:1.1;
  color:#fff;margin:18px 0 20px;
}
.hero-fluxo-lead{
  font-size:18.5px;line-height:1.55;
  color:rgba(255,255,255,.86);max-width:680px;margin-bottom:30px;
}
.hero-fluxo-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-fluxo-actions .btn--ghost{
  background:rgba(255,255,255,.08);color:#fff;
  border:1px solid rgba(255,255,255,.20);
}
.hero-fluxo-actions .btn--ghost:hover{background:rgba(255,255,255,.16)}
.hero-fluxo .hero-eyebrow{color:rgba(255,255,255,.75)}
.hero-fluxo .hero-eyebrow .dot{background:var(--accent-cyan,#00d4ff)}

@media(max-width:768px){
  .hero-fluxo h1{font-size:38px}
  .hero-fluxo-lead{font-size:16.5px}
}

/* Cards 3 colunas (features/diferenciais) */
.cards-3col{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:22px;margin-top:36px;
}
.card-feature{
  background:#fff;border-radius:16px;
  padding:30px 26px;
  border:1px solid #e3eaf1;
  transition:transform .25s,box-shadow .25s,border-color .25s;
}
.card-feature:hover{
  transform:translateY(-3px);
  box-shadow:0 16px 40px rgba(10,22,40,.10);
  border-color:#cdd9e5;
}
.card-feature-icon{
  font-size:28px;width:54px;height:54px;
  border-radius:14px;
  background:linear-gradient(135deg,#eef6fa,#dff2f9);
  display:inline-flex;align-items:center;justify-content:center;
  margin-bottom:18px;
}
.card-feature h3{
  font-size:17px;color:var(--ink-900);font-weight:700;
  margin-bottom:10px;line-height:1.35;
}
.card-feature p{
  font-size:14.5px;color:var(--ink-700);
  line-height:1.6;margin:0;
}
.card-feature--accent{
  background:linear-gradient(180deg,#fff 0%,#f8fbfd 100%);
}

/* Steps grid */
.steps-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:22px;margin-top:36px;
}
.step-card{
  background:#fff;border-radius:16px;
  padding:30px 26px;
  border:1px solid #e3eaf1;
  position:relative;
}
.step-num{
  display:inline-block;
  font-size:32px;font-weight:800;
  background:linear-gradient(180deg,var(--accent-cyan,#00d4ff),#006b8a);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  line-height:1;margin-bottom:14px;
}
.step-card h4{
  font-size:17px;color:var(--ink-900);font-weight:700;
  margin-bottom:10px;line-height:1.35;
}
.step-card p{
  font-size:14.5px;color:var(--ink-700);
  line-height:1.6;margin:0;
}

/* Hub toolbar (busca + filtros) */
.hub-toolbar{
  display:flex;flex-direction:column;gap:18px;
  margin:30px 0 36px;padding:24px;
  background:#fff;border-radius:18px;
  border:1px solid #e3eaf1;
  box-shadow:0 1px 0 rgba(10,22,40,.03);
}
.hub-search{
  position:relative;display:flex;align-items:center;
  background:#f5f7fa;border-radius:12px;
  padding:0 16px;
}
.hub-search svg{color:#3d5a8c;flex-shrink:0}
.hub-search input{
  flex:1;border:none;background:transparent;
  padding:14px 12px;font-size:15px;
  color:var(--ink-900);outline:none;font-family:inherit;
}
.hub-search input::placeholder{color:#7a8aa8}

.hub-filtros{display:flex;flex-wrap:wrap;gap:8px}
.filtro-btn{
  padding:8px 16px;border-radius:999px;
  background:#f5f7fa;border:1px solid transparent;
  font-size:13.5px;font-weight:600;
  color:var(--ink-700);cursor:pointer;
  transition:all .2s;font-family:inherit;
}
.filtro-btn:hover{background:#e7eef5;color:var(--ink-900)}
.filtro-btn.active{background:var(--ink-900);color:#fff;border-color:var(--ink-900)}

/* Grid de artigos */
.artigos-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:22px;margin-top:12px;
}
.article-card{
  display:flex;flex-direction:column;
  background:#fff;border-radius:18px;
  padding:28px 26px 24px;
  border:1px solid #e3eaf1;
  text-decoration:none;color:inherit;
  transition:transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s,border-color .25s;
  position:relative;overflow:hidden;
}
.article-card::before{
  content:"";
  position:absolute;left:0;top:0;height:3px;width:0;
  background:linear-gradient(90deg,var(--accent-cyan,#00d4ff),#006b8a);
  transition:width .3s ease;
}
.article-card:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 44px rgba(10,22,40,.12);
  border-color:#cdd9e5;
}
.article-card:hover::before{width:100%}
.article-cat{
  display:inline-block;
  font-size:11px;letter-spacing:1.5px;text-transform:uppercase;
  font-weight:700;color:#006b8a;
  background:rgba(0,212,255,.10);
  padding:4px 10px;border-radius:6px;
  margin-bottom:14px;align-self:flex-start;
}
.article-card h3{
  font-size:18px;font-weight:700;color:var(--ink-900);
  line-height:1.35;margin-bottom:12px;flex:0 0 auto;
}
.article-card p{
  font-size:14.5px;color:var(--ink-700);
  line-height:1.55;margin:0 0 18px;flex:1;
}
.article-link{
  font-size:13.5px;font-weight:600;
  color:#006b8a;transition:transform .2s;
}
.article-card:hover .article-link{transform:translateX(3px)}

.hub-empty{
  text-align:center;padding:60px 20px;
  color:#3d5a8c;font-size:16px;
}

/* Artigo individual */
.page-hero--article{
  background:linear-gradient(135deg,#0a1628 0%,#1a2942 100%);
}
.page-hero--article h1{color:#fff}
.page-hero--article .breadcrumb,
.page-hero--article .breadcrumb a{color:rgba(255,255,255,.75)}
.page-hero--article .hero-eyebrow{color:rgba(255,255,255,.75)}
.page-hero--article .hero-eyebrow .dot{background:var(--accent-cyan,#00d4ff)}
.article-meta{
  color:rgba(255,255,255,.7);
  font-size:14px;margin-top:24px;
  display:flex;gap:10px;align-items:center;flex-wrap:wrap;
}
.article-meta strong{color:#fff}

.article-body{padding:50px 0 30px}
.article-body .container--narrow{max-width:760px}
.article-body h1{
  font-size:30px;color:var(--ink-900);
  margin:36px 0 18px;line-height:1.25;font-weight:700;
}
.article-body h2{
  font-size:26px;color:var(--ink-900);
  margin:40px 0 16px;line-height:1.3;font-weight:700;
}
.article-body h3{
  font-size:20px;color:var(--ink-900);
  margin:32px 0 12px;line-height:1.35;font-weight:700;
}
.article-body h4{
  font-size:17px;color:var(--ink-900);
  margin:24px 0 10px;font-weight:700;
}
.article-body p{
  font-size:16.5px;line-height:1.75;
  color:var(--ink-700);margin-bottom:20px;
}
.article-body ul,.article-body ol{margin:18px 0 24px;padding-left:24px}
.article-body li{
  font-size:16px;line-height:1.7;
  color:var(--ink-700);margin-bottom:10px;
}
.article-body strong{color:var(--ink-900);font-weight:700}
.article-body em{color:var(--ink-700)}
.article-body code{
  background:#f5f7fa;padding:2px 8px;
  border-radius:4px;font-size:.92em;
  font-family:'SF Mono',Menlo,Consolas,monospace;
}
.article-body a{
  color:#006b8a;text-decoration:underline;
  text-decoration-color:rgba(0,107,138,.3);text-underline-offset:3px;
}
.article-body a:hover{text-decoration-color:#006b8a}
.article-body blockquote{
  border-left:4px solid var(--accent-cyan,#00d4ff);
  padding:16px 24px;margin:24px 0;
  background:rgba(0,212,255,.05);
  border-radius:0 12px 12px 0;
  color:var(--ink-700);font-style:italic;
}
.article-body hr{border:none;border-top:1px solid #e3eaf1;margin:40px 0}

/* FAQ categorias grid */
.faq-cats-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:22px;margin-top:30px;
}
.faq-cat-card{
  display:flex;flex-direction:column;
  background:#fff;border-radius:18px;
  padding:28px 26px 24px;
  border:1px solid #e3eaf1;
  text-decoration:none;color:inherit;
  transition:transform .25s,box-shadow .25s,border-color .25s;
}
.faq-cat-card:hover{
  transform:translateY(-3px);
  box-shadow:0 16px 38px rgba(10,22,40,.10);
  border-color:#cdd9e5;
}
.faq-cat-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;border-radius:12px;
  background:linear-gradient(135deg,var(--accent-cyan,#00d4ff),#006b8a);
  color:#fff;font-weight:800;font-size:18px;
  margin-bottom:16px;
}
.faq-cat-card h3{
  font-size:17px;font-weight:700;color:var(--ink-900);
  line-height:1.35;margin-bottom:10px;
}
.faq-cat-preview{
  font-size:14px;color:#3d5a8c;
  line-height:1.55;font-style:italic;
  margin:0 0 14px;flex:1;
}

/* Encerramento institucional discreto nos artigos */
.encerramento-institucional{
  text-align:center;
  padding:40px 0 20px;
  max-width:680px;margin:0 auto;
}
.encerramento-institucional p{
  font-size:17px;line-height:1.7;
  color:var(--ink-700);
  margin-bottom:24px;
  font-style:italic;
}
.encerramento-institucional .btn{margin-top:8px}

/* FAQ unificado — categorias e contagem */
.faq-category{margin:36px 0 24px}
.faq-category-title{
  font-size:22px;color:var(--ink-900);font-weight:700;
  margin:36px 0 18px;padding-bottom:12px;
  border-bottom:2px solid #e3eaf1;
}
.filtro-count{
  display:inline-block;margin-left:6px;
  background:rgba(255,255,255,.25);
  padding:1px 7px;border-radius:10px;
  font-size:11px;font-weight:700;
}
.filtro-btn:not(.active) .filtro-count{
  background:rgba(0,107,138,.10);color:#006b8a;
}

/* FAQ accordion */
.faq-list{margin:30px 0}
.faq-accordion{
  background:#fff;border:1px solid #e3eaf1;
  border-radius:14px;margin-bottom:12px;
  transition:border-color .2s,box-shadow .2s;
  overflow:hidden;
}
.faq-accordion[open]{
  border-color:#cdd9e5;
  box-shadow:0 8px 28px rgba(10,22,40,.08);
}
.faq-accordion summary{
  list-style:none;cursor:pointer;
  padding:20px 26px;
  font-weight:600;color:var(--ink-900);font-size:16.5px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  transition:background .2s;
}
.faq-accordion summary::-webkit-details-marker{display:none}
.faq-accordion summary:hover{background:#fafbfc}
.faq-accordion summary::after{
  content:"+";flex-shrink:0;
  font-size:28px;color:#006b8a;
  font-weight:300;line-height:1;
  transition:transform .25s;
}
.faq-accordion[open] summary::after{transform:rotate(45deg)}
.faq-answer{padding:0 26px 22px;border-top:1px solid #f1f5f9}
.faq-answer p{
  font-size:15.5px;color:var(--ink-700);
  line-height:1.7;margin:18px 0;
}
.faq-answer p:first-child{margin-top:18px}
.faq-answer p:last-child{margin-bottom:0}
.faq-answer ul,.faq-answer ol{margin:14px 0;padding-left:24px}
.faq-answer li{font-size:15px;color:var(--ink-700);line-height:1.65;margin-bottom:8px}
.faq-answer strong{color:var(--ink-900)}

@media(max-width:540px){
  .hub-toolbar{padding:18px;border-radius:14px}
  .hub-search input{font-size:14px}
  .filtro-btn{font-size:12.5px;padding:6px 12px}
  .artigos-grid,.faq-cats-grid,.cards-3col,.steps-grid{grid-template-columns:1fr}
  .article-card{padding:22px 20px}
  .faq-accordion summary{padding:16px 18px;font-size:15.5px;gap:12px}
  .faq-answer{padding:0 18px 18px}
  .article-body h1{font-size:26px}
  .article-body h2{font-size:22px}
  .article-body p{font-size:15.5px}
}

/* ============================================ */
/* PROMPTS 62 e 63 — DIFERENCIAIS + PORTAL EDIT */
/* ============================================ */

/* Lista de diferenciais numerados (página Sobre) */
.diff-list{margin:30px 0;display:flex;flex-direction:column;gap:18px}
.diff-item{
  display:flex;gap:24px;align-items:flex-start;
  background:#fff;border-radius:14px;
  padding:24px 28px;
  border:1px solid #e3eaf1;
  transition:transform .2s,box-shadow .25s,border-color .25s;
}
.diff-item:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 32px rgba(10,22,40,.08);
  border-color:#cdd9e5;
}
.diff-num{
  flex-shrink:0;
  font-size:30px;font-weight:800;
  background:linear-gradient(180deg,var(--accent-cyan,#00d4ff),#006b8a);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  line-height:1;min-width:50px;
}
.diff-item h4{
  font-size:17px;color:var(--ink-900);font-weight:700;
  margin:0 0 8px;line-height:1.3;
}
.diff-item p{
  font-size:15px;color:var(--ink-700);
  line-height:1.65;margin:0;
}

/* Portal editorial — layout em colunas com sidebar */
.portal-layout{
  display:grid;
  grid-template-columns:1fr 320px;
  gap:48px;
  margin-top:32px;
}
.portal-main{min-width:0}
.portal-sidebar{
  position:sticky;
  top:90px;
  align-self:start;
}
@media(max-width:960px){
  .portal-layout{grid-template-columns:1fr;gap:32px}
  .portal-sidebar{position:static}
}

/* Sidebar widgets */
.sidebar-widget{
  background:#fff;border-radius:16px;
  border:1px solid #e3eaf1;
  padding:24px;margin-bottom:20px;
}
.sidebar-widget h4{
  font-size:13px;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--accent-cyan-dark,#006b8a);font-weight:700;
  margin:0 0 16px;padding-bottom:10px;
  border-bottom:1px solid #e3eaf1;
}
.sidebar-widget ul{list-style:none;padding:0;margin:0}
.sidebar-widget li{margin:0;padding:0}
.sidebar-widget li a{
  display:block;padding:10px 0;
  font-size:14.5px;color:var(--ink-700);
  text-decoration:none;
  border-bottom:1px solid #f1f5f9;
  transition:color .2s,padding-left .2s;
  line-height:1.45;
}
.sidebar-widget li:last-child a{border-bottom:none}
.sidebar-widget li a:hover{
  color:var(--ink-900);padding-left:4px;
}

/* Artigo em destaque (hub editorial) */
.article-featured--text-only{grid-template-columns:1fr !important}
.article-featured--text-only .article-featured-content{max-width:none}
.article-featured{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:36px;align-items:center;
  background:linear-gradient(135deg,#0a1628 0%,#1a2942 100%);
  color:#fff;border-radius:24px;
  padding:48px;margin:30px 0 50px;
  position:relative;overflow:hidden;
}
.article-featured::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 80% 20%, rgba(0,212,255,.18), transparent 60%);
}
.article-featured > *{position:relative;z-index:1}
.article-featured-content .article-cat{
  background:rgba(0,212,255,.22);color:#9be3f3;
}
.article-featured-content h2{
  font-size:32px;color:#fff;line-height:1.25;
  margin:16px 0 18px;font-weight:700;
}
.article-featured-content p{
  font-size:16.5px;color:rgba(255,255,255,.82);
  line-height:1.65;margin:0 0 26px;max-width:540px;
}
.article-featured-image{
  display:flex;align-items:center;justify-content:center;
}
.article-featured-image .pattern{
  width:100%;aspect-ratio:1;max-width:280px;
  border-radius:24px;
  background:
    linear-gradient(135deg, rgba(0,212,255,.12), rgba(0,107,138,.08)),
    repeating-linear-gradient(45deg, rgba(255,255,255,.05) 0 2px, transparent 2px 14px);
  border:1px solid rgba(0,212,255,.25);
  display:flex;align-items:center;justify-content:center;
  font-size:64px;color:rgba(0,212,255,.6);
}
@media(max-width:768px){
  .article-featured{grid-template-columns:1fr;padding:32px 24px;gap:24px}
  .article-featured-content h2{font-size:24px}
  .article-featured-image{display:none}
}

/* Bloco de autoria */
.author-block{
  display:flex;gap:24px;align-items:center;
  background:#f8fafc;border-radius:18px;
  padding:28px 32px;
  margin:40px 0;
  border:1px solid #e3eaf1;
}
.author-photo{
  flex-shrink:0;
  height:130px;width:auto;
  display:inline-flex;
  border-radius:14px;
  overflow:hidden;
  border:3px solid rgba(0,212,255,.30);
  box-shadow:0 8px 24px rgba(10,22,40,.10);
  background:#fff;
  line-height:0;
}
.author-photo img{
  height:100%;width:auto;display:block;object-fit:cover;
}
.author-info{flex:1;min-width:0}
.author-name{
  font-size:18px;color:var(--ink-900);font-weight:700;
  margin:0 0 4px;
}
.author-tagline{
  font-size:13px;color:var(--accent-cyan-dark,#006b8a);
  text-transform:uppercase;letter-spacing:.5px;
  margin:0 0 12px;font-weight:600;
}
.author-bio{
  font-size:14.5px;color:var(--ink-700);
  line-height:1.6;margin:0 0 12px;
}
.author-link{
  font-size:13.5px;font-weight:600;
  color:var(--accent-cyan-dark,#006b8a);
}
.author-link:hover{text-decoration:underline}

@media(max-width:540px){
  .author-block{flex-direction:column;text-align:center;padding:24px}
  .author-photo{margin:0 auto}
  .diff-item{flex-direction:column;gap:12px;padding:20px 22px}
  .diff-num{min-width:auto}
}

/* Meta info pequena nos cards de artigo */
.article-meta-small{
  display:flex;align-items:center;gap:6px;
  font-size:12.5px;color:#7a8aa8;
  margin-top:auto;padding-top:14px;
  border-top:1px solid #f1f5f9;
}

/* ============================================================
   TEXTOS LONGOS - JUSTIFICACAO COM HIFENIZACAO
   Aplica text-align: justify aos containers de texto extenso
   (artigos, FAQs, biografias, leads de secao, blocos de explicacao).
   Em viewports estreitos (<560px), volta a alinhar a esquerda
   para evitar espacos feios em linhas curtas.
============================================================ */
.article-body p,
.article-body li,
.article-body blockquote,
.article-body .article-lead,
.jp-text p,
.trajetoria .traj-block p,
.publicacoes p,
.faq-item p,
.faq-answer p,
.faq-answer li,
.section-lead,
.section-sub,
.hero-fluxo-lead,
.cta-block p,
.cta-inner p,
.diff-item p,
.duo .col p,
.duo .col li,
.contact-wa-card p,
.contact-address-content p,
.publico-card p {
  text-align: justify;
  text-justify: inter-word;
  -webkit-hyphens: auto;
  -ms-hyphens: auto;
  hyphens: auto;
  -webkit-hyphenate-limit-chars: 6 3 3;
  hyphenate-limit-chars: 6 3 3;
}

@media (max-width: 560px) {
  .article-body p,
  .article-body li,
  .article-body blockquote,
  .article-body .article-lead,
  .jp-text p,
  .trajetoria .traj-block p,
  .publicacoes p,
  .faq-item p,
  .faq-answer p,
  .faq-answer li,
  .section-lead,
  .section-sub,
  .hero-fluxo-lead,
  .cta-block p,
  .cta-inner p,
  .diff-item p,
  .duo .col p,
  .duo .col li,
  .contact-wa-card p,
  .contact-address-content p,
  .publico-card p {
    text-align: left;
    hyphens: manual;
  }
}
