/* MCAI app-shell styles — the chrome around the report. Report itself uses report.css. */

@font-face { font-family: 'Avenir LT'; src: url('https://cdn.prod.website-files.com/67efbcc56c24649dd26f4e83/67efd7d4e6ad1f7a41b525c4_Avenir%20LT%20Std%2055%20Roman.woff2') format('woff2'); font-weight: 400; font-display: swap; }
@font-face { font-family: 'Avenir LT'; src: url('https://cdn.prod.website-files.com/67efbcc56c24649dd26f4e83/67efd7d4d8118f6db17f86f8_Avenir%20LT%20Std%2085%20Heavy.woff2') format('woff2'); font-weight: 800; font-display: swap; }
@font-face { font-family: 'Avenir LT'; src: url('https://cdn.prod.website-files.com/67efbcc56c24649dd26f4e83/67efd7d4d4b8be13e0973bac_Avenir%20LT%20Std%2095%20Black.woff2') format('woff2'); font-weight: 900; font-display: swap; }

:root {
  --dark-purple: #332c5c;
  --light-purple: #5e587a;
  --brand-purple: #4d25ff;
  --soft-bg: #f6f3ff;
  --soft-border: #e6e1f0;
  --gradient: linear-gradient(90deg, #72c3ff, #965bfc 65%, #7556ff);
  --red:#a3232c; --amber:#9a6700; --green:#1f6b35;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  font-family: 'Avenir LT', -apple-system, "Helvetica Neue", Arial, sans-serif;
  color: var(--dark-purple);
  background: #faf8ff;
  min-height: 100%;
}

.hidden { display: none !important; }

.app-header {
  border-bottom: 1px solid var(--soft-border);
  background: #fff;
  padding: 14px 24px 12px;
}
.app-header::before {
  content: '';
  display: block;
  height: 4px;
  margin: -14px -24px 14px;
  background: var(--gradient);
}
.app-brand { display: flex; align-items: center; gap: 12px; }
.app-brand-mark {
  font-weight: 900; font-size: 20px; letter-spacing: 1.5px;
  background: var(--gradient); -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}
.app-brand-divider { color: var(--soft-border); font-weight: 800; }
.app-brand-product { color: var(--dark-purple); font-weight: 800; font-size: 14px; letter-spacing: .5px; }
.app-tag { color: var(--light-purple); font-size: 12px; margin-top: 4px; }

.app-main { max-width: 1180px; margin: 0 auto; padding: 24px; }

.panel {
  background: #fff;
  border: 1px solid var(--soft-border);
  border-radius: 16px;
  padding: 20px;
  margin-bottom: 20px;
  position: relative;
  overflow: hidden;
}
.panel::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--gradient);
}

/* Login */
.login-wrap {
  max-width: 420px;
  margin: 80px auto 0;
}
.login-wrap h2 {
  font-size: 16px; font-weight: 900; color: var(--dark-purple);
  margin: 0 0 6px;
}
.login-wrap p { color: var(--light-purple); font-size: 12px; margin: 0 0 14px; }
.login-wrap input[type="password"] {
  width: 100%; padding: 12px 14px; border: 1px solid var(--soft-border);
  border-radius: 12px; font-size: 14px; font-family: inherit;
  color: var(--dark-purple); background: #fff;
}
.login-wrap input[type="password"]:focus {
  outline: none; border-color: var(--brand-purple);
  box-shadow: 0 0 0 3px rgba(77,37,255,.12);
}
.login-wrap .actions { margin-top: 12px; display: flex; gap: 10px; align-items: center; }
.login-wrap .login-error { color: var(--red); font-size: 12px; margin-top: 8px; min-height: 16px; }

/* Drop zone */
.drop-zone {
  border: 2px dashed var(--soft-border);
  border-radius: 14px;
  padding: 36px 24px;
  text-align: center;
  cursor: pointer;
  transition: all .15s ease;
  background: var(--soft-bg);
}
.drop-zone:hover, .drop-zone:focus, .drop-zone.dragging {
  border-color: var(--brand-purple);
  background: #efe9ff;
  outline: none;
}
.dz-icon {
  width: 48px; height: 48px; margin: 0 auto 8px;
  border-radius: 100px;
  background: var(--gradient);
  color: #fff; font-size: 22px; font-weight: 900;
  display: flex; align-items: center; justify-content: center;
}
.dz-title { font-weight: 800; font-size: 14px; color: var(--dark-purple); margin-bottom: 4px; }
.dz-sub { color: var(--light-purple); font-size: 11.5px; }

.file-list {
  list-style: none;
  margin: 16px 0 0;
  padding: 0;
  display: grid;
  gap: 8px;
}
.file-list:empty { display: none; }
.file-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px;
  border: 1px solid var(--soft-border);
  border-radius: 12px;
  background: #fff;
}
.file-item .fi-name { flex: 1; font-size: 12px; font-weight: 800; color: var(--dark-purple); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.file-item .fi-size { color: var(--light-purple); font-size: 11px; }
.file-item .fi-status { font-size: 10px; text-transform: uppercase; letter-spacing: .4px; font-weight: 800; padding: 2px 10px; border-radius: 100px; }
.fi-status.pending { background: #ece9f5; color: var(--light-purple); }
.fi-status.uploading { background: #fff0c8; color: var(--amber); }
.fi-status.done { background: #dcf2dc; color: var(--green); }
.fi-status.error { background: #fae0e2; color: var(--red); }
.file-item button {
  border: 0; background: transparent; cursor: pointer;
  color: var(--light-purple); font-size: 16px; padding: 4px 8px;
}
.file-item button:hover { color: var(--red); }

.actions { margin-top: 16px; display: flex; gap: 10px; }

.primary-btn {
  background: var(--brand-purple); color: #fff; border: 0;
  padding: 10px 24px; border-radius: 100px;
  font-size: 12px; font-weight: 800; letter-spacing: .5px; text-transform: uppercase;
  cursor: pointer; transition: all .2s; font-family: inherit;
  box-shadow: 0 2px 8px rgba(77,37,255,.25);
}
.primary-btn:hover:not(:disabled) { background: var(--dark-purple); }
.primary-btn:disabled { background: #c5bfdb; cursor: not-allowed; box-shadow: none; }

.ghost-btn {
  background: #fff; color: var(--light-purple); border: 1px solid var(--soft-border);
  padding: 10px 18px; border-radius: 100px;
  font-size: 12px; font-weight: 800; letter-spacing: .5px; text-transform: uppercase;
  cursor: pointer; transition: all .2s; font-family: inherit;
}
.ghost-btn:hover { border-color: var(--brand-purple); color: var(--brand-purple); }

/* Progress */
.progress-header { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 12px; }
.progress-title { font-weight: 900; font-size: 14px; color: var(--dark-purple); }
.progress-elapsed { font-variant-numeric: tabular-nums; color: var(--light-purple); font-size: 12px; }
.progress-steps { list-style: none; margin: 0; padding: 0; display: grid; gap: 8px; }
.progress-steps li {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px;
  background: var(--soft-bg);
  border-radius: 10px;
  font-size: 12px;
  color: var(--light-purple);
}
.progress-steps li .step-icon {
  width: 18px; height: 18px; border-radius: 100px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 900;
  background: #c5bfdb; color: #fff;
  flex-shrink: 0;
}
.progress-steps li.active { color: var(--dark-purple); background: #efe9ff; }
.progress-steps li.active .step-icon { background: var(--brand-purple); }
.progress-steps li.done { color: var(--green); }
.progress-steps li.done .step-icon { background: var(--green); }
.progress-steps li.error { color: var(--red); }
.progress-steps li.error .step-icon { background: var(--red); }

/* Error */
.error-panel { background: #fff5f5; border-color: #f0bcc0; color: var(--red); }
.error-panel::before { background: linear-gradient(90deg, var(--red), #d04450); }
.error-panel .error-title { font-weight: 900; margin-bottom: 6px; }
.error-panel pre { white-space: pre-wrap; font-family: monospace; font-size: 11px; margin: 0; color: var(--dark-purple); }

/* Result */
.result-toolbar { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; gap: 12px; flex-wrap: wrap; }
.result-toolbar-left .result-label { font-size: 11px; text-transform: uppercase; letter-spacing: .5px; color: var(--light-purple); font-weight: 800; }
.result-toolbar-right { display: flex; gap: 10px; }

.app-footer {
  text-align: center; color: var(--light-purple); font-size: 11px;
  padding: 20px; border-top: 1px solid var(--soft-border); background: #fff;
}
