/**
 * Projeto: BaseCNPJ
 * Arquivo: pesquisa-avancada.css
 * Autor: Djeferson Capelli
 * Versão: 2.0.0
 * Descrição: Estilos da pesquisa avançada — layout moderno sem Bootstrap
 */

/* ── Reset & tokens ──────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-xl:28px;
  --font-main:'Outfit',sans-serif;--font-mono:'DM Mono',monospace;
  --nav-h:64px;--transition:.2s cubic-bezier(.4,0,.2,1);
}
html:not([data-theme="light"]){
  --bg-void:#040d1a;--bg-deep:#071022;--bg-card:rgba(255,255,255,0.04);--bg-card-h:rgba(255,255,255,0.07);
  --primary:#0C447C;--accent:#3783FF;--accent-b:#5B9BFF;--accent-glow:rgba(55,131,255,0.3);
  --green:#1D9E75;--red:#E24B4A;
  --text:#EEF2F8;--text-muted:#8899BB;--text-dim:#445577;
  --border:rgba(255,255,255,0.07);--border-h:rgba(55,131,255,0.3);
}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-main);background:var(--bg-void);color:var(--text);line-height:1.6;
  min-height:100vh;overflow-x:hidden;
  padding-left:env(safe-area-inset-left,0);padding-right:env(safe-area-inset-right,0);
  padding-bottom:env(safe-area-inset-bottom,0);
}
a{color:var(--accent-b);text-decoration:none}
a:hover{text-decoration:underline}

/* ── Nav ─────────────────────────────────────────────────────────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:10050;min-height:var(--nav-h);
  display:flex;align-items:center;flex-wrap:wrap;
  padding:env(safe-area-inset-top,0) max(5%,env(safe-area-inset-right,0)) 0 max(5%,env(safe-area-inset-left,0));
  background:rgba(4,13,26,.85);backdrop-filter:blur(20px) saturate(1.8);-webkit-backdrop-filter:blur(20px) saturate(1.8);
  border-bottom:1px solid var(--border);
}
.nav-links{display:flex;margin-left:40px;gap:2px}
.nav-links a{padding:6px 14px;font-size:14px;font-weight:500;color:var(--text-muted);text-decoration:none;border-radius:var(--radius-sm);transition:all var(--transition)}
.nav-links a:hover{color:var(--text);background:var(--bg-card-h)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.btn-nav{padding:7px 18px;font-size:13px;font-weight:600;border-radius:var(--radius-sm);text-decoration:none;transition:all var(--transition);display:inline-flex;align-items:center;gap:6px}
.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text-muted)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 0 20px var(--accent-glow)}

/* ── Layout ──────────────────────────────────────────────────────────────── */
.adv-shell{
  min-height:100vh;min-height:100dvh;
  padding-top:calc(var(--nav-h) + env(safe-area-inset-top,0) + 24px);
  background:radial-gradient(ellipse 70% 50% at 50% -10%,rgba(55,131,255,.1) 0%,transparent 65%),var(--bg-void);
  padding-bottom:max(40px,env(safe-area-inset-bottom,0));
  padding-left:max(16px,4vw,env(safe-area-inset-left,0));
  padding-right:max(16px,4vw,env(safe-area-inset-right,0));
}
.adv-wrap{max-width:1200px;margin:0 auto}
.adv-header{margin-bottom:24px}
.adv-header h1{font-size:clamp(24px,3.5vw,36px);font-weight:800;letter-spacing:-.02em;color:var(--text);margin-bottom:6px}
.adv-header p{color:var(--text-muted);font-size:14px;max-width:60ch}

/* ── Filter cards ────────────────────────────────────────────────────────── */
.adv-filters{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
.adv-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;transition:border-color .15s}
.adv-card:hover{border-color:rgba(55,131,255,.25)}
.adv-card-head{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.adv-card-ico{width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:rgba(55,131,255,.1);color:var(--accent);flex-shrink:0}
.adv-card-ico svg{width:18px;height:18px}
.adv-card-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim)}
.adv-card-grid{display:grid;gap:14px}
.adv-card-grid-2{grid-template-columns:1fr 1fr}
.adv-card-grid-3{grid-template-columns:1fr 1fr 1fr}

/* ── Inputs ──────────────────────────────────────────────────────────────── */
.adv-field label{display:block;font-size:11px;font-weight:600;color:var(--text-muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.03em}
.adv-field label .adv-note{font-weight:400;text-transform:none;letter-spacing:0;color:var(--text-dim);font-size:10px}
.adv-input,.adv-select{width:100%;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:8px;padding:10px 12px;color:var(--text);font-size:13px;font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s}
.adv-input::placeholder{color:var(--text-dim);opacity:1}
.adv-input:focus,.adv-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(55,131,255,.12)}
.adv-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%238899BB' stroke-width='2'%3E%3Cpath d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
.adv-select option{background:var(--bg-void,#040d1a);color:var(--text)}

html[data-theme="light"] .adv-input,
html[data-theme="light"] .adv-select{background:#fff}

/* ── Actions bar ─────────────────────────────────────────────────────────── */
.adv-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:24px}
.adv-btn-search{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border:none;border-radius:10px;background:linear-gradient(135deg,#3783ff,#2563eb);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:filter .15s}
.adv-btn-search:hover{filter:brightness(1.1)}
.adv-btn-search svg{width:16px;height:16px}
.adv-btn-clear{padding:10px 20px;border:1px solid var(--border);border-radius:10px;background:transparent;color:var(--text-muted);font-size:13px;font-weight:500;text-decoration:none;transition:border-color .15s,color .15s}
.adv-btn-clear:hover{border-color:var(--accent);color:var(--text)}
.adv-hint{display:inline-flex;align-items:center;gap:6px;margin-left:auto;padding:6px 14px;border:1px solid rgba(55,131,255,.25);border-radius:999px;font-size:11px;color:var(--accent);background:rgba(55,131,255,.06)}
.adv-hint svg{width:14px;height:14px;opacity:.7}

/* ── Active filter count ─────────────────────────────────────────────────── */
.adv-filter-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;border-radius:999px;background:var(--accent);color:#fff;font-size:11px;font-weight:700;padding:0 6px}

/* ── Results ─────────────────────────────────────────────────────────────── */
.adv-results{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-bottom:24px}
.adv-results-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.adv-results-count{font-size:14px;color:var(--text-muted)}
.adv-results-count strong{color:var(--text);font-weight:700}
.adv-results-header{flex-wrap:wrap;gap:4px 0}
.adv-results-capped{display:block;width:100%;font-size:12px;color:var(--amber,#EF9F27);margin-top:2px}
.adv-empty{text-align:center;padding:40px 20px;color:var(--text-dim);font-size:14px}

/* ── Results table ───────────────────────────────────────────────────────── */
.adv-table{width:100%;border-collapse:collapse}
.adv-table th{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);font-weight:600;padding:8px 10px;text-align:left;border-bottom:1px solid var(--border)}
.adv-table th .adv-th-note{font-weight:400;text-transform:none;letter-spacing:0;font-size:.85em;color:var(--text-dim)}
.adv-table td{padding:9px 10px;border-bottom:1px solid rgba(255,255,255,.04);font-size:12px;color:var(--text);vertical-align:top}
html[data-theme="light"] .adv-table td{border-bottom-color:rgba(0,0,0,.06)}
.adv-table tbody tr{transition:background .1s}
.adv-table tbody tr:hover{background:rgba(55,131,255,.06)}
.adv-table a{color:var(--accent);text-decoration:none}
.adv-table a:hover{text-decoration:underline}
.adv-row-name{font-weight:600;font-size:12px;color:var(--text)}
.adv-row-cnpj{font-family:'DM Mono',ui-monospace,monospace;font-size:11px;color:var(--text-muted);margin-top:2px}
.adv-row-sub{font-size:11px;color:var(--text-dim);margin-top:1px}
.adv-row-addr{font-size:11px;color:var(--text-muted);max-width:240px}
.adv-row-contact{font-size:11px;max-width:200px}
.adv-row-email{color:var(--accent);word-break:break-all}
.adv-row-tel{color:var(--text-muted);margin-top:2px}

/* ── Status badges ───────────────────────────────────────────────────────── */
.adv-badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.02em}
.adv-badge--ativa{background:rgba(29,158,117,.12);color:#1D9E75;border:1px solid rgba(29,158,117,.25)}
.adv-badge--baixada{background:rgba(226,75,74,.1);color:#E24B4A;border:1px solid rgba(226,75,74,.25)}
.adv-badge--suspensa{background:rgba(239,159,39,.1);color:#EF9F27;border:1px solid rgba(239,159,39,.25)}
.adv-badge--inapta{background:rgba(239,159,39,.1);color:#EF9F27;border:1px solid rgba(239,159,39,.25)}
.adv-badge--nula{background:rgba(136,153,187,.1);color:#8899BB;border:1px solid rgba(136,153,187,.25)}

/* ── Pagination ──────────────────────────────────────────────────────────── */
.adv-pagination{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:20px;flex-wrap:wrap}
.adv-pg-btn{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;border:1px solid var(--border);border-radius:8px;font-size:13px;color:var(--text-muted);text-decoration:none;transition:all .15s}
.adv-pg-btn:hover{border-color:var(--accent);color:var(--text);background:rgba(55,131,255,.08)}
.adv-pg-btn--active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}
.adv-pg-ellipsis{color:var(--text-dim);padding:0 4px}

/* ── CNAE autocomplete ───────────────────────────────────────────────────── */
.adv-cnae-wrap{position:relative}
.adv-cnae-dropdown{position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:1080;max-height:min(280px,50vh);overflow-y:auto;border-radius:var(--radius-md,12px);border:1px solid var(--border);background:var(--bg-card);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 8px 32px rgba(0,0,0,.3)}
html[data-theme="light"] .adv-cnae-dropdown{background:rgba(255,255,255,.97);box-shadow:0 8px 32px rgba(0,0,0,.1)}
.adv-cnae-item{display:block;width:100%;text-align:left;padding:10px 12px;border:none;border-bottom:1px solid rgba(255,255,255,.06);background:transparent;color:var(--text);font-family:inherit;font-size:13px;line-height:1.35;cursor:pointer;min-height:44px}
html[data-theme="light"] .adv-cnae-item{border-bottom-color:rgba(0,0,0,.06)}
.adv-cnae-item:last-child{border-bottom:none}
.adv-cnae-item:hover,.adv-cnae-item:focus{background:rgba(55,131,255,.1);outline:none}
.adv-cnae-item-line{display:block;font-size:13px;line-height:1.4}
.adv-cnae-item-code{font-family:'DM Mono',ui-monospace,monospace;font-size:12px;color:var(--accent);font-weight:600}
.adv-cnae-item-sep{margin:0 .35em;color:var(--text-dim)}
.adv-cnae-item-name{color:var(--text-muted);font-weight:400}

/* ── Sidebar ─────────────────────────────────────────────────────────────── */
.adv-layout{display:grid;grid-template-columns:1fr 260px;gap:24px;align-items:start}
.adv-sidebar{position:sticky;top:calc(var(--nav-h) + 24px)}
.adv-tip{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px}
.adv-tip-h{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.adv-tip-h svg{width:14px;height:14px;opacity:.6}
.adv-tip p{font-size:13px;color:var(--text-muted);line-height:1.6;margin-bottom:8px}
.adv-tip p:last-child{margin-bottom:0}
.adv-tip ul{list-style:none;padding:0;margin:8px 0 0}
.adv-tip li{font-size:12px;color:var(--text-muted);padding:4px 0;display:flex;align-items:center;gap:6px}
.adv-tip li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:.5;flex-shrink:0}

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media(max-width:1100px){
  .adv-layout{grid-template-columns:1fr}
  .adv-sidebar{position:static;order:-1}
}
@media(max-width:768px){
  .adv-filters{grid-template-columns:1fr}
  .adv-card-grid-2,.adv-card-grid-3{grid-template-columns:1fr}
  .adv-hint{margin-left:0;margin-top:4px;width:100%;justify-content:center}
  .adv-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -12px;padding:0 12px}
}
@media(max-width:480px){
  .adv-actions{flex-direction:column;align-items:stretch}
  .adv-btn-search,.adv-btn-clear{width:100%;justify-content:center;text-align:center}
  .adv-header h1{font-size:22px}
}

/* ── Loader overlay ──────────────────────────────────────────────────────── */
.search-loader-overlay{
  position:fixed;inset:0;z-index:150000;display:none;align-items:center;justify-content:center;
  background:rgba(4,13,26,.78);backdrop-filter:blur(12px) saturate(1.2);-webkit-backdrop-filter:blur(12px) saturate(1.2);
}
.search-loader-overlay.is-visible{display:flex;animation:adv-loader-in .2s ease both}
@keyframes adv-loader-in{from{opacity:0}to{opacity:1}}
.search-loader-inner{
  display:flex;flex-direction:column;align-items:center;gap:20px;padding:32px 40px;border-radius:var(--radius-xl);
  background:rgba(8,20,46,.85);border:1px solid rgba(55,131,255,.3);
  box-shadow:0 24px 64px rgba(0,0,0,.5),0 0 40px rgba(55,131,255,.1);
  animation:adv-loader-card .35s cubic-bezier(.16,1,.3,1) both;
}
@keyframes adv-loader-card{from{opacity:0;transform:scale(.94) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}
.search-loader-spinner{
  width:52px;height:52px;border-radius:50%;border:3px solid rgba(255,255,255,.1);
  border-top-color:var(--accent);border-right-color:rgba(55,131,255,.45);
  animation:adv-loader-spin .7s linear infinite;
}
@keyframes adv-loader-spin{to{transform:rotate(360deg)}}
@media(prefers-reduced-motion:reduce){.search-loader-inner{animation:none}.search-loader-spinner{animation-duration:1.2s}}
.search-loader-text{margin:0;font-size:15px;font-weight:600;color:var(--text);letter-spacing:.02em}
.search-loader-sub{margin:-12px 0 0;font-size:13px;font-weight:400;color:var(--text-muted)}
