/* TGE / STO — page styles */
@import url("colors_and_type.css");

/* Hero — TGE dashboard */
.tg-dash {
  background: linear-gradient(180deg, rgba(15,21,48,0.96), rgba(8,12,28,0.96));
  border: 1px solid rgba(255,176,32,0.32);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 24px 64px rgba(0,0,0,0.6), 0 0 80px rgba(255,176,32,0.14);
}
.tg-dash-bar { display: flex; justify-content: space-between; align-items: center; padding: 14px 18px; border-bottom: 1px solid rgba(255,255,255,0.06); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.16em; }
.tg-dash-label { display: flex; align-items: center; gap: 8px; color: var(--site-text); font-weight: 600; }
.tg-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--site-amber); box-shadow: 0 0 0 3px rgba(255,176,32,0.2); }

.tg-kpi-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: rgba(255,255,255,0.06); border-bottom: 1px solid rgba(255,255,255,0.06); }
.tg-kpi { padding: 18px 20px; background: rgba(8,12,28,0.6); }
.tg-kpi-l { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.16em; color: var(--site-text-3); text-transform: uppercase; }
.tg-kpi-v { font-family: var(--font-mono); font-size: 26px; font-weight: 600; color: var(--site-text); margin: 4px 0 2px; letter-spacing: -0.01em; }
.tg-kpi-d { font-family: var(--font-mono); font-size: 11px; color: var(--site-mint); }

.tg-stage { padding: 18px 20px; border-bottom: 1px solid rgba(255,255,255,0.06); }
.tg-stage-l { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; color: var(--site-text-3); text-transform: uppercase; margin-bottom: 12px; }
.tg-stage-bar { position: relative; height: 8px; background: rgba(255,255,255,0.08); border-radius: 99px; margin-bottom: 28px; }
.tg-stage-fill { height: 100%; background: linear-gradient(90deg, #FFB020, #5EFFA4); border-radius: 99px; box-shadow: 0 0 12px rgba(255,176,32,0.4); }
.tg-stage-mark { position: absolute; top: -3px; transform: translateX(-50%); width: 14px; height: 14px; border-radius: 50%; background: rgba(8,12,28,0.95); border: 2px solid rgba(255,255,255,0.4); }
.tg-stage-mark span { position: absolute; top: 18px; left: 50%; transform: translateX(-50%); font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.14em; color: var(--site-text-3); white-space: nowrap; }
.tg-stage-meta { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 11px; color: var(--site-text-2); }

.tg-tx-list { padding: 12px 18px 16px; }
.tg-tx-head { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; color: var(--site-text-3); margin-bottom: 10px; text-transform: uppercase; }
.tg-tx-counter { color: var(--site-cyan); }
.tg-tx { display: grid; grid-template-columns: 1fr auto auto; gap: 12px; padding: 8px 10px; border-radius: 8px; align-items: center; transition: background 0.3s ease; font-family: var(--font-mono); font-size: 12px; }
.tg-tx.is-live { background: rgba(255,176,32,0.06); }
.tg-tx-addr { color: var(--site-text-2); }
.tg-tx-amt { color: var(--site-text); font-weight: 600; }
.tg-tx-sym { font-size: 10px; color: var(--site-text-3); margin-left: 4px; }
.tg-tx-state { font-size: 9px; letter-spacing: 0.14em; padding: 3px 7px; border-radius: 4px; }
.tg-state-confirmed { color: var(--site-mint); border: 1px solid rgba(94,255,164,0.3); background: rgba(94,255,164,0.06); }
.tg-state-whitelisted { color: var(--site-amber); border: 1px solid rgba(255,176,32,0.3); background: rgba(255,176,32,0.06); }

/* Dual panel */
.tg-dual-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 48px; }
.tg-panel { padding: 28px; border: 1px solid rgba(255,255,255,0.08); background: linear-gradient(180deg, rgba(15,21,48,0.6), rgba(15,21,48,0.25)); border-radius: 16px; }
.tg-panel-investor { border-left: 3px solid rgba(79,200,255,0.4); }
.tg-panel-admin { border-left: 3px solid rgba(255,176,32,0.4); }
.tg-panel-bar { display: flex; justify-content: space-between; align-items: center; padding-bottom: 16px; border-bottom: 1px solid rgba(255,255,255,0.06); margin-bottom: 18px; }
.tg-panel-tag { padding: 4px 10px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.1); border-radius: 4px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; color: var(--site-text-2); }
.tg-panel-meta { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; color: var(--site-text-3); }
.tg-panel-h { font-family: var(--font-display); font-weight: 600; font-size: 22px; color: var(--site-text); letter-spacing: -0.01em; margin-bottom: 8px; }
.tg-panel-d { font-size: 13px; color: var(--site-text-3); line-height: 1.55; margin-bottom: 18px; }
.tg-panel-items { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 8px 14px; }
.tg-panel-items li { display: flex; gap: 10px; align-items: baseline; font-size: 12.5px; color: var(--site-text-2); }
.tg-panel-num { font-family: var(--font-mono); font-size: 10px; color: var(--site-cyan); flex-shrink: 0; }

/* Process rail */
.tg-process-rail { display: grid; grid-template-columns: repeat(9, 1fr); gap: 4px; margin-top: 48px; align-items: stretch; }
.tg-process-step { position: relative; padding: 22px 14px 16px; border: 1px solid rgba(255,255,255,0.07); background: rgba(15,21,48,0.4); border-radius: 12px; }
.tg-process-n { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; color: var(--site-amber); margin-bottom: 10px; font-weight: 600; }
.tg-process-t { font-weight: 600; font-size: 13px; color: var(--site-text); margin-bottom: 6px; line-height: 1.3; }
.tg-process-d { font-size: 11px; color: var(--site-text-3); line-height: 1.5; }
.tg-process-arrow { position: absolute; right: -16px; top: 50%; transform: translateY(-50%); color: rgba(255,176,32,0.5); font-size: 14px; z-index: 2; }

@media (max-width: 1100px) {
  .cx-hero-visual { margin: 0 auto; }
  .tg-dual-grid { grid-template-columns: 1fr; }
  .tg-panel-items { grid-template-columns: 1fr; }
  .tg-process-rail { grid-template-columns: repeat(3, 1fr); gap: 8px; }
  .tg-process-arrow { display: none; }
}
@media (max-width: 700px) {
  .tg-process-rail { grid-template-columns: 1fr; }
}
