/* Phase 100: production polish, operations desks, spatial planning, and overflow hardening. */

#storyboard-app,
#schedule-app,
#safety-app,
#media-app,
#continuity-app,
#spatial-app,
#pcc-app {
  min-height: calc(100vh - 58px);
  overflow-y: auto;
  overflow-x: hidden;
  padding-bottom: max(120px, env(safe-area-inset-bottom, 0px) + 96px) !important;
}

#storyboard-app #sb-body,
#storyboard-app .sb-grid,
#schedule-app #schedule-body,
#schedule-app #sched-days-list {
  min-height: max-content;
  padding-bottom: 112px;
}

#storyboard-app .sb-panel {
  margin-bottom: 18px;
}

#schedule-app .sched-day-card,
#schedule-app .sched-day,
#schedule-app .schedule-card {
  margin-bottom: 18px;
}

#pcc-app.phase100-pcc-transition {
  opacity: 0;
  pointer-events: none;
}

#pcc-app.phase100-pcc-ready {
  opacity: 1;
  transition: opacity 120ms ease;
}

#pcc-app .ss78-flow-shell,
#pcc-app #ss78-command-specialty-pulse,
#pcc-app .phase78-command-pulse {
  display: none !important;
}

#spatial-app [id^="scc-tool-"],
[id^="scc-tool-"] {
  display: none !important;
}

#spatial-app #scc-day-slider {
  position: relative !important;
  z-index: 1 !important;
  max-width: min(100%, 860px) !important;
  margin: 12px auto !important;
}

#spatial-app .scc-topbar,
#spatial-app .scc-toolbar,
#spatial-app .scc-controls {
  max-width: 100% !important;
  flex-wrap: wrap !important;
}

.p100-tension-panel,
.p100-desk,
.p100-continuity-pulse,
.p100-spatial-suite {
  color: #21140c;
  font-family: ui-sans-serif, "Aptos", "Segoe UI", sans-serif;
}

.p100-tension-panel {
  margin: 12px 16px 10px;
  padding: 14px 16px;
  border: 1px solid rgba(108, 73, 31, .18);
  border-radius: 18px;
  background:
    radial-gradient(circle at 14% 0%, rgba(255, 217, 143, .38), transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,.96), rgba(255,248,235,.92));
  box-shadow: 0 14px 34px rgba(83, 54, 18, .12);
}

.p100-tension-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: 10px;
}

.p100-eyebrow {
  margin: 0 0 4px;
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: .68rem;
  font-weight: 900;
  color: #8d5a21;
}

.p100-tension-title,
.p100-desk-title,
.p100-spatial-title {
  margin: 0;
  font-size: clamp(1.15rem, 2vw, 1.75rem);
  line-height: 1.05;
  color: #251509;
}

.p100-muted {
  margin: 4px 0 0;
  color: #765b43;
  line-height: 1.45;
}

.p100-tension-stats {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.p100-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 30px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(104, 76, 45, .16);
  background: rgba(255,255,255,.72);
  color: #3b2816;
  font-weight: 850;
  font-size: .78rem;
  white-space: nowrap;
}

.p100-tension-svg {
  display: block;
  width: 100%;
  min-height: 170px;
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,.78), rgba(250,241,223,.6));
}

.p100-desk {
  width: min(1540px, calc(100% - 28px));
  margin: 14px auto 132px;
  padding: clamp(16px, 2.2vw, 28px);
  border-radius: 30px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.98), rgba(255,248,235,.94)),
    radial-gradient(circle at 92% 0%, rgba(255,190,91,.28), transparent 35%);
  box-shadow: 0 24px 70px rgba(64, 39, 14, .14);
  border: 1px solid rgba(121, 86, 39, .16);
}

.p100-desk-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: start;
  margin-bottom: 18px;
}

.p100-desk-title {
  font-size: clamp(1.55rem, 3vw, 2.65rem);
}

.p100-actions,
.p100-card-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}

.p100-btn {
  appearance: none;
  border: 1px solid rgba(78, 52, 21, .18);
  border-radius: 999px;
  background: #fffaf1;
  color: #2d1b0e;
  padding: 10px 14px;
  font-weight: 900;
  cursor: pointer;
  box-shadow: 0 10px 22px rgba(70, 43, 15, .09);
}

.p100-btn.primary {
  background: linear-gradient(135deg, #f59e0b, #f97316);
  color: #fff;
  border-color: rgba(194, 94, 18, .65);
}

.p100-btn.danger {
  color: #8a1b1b;
  border-color: rgba(138, 27, 27, .18);
}

.p100-kpis,
.p100-media-stack,
.p100-template-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.p100-kpi,
.p100-stack-card,
.p100-card {
  border: 1px solid rgba(97, 67, 31, .14);
  border-radius: 22px;
  background: rgba(255,255,255,.76);
  box-shadow: 0 14px 34px rgba(71, 45, 16, .08);
}

.p100-kpi {
  padding: 16px;
}

.p100-kpi strong {
  display: block;
  font-size: clamp(1.5rem, 2.6vw, 2.15rem);
  color: #241308;
}

.p100-kpi span,
.p100-stack-card span {
  display: block;
  color: #765b43;
  font-weight: 750;
  font-size: .82rem;
}

.p100-main-grid {
  display: grid;
  grid-template-columns: minmax(280px, .9fr) minmax(0, 1.8fr);
  gap: 16px;
  margin-top: 16px;
  align-items: start;
}

.p100-card {
  padding: 16px;
}

.p100-card h3 {
  margin: 0 0 8px;
  color: #2c190b;
  font-size: 1rem;
}

.p100-gates,
.p100-templates,
.p100-check-list {
  display: grid;
  gap: 10px;
}

.p100-gate {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  padding: 11px;
  border-radius: 16px;
  background: rgba(255,249,239,.82);
  border: 1px solid rgba(105, 72, 36, .12);
}

.p100-gate input {
  margin-top: 3px;
  accent-color: #d97706;
}

.p100-gate strong {
  display: block;
  color: #2c190b;
}

.p100-gate small {
  display: block;
  color: #7c654e;
  line-height: 1.35;
}

.p100-field-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.p100-field-grid .wide {
  grid-column: 1 / -1;
}

.p100-field {
  display: grid;
  gap: 6px;
}

.p100-field label,
.p100-table label {
  color: #53351a;
  font-size: .74rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 900;
}

.p100-field input,
.p100-field textarea,
.p100-field select,
.p100-table input,
.p100-table textarea,
.p100-table select {
  width: 100%;
  border: 1px solid rgba(91, 65, 37, .16);
  border-radius: 12px;
  background: rgba(255,255,255,.86);
  color: #261407;
  padding: 9px 10px;
  font: inherit;
  min-height: 42px;
}

.p100-field textarea,
.p100-table textarea {
  min-height: 78px;
  resize: vertical;
}

.p100-table-wrap {
  overflow-x: auto;
  max-width: 100%;
  border-radius: 16px;
  border: 1px solid rgba(97, 67, 31, .12);
}

.p100-table {
  width: 100%;
  min-width: 820px;
  border-collapse: collapse;
}

.p100-table th,
.p100-table td {
  padding: 10px;
  border-bottom: 1px solid rgba(97, 67, 31, .1);
  vertical-align: top;
  text-align: left;
}

.p100-table th {
  background: rgba(255, 244, 225, .9);
  color: #553217;
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.p100-media-stack {
  margin: 14px 0;
}

.p100-stack-card {
  padding: 14px;
  min-width: 0;
}

.p100-stack-card strong {
  display: block;
  color: #29170b;
  font-size: .95rem;
  margin-bottom: 4px;
}

.p100-stack-card .p100-stack-meter {
  height: 8px;
  margin-top: 10px;
  border-radius: 999px;
  background: rgba(80, 54, 26, .12);
  overflow: hidden;
}

.p100-stack-card .p100-stack-meter i {
  display: block;
  height: 100%;
  width: var(--pct, 0%);
  background: linear-gradient(90deg, #22c55e, #14b8a6);
}

.p100-continuity-pulse {
  margin: 12px 0 16px;
  padding: 14px;
  border: 1px solid rgba(72, 51, 27, .14);
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(255,255,255,.9), rgba(255,248,235,.84));
  box-shadow: 0 12px 28px rgba(62, 39, 12, .08);
}

.p100-continuity-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 10px;
}

.p100-continuity-grid div {
  padding: 10px;
  border-radius: 14px;
  background: rgba(255,255,255,.76);
  border: 1px solid rgba(94, 68, 34, .12);
}

.p100-spatial-suite {
  position: relative;
  z-index: 60;
  width: min(1540px, calc(100% - 28px));
  margin: 14px auto 132px;
  padding: clamp(14px, 2vw, 22px);
  border-radius: 28px;
  background: linear-gradient(135deg, #fffaf2, #f3eadc);
  border: 1px solid rgba(101, 73, 36, .16);
  box-shadow: 0 24px 72px rgba(59, 38, 14, .12);
}

.p100-spatial-head {
  display: flex;
  gap: 16px;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  margin-bottom: 14px;
}

.p100-spatial-layout {
  display: grid;
  grid-template-columns: minmax(260px, 360px) minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}

.p100-spatial-map {
  position: relative;
  min-height: 520px;
  border-radius: 24px;
  overflow: hidden;
  border: 2px solid rgba(76, 54, 28, .28);
  background:
    linear-gradient(90deg, rgba(70,47,24,.07) 1px, transparent 1px),
    linear-gradient(0deg, rgba(70,47,24,.07) 1px, transparent 1px),
    radial-gradient(circle at 18% 12%, rgba(255, 211, 127, .38), transparent 30%),
    #fff8ec;
  background-size: 32px 32px, 32px 32px, auto, auto;
  aspect-ratio: var(--room-ratio, 1.45);
}

.p100-spatial-room-label {
  position: absolute;
  left: 14px;
  top: 12px;
  z-index: 4;
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.86);
  color: #3a220f;
  font-weight: 900;
  font-size: .78rem;
  box-shadow: 0 8px 20px rgba(66,44,18,.1);
}

.p100-spatial-pin {
  position: absolute;
  transform: translate(-50%, -50%);
  display: grid;
  place-items: center;
  min-width: 72px;
  max-width: 120px;
  min-height: 50px;
  padding: 7px 9px;
  border-radius: 16px;
  border: 2px solid rgba(61, 40, 18, .24);
  background: rgba(255,255,255,.88);
  box-shadow: 0 14px 28px rgba(53, 35, 14, .16);
  cursor: grab;
  text-align: center;
  font-weight: 900;
  font-size: .74rem;
  user-select: none;
}

.p100-spatial-pin small {
  display: block;
  color: #73583d;
  font-size: .64rem;
  margin-top: 2px;
  line-height: 1.2;
}

.p100-spatial-pin[data-kind="door"] { border-color: rgba(120, 74, 21, .5); }
.p100-spatial-pin[data-kind="window"] { border-color: rgba(14, 116, 144, .45); }
.p100-spatial-pin[data-kind="light"] { border-color: rgba(217, 119, 6, .55); }
.p100-spatial-pin[data-kind="camera"] { border-color: rgba(37, 99, 235, .45); }
.p100-spatial-pin[data-kind="actor"] { border-color: rgba(190, 24, 93, .42); }
.p100-spatial-pin[data-kind="generator"] { border-color: rgba(22, 101, 52, .48); }

.p100-spatial-path {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 2;
}

.p100-spatial-character {
  position: absolute;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: linear-gradient(135deg, #2563eb, #06b6d4);
  box-shadow: 0 0 0 4px rgba(255,255,255,.8), 0 10px 24px rgba(37,99,235,.22);
  z-index: 5;
  transform: translate(-50%, -50%);
  display: none;
}

.p100-check-list button,
.p100-template-row button {
  text-align: left;
}

@media (max-width: 1100px) {
  .p100-kpis,
  .p100-media-stack,
  .p100-continuity-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .p100-main-grid,
  .p100-spatial-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  .p100-desk,
  .p100-spatial-suite {
    width: calc(100% - 14px);
    border-radius: 22px;
    padding: 14px;
  }

  .p100-desk-head,
  .p100-field-grid,
  .p100-kpis,
  .p100-media-stack,
  .p100-continuity-grid {
    grid-template-columns: 1fr;
  }

  .p100-spatial-map {
    min-height: 440px;
  }
}
