
/* ── Economy hero uses shared lp-* ─────────────────────────── */
.eco-status-badge { display: inline-flex; align-items: center; gap: 0.5rem;
  border-radius: 20px; padding: 0.35rem 1rem; font-size: 0.82rem; font-weight: 700; margin-top: 0.8rem; }
.eco-status-badge.ok   { background: rgba(70,251,120,0.12); color: #46fb78; border: 1px solid rgba(70,251,120,0.3); }
.eco-status-badge.warn { background: rgba(255,107,107,0.12); color: #ff7675; border: 1px solid rgba(255,107,107,0.3); }
.eco-status-badge.info { background: rgba(70,226,251,0.1);  color: var(--cyan); border: 1px solid rgba(70,226,251,0.25); }

/* ── Stat cards ───────────────────────────────────────────── */
.eco-stats { display: grid; grid-template-columns: repeat(5, 1fr); gap: 0.85rem; margin-bottom: 1.5rem; }
.eco-stat { background: var(--g-bg); backdrop-filter: var(--g-blur); -webkit-backdrop-filter: var(--g-blur);
  border: 1px solid var(--g-border); box-shadow: var(--g-shine), var(--g-shadow);
  border-radius: var(--radius); padding: 1.2rem 1.3rem; position: relative; overflow: hidden; }
.eco-stat-icon { position: absolute; right: 1rem; top: 1rem; font-size: 1.2rem; opacity: 0.15; }
.eco-stat-label { font-size: 0.7rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.08em; color: rgba(255,255,255,0.4); margin-bottom: 0.35rem; }
.eco-stat-value { font-size: 1.6rem; font-weight: 900; color: #fff; line-height: 1.1; margin-bottom: 0.2rem; }
.eco-stat-sub { font-size: 0.72rem; color: rgba(255,255,255,0.38); }
.eco-stat-sub .accent { color: var(--cyan); font-weight: 700; }

/* ── Charts row ───────────────────────────────────────────── */
.eco-charts { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 2rem; }
.eco-chart-card { background: var(--g-bg); backdrop-filter: var(--g-blur); -webkit-backdrop-filter: var(--g-blur);
  border: 1px solid var(--g-border); box-shadow: var(--g-shine), var(--g-shadow);
  border-radius: var(--radius); padding: 1.5rem; }
.eco-chart-title { font-size: 0.82rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.08em; color: rgba(255,255,255,0.55); margin-bottom: 1.2rem; }
.eco-chart-wrap { position: relative; height: 220px; display: flex; align-items: center; justify-content: center; }
.eco-chart-legend { display: flex; flex-wrap: wrap; gap: 0.5rem 1rem; margin-top: 1rem; }
.eco-legend-item { display: flex; align-items: center; gap: 0.4rem;
  font-size: 0.78rem; color: rgba(255,255,255,0.6); }
.eco-legend-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }

/* ── Section title ────────────────────────────────────────── */
.eco-section-title { font-size: 1rem; font-weight: 800; color: #fff; margin-bottom: 1rem;
  display: flex; align-items: center; gap: 0.5rem; }
.eco-section-title i { color: var(--cyan); }

/* ── Top holders table ────────────────────────────────────── */
.eco-table-wrap { background: var(--g-bg); backdrop-filter: var(--g-blur); -webkit-backdrop-filter: var(--g-blur);
  border: 1px solid var(--g-border); box-shadow: var(--g-shine), var(--g-shadow);
  border-radius: var(--radius); overflow: hidden; margin-bottom: 2rem; }
.eco-table { width: 100%; border-collapse: collapse; }
.eco-table thead th { padding: 0.9rem 1.2rem; text-align: left; font-size: 0.72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.08em; color: var(--cyan);
  background: rgba(70,226,251,0.05); border-bottom: 1px solid rgba(255,255,255,0.08); }
.eco-table thead th.right { text-align: right; }
.eco-table thead th.center { text-align: center; }
.eco-table tbody tr { border-bottom: 1px solid rgba(255,255,255,0.04); transition: background var(--transition); }
.eco-table tbody tr:last-child { border-bottom: none; }
.eco-table tbody tr:hover { background: rgba(70,226,251,0.03); }
.eco-table tbody td { padding: 0.75rem 1.2rem; font-size: 0.88rem; color: rgba(255,255,255,0.8); }
.eco-table tbody td.right { text-align: right; }
.eco-table tbody td.center { text-align: center; }
.eco-rank { color: rgba(255,255,255,0.35); font-size: 0.8rem; }
.eco-rank.top { color: var(--yellow); font-weight: 800; }
.eco-char-link { color: var(--cyan); text-decoration: none; font-weight: 600; }
.eco-char-link:hover { text-decoration: underline; }
.eco-zeny-val { color: rgba(255,220,80,0.9); font-weight: 700; font-variant-numeric: tabular-nums; }
.eco-guild-name { color: var(--blue); }

/* ── Active Sinks ─────────────────────────────────────────── */
.eco-sinks { background: var(--g-bg); backdrop-filter: var(--g-blur); -webkit-backdrop-filter: var(--g-blur);
  border: 1px solid var(--g-border); box-shadow: var(--g-shine), var(--g-shadow);
  border-radius: var(--radius); overflow: hidden; margin-bottom: 2rem; }
.eco-sinks-head { padding: 1.1rem 1.5rem; border-bottom: 1px solid rgba(255,255,255,0.08);
  font-size: 0.82rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--cyan); }
.eco-sink-row { display: grid; grid-template-columns: 1fr auto auto auto;
  padding: 0.85rem 1.5rem; gap: 1.5rem; align-items: center;
  border-bottom: 1px solid rgba(255,255,255,0.04); font-size: 0.88rem; }
.eco-sink-row:last-child { border-bottom: none; }
.eco-sink-name { font-weight: 600; color: #fff; }
.eco-sink-multi { color: var(--cyan); font-weight: 700; font-variant-numeric: tabular-nums; min-width: 55px; text-align: right; }
.eco-sink-note  { color: rgba(255,255,255,0.35); font-size: 0.78rem; min-width: 80px; text-align: right; }
.eco-sink-date  { color: rgba(255,255,255,0.3); font-size: 0.75rem; min-width: 80px; text-align: right; }
.eco-sinks-footer { padding: 0.7rem 1.5rem; font-size: 0.75rem; color: rgba(255,255,255,0.3);
  border-top: 1px solid rgba(255,255,255,0.05); }

/* ── FAQ accordion ────────────────────────────────────────── */
.eco-faq { margin-bottom: 2rem; }
.eco-faq-title { font-size: 1rem; font-weight: 800; color: #fff; margin-bottom: 1rem; }
.eco-faq-item { border: 1px solid rgba(255,255,255,0.08); border-radius: var(--radius-sm);
  margin-bottom: 0.5rem; overflow: hidden; }
.eco-faq-q { padding: 0.9rem 1.2rem; font-size: 0.9rem; font-weight: 600; color: rgba(255,255,255,0.8);
  cursor: pointer; display: flex; justify-content: space-between; align-items: center;
  background: rgba(255,255,255,0.03); transition: background var(--transition); user-select: none; }
.eco-faq-q:hover { background: rgba(255,255,255,0.06); }
.eco-faq-q .eco-faq-arrow { transition: transform 0.2s; color: var(--cyan); font-size: 0.8rem; }
.eco-faq-item.open .eco-faq-arrow { transform: rotate(180deg); }
.eco-faq-a { display: none; padding: 0.9rem 1.2rem; font-size: 0.85rem;
  color: rgba(255,255,255,0.5); line-height: 1.6;
  border-top: 1px solid rgba(255,255,255,0.05); background: rgba(255,255,255,0.01); }
.eco-faq-item.open .eco-faq-a { display: block; }

@media (max-width: 1000px) {
  .eco-stats { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 760px) {
  .eco-stats { grid-template-columns: repeat(2, 1fr); }
  .eco-charts { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .eco-stats { grid-template-columns: 1fr 1fr; }
  .eco-sink-row { grid-template-columns: 1fr auto; }
  .eco-sink-note, .eco-sink-date { display: none; }
}


/* ══════════════════════════════════════════════════════
   TRANSPARENCY HUB — Redesigned with rings + cards
   ══════════════════════════════════════════════════════ */

/* Hero */
.hub-hero { position: relative; padding: 4rem 0 2.5rem; text-align: center; overflow: hidden; }
.hub-hero::before { content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 50% 0%, rgba(70,226,251,.09) 0%, transparent 60%);
  pointer-events: none; }
.hub-hero-inner { position: relative; z-index: 1; max-width: 680px; margin: 0 auto; }
.hub-badge { display: inline-flex; align-items: center; gap: 0.45rem;
  background: rgba(70,226,251,.1); border: 1px solid rgba(70,226,251,.22);
  border-radius: 99px; padding: 0.3rem 1rem; font-size: 0.76rem; font-weight: 700;
  color: var(--cyan); letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 1.2rem; }
.hub-hero h1 { font-size: 2.8rem; font-weight: 900; color: #fff; margin: 0 0 0.6rem; line-height: 1.1;
  background: none !important; -webkit-text-fill-color: #fff !important; }
.hub-hero h1 .grad { background: linear-gradient(90deg, var(--cyan), var(--blue));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.hub-hero p { color: rgba(255,255,255,.48); font-size: 0.96rem; max-width: 520px; margin: 0 auto; }

/* ── Ultra-modern Economy Button ──────────────────────── */
.hub-eco-btn-wrap { display: flex; justify-content: flex-end; margin-bottom: 0.9rem; }
.hub-eco-btn {
  position: relative; overflow: hidden;
  display: inline-flex; align-items: center; gap: 0.6rem;
  background: linear-gradient(135deg, rgba(70,226,251,.18) 0%, rgba(75,159,255,.14) 100%);
  border: 1px solid rgba(70,226,251,.35);
  color: var(--cyan); border-radius: 10px; padding: 0.55rem 1.2rem;
  font-size: 0.82rem; font-weight: 700; text-decoration: none;
  transition: all 0.25s ease; box-shadow: 0 0 0 0 rgba(70,226,251,0); }
.hub-eco-btn::before {
  content: ''; position: absolute; top: 0; left: -75%;
  width: 50%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.12), transparent);
  transform: skewX(-20deg);
  transition: left 0.5s ease; }
.hub-eco-btn:hover { background: linear-gradient(135deg, rgba(70,226,251,.25) 0%, rgba(75,159,255,.2) 100%);
  border-color: var(--cyan); color: #fff; text-decoration: none;
  box-shadow: 0 0 18px rgba(70,226,251,.22), 0 4px 16px rgba(8,24,72,.3); }
.hub-eco-btn:hover::before { left: 150%; }
.hub-eco-btn .arrow { transition: transform 0.2s; }
.hub-eco-btn:hover .arrow { transform: translateX(3px); }

/* ── Stat Cards with Radial Rings ─────────────────────── */
.hub-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; margin-bottom: 2rem; }
.hub-stat {
  background: var(--g-bg); backdrop-filter: var(--g-blur); -webkit-backdrop-filter: var(--g-blur);
  border: 1px solid var(--g-border); box-shadow: var(--g-shine), var(--g-shadow);
  border-radius: var(--radius); padding: 1.3rem 1.4rem;
  display: flex; align-items: center; gap: 1rem; position: relative; overflow: hidden; }
.hub-stat::after { content: ''; position: absolute; top: -40%; right: -20%;
  width: 80px; height: 80px; border-radius: 50%;
  background: radial-gradient(circle, rgba(70,226,251,.05) 0%, transparent 70%);
  pointer-events: none; }

/* SVG ring wrapper */
.hub-stat-ring { flex-shrink: 0; position: relative; width: 70px; height: 70px; }
.hub-stat-ring svg { width: 70px; height: 70px; transform: rotate(-90deg); }
.hub-stat-ring-track { fill: none; stroke: rgba(255,255,255,.06); stroke-width: 5; }
.hub-stat-ring-fill  { fill: none; stroke-width: 5; stroke-linecap: round;
  transition: stroke-dashoffset 1.2s cubic-bezier(.4,0,.2,1); }
.hub-stat-ring-fill.rc-gold  { stroke: var(--yellow); filter: drop-shadow(0 0 4px rgba(255,220,80,.4)); }
.hub-stat-ring-fill.rc-cyan  { stroke: var(--cyan);   filter: drop-shadow(0 0 4px rgba(70,226,251,.4)); }
.hub-stat-ring-fill.rc-blue  { stroke: var(--blue);   filter: drop-shadow(0 0 4px rgba(75,159,255,.4)); }
.hub-stat-ring-fill.rc-green { stroke: #46fb78;       filter: drop-shadow(0 0 4px rgba(70,251,120,.4)); }
.hub-stat-ring-icon { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; }
.hub-stat-ring-icon.ic-gold  { color: var(--yellow); }
.hub-stat-ring-icon.ic-cyan  { color: var(--cyan); }
.hub-stat-ring-icon.ic-blue  { color: var(--blue); }
.hub-stat-ring-icon.ic-green { color: #46fb78; }

/* Stat text */
.hub-stat-body { flex: 1; min-width: 0; }
.hub-stat-label { font-size: 0.73rem; color: rgba(255,255,255,.45); font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.07em; margin-bottom: 0.25rem; }
.hub-stat-value { font-size: 1.7rem; font-weight: 900; color: #fff; line-height: 1; margin-bottom: 0.25rem; }
.hub-stat-value.hv-gold  { color: var(--yellow); }
.hub-stat-value.hv-cyan  { color: var(--cyan); }
.hub-stat-value.hv-green { color: #46fb78; }
.hub-stat-sub { font-size: 0.72rem; color: rgba(255,255,255,.32); }
.hub-stat-sub .up   { color: #46fb78; }
.hub-stat-sub .down { color: #ff7675; }
.hub-stat-pct-pill { display: inline-block; padding: 0.06rem 0.45rem;
  border-radius: 99px; font-size: 0.65rem; font-weight: 800; margin-left: 0.2rem; }
.hub-stat-pct-pill.gold  { background: rgba(255,220,80,.15);  color: var(--yellow); }
.hub-stat-pct-pill.cyan  { background: rgba(70,226,251,.12);  color: var(--cyan); }
.hub-stat-pct-pill.blue  { background: rgba(75,159,255,.12);  color: var(--blue); }
.hub-stat-pct-pill.green { background: rgba(70,251,120,.12);  color: #46fb78; }

/* ── Charts (3-col) ───────────────────────────────────── */
.hub-charts { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; margin-bottom: 2rem; }
.hub-chart-card { background: var(--g-bg); backdrop-filter: var(--g-blur); -webkit-backdrop-filter: var(--g-blur);
  border: 1px solid var(--g-border); box-shadow: var(--g-shine), var(--g-shadow);
  border-radius: var(--radius); padding: 1.4rem; }
.hub-chart-title { font-size: 0.78rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.1em; color: rgba(255,255,255,.5); margin-bottom: 1rem; }
.hub-chart-wrap { position: relative; height: 180px; display: flex; align-items: center; justify-content: center; }
.hub-chart-legend { display: flex; flex-wrap: wrap; gap: 0.4rem 0.9rem; margin-top: 0.85rem; }
.hub-legend-item { display: flex; align-items: center; gap: 0.35rem; font-size: 0.74rem; color: rgba(255,255,255,.55); }
.hub-legend-dot  { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }
.hub-legend-line { width: 20px; height: 2px; border-radius: 2px; flex-shrink: 0; }

/* ── Recent Card Drops — CARD GRID ───────────────────── */
.hub-section-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; }
.hub-section-title { font-size: 1.05rem; font-weight: 800; color: #fff !important;
  background: none !important; -webkit-text-fill-color: #fff !important; }
.hub-section-title .ac { color: var(--yellow); -webkit-text-fill-color: var(--yellow); }

/* View All button — modern */
.hub-viewall {
  position: relative; overflow: hidden;
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.35rem 0.9rem; border-radius: 8px; font-size: 0.76rem; font-weight: 700;
  background: rgba(255,220,80,.1); border: 1px solid rgba(255,220,80,.25);
  color: var(--yellow); text-decoration: none; transition: all 0.2s; }
.hub-viewall:hover { background: rgba(255,220,80,.18); border-color: rgba(255,220,80,.5);
  color: var(--yellow); text-decoration: none; box-shadow: 0 0 12px rgba(255,220,80,.15); }
.hub-viewall i { font-size: 0.72rem; transition: transform 0.2s; }
.hub-viewall:hover i { transform: translateX(3px); }

/* Drop card grid */
.hub-drop-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.75rem; margin-bottom: 2rem; }
.hub-drop-card {
  background: var(--g-bg); backdrop-filter: var(--g-blur-sm); -webkit-backdrop-filter: var(--g-blur-sm);
  border: 1px solid var(--g-border); border-radius: var(--radius-sm);
  padding: 1rem 1.1rem; display: flex; flex-direction: column; gap: 0.45rem;
  transition: all var(--transition); position: relative; overflow: hidden; }
.hub-drop-card:hover { transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(8,24,72,.35), var(--g-shine); }
.hub-drop-card.dc-mvp  { border-color: rgba(255,107,107,.2); }
.hub-drop-card.dc-mini { border-color: rgba(255,220,80,.2); }
.hub-drop-card.dc-reg  { border-color: rgba(70,226,251,.15); }
.hub-drop-card.dc-mvp:hover  { border-color: rgba(255,107,107,.4); box-shadow: 0 8px 28px rgba(255,107,107,.1), var(--g-shine); }
.hub-drop-card.dc-mini:hover { border-color: rgba(255,220,80,.4);  box-shadow: 0 8px 28px rgba(255,220,80,.1), var(--g-shine); }
.hub-drop-card.dc-reg:hover  { border-color: rgba(70,226,251,.3);  box-shadow: 0 8px 28px rgba(70,226,251,.08), var(--g-shine); }
/* Glow top-line */
.hub-drop-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  border-radius: var(--radius-sm) var(--radius-sm) 0 0; opacity: 0.6; }
.hub-drop-card.dc-mvp::before  { background: linear-gradient(90deg, transparent, #ff6b6b, transparent); }
.hub-drop-card.dc-mini::before { background: linear-gradient(90deg, transparent, var(--yellow), transparent); }
.hub-drop-card.dc-reg::before  { background: linear-gradient(90deg, transparent, var(--cyan), transparent); }

/* Card drop icon circle */
.hub-drop-icon-wrap { display: flex; align-items: center; justify-content: space-between; margin-bottom: 0.2rem; }
.hub-drop-icon { width: 36px; height: 36px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center; font-size: 0.9rem; flex-shrink: 0; }
.hub-drop-icon.di-mvp  { background: rgba(255,107,107,.15); color: #ff7675; border: 1px solid rgba(255,107,107,.25); }
.hub-drop-icon.di-mini { background: rgba(255,220,80,.12);  color: var(--yellow); border: 1px solid rgba(255,220,80,.25); }
.hub-drop-icon.di-reg  { background: rgba(70,226,251,.1);   color: var(--cyan);   border: 1px solid rgba(70,226,251,.2); }
.hub-drop-type { display: inline-block; padding: 0.1rem 0.45rem; border-radius: 99px;
  font-size: 0.65rem; font-weight: 800; letter-spacing: 0.04em; text-transform: uppercase; }
.hub-drop-type.dt-mvp  { background: rgba(255,107,107,.14); color: #ff7675; border: 1px solid rgba(255,107,107,.25); }
.hub-drop-type.dt-mini { background: rgba(255,220,80,.12);  color: var(--yellow); border: 1px solid rgba(255,220,80,.25); }
.hub-drop-type.dt-reg  { background: rgba(70,226,251,.1);   color: var(--cyan);   border: 1px solid rgba(70,226,251,.2); }

.hub-drop-name { font-size: 0.88rem; font-weight: 800; color: #fff; line-height: 1.2; }
.hub-drop-mob  { font-size: 0.73rem; color: rgba(255,255,255,.42); display: flex; align-items: center; gap: 0.3rem; }
.hub-drop-mob i { font-size: 0.65rem; }
.hub-drop-map  { font-size: 0.7rem; color: rgba(255,255,255,.28); }
.hub-drop-time { font-size: 0.68rem; color: rgba(255,255,255,.25); margin-top: auto; }

/* Empty state */
.hub-drop-empty { text-align: center; padding: 3rem 1rem; color: rgba(255,255,255,.28);
  background: var(--g-bg); border: 1px solid var(--g-border); border-radius: var(--radius);
  margin-bottom: 2rem; }
.hub-drop-empty i { display: block; font-size: 2rem; margin-bottom: 0.75rem; opacity: 0.25; }

/* ── Anti-inflation ───────────────────────────────────── */
.hub-inflate-wrap { margin-bottom: 2rem; }
.hub-inflate-head { text-align: center; margin-bottom: 1.5rem; }
.hub-inflate-head h3 { font-size: 1.15rem; font-weight: 800; color: #fff;
  background: none !important; -webkit-text-fill-color: #fff !important; }
.hub-inflate-head h3 span { color: var(--cyan); -webkit-text-fill-color: var(--cyan); }
.hub-measures { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.85rem; margin-bottom: 1.2rem; }
.hub-measure {
  background: var(--g-bg); backdrop-filter: var(--g-blur-sm); -webkit-backdrop-filter: var(--g-blur-sm);
  border: 1px solid var(--g-border); border-radius: var(--radius-sm);
  padding: 1.1rem 1.2rem; display: flex; align-items: flex-start; gap: 1rem; }
.hub-measure-icon-box {
  width: 40px; height: 40px; border-radius: 10px; flex-shrink: 0;
  background: rgba(70,226,251,.12); border: 1px solid rgba(70,226,251,.2);
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; color: var(--cyan); }
.hub-measure-name { font-size: 0.87rem; font-weight: 700; color: rgba(255,255,255,.9); margin-bottom: 0.2rem; }
.hub-measure-desc { font-size: 0.75rem; color: rgba(255,255,255,.38); line-height: 1.45; }
.hub-why-box { background: rgba(70,226,251,.04); border: 1px solid rgba(70,226,251,.14);
  border-radius: var(--radius-sm); padding: 1.2rem 1.5rem; margin-bottom: 2rem; }
.hub-why-box h4 { font-size: 0.84rem; font-weight: 800; color: var(--cyan); margin-bottom: 0.6rem; }
.hub-why-box p  { font-size: 0.82rem; color: rgba(255,255,255,.5); margin: 0 0 0.4rem; line-height: 1.6; }
.hub-why-box p:last-child { margin: 0; }

/* ── Detailed Logs Grid ───────────────────────────────── */
.hub-logs-head { font-size: 1.05rem; font-weight: 800; color: #fff !important;
  -webkit-text-fill-color: #fff !important; background: none !important; margin-bottom: 1.2rem; text-align: center; }
.hub-log-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.75rem; margin-bottom: 2rem; }
.hub-log-card {
  background: var(--g-bg); backdrop-filter: var(--g-blur-sm); -webkit-backdrop-filter: var(--g-blur-sm);
  border: 1px solid var(--g-border); border-radius: var(--radius-sm);
  padding: 1.25rem 1.3rem; display: flex; flex-direction: column; gap: 0.5rem;
  text-decoration: none; transition: all 0.22s ease; position: relative; overflow: hidden; }
.hub-log-card::after { content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 50% 0%, rgba(70,226,251,.06) 0%, transparent 65%);
  opacity: 0; transition: opacity 0.22s; pointer-events: none; }
.hub-log-card:hover { border-color: rgba(70,226,251,.4);
  box-shadow: 0 0 0 1px rgba(70,226,251,.1), 0 8px 28px rgba(8,24,72,.35);
  transform: translateY(-2px); text-decoration: none; }
.hub-log-card:hover::after { opacity: 1; }
.hub-log-card-icon { font-size: 1.2rem; color: rgba(255,255,255,.22);
  width: 42px; height: 42px; border-radius: 10px;
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.07);
  display: flex; align-items: center; justify-content: center;
  transition: all 0.22s; }
.hub-log-card:hover .hub-log-card-icon { background: rgba(70,226,251,.1); border-color: rgba(70,226,251,.2); color: var(--cyan); }
.hub-log-card-name { font-size: 0.9rem; font-weight: 700; color: rgba(255,255,255,.88); }
.hub-log-card-vis { font-size: 0.71rem; font-weight: 700; display: flex; align-items: center; gap: 0.3rem; }
.hub-log-card-vis.public     { color: #46fb78; }
.hub-log-card-vis.restricted { color: rgba(255,255,255,.3); }

/* Arrow decoration on log card */
.hub-log-card-arrow { position: absolute; right: 1rem; bottom: 1rem; font-size: 0.65rem;
  color: rgba(255,255,255,.15); transition: all 0.2s; }
.hub-log-card:hover .hub-log-card-arrow { color: var(--cyan); transform: translate(2px, -2px); }

/* Responsive */
@media (max-width: 960px) {
  .hub-stats    { grid-template-columns: repeat(2, 1fr); }
  .hub-charts   { grid-template-columns: 1fr 1fr; }
  .hub-measures { grid-template-columns: repeat(2, 1fr); }
  .hub-drop-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 680px) {
  .hub-charts   { grid-template-columns: 1fr; }
  .hub-log-grid { grid-template-columns: repeat(2, 1fr); }
  .hub-hero h1  { font-size: 2rem; }
}
@media (max-width: 480px) {
  .hub-stats    { grid-template-columns: 1fr 1fr; }
  .hub-measures { grid-template-columns: 1fr 1fr; }
  .hub-drop-grid { grid-template-columns: 1fr 1fr; }
  .hub-stat { flex-direction: column; text-align: center; }
}


/* hero uses shared lp-hero-section */
.tp-search { background: var(--g-bg); backdrop-filter: var(--g-blur); -webkit-backdrop-filter: var(--g-blur);
  border: 1px solid var(--g-border); box-shadow: var(--g-shine), var(--g-shadow);
  border-radius: var(--radius); padding: 1.5rem 2rem; margin-bottom: 2rem; }
.tp-search-row { display: flex; gap: 1rem; align-items: flex-end; flex-wrap: wrap; }
.tp-field { flex: 1; min-width: 180px; }
.tp-field label { display: block; color: var(--cyan); font-size: 0.8rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 0.4rem; }
.tp-field input[type=text] { width: 100%; padding: 0.6rem 1rem;
  background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.2);
  border-radius: var(--radius-sm); color: #fff; font-size: 0.95rem; outline: none;
  transition: border-color var(--transition); box-sizing: border-box; }
.tp-field input[type=text]:focus { border-color: var(--cyan); }
.tp-check { display: flex; align-items: center; gap: 0.5rem; color: rgba(255,255,255,0.7);
  font-size: 0.9rem; padding-bottom: 0.15rem; cursor: pointer; white-space: nowrap; }
.tp-check input[type=checkbox] { accent-color: var(--cyan); width: 16px; height: 16px; }
.tp-table-wrap { background: var(--g-bg); backdrop-filter: var(--g-blur); -webkit-backdrop-filter: var(--g-blur);
  border: 1px solid var(--g-border); box-shadow: var(--g-shine), var(--g-shadow);
  border-radius: var(--radius); overflow: hidden; }
.tp-table { width: 100%; border-collapse: collapse; }
.tp-table thead th { padding: 1rem 1.2rem; text-align: left; font-size: 0.78rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.08em; color: var(--cyan);
  background: rgba(70,226,251,0.06); border-bottom: 1px solid rgba(255,255,255,0.1); }
.tp-table thead th.center { text-align: center; }
.tp-table thead th.right { text-align: right; }
.tp-table tbody tr { border-bottom: 1px solid rgba(255,255,255,0.05);
  transition: background var(--transition); }
.tp-table tbody tr:last-child { border-bottom: none; }
.tp-table tbody tr:hover { background: rgba(70,226,251,0.04); }
.tp-table tbody td { padding: 0.8rem 1.2rem; font-size: 0.92rem; color: rgba(255,255,255,0.85); }
.tp-table tbody td.center { text-align: center; }
.tp-table tbody td.right { text-align: right; }
.tp-char-link { color: var(--cyan); text-decoration: none; font-weight: 600; }
.tp-char-link:hover { text-decoration: underline; }
.tp-lv { color: var(--yellow); font-weight: 700; }
.tp-jlv { color: rgba(255,255,255,0.6); }
.tp-guild { color: var(--blue); }
.tp-zeny { color: rgba(255,220,80,0.9); font-variant-numeric: tabular-nums; }
.tp-badge { display: inline-block; padding: 0.18rem 0.65rem; border-radius: 20px;
  font-size: 0.78rem; font-weight: 700; letter-spacing: 0.03em; }
.tp-badge.online  { background: rgba(70,251,120,0.14); color: #46fb78; border: 1px solid rgba(70,251,120,0.3); }
.tp-badge.offline { background: rgba(255,255,255,0.05); color: rgba(255,255,255,0.35); border: 1px solid rgba(255,255,255,0.1); }
.tp-pager { margin-top: 1.2rem; }
.tp-pager a, .tp-pager span { color: var(--cyan); }
.tp-empty { text-align: center; padding: 3rem 1rem; color: rgba(255,255,255,0.4); font-size: 1rem; }
.tp-info { color: rgba(255,255,255,0.45); font-size: 0.85rem; margin-bottom: 1rem; }
