/* NexProx · publico.css · buscador (tema claro) */
:root {
  --azul: #1E47B8; --azul-esc: #14328A; --azul-claro: #3D6BE0;
  --azul-10: #EBF0FC;
  --bg: #F6F7F9; --card: #fff; --ink: #14181F; --mut: #5B6472;
  --borda: #E7EAF0; --ok: #1B9E4B; --radius: 16px;
  --sombra: 0 1px 2px rgba(20,24,31,.05), 0 8px 24px rgba(20,24,31,.06);
}
* { margin:0; padding:0; box-sizing:border-box; }
body { font-family:'Inter',system-ui,sans-serif; background:var(--bg); color:var(--ink); font-size:15px; line-height:1.55; }
h1,h2,h3 { font-family:'Bricolage Grotesque','Inter',sans-serif; letter-spacing:-.01em; }
a { text-decoration:none; color:inherit; }
button { font-family:inherit; cursor:pointer; }
img { max-width:100%; }

.nav { display:flex; align-items:center; justify-content:space-between; gap:10px; max-width:1100px; margin:0 auto; padding:16px 18px; }
.logo { font-family:'Bricolage Grotesque'; font-weight:800; font-size:23px; color:var(--azul); display:inline-block; transform:skewX(-8deg); letter-spacing:-.02em; }
.logo span { color:#39414E; }
.nav-acoes { display:flex; gap:8px; }

.btn { display:inline-flex; align-items:center; justify-content:center; gap:7px; border:none; border-radius:12px; font-weight:700; font-size:14px; padding:12px 18px; transition:filter .15s, transform .12s; }
.btn:active { transform:scale(.97); }
.btn-azul { background:var(--azul); color:#fff; }
.btn-azul:hover { filter:brightness(1.1); }
.btn-ghost { background:transparent; border:1.5px solid var(--borda); color:var(--ink); }
.btn-sm { padding:9px 14px; font-size:13px; }
.btn-block { width:100%; }

/* ===== Hero / busca ===== */
.hero { text-align:center; padding:60px 18px 74px; position:relative; overflow:hidden;
  background:
    linear-gradient(180deg, rgba(8,14,30,.30), rgba(8,14,30,.10) 40%, rgba(8,14,30,.05)),
    url('../assets/cidade.svg') center bottom / cover no-repeat, #0A1430; }
.hero h1 { font-size:clamp(30px, 6vw, 52px); font-weight:800; line-height:1.08; max-width:680px; margin:0 auto 10px; color:#fff; text-shadow:0 2px 24px rgba(5,10,25,.5); }
.hero h1 em { font-style:normal; color:#9DB9FF; }
.hero p { color:#D9E0EE; max-width:480px; margin:0 auto 28px; font-size:16px; text-shadow:0 1px 12px rgba(5,10,25,.5); }
.busca-box { max-width:620px; margin:0 auto; background:var(--card); border:1.5px solid rgba(255,255,255,.4); border-radius:16px; box-shadow:0 18px 50px rgba(4,9,22,.45); padding:10px; display:flex; gap:8px; flex-wrap:wrap; }
.busca-box .campo { flex:1; min-width:150px; display:flex; align-items:center; gap:8px; padding:6px 10px; color:var(--mut); }
.busca-box input { border:none; outline:none; font-size:15px; width:100%; font-family:inherit; color:var(--ink); background:transparent; }
.busca-box .div { width:1px; background:var(--borda); }
.contador { margin-top:18px; color:#C4CFE3; font-size:13.5px; }
.contador b { color:#9DB9FF; }

/* ===== Seções ===== */
.sec { max-width:1100px; margin:0 auto; padding:44px 18px; }
.sec h2 { font-size:26px; font-weight:800; margin-bottom:4px; }
.sec .sub { color:var(--mut); margin-bottom:22px; }

.categoria-head { display:flex; align-items:center; justify-content:space-between; gap:14px; margin-bottom:18px; }
.categoria-head .sub { margin-bottom:0; }
.sec-categorias .cats[hidden] { display:none !important; }
.sec-categorias .cats { margin-top:12px; }

/* categorias */
.cats { display:grid; grid-template-columns:repeat(auto-fill, minmax(150px,1fr)); gap:10px; }
.cat { background:var(--card); border:1px solid var(--borda); border-radius:14px; padding:16px 14px; display:flex; align-items:center; gap:10px; font-weight:600; font-size:13.5px; transition:border-color .15s, transform .15s; }
.cat:hover { border-color:var(--azul); transform:translateY(-2px); }
.cat .ic { width:36px; height:36px; border-radius:10px; background:var(--azul-10); color:var(--azul); display:grid; place-items:center; flex:none; }

/* cards de profissionais */
.profs { display:grid; grid-template-columns:repeat(auto-fill, minmax(240px,1fr)); gap:14px; }
.prof-card { background:var(--card); border:1px solid var(--borda); border-radius:var(--radius); padding:18px; text-align:center; box-shadow:var(--sombra); transition:transform .15s; position:relative; }
.prof-card:hover { transform:translateY(-3px); }
.prof-card .pc-avatar { width:72px; height:72px; border-radius:50%; margin:0 auto 10px; background:linear-gradient(135deg, var(--pc, var(--azul)), #2a2f3a); background-size:cover; background-position:center; display:grid; place-items:center; color:#fff; font-family:'Bricolage Grotesque'; font-size:26px; font-weight:700; }
.prof-card h3 { font-size:16px; }
.prof-card .pc-prof { color:var(--azul); font-weight:600; font-size:13px; }
.prof-card .pc-local { color:var(--mut); font-size:12.5px; margin-top:2px; }
.prof-card .pc-bio { color:var(--mut); font-size:12.5px; margin-top:8px; min-height:32px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.prof-card .btn { margin-top:12px; width:100%; }
.selo { position:absolute; top:12px; right:12px; color:#E8A435; }

/* como funciona */
.passos { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.passo { background:var(--card); border:1px solid var(--borda); border-radius:var(--radius); padding:20px; text-align:center; }
.passo .n { width:44px; height:44px; border-radius:50%; margin:0 auto 10px; display:grid; place-items:center; font-family:'Bricolage Grotesque'; font-weight:800; font-size:19px; color:#fff; background:linear-gradient(135deg, var(--azul-claro), var(--azul)); }
.passo h3 { font-size:16.5px; margin-bottom:4px; }
.passo p { color:var(--mut); font-size:13.5px; }

/* planos (para profissionais) */
.pro-sec { background:linear-gradient(135deg,#F8FAFF,#EEF3FF); color:var(--ink); border:1px solid #DDE7FF; border-radius:28px; margin:20px auto; max-width:1064px; padding:46px 22px; box-shadow:var(--sombra); }
.pro-sec h2, .pro-sec .sub { text-align:center; }
.pro-sec .sub { color:var(--mut); }
.planos { display:grid; grid-template-columns:repeat(auto-fit, minmax(270px, 360px)); gap:14px; justify-content:center; margin-top:26px; }
.plano { background:#fff; border:1px solid #DDE7FF; border-radius:22px; padding:28px 24px; text-align:center; box-shadow:0 16px 45px rgba(30,71,184,.10); position:relative; overflow:hidden; }
.plano:before { content:""; position:absolute; inset:0 0 auto; height:6px; background:linear-gradient(90deg,var(--azul),#67A3FF); }
.plano.pop { border-color:#BFD0FF; }
.pl-badge { display:inline-flex; padding:5px 12px; border-radius:999px; background:var(--azul-10); color:var(--azul); font-weight:800; font-size:12px; margin-bottom:10px; }
.plano .pl-nome { font-weight:800; font-size:14px; letter-spacing:.06em; text-transform:uppercase; color:#4E5A6B; }
.plano .pl-val { font-family:'Bricolage Grotesque'; font-size:46px; font-weight:800; margin:8px 0 0; color:var(--azul); }
.plano .pl-val small { font-size:15px; color:var(--mut); font-weight:600; }
.pl-mini { color:var(--mut); font-size:13px; margin-top:4px; }
.plano ul { list-style:none; text-align:left; margin:20px 0 20px; display:flex; flex-direction:column; gap:9px; font-size:13.5px; color:#3E4652; }
.plano li { display:flex; gap:8px; align-items:center; }
.plano li svg { color:var(--ok); flex:none; }
.trial-tag { display:inline-block; background:#F2F6FF; color:var(--azul); font-size:12.5px; font-weight:700; padding:6px 14px; border-radius:999px; margin-top:16px; }

.rodape { border-top:1px solid var(--borda); text-align:center; padding:28px 18px; color:var(--mut); font-size:13px; }
.rodape b { font-family:'Bricolage Grotesque'; color:var(--azul); display:inline-block; transform:skewX(-8deg); }
.rodape b span { color:#39414E; }
.rodape .cred { font-size:11.5px; opacity:.7; margin-top:4px; }

/* página de busca */
.busca-topo { background:#fff; border-bottom:1px solid var(--borda); padding-bottom:16px; }
.filtros { max-width:1100px; margin:0 auto; padding:0 18px; display:flex; gap:8px; flex-wrap:wrap; }
.filtros .input { background:var(--bg); border:1.5px solid var(--borda); border-radius:12px; padding:11px 14px; font-size:14px; font-family:inherit; color:var(--ink); flex:1; min-width:140px; }
.filtros .input:focus { outline:none; border-color:var(--azul); }
.vazio { text-align:center; color:var(--mut); padding:60px 20px; }
.vazio b { display:block; color:var(--ink); font-size:17px; margin-bottom:4px; }

.skeleton { height:200px; border-radius:var(--radius); background:linear-gradient(90deg, #eef0f4 25%, #f7f8fa 50%, #eef0f4 75%); background-size:200% 100%; animation:skel 1.2s infinite; }
@keyframes skel { to { background-position:-200% 0; } }

@media (max-width:760px) { .passos { grid-template-columns:1fr; } .categoria-head { align-items:flex-start; flex-direction:column; } .categoria-head .btn { width:100%; } }
@media (prefers-reduced-motion: reduce) { * { animation:none !important; transition:none !important; } }


/* Ajustes finais: botões mais bonitos e responsivos */
.nav { position:relative; z-index:5; }
.nav-acoes .btn { white-space:nowrap; min-height:42px; }
.hero .btn, .busca-box .btn { min-height:46px; }
.cta-dupla { display:grid; grid-template-columns:1fr; gap:10px; margin-top:10px; }
.pro-sec .btn-ghost { background:#fff; border-color:#C9D6FF; color:var(--azul); }

@media (max-width: 640px) {
  .nav { padding:12px 14px; align-items:flex-start; }
  .logo { font-size:21px; margin-top:5px; }
  .nav-acoes { gap:6px; flex-wrap:wrap; justify-content:flex-end; max-width:210px; }
  .nav-acoes .btn { padding:8px 10px; font-size:12px; border-radius:10px; min-height:36px; }
  .hero { padding:42px 14px 52px; }
  .hero p { font-size:14.5px; margin-bottom:20px; }
  .busca-box { flex-direction:column; border-radius:18px; padding:12px; }
  .busca-box .campo { width:100%; min-height:46px; background:#F8FAFF; border:1px solid var(--borda); border-radius:12px; }
  .busca-box .div { display:none; }
  .busca-box .btn { width:100%; }
  .sec { padding:32px 14px; }
  .cats { grid-template-columns:1fr 1fr; gap:8px; }
  .cat { padding:12px 10px; font-size:12.5px; }
  .cat .ic { width:32px; height:32px; }
  .pro-sec { margin:10px 14px; padding:30px 14px; border-radius:22px; }
  .plano { padding:24px 16px; }
  .plano .pl-val { font-size:38px; }
}

@media (max-width: 380px) {
  .nav { flex-direction:column; align-items:stretch; }
  .nav-acoes { max-width:none; display:grid; grid-template-columns:1fr 1fr; }
  .cats { grid-template-columns:1fr; }
}
