/* ═══════════════════════════════════════════
   COMPONENTS.CSS — Buttons, Forms, Cards, UI
═══════════════════════════════════════════ */

/* ── Buttons ──────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;
  padding:8px 16px;border-radius:var(--r);font-weight:600;font-size:.82rem;
  border:none;transition:var(--tr);white-space:nowrap;cursor:pointer;line-height:1;
  letter-spacing:-.01em}
.btn svg{width:14px;height:14px;flex-shrink:0}
.btn-lg{padding:12px 26px;font-size:.93rem;border-radius:var(--r2)}
.btn-lg svg{width:16px;height:16px}
.btn-sm{padding:5px 11px;font-size:.74rem;border-radius:7px}
.btn-sm svg{width:12px;height:12px}
.btn-xs{padding:3px 9px;font-size:.69rem;border-radius:6px}
.btn-xs svg{width:11px;height:11px}

.bp{background:var(--ac);color:#000;font-weight:700;
  box-shadow:0 2px 12px rgba(0,217,181,.2)}
.bp:hover{background:var(--ac2);transform:translateY(-1px);
  box-shadow:0 6px 24px rgba(0,217,181,.35)}
.bp:active{transform:translateY(0)}
.bp:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}

.bg2{background:transparent;border:1px solid var(--br2);color:var(--t2)}
.bg2:hover{border-color:var(--ac);color:var(--ac);background:var(--acg)}

.bbl{background:var(--blg);color:var(--bl);border:1px solid rgba(92,140,245,.18)}
.bbl:hover{background:rgba(92,140,245,.15)}
.bre{background:var(--reg);color:var(--re);border:1px solid rgba(245,101,101,.18)}
.bre:hover{background:rgba(245,101,101,.15)}
.bgn{background:var(--gng);color:var(--gn);border:1px solid rgba(47,212,160,.18)}
.bgn:hover{background:rgba(47,212,160,.15)}
.bor{background:var(--org);color:var(--or);border:1px solid rgba(246,151,42,.18)}
.bor:hover{background:rgba(246,151,42,.15)}
.bpu{background:var(--pug);color:var(--pu);border:1px solid rgba(159,126,255,.18)}
.bpu:hover{background:rgba(159,126,255,.15)}

/* ── Form elements ────────────────────────── */
.fg{display:flex;flex-direction:column;gap:.3rem}
.fg .lbl{font-size:.71rem;font-weight:600;color:var(--t2);letter-spacing:.03em;
  text-transform:uppercase}
.fi{width:100%;padding:10px 13px;background:var(--bg2);border:1px solid var(--br);
  border-radius:var(--r);color:var(--t);font-size:.84rem;outline:none;
  transition:border-color .18s,box-shadow .18s}
.fi:focus{border-color:var(--ac);box-shadow:0 0 0 3px rgba(0,217,181,.07);
  background:var(--bg)}
.fi::placeholder{color:var(--t3)}.fi:disabled{opacity:.45;cursor:not-allowed}
select.fi option{background:var(--sf)}
textarea.fi{resize:vertical;min-height:72px}
.pw-wrap{position:relative}
.pw-eye{position:absolute;right:10px;top:50%;transform:translateY(-50%);
  background:none;border:none;color:var(--t3);cursor:pointer;padding:4px;display:flex}
.pw-eye svg{width:14px;height:14px}
.pw-eye:hover{color:var(--t2)}

/* ── Cards ─────────────────────────────────── */
.card{background:var(--sf);border:1px solid var(--br);border-radius:var(--r3)}
.card-sm{background:var(--sf);border:1px solid var(--br);border-radius:var(--r2)}
.card-glow{box-shadow:0 0 0 1px rgba(0,217,181,.12),
  0 20px 60px rgba(0,0,0,.5),0 0 80px rgba(0,217,181,.05)}

/* ── Stat Cards ─────────────────────────────── */
.stat-card{background:var(--sf);border:1px solid var(--br);border-radius:var(--r2);
  padding:1.15rem 1.25rem;transition:var(--tr);cursor:default;position:relative;overflow:hidden}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--ac),var(--bl));opacity:0;transition:opacity .3s}
.stat-card:hover{border-color:var(--br2);transform:translateY(-1px)}
.stat-card:hover::before{opacity:1}
.slbl{font-size:.66rem;text-transform:uppercase;letter-spacing:.1em;color:var(--t3);
  font-weight:700;margin-bottom:.4rem;display:flex;align-items:center;gap:.3rem}
.slbl svg{width:11px;height:11px}
.sval{font-size:1.75rem;font-weight:900;line-height:1;letter-spacing:-.04em;
  font-family:var(--mono)}
.ssub{font-size:.71rem;color:var(--t2);margin-top:.3rem}

/* ── Badges ─────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:.2rem;padding:2px 8px;
  border-radius:100px;font-size:.66rem;font-weight:700;white-space:nowrap}
.badge svg{width:9px;height:9px}
.b-gn{background:var(--gng);color:var(--gn)}.b-bl{background:var(--blg);color:var(--bl)}
.b-re{background:var(--reg);color:var(--re)}.b-or{background:var(--org);color:var(--or)}
.b-gr{background:rgba(255,255,255,.06);color:var(--t2)}.b-pu{background:var(--pug);color:var(--pu)}
.b-ac{background:var(--acg);color:var(--ac)}

/* ── Alerts ─────────────────────────────────── */
.alert{padding:.8rem 1rem;border-radius:var(--r);font-size:.82rem;
  display:flex;align-items:flex-start;gap:.5rem;line-height:1.55}
.alert svg{width:15px;height:15px;flex-shrink:0;margin-top:1px}
.a-ok{background:rgba(0,217,181,.06);border:1px solid rgba(0,217,181,.18);color:var(--ac)}
.a-er{background:rgba(245,101,101,.06);border:1px solid rgba(245,101,101,.18);color:var(--re)}
.a-in{background:rgba(92,140,245,.06);border:1px solid rgba(92,140,245,.18);color:var(--bl)}
.a-wa{background:rgba(246,151,42,.06);border:1px solid rgba(246,151,42,.18);color:var(--or)}

/* ── Toasts ─────────────────────────────────── */
#toasts{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;
  display:flex;flex-direction:column;gap:.5rem;pointer-events:none}
.toast{background:var(--sf2);border:1px solid var(--br2);border-radius:var(--r2);
  padding:.875rem 1.1rem;font-size:.82rem;display:flex;align-items:center;gap:.6rem;
  animation:tsIn .28s cubic-bezier(.22,1,.36,1);box-shadow:var(--sh);
  min-width:240px;max-width:380px;pointer-events:all;
  backdrop-filter:blur(20px)}
.toast svg{width:15px;height:15px;flex-shrink:0}
.toast-ok{border-color:rgba(0,217,181,.25);color:var(--ac)}
.toast-er{border-color:rgba(245,101,101,.25);color:var(--re)}
.toast-in{border-color:rgba(92,140,245,.25);color:var(--bl)}
.toast-wa{border-color:rgba(246,151,42,.25);color:var(--or)}
@keyframes tsIn{from{opacity:0;transform:translateX(16px) scale(.96)}
  to{opacity:1;transform:translateX(0) scale(1)}}

/* ── Modal ───────────────────────────────────── */
.mol{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  z-index:500;align-items:center;justify-content:center;padding:1rem}
.mol.open{display:flex;animation:mfIn .2s ease}
@keyframes mfIn{from{opacity:0}to{opacity:1}}
.mbox{background:var(--sf);border:1px solid var(--br2);border-radius:var(--r4);
  padding:1.75rem;width:100%;max-width:520px;max-height:92vh;overflow-y:auto;
  box-shadow:var(--sh);position:relative;animation:mIn .25s cubic-bezier(.22,1,.36,1)}
@keyframes mIn{from{opacity:0;transform:scale(.95) translateY(8px)}
  to{opacity:1;transform:scale(1) translateY(0)}}
.mhead{margin-bottom:1.25rem}
.mhead h2{font-size:1.05rem;font-weight:800;display:flex;align-items:center;gap:.5rem;
  letter-spacing:-.02em}
.mhead h2 svg{width:17px;height:17px;color:var(--ac)}
.mhead p{font-size:.81rem;color:var(--t2);margin-top:.25rem}
.mcl{position:absolute;top:1.1rem;right:1.1rem;width:28px;height:28px;border-radius:8px;
  background:rgba(255,255,255,.05);border:1px solid var(--br);color:var(--t3);
  cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--tr)}
.mcl:hover{background:var(--reg);color:var(--re);border-color:transparent}
.mcl svg{width:14px;height:14px}

/* ── Table ─────────────────────────────────── */
.tw{border-radius:var(--r2);overflow:hidden;border:1px solid var(--br)}
.tw-head{display:flex;align-items:center;justify-content:space-between;
  padding:.875rem 1.1rem;border-bottom:1px solid var(--br);
  background:var(--sf);flex-wrap:wrap;gap:.5rem}
.tw-head h3{font-size:.83rem;font-weight:700;display:flex;align-items:center;gap:.4rem}
.tw-head h3 svg{width:14px;height:14px;color:var(--ac)}
table{width:100%;border-collapse:collapse;background:var(--sf)}
th{padding:7px 1rem;font-size:.64rem;text-transform:uppercase;letter-spacing:.08em;
  color:var(--t3);text-align:left;background:var(--bg2);
  border-bottom:1px solid var(--br);white-space:nowrap;font-weight:700}
td{padding:7px 1rem;font-size:.79rem;border-bottom:1px solid rgba(255,255,255,.035);
  color:var(--t2);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(255,255,255,.012)}
.t-empty{text-align:center;padding:2.5rem;color:var(--t3);font-size:.82rem}

/* ── API Key Card ─────────────────────────── */
.api-card{background:var(--sf);border:1px solid var(--br);border-radius:var(--r2);
  padding:1.1rem 1.15rem;transition:var(--tr);margin-bottom:.75rem;position:relative}
.api-card:hover{border-color:var(--br2)}
.api-card.active-card{border-color:rgba(0,217,181,.2)}
.api-card::before{content:'';position:absolute;top:0;left:1.25rem;right:1.25rem;
  height:1px;background:linear-gradient(90deg,transparent,var(--ac),transparent);
  opacity:0;transition:opacity .3s}
.api-card.active-card::before{opacity:.4}
.ac-head{display:flex;align-items:flex-start;justify-content:space-between;
  gap:.75rem;margin-bottom:.75rem}
.ac-name{font-size:.85rem;font-weight:700;color:var(--t);margin-bottom:.1rem}
.ac-app{font-size:.71rem;color:var(--t3)}
.ac-key{font-family:var(--mono);font-size:.71rem;color:var(--t3);background:var(--bg2);
  border:1px solid var(--br);border-radius:7px;padding:7px 11px;margin-bottom:.7rem;
  word-break:break-all;cursor:pointer;transition:var(--tr)}
.ac-key:hover{border-color:var(--ac);color:var(--t2)}
.ac-bars{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.ac-bar{background:var(--bg2);border-radius:7px;padding:.55rem .7rem}
.ac-bar-lbl{font-size:.65rem;color:var(--t3);margin-bottom:.3rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.05em}
.ac-bar-track{height:4px;background:var(--sf3);border-radius:2px;overflow:hidden}
.ac-bar-fill{height:100%;background:var(--ac);border-radius:2px;transition:width .5s ease}
.ac-bar-nums{font-size:.67rem;color:var(--t2);margin-top:.25rem;font-family:var(--mono)}

/* ── Pager ─────────────────────────────────── */
.pager{display:flex;gap:.25rem;justify-content:center;margin-top:1rem;flex-wrap:wrap}
.pager button{min-width:32px;height:32px;border-radius:7px;border:1px solid var(--br);
  background:var(--sf);color:var(--t2);font-size:.78rem;cursor:pointer;transition:var(--tr)}
.pager button:hover{border-color:var(--ac);color:var(--ac)}
.pager button.on{background:var(--ac);color:#000;border-color:transparent;font-weight:700}

/* ── Code block ─────────────────────────────── */
.code-block{background:var(--bg);border:1px solid var(--br);border-radius:var(--r2);
  padding:1rem;font-family:var(--mono);font-size:.78rem;color:var(--t2);
  white-space:pre-wrap;word-break:break-all;line-height:1.7;overflow-x:auto}

/* ── Skeleton Loading ─────────────────────── */
.skel { position:relative; overflow:hidden; border-radius:var(--r); background:var(--sf3); }
.skel::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(90deg, transparent 0%, rgba(255,255,255,.04) 50%, transparent 100%);
  animation:shimmer 1.6s infinite;
}
@keyframes shimmer { 0%{transform:translateX(-100%)} 100%{transform:translateX(100%)} }

/* ── Stat card gowulandyrma ───────────────── */
.stat-card .sval { font-size:1.6rem; font-weight:800; color:var(--t); line-height:1.2; }
.stat-card .slbl { font-size:.72rem; color:var(--t3); margin-bottom:.3rem;
  display:flex; align-items:center; gap:.3rem; text-transform:uppercase; letter-spacing:.04em; }
.stat-card .ssub { font-size:.72rem; color:var(--t3); margin-top:.25rem; }
.stat-card { padding:1.1rem 1.25rem; transition:var(--tr); cursor:default; }

/* ── API Card progress bar ────────────────── */
.key-progress { height:3px; background:var(--sf3); border-radius:2px; overflow:hidden; margin-top:.3rem; }
.key-progress-fill { height:100%; border-radius:2px; transition:width .6s ease; }

/* ── Pagination ───────────────────────────── */
#logsPagination .btn { min-width:60px; }

/* ── Tab panel animasiýa ─────────────────── */
.tab-panel.on { animation:fadeIn .2s ease; }
@keyframes fadeIn { from{opacity:0;transform:translateY(4px)} to{opacity:1;transform:none} }
@keyframes slideDown { from{transform:translateY(-10px);opacity:0} to{transform:none;opacity:1} }

/* ── Dph (dashboard page header) ─────────── */
.dph { display:flex; align-items:flex-start; justify-content:space-between;
  gap:.75rem; margin-bottom:1.25rem; flex-wrap:wrap; }
.dph h1 { display:flex; align-items:center; gap:.5rem; font-size:1rem;
  font-weight:700; margin:0; }
.dph h1 svg { width:16px; height:16px; color:var(--ac); }

/* ── Resp: tablisalar ──────────────────────── */
@media(max-width:600px) {
  .fgrid4 { grid-template-columns:1fr 1fr !important; }
  .stat-card .sval { font-size:1.2rem; }
  table { font-size:.75rem; }
  .dph { gap:.5rem; }
}

