/* Procurement & Contract Management — page styles */
@import url("colors_and_type.css");

/* Hero — contract lifecycle card */
.pc-card {
  background: linear-gradient(180deg, rgba(15,21,48,0.96), rgba(8,12,28,0.96));
  border: 1px solid rgba(79,200,255,0.22);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 24px 64px rgba(0,0,0,0.6), 0 0 80px rgba(79,200,255,0.12);
}
.pc-dot { background: var(--site-cyan) !important; box-shadow: 0 0 0 3px rgba(79,200,255,0.25) !important; }

.pc-meta { padding: 14px 18px; border-bottom: 1px solid rgba(255,255,255,0.06); display: flex; flex-direction: column; gap: 6px; }
.pc-meta-row { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 11.5px; }
.pc-meta-row span:first-child { color: var(--site-text-3); letter-spacing: 0.1em; text-transform: uppercase; font-size: 9.5px; }
.pc-meta-row span:last-child { color: var(--site-text); font-weight: 600; }

.pc-timeline { padding: 16px 18px; }
.pc-timeline-h { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; color: var(--site-text-3); text-transform: uppercase; margin-bottom: 12px; padding-left: 4px; }
.pc-phase { display: grid; grid-template-columns: 24px 1fr; gap: 12px; margin-bottom: 4px; }
.pc-phase-rail { position: relative; display: flex; flex-direction: column; align-items: center; padding-top: 4px; }
.pc-phase-node { width: 11px; height: 11px; border-radius: 50%; background: rgba(15,21,48,0.95); border: 2px solid rgba(255,255,255,0.18); transition: all 0.3s ease; flex-shrink: 0; }
.pc-phase-line { width: 1.5px; flex: 1; min-height: 14px; background: rgba(255,255,255,0.08); margin-top: 2px; }
.pc-phase-done .pc-phase-node { background: var(--site-cyan); border-color: var(--site-cyan); }
.pc-phase-done .pc-phase-line { background: rgba(79,200,255,0.35); }
.pc-phase-live .pc-phase-node { background: var(--site-mint); border-color: var(--site-mint); box-shadow: 0 0 0 4px rgba(94,255,164,0.18), 0 0 12px rgba(94,255,164,0.6); }
.pc-phase-body { padding-bottom: 12px; }
.pc-phase-t { display: flex; align-items: center; gap: 8px; font-size: 12.5px; color: var(--site-text); font-weight: 500; }
.pc-phase-n { font-family: var(--font-mono); font-size: 9.5px; color: var(--site-text-3); letter-spacing: 0.16em; }
.pc-phase-actor { font-size: 10.5px; color: var(--site-text-3); margin-left: auto; font-family: var(--font-mono); letter-spacing: 0.08em; }
.pc-phase-hash { font-family: var(--font-mono); font-size: 10px; color: var(--site-cyan); margin-top: 3px; }

.pc-foot { display: flex; justify-content: space-between; padding: 12px 18px; border-top: 1px solid rgba(255,255,255,0.06); font-family: var(--font-mono); font-size: 10.5px; color: var(--site-text-3); }
.pc-foot strong { color: var(--site-mint); font-weight: 600; }

/* Roles */
.pc-roles-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 48px; }
.pc-role { padding: 22px 18px; border: 1px solid rgba(255,255,255,0.07); background: rgba(15,21,48,0.4); border-radius: 12px; position: relative; }
.pc-role-n { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; color: var(--site-cyan); margin-bottom: 14px; font-weight: 600; }
.pc-role-avatar { width: 36px; height: 36px; border-radius: 50%; background: linear-gradient(135deg, rgba(79,200,255,0.2), rgba(94,255,164,0.15)); border: 1px solid rgba(79,200,255,0.3); display: flex; align-items: center; justify-content: center; font-weight: 600; color: var(--site-cyan); margin-bottom: 14px; font-family: var(--font-mono); }
.pc-role-t { font-weight: 600; font-size: 14px; color: var(--site-text); margin-bottom: 6px; }
.pc-role-d { font-size: 11.5px; color: var(--site-text-3); line-height: 1.5; }

/* Blockchain layer */
.pc-bc-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin-top: 48px; }
.pc-bc { padding: 28px; border: 1px solid rgba(94,255,164,0.18); background: linear-gradient(180deg, rgba(94,255,164,0.04), rgba(15,21,48,0.35)); border-radius: 14px; }
.pc-bc-n { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; color: var(--site-mint); margin-bottom: 14px; font-weight: 600; }
.pc-bc-t { font-weight: 600; font-size: 17px; color: var(--site-text); margin-bottom: 8px; line-height: 1.3; }
.pc-bc-d { font-size: 13px; color: var(--site-text-2); line-height: 1.55; }

/* Outcomes */
.pc-outcomes-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 48px; }
.pc-outcome { padding: 24px 20px; border: 1px solid rgba(255,255,255,0.07); background: rgba(15,21,48,0.4); border-radius: 12px; position: relative; }
.pc-outcome-tick { position: absolute; top: 18px; right: 18px; color: var(--site-mint); font-size: 18px; }
.pc-outcome-n { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; color: var(--site-cyan); margin-bottom: 12px; font-weight: 600; }
.pc-outcome-t { font-weight: 600; font-size: 15px; color: var(--site-text); margin-bottom: 6px; }
.pc-outcome-d { font-size: 12px; color: var(--site-text-3); line-height: 1.5; }

/* Delivery rail */
.pc-delivery-rail { display: flex; align-items: stretch; gap: 6px; margin-top: 48px; overflow-x: auto; padding-bottom: 8px; }
.pc-delivery-step { flex: 1; min-width: 170px; padding: 18px 16px; border: 1px solid rgba(255,255,255,0.07); background: rgba(15,21,48,0.4); border-radius: 12px; }
.pc-delivery-n { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; color: var(--site-cyan); margin-bottom: 10px; font-weight: 600; }
.pc-delivery-t { font-weight: 600; font-size: 13.5px; color: var(--site-text); margin-bottom: 6px; line-height: 1.3; }
.pc-delivery-d { font-size: 11px; color: var(--site-text-3); line-height: 1.5; }
.pc-delivery-arrow { display: flex; align-items: center; color: var(--site-text-3); font-size: 14px; flex-shrink: 0; }

@media (max-width: 1100px) {
  .cx-hero-visual { margin: 0 auto; }
  .pc-roles-grid { grid-template-columns: repeat(2, 1fr); }
  .pc-bc-grid { grid-template-columns: 1fr; }
  .pc-outcomes-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 700px) {
  .pc-roles-grid, .pc-outcomes-grid { grid-template-columns: 1fr; }
}
