/* ═══════════════════════════════════════════════════
   PAGE 2 — DISCOVERY SESSION
═══════════════════════════════════════════════════ */

/* GRID BACKGROUND — matches intake page */
#page2::before {
  content:'';
  position:fixed; inset:0;
  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: 48px 48px;
  pointer-events:none;
  z-index:0;
}

/* STICKY HEADER */
.session-header {
  background:var(--bg);
  border-bottom:1px solid var(--white15);
  position:sticky;
  top:0;
  z-index:100;
  padding:0 2.5rem;
}
.session-header-inner {
  max-width:900px;
  margin:0 auto;
  display:flex;
  align-items:center;
  gap:1.4rem;
  height:120px;
}
.header-logo { width:48px; height:48px; object-fit:contain; flex-shrink:0; }
.header-titles {
  display:flex;
  flex-direction:column;
  gap:0.15rem;
  flex:1;
  min-width:0;
}
.header-doc-title {
  font-family:'League Spartan',sans-serif;
  font-size:0.9rem;
  font-weight:700;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.header-meta {
  font-family:'Lato',sans-serif;
  font-size:0.65rem;
  color:var(--white40);
  letter-spacing:0.05em;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.header-meta span { color:var(--yellow); }

/* Progress */
.header-progress {
  display:flex;
  align-items:center;
  gap:0.6rem;
  flex-shrink:0;
}
.progress-dots { display:flex; gap:4px; }
.pdot {
  width:8px; height:8px; border-radius:50%;
  background:var(--white15);
  border:none;
  cursor:pointer;
  transition:all 0.2s;
  padding:0;
}
.pdot.open { background:var(--yellow); transform:scale(1.25); }
.progress-label-text {
  font-family:'League Spartan',sans-serif;
  font-size:0.55rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--white40);
  white-space:nowrap;
}

/* SAVE INDICATOR */
#saveToast {
  position:fixed;
  bottom:1.2rem; right:1.2rem;
  background:var(--bg);
  border:1px solid var(--white15);
  border-left:3px solid var(--yellow);
  color:var(--white70);
  font-family:'League Spartan',sans-serif;
  font-size:0.6rem;
  letter-spacing:0.12em;
  text-transform:uppercase;
  padding:0.45rem 1rem;
  z-index:9999;
  opacity:0;
  transition:opacity 0.3s;
  pointer-events:none;
}

/* SESSION INTRO CARD */
.session-intro {
  background:transparent;
  border-left:2px solid var(--white15);
  padding:1.5rem 2rem;
  margin-bottom:2rem;
}
.session-intro h2 {
  font-family:'League Spartan',sans-serif;
  font-size:1rem;
  font-weight:700;
  margin-bottom:0.6rem;
  color:var(--white);
  letter-spacing:0.03em;
}
.session-intro p {
  font-family:'Lato',sans-serif;
  font-size:0.92rem;
  line-height:1.75;
  color:var(--white70);
}
.session-intro .time-row {
  margin-top:0.8rem;
  display:flex;
  gap:1.5rem;
  flex-wrap:wrap;
}
.time-chip {
  display:inline-flex;
  align-items:center;
  font-family:'League Spartan',sans-serif;
  font-size:0.6rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--white40);
  border:1px solid var(--white15);
  padding:0.2rem 0.7rem;
}

/* CONTAINER */
.session-body {
  max-width:900px;
  margin:0 auto;
  padding:2rem 2.5rem 6rem;
}

/* SECTION */
.section {
  margin-bottom:1.2rem;
  border:1px solid var(--white15);
  overflow:hidden;
}
.section-header {
  display:flex;
  align-items:center;
  gap:1rem;
  padding:1.2rem 1.6rem;
  cursor:pointer;
  user-select:none;
  transition:background 0.2s;
  background:var(--white08);
}
.section-header:hover { background:rgba(255,255,255,0.12); }
.section.open .section-header { border-bottom:1px solid var(--white15); }

.section-num {
  font-family:'League Spartan',sans-serif;
  font-size:1.8rem;
  font-weight:800;
  color:var(--white);
  line-height:1;
  min-width:2rem;
  transition:color 0.2s;
}
.section.open .section-num { color:var(--yellow); }

.section-title-block h3 {
  font-family:'League Spartan',sans-serif;
  font-size:1rem;
  font-weight:700;
  letter-spacing:0.03em;
}
.section-title-block p {
  font-size:0.72rem;
  color:var(--white40);
  margin-top:0.15rem;
  font-family:'Lato',sans-serif;
}
.section-time {
  font-family:'League Spartan',sans-serif;
  font-size:0.58rem;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--white40);
  margin-left:auto;
  white-space:nowrap;
}
.chevron { font-size:0.7rem; color:var(--white40); transition:transform 0.25s; }
.section.open .chevron { transform:rotate(180deg); }

.section-body {
  display:none;
  padding:0 1.6rem 2rem;
  background:var(--white08);
}
.section.open .section-body { display:block; }

/* ACCENT LINES per section — all brand yellow */
.section[data-s="1"],
.section[data-s="2"],
.section[data-s="3"],
.section[data-s="4"],
.section[data-s="5"] { border-top:2px solid var(--yellow); }

/* CONTEXT CARD (shared screen) */
.context-card {
  background:rgba(251,240,110,0.07);
  border-left:2px solid var(--yellow);
  padding:0.9rem 1.2rem;
  margin-top:1.2rem;
  font-family:'Lato',sans-serif;
  font-size:0.82rem;
  line-height:1.7;
  color:var(--white70);
}
.context-card strong { color:var(--yellow); font-weight:700; }

/* QUESTION CARD */
.q-card {
  background:rgba(255,255,255,0.04);
  border:1px solid var(--white15);
  padding:1.5rem 1.6rem;
  margin-top:1rem;
  position:relative;
}
.q-badge {
  position:absolute;
  top:0.8rem; right:1rem;
  font-family:'League Spartan',sans-serif;
  font-size:0.5rem;
  letter-spacing:0.12em;
  text-transform:uppercase;
  padding:0.15rem 0.5rem;
}
.q-badge.open,
.q-badge.closed,
.q-badge.flag,
.q-badge.list { background:var(--white15); color:var(--white70); }

.q-num {
  font-family:'League Spartan',sans-serif;
  font-size:0.58rem;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--white40);
  margin-bottom:0.35rem;
}
.q-text {
  font-family:'League Spartan',sans-serif;
  font-size:1.05rem;
  font-weight:600;
  line-height:1.45;
  padding-right:5rem;
  color:var(--white);
}
.q-context {
  margin-top:0.5rem;
  font-family:'Lato',sans-serif;
  font-size:0.82rem;
  color:var(--white40);
  line-height:1.6;
  border-left:2px solid var(--white15);
  padding-left:0.7rem;
  font-style:italic;
}

/* TEXTAREA */
.q-response {
  margin-top:0.8rem;
}
.q-response textarea {
  width:100%;
  min-height:60px;
  background:rgba(255,255,255,0.05);
  border:1px solid var(--white15);
  border-bottom:1px solid var(--white40);
  color:var(--white);
  font-family:'Lato',sans-serif;
  font-size:0.88rem;
  padding:0.6rem 0.8rem;
  resize:vertical;
  outline:none;
  transition:border-color 0.2s;
}
.q-response textarea:focus { border-color:var(--yellow); }
.q-response textarea::placeholder { color:var(--white40); font-style:italic; }

/* COMPLIANCE GRID */
.compliance-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0.75rem;
  margin-top:0.8rem;
}
.comp-cell { border:1px solid var(--white15); }
.comp-cell-head {
  font-family:'League Spartan',sans-serif;
  font-size:0.58rem;
  letter-spacing:0.12em;
  text-transform:uppercase;
  padding:0.4rem 0.7rem;
  border-bottom:1px solid var(--white15);
}
.comp-cell.can .comp-cell-head  { background:rgba(251,240,110,0.08); color:var(--yellow); }
.comp-cell.cant .comp-cell-head { background:rgba(224,80,80,0.08);   color:rgba(224,80,80,0.6); }
.comp-cell textarea {
  width:100%;
  min-height:80px;
  background:transparent;
  border:none;
  color:var(--white);
  font-family:'Lato',sans-serif;
  font-size:0.85rem;
  padding:0.5rem 0.7rem;
  resize:vertical;
  outline:none;
}
.comp-cell textarea::placeholder { color:var(--white40); font-style:italic; }

/* CHECKLIST */
.check-list {
  display:flex;
  flex-direction:column;
  gap:0.4rem;
  margin-top:0.8rem;
}
.check-item {
  display:flex;
  align-items:flex-start;
  gap:0.7rem;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--white15);
  padding:0.65rem 0.9rem;
  cursor:pointer;
  user-select:none;
  transition:background 0.15s;
}
.check-item input[type="checkbox"] {
  width:14px; height:14px;
  accent-color:var(--yellow);
  flex-shrink:0;
  margin-top:0.1rem;
  cursor:pointer;
}
.check-item label {
  font-family:'Lato',sans-serif;
  font-size:0.88rem;
  line-height:1.5;
  cursor:pointer;
  color:var(--white70);
}
.check-item:hover { background:rgba(255,255,255,0.07); }
.check-item.flagged { background:var(--yellow10); border-color:var(--yellow20); }
.check-item.flagged label { color:var(--white); }

/* SECTION DIVIDER */
.sdivider {
  display:flex; align-items:center; gap:0.7rem;
  margin:1.3rem 0 0.3rem;
}
.sdivider hr { flex:1; border:none; border-top:1px solid var(--white15); }
.sdivider span {
  font-family:'League Spartan',sans-serif;
  font-size:0.58rem;
  letter-spacing:0.15em;
  text-transform:uppercase;
  color:var(--white40);
  white-space:nowrap;
}

/* PEOPLE SECTION */
.people-bar {
  display:flex;
  align-items:center;
  gap:0.6rem;
  margin-top:1.2rem;
  flex-wrap:wrap;
}
.person-tab {
  font-family:'League Spartan',sans-serif;
  font-size:0.65rem;
  font-weight:600;
  letter-spacing:0.08em;
  text-transform:uppercase;
  padding:0.4rem 0.9rem;
  border:1px solid var(--white15);
  background:transparent;
  color:var(--white40);
  cursor:pointer;
  transition:all 0.2s;
}
.person-tab.active { border-color:var(--yellow); color:var(--yellow); background:var(--yellow10); }
.add-person-btn {
  font-family:'League Spartan',sans-serif;
  font-size:0.6rem;
  font-weight:600;
  letter-spacing:0.1em;
  text-transform:uppercase;
  padding:0.4rem 0.8rem;
  border:1px dashed var(--white15);
  background:transparent;
  color:var(--white40);
  cursor:pointer;
  transition:all 0.2s;
}
.add-person-btn:hover { border-color:var(--yellow); color:var(--yellow); }
.remove-person-btn {
  font-size:0.6rem;
  font-family:'League Spartan',sans-serif;
  letter-spacing:0.08em;
  background:transparent;
  border:1px solid rgba(224,80,80,0.3);
  color:rgba(224,80,80,0.6);
  padding:0.3rem 0.7rem;
  cursor:pointer;
  margin-left:auto;
  transition:all 0.2s;
  text-transform:uppercase;
}
.remove-person-btn:hover { border-color:#e05050; color:#e05050; }

.person-panel { display:none; }
.person-panel.active { display:block; }

/* FILMING SELECTOR FIELD in section */
.in-session-select {
  margin-top:0.8rem;
}
.in-session-select select {
  background:var(--white08);
  border:1px solid var(--white15);
  border-bottom:1px solid var(--white40);
  color:var(--white);
  font-family:'Lato',sans-serif;
  font-size:0.82rem;
  padding:0.5rem 0.8rem;
  outline:none;
  width:auto;
  min-width:200px;
  cursor:pointer;
}
.in-session-select select option { background:var(--bg); }

/* EXPORT / BOTTOM BAR */
.export-bar {
  display:flex;
  gap:0.6rem;
  margin-top:2rem;
  flex-wrap:wrap;
}
.btn-export {
  background:var(--yellow);
  color:var(--bg);
  border:none;
  font-family:'League Spartan',sans-serif;
  font-size:0.65rem;
  font-weight:700;
  letter-spacing:0.15em;
  text-transform:uppercase;
  padding:0.7rem 1.4rem;
  cursor:pointer;
  transition:opacity 0.2s;
}
.btn-export:hover { opacity:0.85; }
.btn-export-ghost {
  background:transparent;
  border:1px solid var(--white15);
  color:var(--white40);
  font-family:'League Spartan',sans-serif;
  font-size:0.65rem;
  font-weight:600;
  letter-spacing:0.15em;
  text-transform:uppercase;
  padding:0.7rem 1.4rem;
  cursor:pointer;
  transition:all 0.2s;
}
.btn-export-ghost:hover { border-color:var(--white40); color:var(--white); }
.btn-danger-ghost {
  background:transparent;
  border:1px solid rgba(224,80,80,0.25);
  color:rgba(224,80,80,0.5);
  font-family:'League Spartan',sans-serif;
  font-size:0.65rem;
  font-weight:600;
  letter-spacing:0.15em;
  text-transform:uppercase;
  padding:0.7rem 1.4rem;
  cursor:pointer;
  transition:all 0.2s;
  margin-left:auto;
}
.btn-danger-ghost:hover { border-color:#e05050; color:#e05050; }

/* COMPLIANCE PARTY HEADING */
.party-heading {
  font-family:'League Spartan',sans-serif;
  font-size:0.7rem;
  font-weight:700;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--yellow);
  margin-top:1.4rem;
  padding-bottom:0.4rem;
  border-bottom:1px solid var(--white15);
}
.party-heading:first-of-type { margin-top:0; }

@media (max-width:640px) {
  .session-header { padding:0 1rem; }
  .session-body { padding:1.5rem 1rem 4rem; }
  .compliance-grid { grid-template-columns:1fr; }
  .intake-h1 { font-size:1.8rem; }
  .film-types { grid-template-columns:1fr; }
}
