/* ETHERSEA · Trade */

.page-trade .deck { padding: 120px 56px 80px; max-width: 1440px; margin: 0 auto; }

.trade-wrap {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 56px;
  align-items: start;
}
.page-title {
  font-size: clamp(56px, 7vw, 104px);
  margin: 8px 0 18px;
  line-height: 0.94;
  letter-spacing: 0.02em;
  color: var(--chart);
}
.lede {
  font-size: 16px;
  line-height: 1.55;
  color: var(--chart-dim);
  max-width: 58ch;
  margin-bottom: 36px;
}

.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 14px;
}
.field {
  display: block;
  border: 1px solid var(--hairline-strong);
  background: rgba(5,10,20,0.65);
  padding: 14px 18px;
}
.field .lbl {
  display: block;
  font-size: 10px;
  letter-spacing: 0.22em;
  color: var(--chart-dim);
  margin-bottom: 8px;
}
.field .control {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: 12px;
}
.field input {
  flex: 1;
  background: transparent;
  border: 0;
  color: var(--beacon);
  font-family: var(--captain);
  font-variant: small-caps;
  font-size: 38px;
  letter-spacing: 0.02em;
  width: 100%;
  outline: none;
}
.field .sym {
  color: var(--chart-dim);
  font-size: 11px;
  letter-spacing: 0.2em;
}

.receipt {
  grid-column: span 2;
  border: 1px solid var(--hairline-strong);
  background: rgba(5,10,20,0.65);
  padding: 20px 22px;
}
.receipt h4 {
  font-family: var(--captain);
  font-variant: small-caps;
  font-size: 20px;
  margin: 0 0 12px;
  color: var(--chart);
  letter-spacing: 0.03em;
}
.receipt .kv {
  grid-template-columns: 160px 1fr 160px 1fr;
  gap: 10px 14px;
}
.receipt dd { color: var(--beacon); }
.actions { grid-column: span 2; display: flex; gap: 10px; }
.warn {
  grid-column: span 2;
  color: var(--rust);
  font-size: 11px;
  letter-spacing: 0.16em;
}

.right { display: flex; flex-direction: column; gap: 20px; align-items: stretch; }
.dial-wrap {
  position: relative;
  aspect-ratio: 1;
  width: 100%;
}
.dial-wrap canvas {
  width: 100%; height: 100%;
  display: block;
  cursor: grab;
}
.dial-wrap canvas:active { cursor: grabbing; }
.dial-meta {
  position: absolute;
  inset: 38% 28% auto 28%;
  text-align: center;
  pointer-events: none;
}
.eng-cycle {
  font-size: 9px;
  letter-spacing: 0.28em;
  color: var(--sonar);
  margin-bottom: 6px;
}
.bell-cur {
  font-family: var(--captain);
  font-variant: small-caps;
  font-style: italic;
  font-size: clamp(20px, 2.6vw, 28px);
  color: var(--beacon);
  letter-spacing: 0.04em;
  text-shadow: 0 0 14px rgba(232,197,72,0.2);
}
.depth-cur {
  font-size: 11px;
  letter-spacing: 0.2em;
  color: var(--chart-dim);
  margin-top: 4px;
}

.bell-list {
  list-style: none; padding: 0; margin: 0;
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0;
  font-size: 9px;
  letter-spacing: 0.14em;
  color: var(--chart-dim);
  border-top: 1px solid var(--hairline-strong);
  border-bottom: 1px solid var(--hairline-strong);
}
.bell-list li {
  padding: 10px 8px;
  border-right: 1px solid var(--hairline);
  text-align: center;
  cursor: pointer;
  transition: background 0.15s;
  text-transform: uppercase;
}
.bell-list li:last-child { border-right: 0; }
.bell-list li:hover { color: var(--chart); background: rgba(45,200,210,0.04); }
.bell-list li.active { color: var(--abyss); background: var(--beacon); }

/* Routing */
.routing { margin-top: 100px; padding-bottom: 60px; }
.routing > header { margin-bottom: 28px; }
.routing > header h2 { font-size: clamp(36px,4vw,52px); margin: 4px 0 0; color: var(--chart); }
.route-steps {
  list-style: none; padding: 0; margin: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--hairline-strong);
}
.route-steps li {
  padding: 28px 28px 28px 0;
  border-right: 1px solid var(--hairline);
}
.route-steps li:last-child { border-right: 0; }
.route-steps li:not(:first-child) { padding-left: 28px; }
.route-steps .num {
  display: block;
  font-size: 11px;
  letter-spacing: 0.24em;
  color: var(--sonar);
  margin-bottom: 16px;
}
.route-steps h3 {
  font-family: var(--captain);
  font-variant: small-caps;
  font-size: 22px;
  margin: 0 0 10px;
  color: var(--chart);
  letter-spacing: 0.03em;
}
.route-steps p { margin: 0; color: var(--chart-dim); line-height: 1.55; font-size: 14.5px; }

@media (max-width: 1100px) {
  .trade-wrap { grid-template-columns: 1fr; }
  .route-steps { grid-template-columns: 1fr; }
  .bell-list { grid-template-columns: 1fr 1fr; }
}
