/* ============================================================
   COMPONENTS.CSS — botões, inputs, cards, badges, alertas
   TrafegoBi © 2026
   ============================================================ */

/* ── Botões ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-sm);padding:10px 20px;border-radius:var(--r-md);font-size:13.5px;font-weight:500;font-family:var(--font-b);cursor:pointer;border:none;transition:all var(--t);white-space:nowrap;user-select:none;text-decoration:none}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important;box-shadow:none!important}
.btn-primary{background:var(--accent);color:#000;font-weight:600}
.btn-primary:hover:not(:disabled){opacity:.88;transform:translateY(-1px);box-shadow:0 4px 18px var(--accent-glow)}
.btn-outline{background:transparent;color:var(--text);border:1px solid var(--border2)}
.btn-outline:hover:not(:disabled){background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.2)}
.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--border)}
.btn-ghost:hover:not(:disabled){color:var(--text);border-color:var(--border2)}
.btn-meta{background:#1877f2;color:#fff;font-weight:600;font-size:15px;padding:14px 20px}
.btn-meta:hover:not(:disabled){background:#166fe5;transform:translateY(-1px)}
.btn-full{width:100%}
.btn-lg{padding:13px 26px;font-size:15px}
.btn-sm{padding:6px 12px;font-size:12px}
.btn-spinner{width:15px;height:15px;border:2px solid rgba(0,0,0,.25);border-top-color:currentColor;border-radius:50%;animation:spin .7s linear infinite;display:none}
.btn.loading .btn-text{display:none}
.btn.loading .btn-spinner{display:block}
.btn.loading{pointer-events:none;opacity:.75}

/* ── Inputs ── */
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:12px;color:var(--muted);letter-spacing:.02em}
.field-wrap{position:relative}
.input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:var(--r-md);padding:11px 14px;font-size:14px;color:var(--text);font-family:var(--font-b);outline:none;transition:border-color var(--t),box-shadow var(--t);appearance:none}
.input:focus{border-color:rgba(0,229,160,.35);box-shadow:0 0 0 3px rgba(0,229,160,.07)}
.input::placeholder{color:var(--muted)}
.input.has-error{border-color:rgba(255,71,87,.4)}
.input:disabled{opacity:.5;cursor:not-allowed}
.input-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);cursor:pointer;color:var(--muted);font-size:12px;user-select:none;transition:color var(--t)}
.input-toggle:hover{color:var(--text)}
.strength-wrap{margin-top:5px}
.strength-bar{height:3px;background:var(--surface2);border-radius:var(--r-full);overflow:hidden}
.strength-bar-fill{height:100%;border-radius:var(--r-full);transition:width .3s,background .3s;width:0%}
.strength-hint{font-size:11px;margin-top:4px;color:var(--muted);min-height:16px}

/* ── Cards ── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--sp-lg)}
.card-sm{padding:var(--sp-md)}
.card-lg{padding:var(--sp-xl)}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-lg)}
.card-title{font-family:var(--font-d);font-size:14px;font-weight:700}

.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--sp-lg) var(--sp-lg) var(--sp-md);position:relative;overflow:hidden;transition:border-color var(--t)}
.kpi-card:hover{border-color:var(--border2)}
.kpi-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px}
.kpi-card.green::before{background:var(--accent)} .kpi-card.purple::before{background:var(--accent2)}
.kpi-card.red::before{background:var(--accent3)}   .kpi-card.yellow::before{background:var(--accent4)}
.kpi-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}
.kpi-value{font-family:var(--font-d);font-size:26px;font-weight:700;letter-spacing:-.04em;margin-bottom:8px}
.kpi-meta{display:flex;align-items:center;gap:var(--sp-xs);font-size:12px;color:var(--muted)}
.kpi-meta .up{color:var(--success)} .kpi-meta .down{color:var(--danger)}

/* ── Badges ── */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:var(--r-full);font-size:11px;font-weight:500}
.badge-green{background:rgba(0,229,160,.1);color:var(--accent)}
.badge-purple{background:rgba(124,108,255,.1);color:var(--accent2)}
.badge-red{background:rgba(255,71,87,.1);color:var(--danger)}
.badge-yellow{background:rgba(255,209,102,.1);color:var(--warning)}
.badge-gray{background:var(--surface2);color:var(--muted)}
.badge-dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.badge-dot.pulse{box-shadow:0 0 5px currentColor;animation:pulse 2s infinite}

/* ── Alertas ── */
.alert{display:flex;align-items:flex-start;gap:var(--sp-sm);padding:11px 14px;border-radius:var(--r-md);font-size:13px;line-height:1.5}
.alert-error{background:rgba(255,71,87,.08);border:1px solid rgba(255,71,87,.2);color:var(--danger)}
.alert-success{background:rgba(0,229,160,.08);border:1px solid rgba(0,229,160,.2);color:var(--success)}
.alert-warning{background:rgba(255,209,102,.08);border:1px solid rgba(255,209,102,.2);color:var(--warning)}
.alert-info{background:rgba(124,108,255,.08);border:1px solid rgba(124,108,255,.2);color:var(--info)}

/* ── Tabela ── */
.table{width:100%;border-collapse:collapse}
.table th{text-align:left;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;padding-bottom:12px;border-bottom:1px solid var(--border);font-weight:500}
.table td{padding:12px 0;font-size:13px;border-bottom:1px solid var(--border)}
.table tr:last-child td{border-bottom:none}
.table tr:hover td{background:rgba(255,255,255,.015)}

/* ── Progress bar ── */
.progress-wrap{margin-bottom:var(--sp-md)}
.progress-header{display:flex;justify-content:space-between;font-size:12px;margin-bottom:6px;color:var(--muted)}
.progress-header span:last-child{color:var(--text);font-weight:500}
.progress-bar{height:5px;background:var(--surface2);border-radius:var(--r-full);overflow:hidden}
.progress-bar-fill{height:100%;border-radius:var(--r-full);transition:width 1s ease}

/* ── Tabs ── */
.tabs{display:flex;gap:4px;background:var(--surface2);border-radius:var(--r-md);padding:4px}
.tab{flex:1;text-align:center;padding:8px 16px;border-radius:var(--r-sm);font-size:13px;cursor:pointer;color:var(--muted);transition:all var(--t);user-select:none}
.tab:hover{color:var(--text2)}
.tab.active{background:var(--bg);color:var(--text);box-shadow:var(--shadow-sm)}

/* ── Divider ── */
.divider{display:flex;align-items:center;gap:var(--sp-sm);color:var(--muted);font-size:12px;margin:var(--sp-md) 0}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--border)}

/* ── Avatar ── */
.avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent2),var(--accent));display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;font-family:var(--font-d);color:#fff;flex-shrink:0}
.avatar-lg{width:44px;height:44px;font-size:16px}

/* ── Spinner ── */
.spinner{width:20px;height:20px;border:2px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}

/* ── Tooltip ── */
[data-tooltip]{position:relative;cursor:help}
[data-tooltip]::after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--surface3);border:1px solid var(--border);color:var(--text2);font-size:11px;padding:5px 9px;border-radius:var(--r-sm);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity var(--t);z-index:999}
[data-tooltip]:hover::after{opacity:1}
