/**
 * CMP Fleet Board — dark "control room" live status board.
 * Mirrors frontend-v1/src/components/sections/PrintFloor.tsx + tokens.css.
 * Mobile-first; breakpoints at 768px / 1024px. Reused theme utilities
 * (.cmp-section, .cmp-container, .cmp-eyebrow, .cmp-h2, .cmp-tick-frame,
 * .cmp-hairline) are NOT redefined here — only fleet-specific layout/skin.
 *
 * Handle: cmp-w-cmp-fleet-board (auto-registered; loaded via get_style_depends()).
 */

.cmp-fleet {
	position: relative;
	overflow: hidden;
	background-color: #0E0D0C;
	color: #f5f1ec;
}

/* Faint build-plate scan grid, masked toward the top-right corner. */
.cmp-fleet__scangrid {
	position: absolute;
	inset: 0;
	pointer-events: none;
	opacity: 0.5;
	background-image:
		linear-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.03) 1px, transparent 1px);
	background-size: 32px 32px;
	-webkit-mask-image: radial-gradient(120% 90% at 80% 0%, #000 35%, transparent 78%);
	mask-image: radial-gradient(120% 90% at 80% 0%, #000 35%, transparent 78%);
}

/* Top / bottom seam rules that seal the band. */
.cmp-fleet__seam {
	position: absolute;
	left: 0;
	right: 0;
	height: 1px;
	background-color: rgba(255, 255, 255, 0.10);
	pointer-events: none;
}
.cmp-fleet__seam--top { top: 0; }
.cmp-fleet__seam--bottom { bottom: 0; }

.cmp-fleet__container {
	position: relative;
	z-index: 1;
}

/* ── Header rail ────────────────────────────────────────────────────────── */
.cmp-fleet__header {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	align-items: end;
}

.cmp-fleet__eyebrow { color: #ff8038; }

.cmp-fleet__title {
	color: #f7f3ee;
	max-width: 15ch;
}

.cmp-fleet__intro {
	margin-top: 1.25rem;
	max-width: 44ch;
	font-size: 0.95rem;
	line-height: 1.625;
	color: #a59c92;
}

/* Oversized mono ONLINE readout. */
.cmp-fleet__online {
	display: inline-flex;
	flex-direction: column;
}

.cmp-fleet__online-nums {
	display: flex;
	align-items: baseline;
	gap: 0.5rem;
	font-family: var(--font-mono);
	font-variant-numeric: tabular-nums;
	line-height: 1;
}

.cmp-fleet__online-avail {
	font-size: clamp(3.5rem, 9vw, 6.5rem);
	font-weight: 700;
	color: var(--green);
}

.cmp-fleet__online-sep {
	font-size: clamp(2rem, 4.5vw, 3.2rem);
	font-weight: 300;
	color: rgba(255, 255, 255, 0.35);
}

.cmp-fleet__online-total {
	font-size: clamp(2rem, 4.5vw, 3.2rem);
	font-weight: 700;
	color: rgba(255, 255, 255, 0.55);
}

.cmp-fleet__online-label {
	margin-top: 0.5rem;
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-family: var(--font-mono);
	font-size: 0.7rem;
	text-transform: uppercase;
	letter-spacing: 0.22em;
	color: #a59c92;
}

.cmp-fleet__rule {
	height: 1px;
	width: 100%;
	margin: 2.25rem 0;
	background-color: rgba(255, 255, 255, 0.10);
}

/* ── Main grid: hero cell + status board ────────────────────────────────── */
.cmp-fleet__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
}

/* ── Hero printer cell ──────────────────────────────────────────────────── */
.cmp-fleet__hero {
	position: relative;
	overflow: hidden;
	border-radius: var(--r-md);
	border: 1px solid rgba(255, 255, 255, 0.10);
	background-color: #121110;
	padding: 1.5rem;
}

.cmp-fleet__hero-head {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1rem;
}

.cmp-fleet__hero-node {
	font-family: var(--font-mono);
	font-size: 0.66rem;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: #a59c92;
}

.cmp-fleet__hero-name {
	margin: 0.25rem 0 0;
	font-family: var(--font-display);
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.1;
	color: #f7f3ee;
}

/* Tech tag (shared FDM / Resin pill). */
.cmp-fleet__tech-tag {
	flex-shrink: 0;
	border-radius: var(--r-xs);
	border: 1px solid rgba(255, 255, 255, 0.15);
	padding: 0.25rem 0.5rem;
	font-family: var(--font-mono);
	font-size: 0.62rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: #cabfb3;
	white-space: nowrap;
}

.cmp-fleet__tech-tag--sm {
	font-size: 0.58rem;
	padding: 0.125rem 0.375rem;
	color: #a59c92;
	border-color: rgba(255, 255, 255, 0.12);
}

.cmp-fleet__hero-status {
	margin-top: 1.5rem;
}

/* Status chips. */
.cmp-fleet__chip {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	border-radius: var(--r-pill);
	padding: 0.375rem 0.75rem;
	font-family: var(--font-mono);
	font-size: 0.72rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.cmp-fleet__chip--printing {
	color: var(--blue);
	border: 1px solid color-mix(in srgb, var(--blue) 45%, transparent);
	background-color: color-mix(in srgb, var(--blue) 14%, transparent);
}

.cmp-fleet__chip--available {
	color: var(--green);
	border: 1px solid color-mix(in srgb, var(--green) 45%, transparent);
	background-color: color-mix(in srgb, var(--green) 14%, transparent);
}

.cmp-fleet__chip-inline {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	font-family: var(--font-mono);
	font-size: 0.64rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.cmp-fleet__chip-inline.cmp-fleet__chip--available {
	color: var(--green);
	border: 0;
	background: transparent;
	padding: 0;
}

.cmp-fleet__chip-inline.cmp-fleet__chip--printing {
	color: var(--blue);
	border: 0;
	background: transparent;
	padding: 0;
}

/* Status dots + animated ping. */
.cmp-fleet__dot--blue,
.cmp-fleet__dot--green {
	width: 0.375rem;
	height: 0.375rem;
	border-radius: 9999px;
	flex-shrink: 0;
}
.cmp-fleet__dot--blue { background-color: var(--blue); }
.cmp-fleet__dot--green { background-color: var(--green); }

.cmp-fleet__ping {
	position: relative;
	display: inline-flex;
	width: 0.375rem;
	height: 0.375rem;
	flex-shrink: 0;
}

.cmp-fleet__ping::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: 9999px;
	background-color: var(--green);
	opacity: 0.7;
	animation: cmp-fleet-ping 1s cubic-bezier(0, 0, 0.2, 1) infinite;
}

.cmp-fleet__ping::after {
	content: "";
	position: relative;
	display: inline-flex;
	width: 0.375rem;
	height: 0.375rem;
	border-radius: 9999px;
	background-color: var(--green);
}

@keyframes cmp-fleet-ping {
	75%, 100% {
		transform: scale(2);
		opacity: 0;
	}
}

@media (prefers-reduced-motion: reduce) {
	.cmp-fleet__ping::before { animation: none; }
}

/* Hero progress block. */
.cmp-fleet__hero-progress { margin-top: 1.75rem; }

.cmp-fleet__hero-progress-top {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 1rem;
	font-family: var(--font-mono);
	font-variant-numeric: tabular-nums;
}

.cmp-fleet__hero-pct {
	font-size: 3rem;
	font-weight: 700;
	line-height: 1;
	color: #f7f3ee;
}

.cmp-fleet__hero-pct-sign {
	font-size: 1.2rem;
	color: #a59c92;
}

.cmp-fleet__hero-queue {
	font-size: 0.7rem;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: #a59c92;
}

/* Progress bars. */
.cmp-fleet__bar {
	margin-top: 0.75rem;
	height: 0.375rem;
	width: 100%;
	overflow: hidden;
	border-radius: 9999px;
	background-color: rgba(255, 255, 255, 0.08);
}

.cmp-fleet__bar--sm {
	height: 0.25rem;
	width: 8rem;
	max-width: 40vw;
	margin-top: 0;
}

.cmp-fleet__bar-fill {
	height: 100%;
	border-radius: 9999px;
}
.cmp-fleet__bar-fill--printing { background-color: var(--blue); }
.cmp-fleet__bar-fill--available { background-color: var(--green); }

.cmp-fleet__hero-hair { margin-top: 1.75rem; }

/* Hero spec footer. */
.cmp-fleet__specs {
	margin-top: 1.25rem;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
	font-family: var(--font-mono);
	font-size: 0.62rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: #a59c92;
}

.cmp-fleet__spec-label { color: rgba(255, 255, 255, 0.40); }

.cmp-fleet__spec-value {
	margin-top: 0.25rem;
	font-size: 0.74rem;
	color: #cabfb3;
}

/* ── Status board ───────────────────────────────────────────────────────── */
.cmp-fleet__board {
	overflow: hidden;
	border-radius: var(--r-md);
	border: 1px solid rgba(255, 255, 255, 0.10);
	background-color: #0F0E0D;
}

.cmp-fleet__board-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	border-bottom: 1px solid rgba(255, 255, 255, 0.10);
	padding: 0.75rem 1.25rem;
	font-family: var(--font-mono);
	font-size: 0.62rem;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: rgba(255, 255, 255, 0.35);
}

.cmp-fleet__rows > .cmp-fleet__row + .cmp-fleet__row {
	border-top: 1px solid rgba(255, 255, 255, 0.07);
}

.cmp-fleet__row {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 1rem 1.25rem;
	transition: background-color 0.2s ease;
}

.cmp-fleet__row:hover {
	background-color: rgba(255, 255, 255, 0.03);
}

.cmp-fleet__row-idx {
	width: 2rem;
	flex-shrink: 0;
	font-family: var(--font-mono);
	font-variant-numeric: tabular-nums;
	font-size: 0.7rem;
	color: rgba(255, 255, 255, 0.25);
}

.cmp-fleet__row-main {
	min-width: 0;
	flex: 1;
}

.cmp-fleet__row-title {
	display: flex;
	align-items: center;
	gap: 0.625rem;
}

.cmp-fleet__row-name {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	font-family: var(--font-display);
	font-size: 1rem;
	font-weight: 600;
	color: #f0ebe5;
}

.cmp-fleet__row-prog {
	margin-top: 0.5rem;
	display: flex;
	align-items: center;
	gap: 0.625rem;
}

.cmp-fleet__row-pct {
	font-family: var(--font-mono);
	font-variant-numeric: tabular-nums;
	font-size: 0.62rem;
	color: #a59c92;
}

.cmp-fleet__row-idle {
	margin-top: 0.5rem;
	font-family: var(--font-mono);
	font-size: 0.6rem;
	text-transform: uppercase;
	letter-spacing: 0.16em;
	color: rgba(255, 255, 255, 0.25);
}

.cmp-fleet__row-status {
	display: flex;
	flex-shrink: 0;
	flex-direction: column;
	align-items: flex-end;
	gap: 0.375rem;
}

.cmp-fleet__row-queue {
	font-family: var(--font-mono);
	font-size: 0.6rem;
	text-transform: uppercase;
	letter-spacing: 0.16em;
	color: rgba(255, 255, 255, 0.30);
}

.cmp-fleet__board-foot {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	border-top: 1px solid rgba(255, 255, 255, 0.10);
	padding: 0.75rem 1.25rem;
	font-family: var(--font-mono);
	font-size: 0.6rem;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: rgba(255, 255, 255, 0.30);
}

.cmp-fleet__board-ready {
	color: color-mix(in srgb, var(--green) 70%, transparent);
}

/* ── Tablet ─────────────────────────────────────────────────────────────── */
@media (min-width: 768px) {
	.cmp-fleet__hero { padding: 1.75rem; }
}

/* ── Desktop: asymmetric 12-col header + 5/7 main grid ──────────────────── */
@media (min-width: 1024px) {
	.cmp-fleet__header {
		grid-template-columns: repeat(12, 1fr);
		column-gap: 2rem;
	}
	.cmp-fleet__intro-col { grid-column: span 7; }
	.cmp-fleet__online {
		grid-column: span 5;
		justify-self: end;
	}
	.cmp-fleet__online-label { justify-content: flex-end; }

	.cmp-fleet__grid {
		grid-template-columns: repeat(12, 1fr);
	}
	.cmp-fleet__hero { grid-column: span 5; }
	.cmp-fleet__board { grid-column: span 7; }
}
