/* TENDIES terminal — светлый Bloomberg-стиль, моно, острые углы */
:root {
  --bg: #eef0f3;
  --panel: #ffffff;
  --line: #d4d9df;
  --line2: #e6e9ed;
  --fg: #14181d;
  --dim: #6b7683;
  --green: #0a8f3c;
  --red: #cc2f2f;
  --amber: #ff6a00;
  --amber2: #ffb400;
  --dark: #16181c;
  --mono: ui-monospace, Menlo, Monaco, "Cascadia Mono", "SF Mono", Consolas, monospace;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html { color-scheme: light; }

body {
  background: var(--bg);
  color: var(--fg);
  font: 13px/1.5 var(--mono);
  font-variant-numeric: tabular-nums;
  -webkit-font-smoothing: antialiased;
  border-top: 3px solid var(--amber);
}

a { color: var(--fg); text-decoration: underline; text-decoration-color: var(--amber); text-underline-offset: 2px; }
a:hover { color: var(--amber); }

.dim { color: var(--dim); }
.green { color: var(--green); }
.red { color: var(--red); }
.r { text-align: right; }

/* ── бегущая лента тикеров (бесшовный цикл из двух одинаковых половин) ── */
.tape-wrap {
  background: var(--dark);
  border-bottom: 1px solid #000;
  overflow: hidden;
  white-space: nowrap;
}
.tape { padding: 5px 0; color: #cfd6de; }
.tape-inner {
  display: inline-flex;
  animation: marquee 55s linear infinite;
  will-change: transform;
}
.tape-wrap:hover .tape-inner { animation-play-state: paused; }
@keyframes marquee { to { transform: translateX(-50%); } }
.tape-half { display: inline-flex; }
.tape-set { display: inline-flex; }
.tape .tk { margin-right: 22px; cursor: pointer; }
.tape .tk:hover b { color: var(--amber2); }
.tape .tk b { color: #fff; margin-right: 6px; font-weight: 600; }
.tape .tk .green { color: #35d06b; }
.tape .tk .red { color: #ff6b5e; }

/* ── header ── */
.hdr {
  display: flex; justify-content: space-between; align-items: flex-end;
  padding: 16px 18px 12px;
  max-width: 1180px; margin: 0 auto;
}
.logo { font-size: 26px; font-weight: 700; letter-spacing: 1px; }
.logo .accent { color: var(--amber); }
.sub { color: var(--dim); margin-top: 2px; }
.hdr-right { text-align: right; }
.clock { font-size: 15px; }
.badges { margin-top: 4px; display: flex; gap: 6px; justify-content: flex-end; }
.badge {
  border: 1px solid var(--line); padding: 2px 8px; font-size: 11px;
  background: var(--panel); color: var(--dim);
}
.badge.on { border-color: var(--green); color: var(--green); }
.badge.off { border-color: var(--amber); color: var(--amber); }
.soc {
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px; border: 1px solid var(--line); background: var(--panel);
}
.soc img { width: 13px; height: 13px; display: block; }
.soc:hover { border-color: var(--fg); }
.soc.soon { opacity: .35; pointer-events: none; }

main { max-width: 1180px; margin: 0 auto; padding: 0 18px 24px; }

/* ── stats ── */
.stats {
  display: grid; grid-template-columns: repeat(4, 1fr) 1.6fr; gap: 8px;
  margin-bottom: 10px;
}
.stat { background: var(--panel); border: 1px solid var(--line); padding: 10px 12px; }
.stat-k { color: var(--dim); font-size: 11px; text-transform: uppercase; letter-spacing: .4px; }
.stat-v { font-size: 19px; margin-top: 3px; }
.stat .unit { font-size: 12px; color: var(--dim); }
.bar { height: 10px; border: 1px solid var(--line); margin-top: 9px; background: var(--line2); }
.bar-fill { height: 100%; width: 0; background: var(--amber); transition: width .6s; }

/* ── panels ── */
.cols { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 10px; }
.panel { background: var(--panel); border: 1px solid var(--line); display: flex; flex-direction: column; min-width: 0; }
.panel-title {
  background: var(--dark); color: var(--amber2);
  font-size: 11px; letter-spacing: .8px; text-transform: uppercase;
  padding: 6px 10px;
  display: flex; align-items: center; gap: 8px;
}
.panel-note { color: #8b95a1; text-transform: none; letter-spacing: 0; margin-left: auto; }

.scroll { overflow-y: auto; }
.scroll-tall { max-height: 380px; }
.scroll-mid { max-height: 240px; }

/* ── tables ── */
.tbl { width: 100%; border-collapse: collapse; }
.tbl th {
  text-align: left; color: var(--dim); font-weight: 400; font-size: 11px;
  padding: 6px 10px; border-bottom: 1px solid var(--line);
  position: sticky; top: 0; background: var(--panel); z-index: 1;
}
.tbl th.r { text-align: right; }
.tbl td { padding: 6px 10px; border-bottom: 1px solid var(--line2); vertical-align: middle; }
.tbl tr:hover td { background: #f5f7f9; }
.tbl .empty { color: var(--dim); text-align: center; padding: 24px 0; }

.sym-cell { display: flex; align-items: center; gap: 8px; font-weight: 600; }
.slogo { width: 18px; height: 18px; object-fit: contain; display: block; }

.delta { font-size: 12px; }

/* кнопки */
.btn {
  font: 11px var(--mono); letter-spacing: .5px;
  border: 1px solid var(--fg); background: var(--panel); color: var(--fg);
  padding: 3px 9px; cursor: pointer; text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 5px; text-decoration: none;
}
.btn:hover { background: var(--dark); color: #fff; }
.btn:hover img { filter: invert(1); }
.btn img { width: 12px; height: 12px; display: block; }
.btn.amber { border-color: var(--amber); color: var(--amber); }
.btn.amber:hover { background: var(--amber); color: #fff; }
.actions { display: flex; gap: 6px; justify-content: flex-end; }

.kind { font-size: 11px; padding: 1px 6px; border: 1px solid; }
.kind.holder { color: var(--green); border-color: var(--green); }
.kind.twitter { color: #1d7fc4; border-color: #1d7fc4; }

.st { font-size: 11px; padding: 1px 6px; border: 1px solid var(--line); color: var(--dim); }
.st.eligible { color: var(--green); border-color: var(--green); }
.st.paid { color: #fff; background: var(--green); border-color: var(--green); }
.st.rejected { color: var(--red); border-color: var(--red); }

/* ── how it works: простой список шагов ── */
.how { padding-bottom: 8px; }
.blue { color: #1d7fc4; }
.steps { padding: 12px 14px 10px; }
.step { padding: 4px 0; font-size: 12.5px; color: #2c343d; }
.step-n { color: var(--amber); font-weight: 700; margin-right: 12px; }
.step-note { border-top: 1px solid var(--line2); margin-top: 8px; padding-top: 9px; font-size: 11.5px; }

/* ── footer ── */
.ftr { max-width: 1180px; margin: 0 auto; padding: 4px 18px 26px; }
.ftr-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.addr { word-break: break-all; }
.ftr-note { margin-top: 6px; font-size: 11px; }

/* ── modal chart ── */
.modal-back {
  position: fixed; inset: 0; background: rgba(20, 24, 29, .45);
  display: none; align-items: center; justify-content: center; z-index: 50;
}
.modal-back.open { display: flex; }
.modal {
  background: var(--panel); border: 1px solid var(--dark);
  width: min(860px, calc(100vw - 32px));
  box-shadow: 0 12px 40px rgba(0,0,0,.25);
}
.modal-hdr {
  background: var(--dark); color: #fff;
  display: flex; align-items: center; gap: 10px; padding: 8px 12px;
}
.modal-hdr .slogo { width: 20px; height: 20px; background: #fff; padding: 2px; }
.modal-hdr .m-sym { font-weight: 700; letter-spacing: .5px; }
.modal-hdr .m-name { color: #9aa5b1; }
.modal-hdr .m-price { margin-left: auto; font-size: 16px; color: var(--amber2); }
.m-close {
  background: none; border: none; color: #fff; font: 18px var(--mono);
  cursor: pointer; padding: 0 2px 0 10px;
}
.m-close:hover { color: var(--amber); }
.modal-body { padding: 12px; }
.m-tools { display: flex; gap: 6px; margin-bottom: 10px; align-items: center; }
.m-range.active { background: var(--dark); color: #fff; }
.m-meta { margin-left: auto; color: var(--dim); font-size: 11.5px; }
.m-foot { display: flex; gap: 8px; margin-top: 10px; }

/* ── страница акции ── */
.home-link { text-decoration: none; color: var(--fg); }
.sym-link { text-decoration: none; color: var(--fg); }
.sym-link:hover { color: var(--amber); }
.stock-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px; margin-bottom: 10px; flex-wrap: wrap; gap: 12px;
}
.stock-id { display: flex; align-items: center; gap: 14px; }
.slogo-big { width: 40px; height: 40px; object-fit: contain; }
.stock-sym { font-size: 24px; font-weight: 700; letter-spacing: .5px; }
.stock-price { margin-left: 18px; text-align: right; }
.stock-price .stat-v { font-size: 26px; }
.stock-links { display: flex; gap: 6px; }
.chart-box { padding: 12px; }
.chart-box .m-tools { margin-bottom: 10px; }
#chart { width: 100%; height: 320px; display: block; border: 1px solid var(--line2); cursor: crosshair; }
.stat .dim { font-size: 11px; margin-top: 2px; }

/* ── launchpad ── */
.lform { padding: 12px 14px; display: flex; flex-direction: column; gap: 10px; }
.lform label { display: flex; flex-direction: column; gap: 4px; font-size: 11px; color: var(--dim); text-transform: uppercase; letter-spacing: .4px; flex: 1; }
.lform input, .lform textarea {
  font: 13px var(--mono); color: var(--fg);
  border: 1px solid var(--line); background: #fafbfc; padding: 7px 9px; outline: none;
}
.lform textarea { resize: none; }
.lform input:focus, .lform textarea:focus { border-color: var(--amber); }
.lform input[type="file"] { padding: 5px; }
.lform input[type="file"]::file-selector-button {
  font: 11px var(--mono); text-transform: uppercase; letter-spacing: .5px;
  border: 1px solid var(--fg); background: var(--panel); color: var(--fg);
  padding: 4px 10px; margin-right: 10px; cursor: pointer;
}
.lform input[type="file"]::file-selector-button:hover { background: var(--dark); color: #fff; }
.lrow2 { display: flex; gap: 10px; }
.lstocks-label { font-size: 11px; color: var(--dim); text-transform: uppercase; letter-spacing: .4px; }
.lstocks { display: flex; flex-wrap: wrap; gap: 6px; }
.chip {
  font: 12px var(--mono); display: inline-flex; align-items: center; gap: 6px;
  border: 1px solid var(--line); background: var(--panel); color: var(--fg);
  padding: 5px 10px; cursor: pointer;
}
.chip img { width: 14px; height: 14px; }
.chip:hover { border-color: var(--fg); }
.chip.on { border-color: var(--amber); background: #fff4ec; }
.chip.mini { padding: 2px 7px; font-size: 11px; cursor: default; margin: 1px 0; }
.chip.mini img { width: 12px; height: 12px; }
.chip.mini:hover { border-color: var(--line); }
.lsubmit { padding: 9px; font-size: 13px; justify-content: center; }
.lsubmit:disabled { opacity: .45; cursor: default; pointer-events: none; }
.llog { display: flex; flex-direction: column; gap: 2px; max-height: 160px; overflow-y: auto; }
.llog-line { font-size: 12px; }
.llog-btns { display: flex; gap: 6px; margin-top: 8px; flex-wrap: wrap; }

/* мини-инструкция твиттер-команды (панель X ENTRIES) */
.tw-howto { padding: 9px 10px; border-bottom: 1px solid var(--line); font-size: 12px; display: flex; flex-direction: column; gap: 3px; }
.tw-howto .dim { font-size: 11px; }
.tw-cmd {
  font-weight: 600; background: #fff4ec; border: 1px solid var(--amber);
  color: var(--amber); padding: 1px 6px; white-space: nowrap;
}

/* распределение купленных акций (страница лонча) */
.dist { padding: 10px 14px; display: flex; flex-direction: column; gap: 7px; }
.dist-row { display: flex; align-items: center; gap: 8px; }
.dist-sym { display: flex; align-items: center; gap: 6px; width: 84px; font-weight: 600; flex: none; }
.dist-sym img { width: 15px; height: 15px; object-fit: contain; }
.dist-bar { display: block; flex: 1; height: 9px; border: 1px solid var(--line); background: var(--line2); }
.dist-fill { display: block; height: 100%; background: var(--amber); }
.dist-amt { width: 130px; text-align: right; flex: none; font-size: 12px; }
.dist-pct { width: 44px; text-align: right; flex: none; color: var(--dim); font-size: 11px; }

@media (max-width: 900px) {
  .stats { grid-template-columns: repeat(2, 1fr); }
  .stat-wide { grid-column: span 2; }
  .cols, .how-cols { grid-template-columns: 1fr; }
}
