﻿/* Topic-specific styles moved out of topics/shared/generic-topic.css. */
.lc2-slots {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin: 12px 0;
  padding-top: 28px;
  border-top: 4px solid rgba(76, 131, 240, 0.42);
}

.lc2-slot {
  min-height: 104px;
  padding: 10px;
  border: 1px solid rgba(190, 202, 222, 0.86);
  border-radius: 14px;
  background: linear-gradient(180deg, #fff, #f7faff);
}

.lc2-slot strong {
  display: block;
  margin-bottom: 8px;
  color: #4c83f0;
  font-weight: 950;
  text-align: center;
}

.lc2-slot span {
  display: grid;
  place-items: center;
  min-height: 52px;
}

.lc-case-visual div i[style*="width"] {
  display: block;
  height: 14px;
  min-width: 8px;
  border-radius: 999px;
}

.lc2-plates,
.lc2-scoreboard {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 10px;
  align-items: center;
}

.lc2-plates b,
.lc2-scoreboard b {
  display: grid;
  place-items: center;
  min-height: 56px;
  border-radius: 999px;
  color: #fff;
  background: #4c83f0;
}

.lc2-plates b:last-child,
.lc2-scoreboard b:last-child {
  background: #e25442;
}

.lc2-scoreboard span {
  font-weight: 950;
}

.lc2-queue,
.lc2-building,
.lc2-boxes {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.lc2-queue i,
.lc2-building i,
.lc2-boxes i {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 7px;
  color: #667085;
  font-style: normal;
  font-size: 0.72rem;
  font-weight: 900;
  background: #e6edf8;
}

.lc2-queue i.is-on,
.lc2-building i.is-a {
  color: #fff;
  background: #4c83f0;
}

.lc2-building i.is-b {
  color: #fff;
  background: #e25442;
}

.lc2-track {
  position: relative;
  height: 54px;
  border-bottom: 5px solid #98a2b3;
}

.lc2-track span {
  position: absolute;
  bottom: -17px;
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  color: #fff;
  font-weight: 950;
  background: #4c83f0;
}

.lc2-track span:last-child {
  background: #e25442;
}

.lc2-rulers {
  display: flex;
  align-items: end;
  gap: 16px;
  height: 110px;
}

.lc2-rulers i {
  width: 44px;
  border-radius: 10px 10px 4px 4px;
  background: #4c83f0;
}

.lc2-rulers i:last-child {
  background: #e25442;
}

.lc2-boxes i {
  border: 2px solid #98a2b3;
  background: #fff;
}

.lc2-boxes i.toy {
  background: #4c83f0;
}

.lc2-station-route {
  position: relative;
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 4px;
  align-items: center;
  min-height: 72px;
}

.lc2-station-route::before {
  content: "";
  position: absolute;
  left: 16px;
  right: 16px;
  top: 50%;
  height: 6px;
  border-radius: 999px;
  background: #d0d9ea;
}

.lc2-station-route i {
  z-index: 1;
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  margin: auto;
  border: 3px solid #fff;
  border-radius: 999px;
  color: #667085;
  background: #98a2b3;
  font-style: normal;
  font-weight: 900;
}

.lc2-station-route i.is-between {
  background: #d7e5fb;
}

.lc2-station-route i.is-a {
  color: #fff;
  background: #4c83f0;
}

.lc2-station-route i.is-b {
  color: #fff;
  background: #e25442;
}

.lc2-calendar {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 4px;
}

.lc2-calendar i {
  display: grid;
  place-items: center;
  min-height: 22px;
  border-radius: 6px;
  color: #667085;
  background: rgba(102, 112, 133, 0.08);
  font-style: normal;
  font-size: 0.72rem;
  font-weight: 900;
}

.lc2-calendar i.is-a {
  color: #fff;
  background: #4c83f0;
}

.lc2-calendar i.is-b {
  color: #fff;
  background: #e25442;
}

.lc2-pages {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 10px;
  align-items: center;
  min-height: 92px;
}

.lc2-pages section {
  display: grid;
  place-items: center;
  min-width: 62px;
  padding: 8px;
  border-radius: 10px;
  background: #fff;
}

.lc2-pages section b {
  color: #4c83f0;
  font-size: 1.5rem;
}

.lc2-pages section:last-child b {
  color: #e25442;
}

.lc2-pages section span {
  color: #667085;
  font-size: 0.7rem;
  font-weight: 900;
}

.lc2-pages div {
  position: relative;
  min-height: 76px;
}

.lc2-pages div i {
  position: absolute;
  left: calc(12px + var(--turn) * 8px);
  top: calc(8px + var(--turn) * 3px);
  width: 54px;
  height: 64px;
  transform: rotate(calc(var(--turn) * -2deg));
  border: 1px solid rgba(120, 139, 168, 0.28);
  border-radius: 5px;
  background: #fff;
  box-shadow: 0 8px 16px rgba(36, 54, 84, 0.08);
}

.lc2-pages div i.is-past {
  background: #edf4ff;
}

