/* ============================================================
   03-COMPONENTS · Todos os componentes visuais
   Organizado por seção — busque o comentário do componente.
   ============================================================ */

/* ---------- TOPBAR ---------- */
.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:8px;height:62px;padding:0 22px;
  background:var(--topbar-bg);backdrop-filter:blur(18px) saturate(140%);border-bottom:1px solid var(--border)}
.brand{display:flex;align-items:center;gap:11px;padding-right:14px;flex-shrink:0}
.brand-mark{width:34px;height:34px;border-radius:9px;flex-shrink:0;
  background:linear-gradient(150deg,var(--gold-bright),var(--gold) 55%,#9c7e44);display:grid;place-items:center;
  box-shadow:0 2px 12px -2px rgba(217,182,115,.4),inset 0 1px 0 rgba(255,255,255,.35)}
.brand-mark svg{width:19px;height:19px;stroke:#23190a}
.brand-name{font-family:var(--font-display);font-weight:600;font-size:16px;letter-spacing:-.01em}
.brand-name span{color:var(--gold)}
.nav{display:flex;gap:2px;margin-left:8px;flex-wrap:wrap}
.nav-item{position:relative;padding:8px 14px;border-radius:9px;font-size:13.5px;font-weight:500;color:var(--text-2);
  transition:color .16s,background .16s;white-space:nowrap}
.nav-item:hover{color:var(--text);background:rgba(255,255,255,.035)}
[data-theme="light"] .nav-item:hover{background:rgba(16,20,28,.04)}
.nav-item.active{color:var(--text)}
.nav-item.active::after{content:'';position:absolute;left:14px;right:14px;bottom:-1px;height:2px;background:var(--gold);border-radius:2px;box-shadow:0 0 10px var(--gold)}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.icon-btn{width:36px;height:36px;border-radius:9px;display:grid;place-items:center;color:var(--text-2);transition:.16s}
.icon-btn:hover{background:rgba(255,255,255,.05);color:var(--text)}
[data-theme="light"] .icon-btn:hover{background:rgba(16,20,28,.05)}
.avatar{width:34px;height:34px;border-radius:50%;flex-shrink:0;background:linear-gradient(150deg,#2a3242,#1a2030);
  border:1px solid var(--border-strong);display:grid;place-items:center;font-weight:600;font-size:13px;color:var(--gold-bright)}

/* seletor de tema */
.theme-wrap{position:relative}
.theme-menu{position:absolute;top:46px;right:0;min-width:166px;z-index:60;background:var(--surface);
  border:1px solid var(--border-strong);border-radius:12px;padding:7px;box-shadow:var(--shadow);
  opacity:0;visibility:hidden;transform:translateY(-6px);transition:.16s}
.theme-menu.open{opacity:1;visibility:visible;transform:none}
.theme-menu-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);padding:6px 10px 8px}
.theme-opt{display:flex;align-items:center;gap:10px;width:100%;padding:9px 10px;border-radius:8px;font-size:13.5px;font-weight:500;color:var(--text-2);transition:.13s}
.theme-opt:hover{background:var(--surface-2);color:var(--text)}
.theme-opt svg{width:16px;height:16px}
.theme-opt.active{color:var(--gold);background:var(--gold-dim)}
.theme-opt .check{margin-left:auto;opacity:0}
.theme-opt.active .check{opacity:1}

/* ---------- KPI CARDS ---------- */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:16px}
.kpi{position:relative;overflow:hidden;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 18px 16px;transition:transform .2s,border-color .2s}
.kpi:hover{transform:translateY(-2px);border-color:var(--border-strong)}
.kpi::before{content:'';position:absolute;inset:0;opacity:0;transition:.25s;background:radial-gradient(420px 120px at 90% -20%,var(--accent-glow,transparent),transparent 70%)}
.kpi:hover::before{opacity:1}
.kpi-ico{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;margin-bottom:14px}
.kpi-ico svg{width:19px;height:19px}
.kpi-val{font-family:var(--font-display);font-size:30px;font-weight:600;letter-spacing:-.025em;line-height:1}
.kpi-label{color:var(--text-3);font-size:12.5px;margin-top:6px;font-weight:500}
.kpi-trend{position:absolute;top:18px;right:18px;font-size:11.5px;font-weight:600;display:flex;align-items:center;gap:3px;font-family:var(--font-mono)}
.t-up{color:var(--emerald)} .t-down{color:var(--rose)}
.i-blue{background:var(--blue-dim);color:var(--blue)} .kpi.b{--accent-glow:rgba(91,157,255,.10)}
.i-violet{background:rgba(169,139,245,.13);color:var(--violet)} .kpi.v{--accent-glow:rgba(169,139,245,.10)}
.i-emerald{background:var(--emerald-dim);color:var(--emerald)} .kpi.e{--accent-glow:rgba(63,207,142,.10)}
.i-rose{background:var(--rose-dim);color:var(--rose)} .kpi.r{--accent-glow:rgba(240,97,122,.10)}

/* ---------- VGV HERO (assinatura) ---------- */
.vgv-hero{position:relative;overflow:hidden;margin-bottom:16px;border-radius:var(--r-xl);padding:24px 26px;
  background:linear-gradient(110deg,rgba(217,182,115,.10),rgba(217,182,115,.02) 50%,transparent),var(--surface);
  border:1px solid rgba(217,182,115,.22);display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
[data-theme="light"] .vgv-hero{border-color:rgba(168,126,55,.28)}
.vgv-hero::after{content:'';position:absolute;right:-60px;top:-80px;width:340px;height:340px;background:radial-gradient(circle,rgba(217,182,115,.16),transparent 65%);pointer-events:none}
.vgv-left{position:relative;z-index:1}
.vgv-eyebrow{display:flex;align-items:center;gap:8px;color:var(--gold);font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}
.vgv-eyebrow svg{width:15px;height:15px}
.vgv-num{font-family:var(--font-display);font-size:46px;font-weight:700;letter-spacing:-.03em;line-height:1.05;margin-top:8px;
  background:linear-gradient(120deg,#fff 20%,var(--gold-bright));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
[data-theme="light"] .vgv-num{background:linear-gradient(120deg,#2b2210 25%,var(--gold));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.vgv-meta{color:var(--text-3);font-size:13px;margin-top:7px}
.vgv-meta b{color:var(--emerald);font-family:var(--font-mono)}
.vgv-spark{position:relative;z-index:1;flex-shrink:0}

/* ---------- PAINÉIS / CHARTS ---------- */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.grid-32{display:grid;grid-template-columns:1.35fr 1fr;gap:16px;margin-bottom:16px}
.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px}
.panel-title{font-family:var(--font-display);font-size:15px;font-weight:600;letter-spacing:-.01em;display:flex;align-items:center;gap:9px}
.panel-title .dot{width:7px;height:7px;border-radius:50%;background:var(--gold)}
.legend{display:flex;gap:18px;justify-content:center;margin-top:14px;font-size:12px;color:var(--text-2)}
.legend i{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:6px;vertical-align:middle}
.donut-wrap{display:flex;align-items:center;gap:24px;justify-content:center;padding:6px 0}
.donut-legend{display:flex;flex-direction:column;gap:11px}
.dl-row{display:flex;align-items:center;gap:10px;font-size:13px}
.dl-row i{width:10px;height:10px;border-radius:3px}
.dl-row .v{margin-left:auto;font-family:var(--font-mono);font-weight:600;color:var(--text)}
.dl-row .k{color:var(--text-2)}

/* ranking */
.rank-list{display:flex;flex-direction:column;gap:3px;max-height:330px;overflow-y:auto;margin:-6px -6px 0;padding:6px}
.rank-row{display:flex;align-items:center;gap:13px;padding:11px 12px;border-radius:11px;transition:.15s}
.rank-row:hover{background:var(--surface-2)}
.rank-pos{width:24px;text-align:center;font-family:var(--font-mono);font-weight:600;font-size:13px;color:var(--text-3);flex-shrink:0}
.rank-pos.medal{font-size:16px}
.rank-av{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:600;flex-shrink:0;background:var(--surface-3);color:var(--text-2);border:1px solid var(--border)}
.rank-info{min-width:0;flex:1}
.rank-name{font-size:13.5px;font-weight:550;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rank-sub{font-size:11.5px;color:var(--text-3);margin-top:1px}
.rank-val{font-family:var(--font-mono);font-weight:600;font-size:13px;flex-shrink:0}
.rank-val.zero{color:var(--rose)}
.rank-bar{height:4px;border-radius:3px;background:var(--surface-3);margin-top:6px;overflow:hidden}
.rank-bar span{display:block;height:100%;border-radius:3px;background:linear-gradient(90deg,var(--gold),var(--gold-bright))}

/* ---------- TABELA CONTATOS ---------- */
.toolbar{display:flex;gap:12px;align-items:center;margin-bottom:18px;flex-wrap:wrap}
.search{flex:1;min-width:240px;position:relative}
.search svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:17px;height:17px;color:var(--text-3)}
.search input{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:11px;padding:11px 14px 11px 42px;color:var(--text);font-size:13.5px;transition:.15s}
.search input::placeholder{color:var(--text-3)}
.search input:focus{outline:none;border-color:rgba(217,182,115,.45);background:var(--surface-2)}
.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}
table{width:100%;border-collapse:collapse}
thead th{text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);padding:14px 18px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.012)}
[data-theme="light"] thead th{background:rgba(16,20,28,.015)}
tbody td{padding:14px 18px;border-bottom:1px solid var(--border);font-size:13.5px;vertical-align:middle}
tbody tr{transition:background .13s;cursor:pointer}
tbody tr:hover{background:var(--surface-2)}
tbody tr:last-child td{border-bottom:none}
.c-name{font-weight:600;display:flex;align-items:center;gap:11px}
.c-av{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;font-size:12px;font-weight:600;flex-shrink:0;background:var(--surface-3);color:var(--gold);border:1px solid var(--border)}
.c-phone{font-family:var(--font-mono);color:var(--text-2);font-size:12.5px;display:flex;align-items:center;gap:7px}
.c-phone svg{width:13px;height:13px;color:var(--text-3)}
.tag-src{font-size:11px;font-family:var(--font-mono);color:var(--text-3);background:var(--surface-2);padding:3px 9px;border-radius:6px;border:1px solid var(--border)}
.c-date{color:var(--text-3);font-family:var(--font-mono);font-size:12px}
.empty-cell{text-align:center;padding:40px;color:var(--text-3)}

/* ---------- KANBAN ---------- */
.kanban{display:flex;gap:14px;overflow-x:auto;padding:0 22px 10px}
.kcol{flex:0 0 290px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);display:flex;flex-direction:column;max-height:calc(100vh - 250px);transition:border-color .15s,background .15s}
.kcol.drag-over{border-color:var(--gold);background:var(--gold-dim)}
.kcol-head{display:flex;align-items:center;gap:9px;padding:15px 16px 12px;border-bottom:1px solid var(--border)}
.kcol-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.kcol-title{font-weight:600;font-size:13.5px}
.kcol-count{margin-left:auto;font-family:var(--font-mono);font-size:11.5px;font-weight:600;color:var(--text-2);background:var(--surface-3);padding:2px 9px;border-radius:20px}
.kcol-body{padding:12px;display:flex;flex-direction:column;gap:10px;overflow-y:auto;min-height:80px;flex:1}
.kcard{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:13px 14px;cursor:grab;transition:.16s;position:relative}
.kcard:hover{border-color:rgba(217,182,115,.35);transform:translateY(-2px);box-shadow:var(--shadow)}
.kcard.dragging{opacity:.4;cursor:grabbing}
.kcard-name{font-weight:600;font-size:13.5px;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.kcard-name .src-i{font-size:10px;color:var(--text-3);font-weight:500}
.kcard-stale{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--rose);margin-bottom:10px}
.kcard-stale i{width:5px;height:5px;border-radius:50%;background:var(--rose)}
.kcard-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-2);font-family:var(--font-mono);margin-bottom:6px}
.kcard-row svg{width:13px;height:13px;color:var(--text-3);flex-shrink:0}
.kcard-actions{display:flex;gap:6px;margin-top:11px}
.k-act{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;background:var(--surface-3);color:var(--text-2);transition:.15s}
.k-act:hover{background:var(--surface)}
.k-wa{background:rgba(63,207,142,.13);color:var(--emerald)}
.k-wa:hover{background:var(--emerald);color:#08130d}
.k-act svg{width:15px;height:15px}
.kcard-val{margin-left:auto;font-family:var(--font-mono);font-size:12.5px;font-weight:600;color:var(--gold)}
.kdrop{border:1.5px dashed var(--border-strong);border-radius:12px;padding:30px 14px;text-align:center;color:var(--text-3);font-size:12.5px}
.pstats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px;padding:0 22px}
.pstat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px;display:flex;align-items:center;gap:14px}
.pstat-ico{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;flex-shrink:0}
.pstat-ico svg{width:21px;height:21px}
.pstat-val{font-family:var(--font-display);font-size:24px;font-weight:600;letter-spacing:-.02em;line-height:1}
.pstat-label{font-size:12px;color:var(--text-3);margin-top:3px}

/* ---------- INTEGRAÇÕES ---------- */
.integ-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px}
.integ-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;transition:.18s;position:relative}
.integ-card:hover{border-color:var(--border-strong);transform:translateY(-2px)}
.integ-card.featured{border-color:rgba(217,182,115,.30)}
.integ-top{display:flex;align-items:center;gap:12px;margin-bottom:13px}
.integ-logo{width:44px;height:44px;border-radius:11px;display:grid;place-items:center;flex-shrink:0}
.integ-logo svg{width:24px;height:24px}
.lg-meta{background:rgba(11,132,255,.13)} .lg-wa{background:var(--emerald-dim)}
.lg-google{background:rgba(234,67,53,.12)} .lg-hook{background:rgba(169,139,245,.13)}
.integ-name{font-family:var(--font-display);font-size:15px;font-weight:600}
.integ-name .sub{display:block;font-family:var(--font-body);font-size:11.5px;font-weight:400;color:var(--text-3);margin-top:2px}
.integ-desc{font-size:12.5px;color:var(--text-2);line-height:1.55;margin-bottom:16px;min-height:38px}
.integ-foot{display:flex;align-items:center;justify-content:space-between;gap:10px}
.status-pill{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;padding:4px 10px;border-radius:7px}
.status-pill i{width:6px;height:6px;border-radius:50%}
.status-on{background:var(--emerald-dim);color:var(--emerald)} .status-on i{background:var(--emerald);box-shadow:0 0 6px var(--emerald)}
.status-off{background:rgba(255,255,255,.05);color:var(--text-3)} .status-off i{background:var(--text-3)}
[data-theme="light"] .status-off{background:rgba(16,20,28,.05)}
.meta-module{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}
.meta-head{display:flex;align-items:center;gap:14px;padding:20px 22px;border-bottom:1px solid var(--border);background:linear-gradient(110deg,rgba(11,132,255,.06),transparent 60%)}
.meta-head .integ-logo{width:48px;height:48px}
.meta-acct{flex:1;min-width:0}
.meta-acct h3{font-family:var(--font-display);font-size:16px;font-weight:600;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.meta-acct .acct-line{font-size:12.5px;color:var(--text-3);margin-top:3px;font-family:var(--font-mono)}
.meta-actions{display:flex;gap:9px;flex-shrink:0;flex-wrap:wrap}
.sync-bar{display:flex;align-items:center;gap:10px;padding:11px 22px;font-size:12.5px;color:var(--text-3);border-bottom:1px solid var(--border);background:var(--surface-2)}
.sync-bar b{color:var(--text-2)}
.sync-dot{width:7px;height:7px;border-radius:50%;background:var(--emerald);box-shadow:0 0 7px var(--emerald);flex-shrink:0}
.forms-head,.form-row{display:grid;grid-template-columns:2.4fr 1.3fr 1fr 1.4fr 70px;gap:14px;align-items:center;padding:13px 22px}
.forms-head{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);border-bottom:1px solid var(--border)}
.form-row{border-bottom:1px solid var(--border);transition:.13s}
.form-row:last-child{border-bottom:none}
.form-row:hover{background:var(--surface-2)}
.form-name{font-weight:600;font-size:13.5px;display:flex;align-items:center;gap:10px}
.form-fb{width:30px;height:30px;border-radius:8px;background:rgba(11,132,255,.13);display:grid;place-items:center;flex-shrink:0}
.form-fb svg{width:15px;height:15px}
.form-page{font-size:12.5px;color:var(--text-2)}
.form-num{font-family:var(--font-mono);font-size:13px;font-weight:600}
.form-sync{font-size:12px;color:var(--text-3);font-family:var(--font-mono)}
.map-section{padding:18px 22px;border-top:1px solid var(--border)}
.map-title{font-size:12.5px;font-weight:600;color:var(--text-2);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.map-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}
.map-row{display:flex;align-items:center;gap:10px;background:var(--surface-2);border:1px solid var(--border);border-radius:9px;padding:9px 12px;font-size:12.5px}
.map-from{color:var(--text-2);font-family:var(--font-mono)}
.map-arrow{color:var(--gold)}
.map-to{color:var(--text);font-weight:600;margin-left:auto}

/* ---------- TOGGLE SWITCH ---------- */
.switch{position:relative;width:38px;height:22px;flex-shrink:0;display:inline-block}
.switch input{opacity:0;width:0;height:0}
.switch .track{position:absolute;inset:0;border-radius:20px;background:var(--surface-3);border:1px solid var(--border);transition:.2s;cursor:pointer}
.switch .track::before{content:'';position:absolute;left:2px;top:2px;width:16px;height:16px;border-radius:50%;background:var(--text-3);transition:.2s}
.switch input:checked + .track{background:var(--emerald-dim);border-color:transparent}
.switch input:checked + .track::before{transform:translateX(16px);background:var(--emerald)}

/* ---------- MODAL ---------- */
.modal-overlay{position:fixed;inset:0;z-index:120;background:var(--overlay);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:.2s}
.modal-overlay.open{opacity:1;visibility:visible}
.modal{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-xl);width:100%;max-width:480px;box-shadow:var(--shadow);transform:translateY(14px) scale(.98);transition:.22s;max-height:90vh;overflow-y:auto}
.modal-overlay.open .modal{transform:none}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 22px 4px}
.modal-head h3{font-family:var(--font-display);font-size:18px;font-weight:600}
.modal-close{width:32px;height:32px;border-radius:8px;display:grid;place-items:center;color:var(--text-3);transition:.15s}
.modal-close:hover{background:var(--surface-2);color:var(--text)}
.modal-close svg{width:18px;height:18px}
.modal-body{padding:14px 22px 8px}
.field{margin-bottom:14px}
.field label{display:block;font-size:12px;font-weight:600;color:var(--text-2);margin-bottom:6px}
.field input,.field select{width:100%;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:10px 12px;color:var(--text);font-size:13.5px;transition:.15s}
.field input:focus,.field select:focus{outline:none;border-color:rgba(217,182,115,.5);background:var(--surface-3)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.modal-foot{display:flex;gap:10px;justify-content:flex-end;padding:14px 22px 20px}

/* ---------- TOAST ---------- */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);z-index:200;background:var(--surface-3);border:1px solid var(--border-strong);border-radius:11px;padding:12px 18px;display:flex;align-items:center;gap:10px;font-size:13.5px;font-weight:500;box-shadow:var(--shadow);opacity:0;visibility:hidden;transition:.25s}
.toast.show{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.toast svg{width:17px;height:17px;color:var(--emerald)}

/* ---------- FOOTER ---------- */
.app-foot{text-align:center;padding:22px;color:var(--text-3);font-size:11.5px;font-family:var(--font-mono)}
.app-foot b{color:var(--text-2)}

/* ---------- EMPTY STATE ---------- */
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl)}
.empty-ico{width:60px;height:60px;border-radius:16px;background:var(--surface-2);border:1px solid var(--border);display:grid;place-items:center;color:var(--gold);margin-bottom:18px}
.empty-ico svg{width:28px;height:28px}
.empty h3{font-family:var(--font-display);font-size:18px;font-weight:600;margin-bottom:8px}
.empty p{color:var(--text-3);font-size:14px;max-width:380px;line-height:1.6}

/* ---------- RESPONSIVO ---------- */
@media (max-width:980px){
  .kpi-grid{grid-template-columns:1fr 1fr}
  .grid-2,.grid-32{grid-template-columns:1fr}
  .pstats{grid-template-columns:1fr}
  .nav{display:none}
  .integ-grid{grid-template-columns:1fr}
  .forms-head{display:none}
  .form-row{grid-template-columns:1fr auto;gap:8px 8px}
  .form-row>*:nth-child(2),.form-row>*:nth-child(3),.form-row>*:nth-child(4){grid-column:1}
  .field-row{grid-template-columns:1fr}
}
