/* ===========================================================
   OGRE — MAINTAIN pillar (bespoke)
   Theme: Fleet Uptime & Operational Excellence.
   Feeling: operations center, monitoring, uptime, control.
   Builds on pillar-redesign.css primitives.
   =========================================================== */

/* ---- Vendor showcase: anchor the orange glow behind the heading so it frames
   the Module 04 eyebrow + headline instead of floating in empty space ---- */
.mnt-vendor-showcase::before {
  top: -16%;
  left: -10%;
  right: auto;
  width: 760px;
  height: 760px;
}

/* ---- Hero: live ops dashboard panel ---- */
.mnt-ops { padding: 20px; display: flex; flex-direction: column; gap: 14px; }
.mnt-ops-status { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.mnt-stat { border: 1px solid var(--border-muted-light); border-radius: 10px; padding: 12px 12px 13px; text-align: left; }
.mnt-stat .v { font-family: 'Satoshi', sans-serif; font-weight: 900; font-size: 22px; line-height: 1; letter-spacing: -0.03em; color: var(--px-ink); }
.mnt-stat .l { font-family: 'Hanken Grotesk', sans-serif; font-size: 8.5px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--px-muted); margin-top: 7px; }
.mnt-stat.ok .v { color: var(--px-ok); }
.mnt-stat.warn .v { color: var(--px-warn); }
.mnt-stat.bad .v { color: var(--orange); }

.mnt-ops-bar { border: 1px solid var(--border-muted-light); border-radius: 11px; padding: 15px 16px; }
.mnt-ops-bar-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.mnt-ops-bar-head .t { font-family: 'Hanken Grotesk', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--px-muted); }
.mnt-ops-bar-head .p { font-family: 'Satoshi', sans-serif; font-weight: 900; font-size: 18px; letter-spacing: -0.03em; color: var(--px-ink); }
.mnt-ops-bar-head .p small { color: var(--orange); font-size: 12px; }
.mnt-ops-meter { height: 9px; border-radius: 6px; background: var(--bg-subtle-gray); overflow: hidden; }
.mnt-ops-meter span { display: block; height: 100%; border-radius: 6px; background: linear-gradient(90deg, var(--px-ok), #34B36A); }

.mnt-ops-feed { display: flex; flex-direction: column; gap: 0; }
.mnt-feed-row { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 12px; padding: 10px 2px; border-bottom: 1px solid var(--border-muted-light); }
.mnt-feed-row:last-child { border-bottom: none; }
.mnt-feed-ic { width: 26px; height: 26px; border-radius: 7px; display: grid; place-items: center; flex-shrink: 0; }
.mnt-feed-ic svg { width: 14px; height: 14px; }
.mnt-feed-ic.ok { background: var(--px-ok-bg); color: var(--px-ok); }
.mnt-feed-ic.warn { background: var(--px-warn-bg); color: var(--px-warn); }
.mnt-feed-ic.info { background: var(--px-info-bg); color: var(--px-info); }
.mnt-feed-txt { font-size: 12.5px; color: var(--px-ink); }
.mnt-feed-txt span { display: block; font-family: 'Hanken Grotesk', sans-serif; font-size: 10px; color: var(--px-muted); margin-top: 2px; }
.mnt-feed-time { font-family: 'Hanken Grotesk', sans-serif; font-size: 10px; color: var(--px-muted); white-space: nowrap; }

/* ===========================================================
   Section 1 — compliance dashboard (full) + caps
   =========================================================== */
.mnt-dash { display: grid; grid-template-columns: 220px 1fr 1fr; min-height: 320px; }
@media (max-width: 880px) { .mnt-dash { grid-template-columns: 1fr; } .mnt-dash .px-side { display: none; } }
.mnt-dash-col { padding: 22px 24px; border-right: 1px solid var(--border-muted-light); }
.mnt-dash-col:last-child { border-right: none; }
.mnt-dash-h { font-family: 'Satoshi', sans-serif; font-weight: 900; font-size: 16px; letter-spacing: -0.02em; color: var(--px-ink); margin-bottom: 16px; }
.mnt-donut-wrap { display: flex; align-items: center; gap: 18px; margin-bottom: 18px; }
.mnt-donut { width: 92px; height: 92px; border-radius: 50%; background: conic-gradient(var(--px-ok) 0% 99%, var(--bg-subtle-gray) 99% 100%); display: grid; place-items: center; position: relative; flex-shrink: 0; }
.mnt-donut::after { content: ''; position: absolute; inset: 11px; border-radius: 50%; background: var(--bg-pure-white); }
.mnt-donut-v { position: relative; z-index: 1; font-family: 'Satoshi', sans-serif; font-weight: 900; font-size: 21px; letter-spacing: -0.03em; color: var(--px-ink); }
.mnt-donut-v small { font-size: 12px; color: var(--px-ok); }
.mnt-donut-cap .t { font-size: 13px; font-weight: 600; color: var(--px-ink); }
.mnt-donut-cap .s { font-size: 12px; color: var(--px-slate); margin-top: 4px; line-height: 1.4; }
.mnt-dash-row { display: flex; align-items: center; justify-content: space-between; padding: 11px 0; border-bottom: 1px solid var(--border-muted-light); font-size: 13px; color: var(--px-slate); }
.mnt-dash-row:last-child { border-bottom: none; }
.mnt-dash-row .dv { font-family: 'Hanken Grotesk', sans-serif; font-size: 12px; color: var(--px-ink); }

/* ===========================================================
   Section 1 — asset compliance record (replaces donut dash)
   =========================================================== */
.mnt-asset { background: var(--bg-pure-white); }
.mnt-asset-head { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 22px 26px; border-bottom: 1px solid var(--border-muted-light); flex-wrap: wrap; }
.mnt-asset-id { display: flex; align-items: center; gap: 16px; }
.mnt-asset-reg {
  font-family: 'Satoshi', sans-serif; font-weight: 900; font-size: 19px; letter-spacing: 0.04em;
  color: #1B2130; background: #F4C430; border: 1px solid #d9ad1f; border-radius: 7px; padding: 9px 16px; white-space: nowrap;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.4);
}
.mnt-asset-id .meta .nm { font-family: 'Satoshi', sans-serif; font-weight: 700; font-size: 14px; color: var(--px-ink); }
.mnt-asset-id .meta .sub { font-family: 'Hanken Grotesk', sans-serif; font-size: 11px; color: var(--px-muted); margin-top: 3px; }
.mnt-asset-status { display: flex; align-items: stretch; gap: 0; }
.mnt-asset-status .st { padding: 0 18px; display: flex; flex-direction: column; gap: 4px; border-left: 1px solid var(--border-muted-light); }
.mnt-asset-status .st:first-child { border-left: none; }
.mnt-asset-status .st .l { font-family: 'Hanken Grotesk', sans-serif; font-size: 9.5px; font-weight: 600; letter-spacing: 0.07em; text-transform: uppercase; color: var(--px-muted); }
.mnt-asset-status .st .v { font-family: 'Satoshi', sans-serif; font-weight: 700; font-size: 14px; color: var(--px-ink); display: flex; align-items: center; gap: 6px; }
.mnt-asset-status .st .v.ok::before { content: ''; width: 8px; height: 8px; border-radius: 50%; background: var(--px-ok); }

.mnt-asset-tabs { display: flex; align-items: center; gap: 24px; padding: 0 26px; border-bottom: 1px solid var(--border-muted-light); overflow-x: auto; -ms-overflow-style: none; scrollbar-width: none; }
.mnt-asset-tabs::-webkit-scrollbar { display: none; }
.mnt-asset-tabs span { font-family: 'Hanken Grotesk', sans-serif; font-size: 12.5px; font-weight: 600; color: var(--px-muted); padding: 15px 0 13px; white-space: nowrap; border-bottom: 2px solid transparent; }
.mnt-asset-tabs span.active { color: var(--orange); border-bottom-color: var(--orange); }

/* Two-tier compliance: stat cards + supporting detail row */
.mnt-comp { padding: 24px 26px 26px; }
.mnt-comp-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.mnt-comp-stat {
  background: var(--bg-pure-white);
  border: 1px solid var(--border-muted-light);
  border-radius: 14px;
  padding: 20px 22px 22px;
}
.mnt-comp-stat-top { display: flex; align-items: center; justify-content: space-between; gap: 12px; min-height: 24px; }
.mnt-comp-stat-top .lbl { font-family: 'Hanken Grotesk', sans-serif; font-size: 10.5px; font-weight: 700; letter-spacing: 0.09em; text-transform: uppercase; color: var(--px-muted); white-space: nowrap; }
.mnt-comp-stat .val { font-family: 'Satoshi', sans-serif; font-weight: 900; font-size: 28px; letter-spacing: -0.02em; color: var(--px-ink); margin-top: 14px; line-height: 1; }
.mnt-comp-badge { display: inline-flex; align-items: center; gap: 6px; background: var(--px-ok-bg); color: var(--px-ok); border-radius: 100px; padding: 4px 11px 4px 9px; font-family: 'Hanken Grotesk', sans-serif; font-size: 10.5px; font-weight: 700; letter-spacing: 0.02em; }
.mnt-comp-badge::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: var(--px-ok); }

.mnt-comp-details { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 12px; }
.mnt-comp-detail { display: flex; flex-direction: column; gap: 6px; padding: 14px 18px; background: var(--bg-subtle-gray); border-radius: 11px; }
.mnt-comp-detail .lbl { font-family: 'Hanken Grotesk', sans-serif; font-size: 9.5px; font-weight: 700; letter-spacing: 0.09em; text-transform: uppercase; color: var(--px-muted); }
.mnt-comp-detail .val { font-family: 'Hanken Grotesk', sans-serif; font-size: 14px; font-weight: 600; color: var(--px-ink); }
.mnt-comp-detail .val.link { color: var(--px-info); }
@media (max-width: 760px) { .mnt-comp-stats, .mnt-comp-details { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .mnt-comp-stats, .mnt-comp-details { grid-template-columns: 1fr; } }

/* Inline customer / depot / mileage line beneath the asset header */
.mnt-asset-subline {
  font-family: 'Hanken Grotesk', sans-serif; font-size: 12.5px; font-weight: 500;
  color: var(--px-muted); padding: 12px 26px; border-bottom: 1px solid var(--border-muted-light);
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.mnt-asset-subline span { color: var(--border-muted); opacity: 0.7; }

/* Bottom crop: console content bleeds off naturally below the 2nd event row */
.px-console.px-crop {
  max-height: 588px;
  overflow: hidden;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}

.mnt-asset-events { padding: 20px 26px 24px; }
.mnt-asset-events-head { display: flex; align-items: center; gap: 14px; margin-bottom: 14px; flex-wrap: wrap; }
.mnt-asset-events-head h4 { font-family: 'Satoshi', sans-serif; font-weight: 900; font-size: 15px; letter-spacing: -0.01em; color: var(--px-ink); margin: 0; white-space: nowrap; }
.mnt-asset-events-head .acts { margin-left: auto; display: flex; align-items: center; gap: 16px; }
.mnt-asset-events-head .acts span { font-family: 'Hanken Grotesk', sans-serif; font-size: 11px; font-weight: 600; color: var(--px-muted); display: flex; align-items: center; gap: 6px; }
.mnt-asset-events-head .acts svg { width: 13px; height: 13px; }
.mnt-asset-table-wrap { overflow-x: auto; border: 1px solid var(--border-muted-light); border-radius: 11px; }
.mnt-asset-table { width: 100%; border-collapse: collapse; min-width: 640px; }
.mnt-asset-table thead th { background: var(--bg-subtle-gray); text-align: left; font-family: 'Hanken Grotesk', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; color: var(--px-muted); padding: 12px 14px; white-space: nowrap; }
.mnt-asset-table tbody td { font-family: 'Hanken Grotesk', sans-serif; font-size: 13px; color: var(--px-slate); padding: 14px 14px; border-top: 1px solid var(--border-muted-light); white-space: nowrap; }
.mnt-asset-table tbody td .ev { display: flex; align-items: center; gap: 9px; font-weight: 600; color: var(--px-ink); }
.mnt-asset-table tbody td .ev .ic { width: 24px; height: 24px; border-radius: 7px; display: grid; place-items: center; flex-shrink: 0; background: var(--orange-tint); color: var(--orange); }
.mnt-asset-table tbody td .ev .ic svg { width: 13px; height: 13px; }
.mnt-asset-table tbody td .due { font-weight: 700; color: var(--px-ink); }
.mnt-asset-status-chip { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; padding: 5px 11px; border-radius: 100px; }
.mnt-asset-status-chip.unbooked { background: var(--px-warn-bg); color: var(--px-warn); }
.mnt-asset-status-chip.booked { background: var(--px-info-bg); color: var(--px-info); }

/* ===========================================================
   Section 2 — vertical compliance monitoring timeline
   =========================================================== */
.mnt-vtimeline { position: relative; max-width: 760px; margin: 0 auto; padding-left: 40px; }
.mnt-vtimeline::before { content: ''; position: absolute; left: 23px; top: 8px; bottom: 8px; width: 2px; transform: translateX(-50%); background: var(--border-muted-light); }
.mnt-event { position: relative; padding: 0 0 34px 28px; }
.mnt-event:last-child { padding-bottom: 0; }
.mnt-event::before {
  content: ''; position: absolute; left: -33px; top: 2px; width: 32px; height: 32px; border-radius: 9px;
  background: var(--bg-pure-white); border: 1px solid var(--border-muted-light); z-index: 1;
}
.mnt-event-ic { position: absolute; left: -25px; top: 9px; z-index: 2; color: var(--orange); }
.mnt-event-ic svg { width: 16px; height: 16px; display: block; }
.mnt-event-card {
  background: var(--bg-pure-white); border: 1px solid var(--border-muted-light); border-radius: 13px;
  padding: 18px 22px; transition: transform .4s cubic-bezier(0.16,1,0.3,1), box-shadow .4s ease, border-color .4s ease;
}
.mnt-event-card:hover { transform: translateX(5px); border-color: rgba(233,78,27,0.28); box-shadow: 0 22px 44px -28px rgba(27,36,48,0.3); }
.mnt-event-top { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 8px; }
.mnt-event-type { font-family: 'Hanken Grotesk', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--orange); }
.mnt-event-date { font-family: 'Hanken Grotesk', sans-serif; font-size: 11px; color: var(--px-muted); }
.mnt-event-card h3 { font-family: 'Satoshi', sans-serif; font-weight: 700; font-size: 17px; letter-spacing: -0.015em; color: var(--px-ink); margin: 0 0 6px; line-height: 1.25; }
.mnt-event-card p { font-size: 13.5px; line-height: 1.55; color: var(--px-slate); margin: 0; }

/* ===========================================================
   Section 5 — field ops mobile devices
   =========================================================== */
.mnt-mobile { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 5vw, 72px); align-items: center; }
@media (max-width: 920px) { .mnt-mobile { grid-template-columns: 1fr; gap: 48px; } }
.mnt-phones { display: flex; gap: 26px; justify-content: center; align-items: flex-start; }
.mnt-phone-img {
  display: block; width: clamp(212px, 21vw, 262px); height: auto; flex-shrink: 0;
  filter: drop-shadow(0 28px 56px rgba(0,0,0,0.14)) drop-shadow(0 10px 24px rgba(27,36,48,0.10));
}
.mnt-phone-img-2 { margin-top: 40px; }
@media (max-width: 920px) { .mnt-phone-img { width: clamp(190px, 30vw, 250px); } }
@media (max-width: 560px) { .mnt-phones { gap: 14px; } .mnt-phone-img { width: 150px; } .mnt-phone-img-2 { margin-top: 22px; } }
.mnt-phone {
  width: 248px; flex-shrink: 0; border-radius: 38px; background: #0B0C10; padding: 11px;
  box-shadow: 0 50px 90px -40px rgba(0,0,0,0.55), 0 18px 40px -28px rgba(27,36,48,0.4);
  position: relative;
}
.mnt-phone:nth-child(2) { margin-top: 36px; }
.mnt-phone-screen { border-radius: 29px; overflow: hidden; background: var(--bg-light); position: relative; }
.mnt-phone-notch { position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 96px; height: 22px; background: #0B0C10; border-radius: 0 0 14px 14px; z-index: 5; }
.mnt-phone-status { display: flex; align-items: center; justify-content: space-between; padding: 9px 18px 7px; font-family: 'Hanken Grotesk', sans-serif; font-size: 9px; color: var(--px-muted); }
.mnt-app-head { padding: 6px 16px 14px; border-bottom: 1px solid var(--border-muted-light); }
.mnt-app-head .a { font-family: 'Hanken Grotesk', sans-serif; font-size: 9px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--orange); }
.mnt-app-head .b { font-family: 'Satoshi', sans-serif; font-weight: 900; font-size: 17px; letter-spacing: -0.02em; color: var(--px-ink); margin-top: 4px; }
.mnt-app-body { padding: 14px 16px 20px; display: flex; flex-direction: column; gap: 10px; }
.mnt-app-search { display: flex; align-items: center; gap: 8px; padding: 9px 12px; border: 1px solid var(--border-muted-light); border-radius: 9px; background: var(--bg-pure-white); font-family: 'Hanken Grotesk', sans-serif; font-size: 10px; color: var(--px-muted); }
.mnt-app-search svg { width: 12px; height: 12px; }
.mnt-app-card { border: 1px solid var(--border-muted-light); border-radius: 10px; padding: 12px 13px; background: var(--bg-pure-white); }
.mnt-app-card .r { display: flex; align-items: center; justify-content: space-between; }
.mnt-app-card .id { font-family: 'Hanken Grotesk', sans-serif; font-size: 11px; font-weight: 600; color: var(--px-ink); }
.mnt-app-card .nm { font-size: 12px; color: var(--px-slate); margin-top: 4px; }
.mnt-app-btn { margin-top: 4px; text-align: center; padding: 11px; border-radius: 9px; background: var(--orange); color: #fff; font-family: 'Hanken Grotesk', sans-serif; font-weight: 600; font-size: 12px; }
.mnt-app-defect { display: flex; align-items: center; gap: 10px; padding: 11px 13px; border: 1px solid var(--border-muted-light); border-radius: 10px; background: var(--bg-pure-white); }
.mnt-app-defect .dic { width: 28px; height: 28px; border-radius: 8px; display: grid; place-items: center; flex-shrink: 0; }
.mnt-app-defect .dt { font-size: 12px; color: var(--px-ink); font-weight: 500; }
.mnt-app-defect .dt span { display: block; font-family: 'Hanken Grotesk', sans-serif; font-size: 9px; color: var(--px-muted); margin-top: 2px; font-weight: 400; }

.mnt-mobile-caps { display: flex; flex-direction: column; }
.mnt-mcap { padding: 20px 0; border-top: 1px solid var(--border-muted-light); display: grid; grid-template-columns: 40px 1fr; gap: 16px; align-items: start; }
.mnt-mcap:last-child { border-bottom: 1px solid var(--border-muted-light); }
.mnt-mcap-ic { width: 40px; height: 40px; border-radius: 11px; background: var(--orange-tint); color: var(--orange); display: grid; place-items: center; }
.mnt-mcap-ic svg { width: 19px; height: 19px; }
.mnt-mcap h3 { font-family: 'Satoshi', sans-serif; font-weight: 700; font-size: 17px; letter-spacing: -0.015em; color: var(--px-ink); margin: 2px 0 7px; line-height: 1.25; }
.mnt-mcap p { font-size: 14px; line-height: 1.55; color: var(--px-slate); margin: 0; text-wrap: pretty; }

/* work-order flow rail (4 stages) */
.mnt-flow-rail { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 760px) { .mnt-flow-rail { grid-template-columns: 1fr 1fr; } .mnt-flow-rail.px-rail::before { display: none; } }
@media (max-width: 440px) { .mnt-flow-rail { grid-template-columns: 1fr; } }

/* vendor portal feature grid columns */
.mnt-vendor-feats { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 900px) { .mnt-vendor-feats { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .mnt-vendor-feats { grid-template-columns: 1fr; } }
