/* ============================================================
   SECOPS PORTFOLIO — modal.css
   Panneau latéral qui slide depuis la droite
============================================================ */

#missionModal {
  position: fixed;
  inset: 0;
  z-index: 5000;
  pointer-events: none;
}

#missionModal.is-open {
  pointer-events: all;
}

/* OVERLAY */
.mm-overlay {
  position: absolute;
  inset: 0;
  background: rgba(15, 15, 13, 0.6);
  backdrop-filter: blur(3px);
  opacity: 0;
  transition: opacity 0.5s cubic-bezier(0.65, 0, 0.35, 1);
}

#missionModal.is-open .mm-overlay {
  opacity: 1;
}

/* PANEL */
.mm-panel {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: min(700px, 94vw);
  background: linear-gradient(180deg, #f6f1e9 0%, #f2ede4 100%);
  border-left: 1px solid rgba(15,15,13,0.18);
  box-shadow: -18px 0 40px rgba(15,15,13,0.08);
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  overflow: hidden;
}

#missionModal.is-open .mm-panel {
  transform: translateX(0);
}

/* PANEL HEADER — fixe */
.mm-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.5rem 2.5rem;
  border-bottom: 1px solid rgba(15,15,13,0.12);
  flex-shrink: 0;
  background: #f2ede4;
  position: sticky;
  top: 0;
  z-index: 2;
}

.mm-panel-meta {
  display: flex;
  align-items: center;
  gap: 1.2rem;
}

.mm-num {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.2rem;
  color: #d63b2a;
  letter-spacing: 0.08em;
}

.mm-cat-display {
  font-family: 'DM Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.3em;
  color: #d63b2a;
  background: rgba(214,59,42,0.08);
  border: 1px solid rgba(214,59,42,0.2);
  padding: 0.2rem 0.6rem;
}

.mm-period-display {
  font-family: 'DM Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.15em;
  color: #6b6b68;
}

.mm-close {
  width: 38px;
  height: 38px;
  border: 1px solid rgba(15,15,13,0.2);
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: none;
  transition: background 0.2s, border-color 0.2s;
  flex-shrink: 0;
}

.mm-close:hover {
  background: #0f0f0d;
  border-color: #0f0f0d;
}

.mm-close:hover svg {
  color: #f2ede4;
}

.mm-close svg {
  width: 16px;
  color: #0f0f0d;
  transition: color 0.2s;
}

/* PANEL CONTENT — scrollable */
.mm-content {
  flex: 1;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding: 2.5rem;
  scrollbar-width: thin;
  scrollbar-color: rgba(15,15,13,0.15) transparent;
}

.mm-title {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(2rem, 5vw, 3.2rem);
  line-height: 0.92;
  letter-spacing: 0.02em;
  color: #0f0f0d;
  margin-bottom: 1.5rem;
}

.mm-tags-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 2rem;
}

.mm-tags-row span {
  font-family: 'DM Mono', monospace;
  font-size: 0.62rem;
  letter-spacing: 0.15em;
  color: #6b6b68;
  border: 1px solid rgba(15,15,13,0.15);
  padding: 0.25rem 0.65rem;
}

.mm-rule {
  height: 1px;
  background: rgba(15,15,13,0.12);
  margin-bottom: 2rem;
  position: relative;
  overflow: hidden;
}

.mm-rule::after {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 50%;
  height: 100%;
  background: linear-gradient(90deg, transparent, #d63b2a, transparent);
  animation: ruleSlide 0.8s cubic-bezier(0.16, 1, 0.3, 1) 0.3s forwards;
}

@keyframes ruleSlide {
  to { left: 150%; }
}

.mm-sections {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
  margin-bottom: 2.5rem;
}

.mm-section {}

.mm-section-label {
  font-family: 'DM Mono', monospace;
  font-size: 0.58rem;
  letter-spacing: 0.35em;
  color: #d63b2a;
  text-transform: uppercase;
  margin-bottom: 0.8rem;
  display: flex;
  align-items: center;
  gap: 0.8rem;
}

.mm-section-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: rgba(15,15,13,0.08);
}

.mm-section p {
  font-family: 'DM Mono', monospace;
  font-size: 0.82rem;
  line-height: 1.95;
  color: #2a2a28;
  max-width: 62ch;
}

.mm-section ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.mm-section ul li {
  font-family: 'DM Mono', monospace;
  font-size: 0.8rem;
  line-height: 1.72;
  color: #2a2a28;
  display: grid;
  grid-template-columns: 1.5rem 1fr;
  gap: 0.4rem;
}

.mm-section ul li::before {
  content: '▸';
  color: #d63b2a;
  font-size: 0.65rem;
  margin-top: 0.15rem;
}

/* FOOTER META */
.mm-footer-meta {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: rgba(15,15,13,0.12);
  border: 1px solid rgba(15,15,13,0.12);
}

.mm-meta-cell {
  background: #f2ede4;
  padding: 1.2rem;
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}

.mm-meta-label {
  font-family: 'DM Mono', monospace;
  font-size: 0.55rem;
  letter-spacing: 0.25em;
  color: #b0afa9;
  text-transform: uppercase;
}

.mm-meta-value {
  font-family: 'Archivo Black', sans-serif;
  font-size: 0.88rem;
  color: #0f0f0d;
}

.mm-meta-value.accent {
  color: #d63b2a;
}

/* Responsive */
@media (max-width: 600px) {
  .mm-panel-header { padding: 1.2rem 1.5rem; }
  .mm-content { padding: 1.8rem 1.5rem; }
  .mm-footer-meta { grid-template-columns: 1fr; }
}
