/* ══════════════════════════════════════════════════════
   Safety Incident Reporting — Styles
   ══════════════════════════════════════════════════════ */

.si-report-form {
  background: rgba(30,30,30,.55);
  border: 1px solid rgba(181,183,185,.08);
  border-radius: 10px;
  padding: 20px;
}

.si-form-title {
  font-size: 15px;
  font-weight: 700;
  color: #fff;
  margin: 0 0 18px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.si-field {
  margin-bottom: 14px;
}

.si-field label {
  display: block;
  font-size: 12px;
  font-weight: 650;
  color: rgba(255,255,255,.7);
  margin-bottom: 5px;
  text-transform: uppercase;
  letter-spacing: .03em;
}

.si-req {
  color: #ef4444;
}

.si-field input[type="text"],
.si-field input[type="date"],
.si-field input[type="time"],
.si-field select,
.si-field textarea {
  width: 100%;
  padding: 10px 12px;
  background: rgba(20,20,20,.6);
  border: 1px solid rgba(181,183,185,.12);
  border-radius: 6px;
  color: #fff;
  font-size: 14px;
  font-family: inherit;
  outline: none;
  transition: border-color .15s;
  box-sizing: border-box;
}

.si-field input:focus,
.si-field select:focus,
.si-field textarea:focus {
  border-color: var(--bronze, #8C6A3E);
}

.si-field select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23999' viewBox='0 0 24 24'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 30px;
}

.si-field textarea {
  resize: vertical;
  min-height: 80px;
}

/* ── Date & Time row ── */
.si-row {
  display: flex;
  gap: 10px;
}

.si-half {
  flex: 1;
  min-width: 0;
}

@media (max-width: 480px) {
  .si-row {
    flex-direction: column;
    gap: 0;
  }
}

/* ── Date & time input color scheme fix ── */
.si-field input[type="date"]::-webkit-calendar-picker-indicator,
.si-field input[type="time"]::-webkit-calendar-picker-indicator {
  filter: invert(.7);
  cursor: pointer;
}

/* ── Severity buttons ── */
.si-sev-group {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.si-sev-btn {
  padding: 7px 14px;
  border: 1px solid rgba(181,183,185,.15);
  border-radius: 6px;
  background: rgba(20,20,20,.5);
  color: rgba(255,255,255,.6);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: all .15s;
}

.si-sev-btn:hover {
  border-color: var(--sev-color, #8C6A3E);
  color: #fff;
}

.si-sev-btn.active {
  background: var(--sev-color, #8C6A3E);
  border-color: var(--sev-color, #8C6A3E);
  color: #fff;
}

/* ── Dynamic rows (workers, witnesses) ── */
.si-dynamic-row {
  display: flex;
  gap: 8px;
  margin-bottom: 8px;
  align-items: flex-start;
}

.si-dynamic-row input[type="text"],
.si-dynamic-row textarea {
  flex: 1;
  min-width: 0;
  padding: 9px 12px;
  background: rgba(20,20,20,.6);
  border: 1px solid rgba(181,183,185,.12);
  border-radius: 6px;
  color: #fff;
  font-size: 13px;
  font-family: inherit;
  outline: none;
  transition: border-color .15s;
  box-sizing: border-box;
}

.si-dynamic-row input:focus,
.si-dynamic-row textarea:focus {
  border-color: var(--bronze, #8C6A3E);
}

.si-worker-name {
  flex: 1.2 !important;
}

.si-worker-role {
  flex: 0.8 !important;
}

.si-witness-row {
  flex-wrap: wrap;
}

.si-witness-name {
  flex: 1 !important;
  min-width: 120px;
}

.si-witness-statement {
  flex-basis: 100% !important;
  min-height: 50px;
  resize: vertical;
}

.si-remove-row {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  border: 1px solid rgba(239,68,68,.2);
  border-radius: 6px;
  background: rgba(239,68,68,.08);
  color: #ef4444;
  font-size: 16px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .15s;
}

.si-remove-row:hover {
  background: rgba(239,68,68,.2);
  border-color: #ef4444;
}

.si-add-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border: 1px dashed rgba(181,183,185,.2);
  border-radius: 6px;
  background: transparent;
  color: rgba(255,255,255,.5);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: all .15s;
}

.si-add-btn:hover {
  border-color: var(--bronze, #8C6A3E);
  color: var(--bronze, #8C6A3E);
}

/* ── Photo upload (multi-photo) ── */
.si-photo-drop {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 24px;
  border: 2px dashed rgba(181,183,185,.15);
  border-radius: 8px;
  cursor: pointer;
  transition: border-color .15s, background .15s;
  text-align: center;
}

.si-photo-drop span {
  font-size: 12px;
  color: rgba(255,255,255,.4);
}

.si-photo-drop:hover,
.si-photo-drop.si-drag-over {
  border-color: var(--bronze, #8C6A3E);
  background: rgba(140,106,62,.06);
}

.si-photos-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 8px;
}

.si-photos-grid:empty {
  margin-bottom: 0;
}

.si-photo-thumb {
  position: relative;
  width: 100px;
  height: 100px;
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid rgba(181,183,185,.1);
}

.si-photo-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.si-photo-thumb .si-photo-remove {
  position: absolute;
  top: 3px;
  right: 3px;
  width: 22px;
  height: 22px;
  border: none;
  border-radius: 50%;
  background: rgba(0,0,0,.7);
  color: #fff;
  font-size: 13px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  line-height: 1;
}

.si-photo-thumb .si-photo-remove:hover {
  background: #ef4444;
}

/* Backward compat for single-photo preview */
.si-photo-preview {
  position: relative;
  border-radius: 8px;
  overflow: hidden;
  max-width: 300px;
}

.si-photo-preview img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 8px;
}

/* ── Submit ── */
.si-actions {
  margin-top: 16px;
}

.si-submit-btn {
  width: 100%;
  padding: 12px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
}

/* ── Toast ── */
.si-toast {
  margin-top: 12px;
  padding: 10px 14px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 600;
  text-align: center;
}

.si-toast-success {
  background: rgba(34,197,94,.12);
  color: #22c55e;
  border: 1px solid rgba(34,197,94,.2);
}

.si-toast-error {
  background: rgba(239,68,68,.12);
  color: #ef4444;
  border: 1px solid rgba(239,68,68,.2);
}

/* ── Incident list ── */
.si-incident-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.si-incident-item {
  padding: 12px 0;
  border-bottom: 1px solid rgba(181,183,185,.06);
}

.si-incident-item:last-child {
  border-bottom: none;
}

.si-incident-header {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 4px;
}

.si-incident-num {
  font-size: 12px;
  font-weight: 700;
  color: var(--bronze, #8C6A3E);
}

.si-incident-sev,
.si-incident-status {
  font-size: 10px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.si-sev-low       { background: rgba(107,114,128,.15); color: #9ca3af; }
.si-sev-medium    { background: rgba(245,158,11,.12);  color: #f59e0b; }
.si-sev-high      { background: rgba(239,68,68,.12);   color: #ef4444; }
.si-sev-critical  { background: rgba(220,38,38,.18);   color: #dc2626; }

.si-status-reported     { background: rgba(59,130,246,.12);  color: #3b82f6; }
.si-status-under-review { background: rgba(245,158,11,.12);  color: #f59e0b; }
.si-status-resolved     { background: rgba(34,197,94,.12);   color: #22c55e; }
.si-status-closed       { background: rgba(107,114,128,.12); color: #6b7280; }

.si-incident-type {
  font-size: 13px;
  font-weight: 650;
  color: #fff;
}

.si-incident-desc {
  font-size: 12px;
  color: rgba(255,255,255,.55);
  margin-top: 2px;
  line-height: 1.4;
}

.si-incident-badges {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 4px;
}

.si-incident-badge {
  font-size: 10px;
  font-weight: 600;
  padding: 2px 7px;
  border-radius: 4px;
  letter-spacing: .02em;
}

.si-badge-photo {
  background: rgba(99,102,241,.12);
  color: #818cf8;
}

.si-badge-workers {
  background: rgba(245,158,11,.1);
  color: #fbbf24;
}

.si-badge-witness {
  background: rgba(34,197,94,.1);
  color: #4ade80;
}

.si-incident-meta {
  display: flex;
  gap: 12px;
  margin-top: 4px;
  font-size: 11px;
  color: rgba(255,255,255,.35);
}

.si-incident-photo-badge {
  font-size: 13px;
}

.si-empty {
  text-align: center;
  padding: 20px;
  color: rgba(255,255,255,.35);
  font-size: 13px;
}

/* ── Follow-Up Form ── */
.si-followup-form {
  background: rgba(20,20,20,.5);
  border: 1px solid rgba(140,106,62,.2);
  border-radius: 8px;
  padding: 16px;
  margin-top: 10px;
}

.si-followup-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--bronze, #8C6A3E);
  margin: 0 0 14px;
  display: flex;
  align-items: center;
  gap: 6px;
}

.si-followup-container:empty {
  display: none;
}

.si-incident-actions {
  margin-top: 8px;
}

.si-followup-btn {
  padding: 5px 12px;
  border: 1px solid rgba(140,106,62,.3);
  border-radius: 5px;
  background: rgba(140,106,62,.08);
  color: var(--bronze, #8C6A3E);
  font-size: 11px;
  font-weight: 650;
  cursor: pointer;
  transition: all .15s;
}

.si-followup-btn:hover {
  background: rgba(140,106,62,.18);
  border-color: var(--bronze, #8C6A3E);
}

/* ── Follow-Up Display (timeline steps) ── */
.si-followup-display {
  margin-top: 10px;
  background: rgba(20,20,20,.4);
  border: 1px solid rgba(140,106,62,.12);
  border-radius: 8px;
  padding: 12px 14px;
}

.si-followup-header {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 10px;
  color: var(--bronze, #8C6A3E);
}

.si-followup-label {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .03em;
}

.si-followup-date {
  font-size: 11px;
  color: rgba(255,255,255,.35);
  margin-left: auto;
}

.si-followup-steps {
  padding-left: 8px;
  border-left: 2px solid rgba(140,106,62,.2);
  margin-left: 6px;
}

.si-followup-step {
  position: relative;
  padding: 0 0 12px 16px;
}

.si-followup-step-last {
  padding-bottom: 0;
}

.si-followup-step-dot {
  position: absolute;
  left: -6px;
  top: 3px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--bronze, #8C6A3E);
  border: 2px solid rgba(30,30,30,.9);
}

.si-followup-step-label {
  font-size: 10px;
  font-weight: 700;
  color: rgba(255,255,255,.5);
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-bottom: 2px;
}

.si-followup-step-value {
  font-size: 12px;
  color: rgba(255,255,255,.75);
  line-height: 1.45;
}

.si-followup-meta {
  margin-top: 8px;
  font-size: 11px;
  color: rgba(255,255,255,.35);
}

/* ── Follow-up badge ── */
.si-badge-followup {
  background: rgba(140,106,62,.12);
  color: var(--bronze, #8C6A3E);
}

/* ── Worker Status Tags ── */
.si-worker-status-tag,
.si-rtw-tag {
  display: inline-block;
  font-size: 11px;
  font-weight: 650;
  padding: 2px 8px;
  border-radius: 4px;
}

.si-ws-uninjured       { background: rgba(34,197,94,.12);  color: #22c55e; }
.si-ws-first-aid       { background: rgba(245,158,11,.12); color: #f59e0b; }
.si-ws-medical-attention { background: rgba(239,68,68,.12); color: #ef4444; }
.si-ws-hospitalized    { background: rgba(220,38,38,.18);  color: #dc2626; }
.si-ws-light-duties    { background: rgba(59,130,246,.12); color: #3b82f6; }
.si-ws-off-site        { background: rgba(107,114,128,.15); color: #9ca3af; }

.si-rtw-cleared        { background: rgba(34,197,94,.12);  color: #22c55e; }
.si-rtw-restricted     { background: rgba(245,158,11,.12); color: #f59e0b; }
.si-rtw-pending        { background: rgba(59,130,246,.12); color: #3b82f6; }
.si-rtw-not-required   { background: rgba(107,114,128,.15); color: #9ca3af; }

/* ── Mobile Field Optimization ── */
@media (max-width: 900px) {
  /* Touch targets — min 44px for interactive elements */
  .si-sev-btn { min-height: 44px; padding: 10px 16px; font-size: 13px; }
  .si-add-btn { min-height: 44px; padding: 10px 16px; font-size: 13px; }
  .si-remove-row { width: 44px; height: 44px; font-size: 18px; }
  .si-followup-btn { min-height: 44px; padding: 10px 16px; font-size: 13px; }
  .si-photo-drop { padding: 20px; min-height: 64px; }
  .si-photo-thumb .si-photo-remove { width: 32px; height: 32px; font-size: 16px; }
  .si-incident-item { padding: 14px 0; min-height: 48px; }

  /* Input font size — 16px prevents iOS zoom */
  .si-field input[type="text"],
  .si-field input[type="date"],
  .si-field input[type="time"],
  .si-field select,
  .si-field textarea,
  .si-dynamic-row input[type="text"],
  .si-dynamic-row textarea { font-size: 16px; padding: 12px 14px; min-height: 48px; }
  .si-field select { padding-right: 34px; }

  /* Readable text for outdoor / field incident reporting */
  .si-form-title { font-size: 17px; }
  .si-field label { font-size: 13px; }
  .si-incident-type { font-size: 15px; }
  .si-incident-desc { font-size: 13px; }
  .si-incident-num { font-size: 13px; }
  .si-incident-sev,
  .si-incident-status { font-size: 11px; padding: 3px 10px; }
  .si-incident-meta { font-size: 12px; gap: 10px; }
  .si-followup-step-value { font-size: 13px; }
  .si-followup-label { font-size: 13px; }
  .si-worker-status-tag,
  .si-rtw-tag { font-size: 12px; padding: 4px 10px; }

  /* Card and item spacing */
  .si-report-form { padding: 18px; }
  .si-field { margin-bottom: 16px; }
  .si-dynamic-row { gap: 8px; margin-bottom: 10px; }
  .si-followup-form { padding: 16px; }
  .si-followup-display { padding: 14px 16px; }
  .si-photo-thumb { width: 80px; height: 80px; }

  /* Full-width buttons on small screens */
  .si-submit-btn { min-height: 52px; font-size: 16px !important; }
  .si-actions { margin-top: 20px; }
  .si-row { gap: 12px; }
}
