/* ══════════════════════════════════════════════════════════════════
   UI Component Library — capte CRM
   Componentes reutilizáveis para todas as páginas
   Import: @import url('/core/ui.css');
   ══════════════════════════════════════════════════════════════════ */

/* ── VARIABLES ─────────────────────────────────────────────────── */
:root {
  --bg:#0a0a0f; --surface:#111118; --surface2:#1a1a24;
  --border:#ffffff10; --border2:#ffffff1a; --text:#e8e8f0;
  --muted:#6b6b80; --accent:#6366f1; --accent2:#8b5cf6;
  --green:#22c55e; --yellow:#eab308; --red:#ef4444;
}

/* ── RESET ─────────────────────────────────────────────────────── */
* { margin:0; padding:0; box-sizing:border-box; }
body { font-family:'Inter',sans-serif; background:var(--bg); color:var(--text); }

/* ── LAYOUT ────────────────────────────────────────────────────── */
.ui-layout { display:flex; height:100vh; overflow:hidden; }
.ui-main   { flex:1; overflow:hidden; display:flex; flex-direction:column; }

/* ── TOPBAR ────────────────────────────────────────────────────── */
.ui-topbar { height:52px; background:var(--surface); border-bottom:1px solid var(--border); display:flex; align-items:center; padding:0 24px; gap:12px; flex-shrink:0; }
.ui-topbar-title { font-size:14px; font-weight:600; }
.ui-sp { flex:1; }

/* ── CONTENT ───────────────────────────────────────────────────── */
.ui-content { flex:1; overflow-y:auto; padding:24px; display:flex; flex-direction:column; gap:14px; }

/* ── BUTTONS ───────────────────────────────────────────────────── */
.ui-btn { padding:7px 14px; border-radius:7px; font-size:12px; font-weight:500; cursor:pointer; border:none; display:flex; align-items:center; gap:6px; font-family:'Inter',sans-serif; transition:all .15s; }
.ui-btn-p { background:var(--accent); color:#fff; }
.ui-btn-p:hover { background:var(--accent2); }
.ui-btn-g { background:transparent; color:var(--muted); border:1px solid var(--border2); }
.ui-btn-g:hover { background:var(--border); color:var(--text); }
.ui-btn-danger { background:#ef444418; color:var(--red); border:1px solid #ef444430; }
.ui-btn-danger:hover { background:#ef444430; }
.ui-btn-green { background:#22c55e18; color:var(--green); border:1px solid #22c55e30; }
.ui-btn-green:hover { background:#22c55e28; }
.ui-btn-sm { padding:5px 10px; font-size:11px; }

/* ── BADGES ────────────────────────────────────────────────────── */
.ui-badge { display:inline-flex; align-items:center; gap:4px; font-size:10px; font-weight:600; padding:2px 8px; border-radius:20px; }
.ui-dot   { width:5px; height:5px; border-radius:50%; background:currentColor; }
.ui-badge-new         { background:#6366f118; color:#818cf8; border:1px solid #6366f130; }
.ui-badge-contacted   { background:#06b6d418; color:#22d3ee; border:1px solid #06b6d430; }
.ui-badge-negotiating { background:#eab30818; color:var(--yellow); border:1px solid #eab30830; }
.ui-badge-converted   { background:#22c55e18; color:var(--green); border:1px solid #22c55e30; }
.ui-badge-lost        { background:#ef444418; color:var(--red); border:1px solid #ef444430; }
.ui-badge-active      { background:#22c55e18; color:var(--green); border:1px solid #22c55e30; }
.ui-badge-inactive    { background:#6b6b8018; color:var(--muted); border:1px solid #6b6b8030; }
.ui-badge-pending     { background:#eab30818; color:var(--yellow); border:1px solid #eab30830; }
.ui-badge-danger      { background:#ef444418; color:var(--red); border:1px solid #ef444430; }

/* ── TOGGLE SWITCH ─────────────────────────────────────────────── */
.ui-toggle { position:relative; display:inline-flex; width:40px; height:22px; flex-shrink:0; cursor:pointer; }
.ui-toggle input { position:absolute; opacity:0; width:0; height:0; pointer-events:none; }
.ui-toggle-slider { position:absolute; inset:0; background:var(--surface2); border:1px solid var(--border2); border-radius:11px; cursor:pointer; transition:background .2s,border-color .2s; }
.ui-toggle-slider:before { content:''; position:absolute; width:16px; height:16px; left:2px; top:2px; border-radius:50%; background:var(--muted); transition:transform .2s,background .2s; }
.ui-toggle input:checked + .ui-toggle-slider { background:#22c55e20; border-color:var(--green); }
.ui-toggle input:checked + .ui-toggle-slider:before { transform:translateX(18px); background:var(--green); }

/* ── FORM FIELDS ───────────────────────────────────────────────── */
.ui-field { margin-bottom:14px; display:flex; flex-direction:column; gap:5px; }
.ui-label { font-size:11px; color:var(--muted); font-weight:500; }
.ui-input { width:100%; background:var(--surface2); border:1px solid var(--border2); border-radius:8px; padding:9px 12px; font-size:13px; color:var(--text); outline:none; font-family:'Inter',sans-serif; transition:border-color .15s; }
.ui-input:focus { border-color:var(--accent); }
.ui-input::placeholder { color:var(--muted); }
.ui-err { font-size:11px; color:var(--red); margin-top:4px; display:none; }
.ui-hint { font-size:11px; color:var(--muted); margin-top:2px; }
.ui-row2 { display:grid; grid-template-columns:1fr 1fr; gap:12px; }

/* ── MODAL / OVERLAY ───────────────────────────────────────────── */
.ui-overlay { position:fixed; inset:0; background:#00000070; z-index:1000; display:none; align-items:center; justify-content:center; backdrop-filter:blur(4px); }
.ui-overlay.open { display:flex; animation:uiFadeIn .15s ease; }
@keyframes uiFadeIn { from{opacity:0} to{opacity:1} }

.ui-modal { background:var(--surface); border:1px solid var(--border2); border-radius:14px; width:480px; max-width:95vw; max-height:90vh; overflow-y:auto; box-shadow:0 20px 60px #00000090; animation:uiSlideUp .15s ease; }
@keyframes uiSlideUp { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:translateY(0)} }

.ui-modal-hd { padding:18px 20px; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; position:sticky; top:0; background:var(--surface); z-index:1; }
.ui-modal-ttl { font-size:14px; font-weight:600; }
.ui-modal-x { width:28px; height:28px; border-radius:6px; background:transparent; border:none; cursor:pointer; color:var(--muted); font-size:16px; display:flex; align-items:center; justify-content:center; transition:all .15s; }
.ui-modal-x:hover { background:var(--border); color:var(--text); }
.ui-modal-body { padding:20px; display:flex; flex-direction:column; gap:16px; }
.ui-modal-ft { display:flex; gap:8px; justify-content:flex-end; padding:16px 20px; border-top:1px solid var(--border); }

/* ── TABLE ─────────────────────────────────────────────────────── */
.ui-table-wrap { background:var(--surface); border:1px solid var(--border); border-radius:12px; overflow:hidden; }
.ui-table { width:100%; border-collapse:collapse; }
.ui-table th { padding:10px 16px; font-size:11px; font-weight:600; color:var(--muted); text-align:left; border-bottom:1px solid var(--border); background:var(--surface2); text-transform:uppercase; letter-spacing:.05em; }
.ui-table td { padding:13px 16px; font-size:13px; border-bottom:1px solid var(--border); vertical-align:middle; }
.ui-table tr:last-child td { border-bottom:none; }
.ui-table tr:hover td { background:#ffffff04; }

/* ── TABLE ACTIONS (hover reveal) ──────────────────────────────── */
.ui-actions { display:flex; gap:6px; opacity:0; transition:opacity .15s; }
tr:hover .ui-actions, .ui-row:hover .ui-actions { opacity:1; }
.ui-act { width:26px; height:26px; border-radius:6px; background:transparent; border:1px solid var(--border2); display:flex; align-items:center; justify-content:center; cursor:pointer; color:var(--muted); transition:all .15s; }
.ui-act:hover { border-color:var(--accent); color:var(--accent); }
.ui-act.del:hover { border-color:var(--red); color:var(--red); }

/* ── ALERT / WARNING BANNER ─────────────────────────────────────── */
.ui-alert { display:flex; align-items:flex-start; gap:10px; padding:12px 16px; border-radius:10px; font-size:13px; line-height:1.5; }
.ui-alert-icon { flex-shrink:0; width:18px; height:18px; display:flex; align-items:center; justify-content:center; margin-top:1px; }
.ui-alert-content { flex:1; }
.ui-alert-title { font-weight:600; font-size:13px; margin-bottom:2px; }
.ui-alert-msg { font-size:12px; opacity:.85; }
.ui-alert-close { flex-shrink:0; background:none; border:none; cursor:pointer; color:inherit; opacity:.5; font-size:16px; padding:0 2px; transition:opacity .15s; }
.ui-alert-close:hover { opacity:1; }
.ui-alert-info    { background:#6366f112; color:#818cf8; border:1px solid #6366f125; }
.ui-alert-success { background:#22c55e12; color:var(--green); border:1px solid #22c55e25; }
.ui-alert-warning { background:#eab30812; color:var(--yellow); border:1px solid #eab30825; }
.ui-alert-error   { background:#ef444412; color:var(--red); border:1px solid #ef444425; }

/* ── EMPTY STATE ───────────────────────────────────────────────── */
.ui-empty { padding:60px; text-align:center; color:var(--muted); }
.ui-empty-ico { font-size:40px; margin-bottom:16px; opacity:.3; }
.ui-empty-t { font-size:15px; font-weight:600; color:var(--text); margin-bottom:6px; }
.ui-empty-s { font-size:13px; }

/* ── FILTER BAR ────────────────────────────────────────────────── */
.ui-filters { display:flex; flex-wrap:wrap; gap:8px; align-items:center; background:var(--surface); border:1px solid var(--border); border-radius:10px; padding:12px 16px; }
.ui-search { display:flex; align-items:center; gap:8px; background:var(--surface2); border:1px solid var(--border2); border-radius:8px; padding:7px 12px; flex:1; min-width:200px; }
.ui-search input { background:transparent; border:none; outline:none; font-size:13px; color:var(--text); font-family:'Inter',sans-serif; width:100%; }
.ui-search input::placeholder { color:var(--muted); }
.ui-sel { background:var(--surface2); border:1px solid var(--border2); border-radius:8px; padding:7px 10px; font-size:12px; color:var(--text); outline:none; font-family:'Inter',sans-serif; cursor:pointer; }
.ui-filter-sep { width:1px; height:24px; background:var(--border2); }

/* ── AUTOCOMPLETE / COMBOBOX ────────────────────────────────────── */
.ui-combo { position:relative; }
.ui-combo-input { width:100%; background:var(--surface2); border:1px solid var(--border2); border-radius:8px; padding:9px 12px; font-size:13px; color:var(--text); outline:none; font-family:'Inter',sans-serif; transition:border-color .15s; }
.ui-combo-input:focus { border-color:var(--accent); }
.ui-combo-input::placeholder { color:var(--muted); }
.ui-combo-list { position:absolute; top:100%; left:0; right:0; margin-top:4px; background:var(--surface); border:1px solid var(--border2); border-radius:10px; max-height:200px; overflow-y:auto; z-index:200; display:none; box-shadow:0 8px 24px #00000060; scrollbar-width:thin; scrollbar-color:#ffffff18 transparent; }
.ui-combo-list.open { display:block; animation:uiSlideUp .12s ease; }
.ui-combo-item { padding:8px 12px; font-size:12px; cursor:pointer; transition:background .1s; display:flex; align-items:center; gap:8px; }
.ui-combo-item:hover, .ui-combo-item.highlighted { background:var(--border); color:var(--text); }
.ui-combo-item-sub { font-size:10px; color:var(--muted); }
.ui-combo-empty { padding:12px; font-size:12px; color:var(--muted); text-align:center; }

/* ── TABS ──────────────────────────────────────────────────────── */
.ui-tabs { display:flex; gap:2px; padding:0 24px; background:var(--surface); border-bottom:1px solid var(--border); flex-shrink:0; }
.ui-tab { padding:10px 16px; font-size:12px; font-weight:500; color:var(--muted); cursor:pointer; border:none; border-bottom:2px solid transparent; background:none; font-family:'Inter',sans-serif; transition:all .15s; }
.ui-tab:hover { color:var(--text); }
.ui-tab.active { color:var(--accent); border-bottom-color:var(--accent); }
.ui-tab-panel { display:none; }
.ui-tab-panel.active { display:block; }

/* ── PAGINATION ────────────────────────────────────────────────── */
.ui-pagination { display:flex; align-items:center; justify-content:center; gap:4px; padding:14px 16px; border-top:1px solid var(--border); }
.ui-pg-btn { min-width:30px; height:30px; padding:0 8px; border-radius:7px; background:transparent; border:1px solid var(--border2); color:var(--muted); font-size:12px; font-family:'Inter',sans-serif; cursor:pointer; transition:all .15s; display:flex; align-items:center; justify-content:center; }
.ui-pg-btn:hover:not(:disabled) { border-color:var(--accent); color:var(--accent); }
.ui-pg-btn.active { background:var(--accent); border-color:var(--accent); color:#fff; }
.ui-pg-btn:disabled { opacity:.3; cursor:default; }
.ui-pg-ellipsis { color:var(--muted); font-size:12px; padding:0 2px; }

/* ── SKELETON LOADER ───────────────────────────────────────────── */
.ui-sk { border-radius:5px; background:linear-gradient(90deg,#ffffff08 25%,#ffffff12 50%,#ffffff08 75%); background-size:200% 100%; animation:uiShimmer 1.4s infinite; }
@keyframes uiShimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

/* ── PAGE LOADER (tela cheia) ─────────────────────────────────── */
.ui-page-loader { position:fixed; inset:0; background:var(--bg, #0a0a0f); display:flex; flex-direction:column; align-items:center; justify-content:center; z-index:9998; gap:16px; }
.ui-page-loader-spinner { width:36px; height:36px; border:3px solid #ffffff10; border-top-color:var(--accent, #6366f1); border-radius:50%; animation:uiSpin .7s linear infinite; }
.ui-page-loader-text { font-size:13px; color:var(--muted, #6b6b80); font-family:'Inter',sans-serif; }
@keyframes uiSpin { to { transform:rotate(360deg) } }

/* ── INLINE SPINNER (dentro de botão ou seção) ────────────────── */
.ui-spinner { width:18px; height:18px; border:2px solid #ffffff20; border-top-color:currentColor; border-radius:50%; animation:uiSpin .7s linear infinite; display:inline-block; vertical-align:middle; }
.ui-spinner-sm { width:14px; height:14px; border-width:1.5px; }
.ui-spinner-lg { width:28px; height:28px; border-width:3px; }

/* ── SECTION LOADER (dentro de uma área) ──────────────────────── */
.ui-section-loader { display:flex; flex-direction:column; align-items:center; justify-content:center; padding:48px 24px; gap:12px; }
.ui-section-loader-spinner { width:28px; height:28px; border:2.5px solid #ffffff10; border-top-color:var(--accent, #6366f1); border-radius:50%; animation:uiSpin .7s linear infinite; }
.ui-section-loader-text { font-size:12px; color:var(--muted, #6b6b80); }

/* ── TOAST ─────────────────────────────────────────────────────── */
.ui-toast { position:fixed; bottom:24px; right:24px; background:#1a1a24; border:1px solid rgba(255,255,255,.12); border-radius:10px; padding:12px 16px; font-size:13px; z-index:9999; display:none; align-items:center; gap:8px; box-shadow:0 8px 32px #00000060; color:#e8e8f0; }
.ui-toast.show { display:flex; animation:uiToastIn .2s ease; }
@keyframes uiToastIn { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }
.ui-toast.ok  { border-color:#22c55e40; color:var(--green); }
.ui-toast.err { border-color:#ef444440; color:var(--red); }

/* ── SCROLLBAR ─────────────────────────────────────────────────── */
.ui-scroll { scrollbar-width:thin; scrollbar-color:#ffffff18 transparent; }
.ui-scroll::-webkit-scrollbar { width:4px; height:4px; }
.ui-scroll::-webkit-scrollbar-track { background:transparent; }
.ui-scroll::-webkit-scrollbar-thumb { background:#ffffff18; border-radius:4px; }
.ui-scroll::-webkit-scrollbar-thumb:hover { background:#ffffff35; }

/* ── RESPONSIVE ────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .ui-topbar { padding:0 16px; gap:8px; }
  .ui-topbar-title { font-size:13px; }
  .ui-btn { padding:6px 10px; font-size:11px; }
  .ui-content { padding:12px 16px; gap:10px; }
  .ui-filters { flex-wrap:wrap; gap:6px; padding:10px 12px; }
  .ui-sel { font-size:11px; padding:5px 8px; }
  .ui-modal { width:calc(100vw - 32px); border-radius:20px; }
  .ui-row2 { grid-template-columns:1fr; }
}
