/* ==========================================================================
   netts.io — Terminal page kit
   /css/terminal.css
   Shared typography + layout primitives for services / team / token / market
   Paired with chrome.css (nav + footer).
   ========================================================================== */

:root{
  --tm-blue:#2d4bdb;
  --tm-blue-hover:#3e68ff;
  --tm-blue-soft:#eef1ff;
  --tm-ink:#0b1020;
  --tm-ink-soft:#1a2240;
  --tm-text:#3a4366;
  --tm-text-soft:#5c6690;
  --tm-muted:#8892b8;
  --tm-line:#e2e6f2;
  --tm-line-soft:#eef0f7;
  --tm-bg:#f7f8fc;
  --tm-bg-white:#ffffff;
  --tm-panel:#fbfcff;

  --tm-green:#00a86b;
  --tm-amber:#d98a00;
  --tm-red:#d93838;

  --tm-radius:12px;
  --tm-radius-sm:8px;
  --tm-radius-lg:16px;

  --tm-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  --tm-font:"Urbanist","Inter",system-ui,-apple-system,Arial,sans-serif;

  --tm-page-max:1440px;
  --tm-page-pad:28px;
}

/* ------- base -------- */
body.tm-body{
  margin:0;
  background:var(--tm-bg);
  color:var(--tm-ink);
  font-family:var(--tm-font);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
.tm-body *{box-sizing:border-box}

/* subtle grid backdrop behind everything */
.tm-body::before{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;
  z-index:0;
  background-image:
    linear-gradient(rgba(45,75,219,.035) 1px,transparent 1px),
    linear-gradient(90deg,rgba(45,75,219,.035) 1px,transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse at 50% 0%,#000 30%,transparent 85%);
  -webkit-mask-image:radial-gradient(ellipse at 50% 0%,#000 30%,transparent 85%);
}
.tm-body > *{position:relative;z-index:1}

/* ------- page shell -------- */
.tm-page{
  max-width:var(--tm-page-max);
  margin:0 auto;
  padding:32px var(--tm-page-pad) 80px;
}
.tm-page--narrow{max-width:1200px}

/* ------- mono helpers -------- */
.tm-mono{font-family:var(--tm-mono);font-variant-numeric:tabular-nums}
.tm-caps{text-transform:uppercase;letter-spacing:.12em;font-family:var(--tm-mono);font-size:11px;font-weight:700}

/* ------- terminal window shell -------- */
.tm-win{
  background:var(--tm-bg-white);
  border:1px solid var(--tm-line);
  border-radius:var(--tm-radius-lg);
  overflow:hidden;
  box-shadow:0 1px 0 rgba(11,16,32,.02),0 30px 60px -40px rgba(11,16,32,.12);
}
.tm-win__bar{
  display:flex;align-items:center;gap:14px;
  padding:10px 16px;
  background:var(--tm-bg);
  border-bottom:1px solid var(--tm-line);
  font-family:var(--tm-mono);
  font-size:12px;
  color:var(--tm-text-soft);
}
.tm-win__dots{display:flex;gap:6px}
.tm-win__dots span{width:11px;height:11px;border-radius:50%;background:var(--tm-line);display:inline-block}
.tm-win__dots span:nth-child(1){background:#ff5f56}
.tm-win__dots span:nth-child(2){background:#ffbd2e}
.tm-win__dots span:nth-child(3){background:#27c93f}
.tm-win__title{color:var(--tm-text);font-weight:600}
.tm-win__path{color:var(--tm-muted)}
.tm-win__meta{margin-left:auto;color:var(--tm-muted);font-size:11px;letter-spacing:.08em;text-transform:uppercase}
.tm-win__body{padding:28px 32px}
.tm-win__body--pad-lg{padding:44px 48px}
.tm-win__body--pad-sm{padding:20px 24px}
.tm-win__body--flush{padding:0}

/* tabs along the window top */
.tm-tabs{
  display:flex;
  border-bottom:1px solid var(--tm-line);
  background:var(--tm-bg);
  font-family:var(--tm-mono);
  font-size:12px;
  overflow-x:auto;
}
.tm-tab{
  padding:10px 18px;
  color:var(--tm-muted);
  border-right:1px solid var(--tm-line);
  cursor:default;
  white-space:nowrap;
  display:inline-flex;align-items:center;gap:8px;
}
.tm-tab.on{background:var(--tm-bg-white);color:var(--tm-ink);position:relative}
.tm-tab.on::before{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:var(--tm-blue)}
.tm-tab .dot{width:6px;height:6px;border-radius:50%;background:var(--tm-muted)}
.tm-tab.on .dot{background:var(--tm-blue)}

/* ------- hero block (common to all terminal pages) -------- */
.tm-hero{display:grid;grid-template-columns:1.2fr 1fr;gap:0}
.tm-hero__left{padding:48px 48px 40px;border-right:1px solid var(--tm-line)}
.tm-hero__right{padding:32px 40px;background:var(--tm-bg);display:flex;flex-direction:column;gap:16px}

.tm-prompt{
  font-family:var(--tm-mono);
  font-size:13px;
  color:var(--tm-text-soft);
  margin-bottom:20px;
  display:flex;align-items:center;gap:8px;
}
.tm-prompt .chev{color:var(--tm-blue);font-weight:700}
.tm-prompt .cursor{
  display:inline-block;width:8px;height:14px;background:var(--tm-blue);
  margin-left:2px;vertical-align:-2px;
  animation:tm-blink 1.1s steps(2,start) infinite;
}
@keyframes tm-blink{to{visibility:hidden}}

.tm-title{
  font-size:clamp(36px,4.2vw,56px);
  font-weight:800;
  letter-spacing:-.02em;
  line-height:1.05;
  margin:0 0 18px;
  color:var(--tm-ink);
}
.tm-title em{font-style:normal;color:var(--tm-blue)}
.tm-lede{
  font-size:17px;
  line-height:1.6;
  color:var(--tm-text);
  margin:0 0 24px;
  max-width:60ch;
}

.tm-cta{display:flex;gap:10px;flex-wrap:wrap}
.tm-btn{
  display:inline-flex;align-items:center;gap:8px;
  white-space:nowrap;
  padding:11px 18px;
  border-radius:var(--tm-radius-sm);
  font-family:var(--tm-mono);
  font-size:13px;font-weight:600;
  border:1px solid var(--tm-line);
  background:var(--tm-bg-white);
  color:var(--tm-ink);
  cursor:pointer;
  transition:all .15s;
  text-decoration:none;
}
.tm-btn:hover{border-color:var(--tm-blue);color:var(--tm-blue)}
.tm-btn--primary{background:var(--tm-ink);color:#fff;border-color:var(--tm-ink)}
.tm-btn--primary:hover{background:var(--tm-blue);border-color:var(--tm-blue);color:#fff}
.tm-btn i.bi{font-size:13px;opacity:.8}

/* hero stats (right column) */
.tm-stat-list{display:flex;flex-direction:column;gap:0;font-family:var(--tm-mono);font-size:13px}
.tm-stat-row{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:14px 0;
  border-bottom:1px dashed var(--tm-line);
}
.tm-stat-row:last-child{border-bottom:0}
.tm-stat-row .k{color:var(--tm-text-soft);letter-spacing:.04em}
.tm-stat-row .v{color:var(--tm-ink);font-weight:700;font-size:15px;white-space:nowrap}
.tm-stat-row .v .unit{color:var(--tm-muted);font-weight:500;font-size:12px;margin-left:3px}

/* ------- section header -------- */
.tm-section{margin-top:48px}
.tm-section-head{
  display:flex;align-items:baseline;gap:14px;
  margin:0 0 18px;
  padding:0 4px;
}
.tm-section-head .idx{
  font-family:var(--tm-mono);
  font-size:12px;
  color:var(--tm-muted);
  letter-spacing:.06em;
}
.tm-section-head h2{
  margin:0;
  flex:1 1 auto;
  white-space:nowrap;
  font-size:26px;
  font-weight:700;
  color:var(--tm-ink);
  letter-spacing:-.01em;
}
.tm-section-head .note{
  margin-left:auto;
  font-family:var(--tm-mono);
  font-size:12px;
  color:var(--tm-muted);
}

/* ------- panels -------- */
.tm-panel{
  background:var(--tm-bg-white);
  border:1px solid var(--tm-line);
  border-radius:var(--tm-radius);
  padding:24px;
}
.tm-panel__label{
  font-family:var(--tm-mono);
  font-size:11px;
  color:var(--tm-muted);
  text-transform:uppercase;
  letter-spacing:.12em;
  margin-bottom:8px;
  display:flex;align-items:center;gap:8px;
}
.tm-panel__label .dot{width:7px;height:7px;border-radius:50%;background:var(--tm-blue)}
.tm-panel__label .dot--g{background:var(--tm-green)}
.tm-panel__label .dot--a{background:var(--tm-amber)}
.tm-panel__title{
  font-size:19px;font-weight:700;color:var(--tm-ink);
  margin:0 0 8px;letter-spacing:-.01em;
}
.tm-panel__desc{
  color:var(--tm-text);line-height:1.55;margin:0 0 16px;font-size:14px;
}

/* list with check marks, in mono, for features */
.tm-list{list-style:none;padding:0;margin:0;font-family:var(--tm-mono);font-size:13px;line-height:1.8}
.tm-list li{display:flex;align-items:flex-start;gap:10px;color:var(--tm-text);padding:4px 0}
.tm-list li::before{
  content:"✓";
  color:var(--tm-green);
  font-weight:700;
  flex-shrink:0;
  width:16px;
}
.tm-list li strong{color:var(--tm-ink);font-weight:700}

/* key-value metadata block */
.tm-kv{font-family:var(--tm-mono);font-size:12.5px;line-height:1.9}
.tm-kv .row{display:flex;gap:12px;padding:5px 0;border-bottom:1px dashed var(--tm-line-soft)}
.tm-kv .row:last-child{border-bottom:0}
.tm-kv .k{color:var(--tm-muted);width:140px;flex-shrink:0}
.tm-kv .v{color:var(--tm-ink);flex:1;word-break:break-word}

/* tag pill */
.tm-tag{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 9px;
  font-family:var(--tm-mono);font-size:11px;font-weight:600;
  color:var(--tm-text);
  background:var(--tm-bg);
  border:1px solid var(--tm-line);
  border-radius:6px;
  letter-spacing:.04em;
}
.tm-tag--blue{background:var(--tm-blue-soft);color:var(--tm-blue);border-color:rgba(45,75,219,.2)}
.tm-tag--green{background:#e8f7f0;color:#0a7c52;border-color:rgba(0,168,107,.25)}
.tm-tag--amber{background:#fff5e1;color:#8a5a00;border-color:rgba(217,138,0,.3)}

/* ------- code block -------- */
.tm-code{
  background:var(--tm-ink);
  color:#c6d0ff;
  border-radius:var(--tm-radius);
  font-family:var(--tm-mono);
  font-size:13px;
  line-height:1.65;
  overflow:hidden;
}
.tm-code__head{
  padding:8px 14px;
  background:#060915;
  border-bottom:1px solid rgba(255,255,255,.08);
  color:#8892b8;
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  display:flex;align-items:center;gap:10px;
}
.tm-code__body{padding:18px 20px;overflow-x:auto;margin:0;white-space:pre}
.tm-code .c-com{color:#5c6690}
.tm-code .c-key{color:#7a96ff}
.tm-code .c-str{color:#7fe3a6}
.tm-code .c-fn{color:#ffbe5a}
.tm-code .c-var{color:#e9edff}
.tm-code .c-num{color:#f78c6c}

/* ------- table (terminal grid) -------- */
.tm-table{
  width:100%;
  border-collapse:separate;border-spacing:0;
  font-family:var(--tm-mono);
  font-size:13px;
  background:var(--tm-bg-white);
  border:1px solid var(--tm-line);
  border-radius:var(--tm-radius);
  overflow:hidden;
}
.tm-table th,.tm-table td{
  padding:12px 16px;text-align:left;
  border-bottom:1px solid var(--tm-line-soft);
  vertical-align:top;
}
.tm-table thead th{
  background:var(--tm-bg);
  color:var(--tm-text-soft);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:11px;
}
.tm-table tbody tr:last-child td{border-bottom:0}
.tm-table tbody tr:hover{background:var(--tm-bg)}
.tm-table td:first-child,.tm-table th:first-child{color:var(--tm-ink);font-weight:600}
.tm-table .yes{color:var(--tm-green)}
.tm-table .no{color:var(--tm-red)}
.tm-table .neutral{color:var(--tm-muted)}

/* ------- sidebar filetree -------- */
.tm-tree{
  font-family:var(--tm-mono);
  font-size:12.5px;
  padding:8px 0;
  background:var(--tm-bg);
  border-right:1px solid var(--tm-line);
  min-width:220px;
}
.tm-tree__group{padding:14px 16px 4px;color:var(--tm-muted);font-size:10.5px;text-transform:uppercase;letter-spacing:.12em}
.tm-tree__item{
  display:flex;align-items:center;gap:8px;
  padding:6px 16px;
  color:var(--tm-text);
  cursor:pointer;
  border-left:2px solid transparent;
  white-space:nowrap;
}
.tm-tree__item:hover{background:var(--tm-bg-white);color:var(--tm-ink)}
.tm-tree__item.on{background:var(--tm-bg-white);color:var(--tm-ink);border-left-color:var(--tm-blue);font-weight:600}
.tm-tree__item i.bi{font-size:12px;opacity:.7;width:14px;text-align:center}
.tm-tree__item.on i.bi{color:var(--tm-blue);opacity:1}
.tm-tree__item .badge{
  margin-left:auto;font-size:10px;
  background:var(--tm-line);color:var(--tm-text-soft);
  padding:1px 6px;border-radius:4px;
}

/* ------- status indicators -------- */
.tm-status{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--tm-mono);font-size:11px;font-weight:600;
  color:var(--tm-green);
  letter-spacing:.04em;text-transform:uppercase;
}
.tm-status .led{
  width:8px;height:8px;border-radius:50%;
  background:var(--tm-green);
  box-shadow:0 0 0 2px rgba(0,168,107,.15);
  animation:tm-pulse 2s ease-in-out infinite;
}
@keyframes tm-pulse{
  0%,100%{opacity:1}
  50%{opacity:.4}
}
.tm-status--amber{color:var(--tm-amber)}
.tm-status--amber .led{background:var(--tm-amber);box-shadow:0 0 0 2px rgba(217,138,0,.15)}
.tm-status--muted{color:var(--tm-muted)}
.tm-status--muted .led{background:var(--tm-muted);box-shadow:none;animation:none}

/* ------- grid helpers -------- */
.tm-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.tm-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tm-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.tm-grid-side{display:grid;grid-template-columns:220px 1fr;gap:0}

/* responsive */
@media (max-width:1100px){
  .tm-hero{grid-template-columns:1fr}
  .tm-hero__left{border-right:0;border-bottom:1px solid var(--tm-line);padding:36px 32px 32px}
  .tm-hero__right{padding:24px 32px}
  .tm-grid-4{grid-template-columns:repeat(2,1fr)}
  .tm-grid-3{grid-template-columns:1fr 1fr}
  .tm-grid-side{grid-template-columns:1fr}
  .tm-tree{border-right:0;border-bottom:1px solid var(--tm-line)}
  .tm-win__body{padding:22px}
  .tm-win__body--pad-lg{padding:30px}
}
@media (max-width:720px){
  :root{--tm-page-pad:16px}
  .tm-title{font-size:30px}
  .tm-hero__left{padding:28px 20px}
  .tm-hero__right{padding:20px}
  .tm-grid-2,.tm-grid-3,.tm-grid-4{grid-template-columns:1fr}
  .tm-kv .k{width:110px}
}
