/* ── BidWeb Platform — CSS (paleta Big 4) ──────────────────────────── */
:root {
  --navy:   #0B1E3F;
  --teal:   #1FB8A4;
  --gold:   #C9A227;
  --slate:  #2E3A4B;
  --grey:   #6B7280;
  --light:  #F4F6F8;
  --lighter:#FAFBFC;
  --border: #D8DCE2;
  --white:  #FFFFFF;
  --crit:   #7A0000;
  --high:   #C0392B;
  --med:    #E67E22;
  --low:    #27AE60;
  --info:   #2980B9;
  --radius: 8px;
  --shadow: 0 2px 12px rgba(11,30,63,0.10);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: 'Inter', system-ui, sans-serif;
  background-color: #060C10;
  background-image: url('/static/img/bg-waves.svg');
  background-size: cover;
  background-position: center center;
  background-attachment: fixed;
  color: var(--slate);
  min-height: 100vh;
}

/* ── Navbar ─────────────────────────────────────────────────────────── */
.navbar {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  background: var(--navy);
  padding: 0 2rem;
  height: 56px;
  box-shadow: 0 2px 8px rgba(0,0,0,.2);
  position: sticky; top: 0; z-index: 100;
}
.nav-brand { display: flex; align-items: baseline; gap: .4rem; }
.nav-logo  { color: var(--white); font-weight: 700; font-size: 1.1rem; }
.nav-sub   { color: var(--teal);  font-size: .75rem; }
.nav-links { display: flex; gap: .5rem; margin-left: .5rem; }
.nav-link  {
  display: flex; align-items: center; gap: .4rem;
  color: rgba(255,255,255,.75); text-decoration: none;
  padding: .4rem .8rem; border-radius: var(--radius);
  font-size: .875rem; transition: background .15s, color .15s;
}
.nav-link:hover, .nav-link.active {
  background: rgba(31,184,164,.15);
  color: var(--teal);
}
.nav-user  { display: flex; align-items: center; gap: .6rem; margin-left: auto; }
.nav-avatar { width: 28px; height: 28px; border-radius: 50%; border: 2px solid var(--teal); }
.nav-username { color: rgba(255,255,255,.85); font-size: .875rem; }
.nav-logout {
  color: var(--grey); font-size: .8rem; text-decoration: none;
  padding: .25rem .6rem; border: 1px solid rgba(255,255,255,.15);
  border-radius: var(--radius); transition: all .15s;
}
.nav-logout:hover { color: var(--white); border-color: var(--white); }

/* ── Page layouts ──────────────────────────────────────────────────── */
.page-auth {
  display: flex; align-items: center; justify-content: center;
  min-height: 100vh;
  background: linear-gradient(135deg, var(--navy) 0%, #163460 100%);
}
.page-main { max-width: 1100px; margin: 0 auto; padding: 2rem 1.5rem; background: transparent; }

/* ── Auth Card ─────────────────────────────────────────────────────── */
.auth-card {
  background: var(--white);
  border-radius: 12px;
  box-shadow: 0 8px 40px rgba(0,0,0,.3);
  width: 100%; max-width: 440px;
  overflow: hidden;
}
.auth-brand {
  background: var(--navy);
  padding: 2rem;
  text-align: center;
  border-bottom: 3px solid var(--teal);
}
.auth-logo     { color: var(--white); font-size: 1.8rem; font-weight: 700; }
.auth-logo-sub { color: var(--teal);  font-size: .8rem; margin-top: .2rem; }
.auth-body     { padding: 2rem; }
.auth-title    { font-size: 1.3rem; color: var(--navy); margin-bottom: .4rem; }
.auth-desc     { color: var(--grey); font-size: .875rem; line-height: 1.5; margin-bottom: 1.5rem; }
.auth-note {
  display: flex; align-items: center; gap: .5rem;
  background: var(--light); border-radius: var(--radius);
  padding: .75rem 1rem; font-size: .8rem; color: var(--grey);
  margin-top: 1rem;
}

/* ── Forms ─────────────────────────────────────────────────────────── */
.form-group   { margin-bottom: 1.2rem; }
label {
  display: flex; align-items: center; justify-content: space-between;
  font-size: .875rem; font-weight: 500; color: var(--navy); margin-bottom: .4rem;
}
.help-link { font-size: .78rem; color: var(--teal); text-decoration: none; font-weight: 400; }
.help-link:hover { text-decoration: underline; }
input[type=text], input[type=password] {
  width: 100%; padding: .65rem .9rem;
  border: 1.5px solid var(--border); border-radius: var(--radius);
  font-size: .95rem; color: var(--slate); background: var(--white);
  transition: border-color .15s, box-shadow .15s;
  font-family: inherit;
}
input[type=text]:focus, input[type=password]:focus {
  outline: none; border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(31,184,164,.15);
}
.form-hint { font-size: .78rem; color: var(--grey); margin-top: .3rem; display: block; }
code { background: var(--light); padding: .1em .3em; border-radius: 3px; font-size: .85em; }
.input-eye { position: relative; }
.input-eye input { padding-right: 2.5rem; }
.eye-btn {
  position: absolute; right: .6rem; top: 50%; transform: translateY(-50%);
  background: none; border: none; cursor: pointer; color: var(--grey);
  padding: .2rem;
}
.eye-btn:hover { color: var(--navy); }

/* ── Buttons ───────────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: .4rem;
  padding: .6rem 1.2rem; border-radius: var(--radius);
  font-size: .875rem; font-weight: 500; cursor: pointer;
  border: none; text-decoration: none; transition: all .15s;
  font-family: inherit;
}
.btn:disabled { opacity: .6; cursor: not-allowed; }
.btn-primary  { background: var(--navy); color: var(--white); }
.btn-primary:hover:not(:disabled) { background: #162d5a; }
.btn-block { width: 100%; justify-content: center; padding: .75rem; font-size: 1rem; }
.btn-sm   { padding: .4rem .8rem; font-size: .8rem; }
.btn-dl   { background: var(--teal); color: var(--white); }
.btn-dl:hover { background: #18a090; }
.btn-gh   { background: var(--slate); color: var(--white); }
.btn-gh:hover { background: #1a2535; }
.btn-vsc  { background: #0078d4; color: var(--white); }
.btn-vsc:hover { background: #005fa3; }
.btn-grey { background: var(--light); color: var(--slate); border: 1px solid var(--border); }
.btn-grey:hover { background: var(--border); }

/* ── Alerts ────────────────────────────────────────────────────────── */
.alert {
  padding: .75rem 1rem; border-radius: var(--radius); margin-bottom: 1rem;
  font-size: .875rem;
}
.alert-error   { background: #fee; border-left: 3px solid var(--high); color: #8b1010; }
.alert-success { background: #efe; border-left: 3px solid var(--low);  color: #1a5c2a; }
.alert-info    { background: #e8f4fb; border-left: 3px solid var(--info); color: #1a4a6e; }

/* ── Badges ────────────────────────────────────────────────────────── */
.badge {
  display: inline-block; padding: .2rem .6rem; border-radius: 20px;
  font-size: .75rem; font-weight: 600;
}
.badge-ok      { background: #e8f8f1; color: var(--low);  border: 1px solid #b7e4cc; }
.badge-running { background: #fff3e0; color: var(--med);  border: 1px solid #ffc87a; }
.badge-error   { background: #fee;    color: var(--high); border: 1px solid #f5b7b1; }
.badge-git     { background: #e8f4fb; color: var(--info); border: 1px solid #a9d4f0; }
.badge-grey    { background: var(--light); color: var(--grey); border: 1px solid var(--border); }
.badge-ai      { background: #e6faf8; color: var(--teal); border: 1px solid #a8e6df; }

/* ── AI Section ─────────────────────────────────────────────────────── */
.ai-section {
  margin-top: 1.1rem;
  border-top: 1px solid var(--border);
  padding-top: 1rem;
}
.ai-toggle-row { display: flex; align-items: center; }
.ai-toggle-label {
  display: flex; align-items: center; gap: .4rem;
  font-size: .875rem; font-weight: 500; color: var(--slate);
  cursor: pointer; user-select: none;
}
.ai-toggle-label input[type=checkbox] { accent-color: var(--teal); }
.ai-fields-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1rem;
  margin-bottom: .6rem;
}
.ai-fields-grid .form-group { margin-bottom: 0; }
select.form-control {
  width: 100%; padding: .65rem .9rem;
  border: 1.5px solid var(--border); border-radius: var(--radius);
  font-size: .875rem; color: var(--slate); background: var(--white);
  font-family: inherit; cursor: pointer;
  transition: border-color .15s, box-shadow .15s;
}
select.form-control:focus {
  outline: none; border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(31,184,164,.15);
}
input.form-control {
  width: 100%; padding: .65rem .9rem;
  border: 1.5px solid var(--border); border-radius: var(--radius);
  font-size: .875rem; color: var(--slate); background: var(--white);
  font-family: inherit; transition: border-color .15s, box-shadow .15s;
}
input.form-control:focus {
  outline: none; border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(31,184,164,.15);
}
.ai-note {
  display: flex; align-items: flex-start; gap: .4rem;
  font-size: .78rem; color: var(--grey); line-height: 1.45;
  padding: .5rem .75rem; background: var(--light);
  border-radius: var(--radius); border: 1px solid var(--border);
}

/* ── Cards ─────────────────────────────────────────────────────────── */
.card {
  background: var(--white); border-radius: var(--radius);
  border: 1px solid var(--border); box-shadow: var(--shadow);
}
.card-header {
  display: flex; align-items: center; gap: .5rem;
  padding: .9rem 1.25rem; font-weight: 600; color: var(--navy);
  border-bottom: 1px solid var(--border); font-size: .95rem;
}
.card-body { padding: 1.25rem; }
.mt-4 { margin-top: 1.25rem; }

/* ── Page header ───────────────────────────────────────────────────── */
.page-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  margin-bottom: 1.5rem; gap: 1rem;
}
.page-title { font-size: 1.5rem; color: var(--navy); font-weight: 700; }
.page-sub   { color: var(--grey); font-size: .875rem; margin-top: .2rem; }
.user-badge { display: flex; align-items: center; gap: .75rem; }
.badge-avatar { width: 40px; height: 40px; border-radius: 50%; border: 2px solid var(--teal); }
.badge-name { font-weight: 600; color: var(--navy); font-size: .9rem; }
.badge-user { color: var(--grey); font-size: .8rem; }

/* ── Prompt master ─────────────────────────────────────────────────── */
.prompt-master {
  background: linear-gradient(90deg, var(--navy) 0%, #163460 100%);
  color: var(--white); border-radius: var(--radius);
  padding: .85rem 1.1rem; margin-bottom: 1.2rem;
  font-size: .9rem; font-family: 'Courier New', monospace;
}
.prompt-master strong { color: var(--teal); }
.prompt-master em { color: var(--gold); font-style: normal; }

/* ── Domain input row ──────────────────────────────────────────────── */
.domain-input-row { display: flex; gap: 1rem; align-items: flex-end; }
.domain-input-row .form-group { margin-bottom: 0; }
.flex-1 { flex: 1; }
.domain-input { font-size: 1rem !important; }
.btn-launch { padding: .65rem 1.5rem; font-size: 1rem; height: fit-content; align-self: flex-end; margin-bottom: 0; }

/* ── Steps grid ────────────────────────────────────────────────────── */
.steps-grid {
  display: flex; gap: 1rem; flex-wrap: wrap;
}
.step {
  display: flex; align-items: center; gap: .75rem;
  background: var(--light); border-radius: var(--radius);
  padding: .75rem 1rem; flex: 1; min-width: 160px;
  border: 1px solid var(--border);
}
.step-num {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--navy); color: var(--white);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: .9rem; flex-shrink: 0;
}
.step-label { font-size: .85rem; color: var(--slate); }
.step-label small { color: var(--grey); display: block; margin-top: .15rem; }

/* ── Job cards ─────────────────────────────────────────────────────── */
.job-card {
  border: 1px solid var(--border); border-radius: var(--radius);
  padding: 1rem; margin-bottom: .75rem; background: var(--lighter);
}
.job-domain { font-weight: 700; color: var(--navy); font-size: 1rem; margin-bottom: .4rem; }
.job-status { margin-bottom: .4rem; }
.job-log pre {
  background: var(--navy); color: #a8d5b5; font-size: .78rem;
  padding: .6rem .8rem; border-radius: var(--radius);
  max-height: 160px; overflow-y: auto; margin: .4rem 0;
  white-space: pre-wrap; font-family: 'Courier New', monospace;
}
.job-actions { display: flex; gap: .5rem; flex-wrap: wrap; margin-top: .5rem; }

/* ── Assessments list ──────────────────────────────────────────────── */
.assessments-list { display: flex; flex-direction: column; gap: 1rem; }
.assessment-card {
  background: var(--white); border-radius: var(--radius);
  border: 1px solid var(--border); box-shadow: var(--shadow);
  padding: 1.25rem; border-left: 4px solid var(--border);
}
.assessment-card.status-ok  { border-left-color: var(--low);  }
.assessment-card.status-err { border-left-color: var(--high); }
.assessment-card.status-run { border-left-color: var(--med);  }
.acard-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: .5rem; }
.acard-domain { font-size: 1.1rem; font-weight: 700; color: var(--navy); }
.acard-badges { display: flex; gap: .4rem; flex-wrap: wrap; }
.acard-meta {
  display: flex; gap: 1.2rem; flex-wrap: wrap;
  font-size: .8rem; color: var(--grey); margin-bottom: .75rem;
}
.acard-log { margin-bottom: .75rem; }
.acard-log summary { font-size: .82rem; color: var(--grey); cursor: pointer; }
.acard-log pre {
  background: var(--navy); color: #a8d5b5; font-size: .78rem;
  padding: .6rem .8rem; border-radius: var(--radius);
  margin-top: .4rem; max-height: 160px; overflow-y: auto;
  white-space: pre-wrap; font-family: 'Courier New', monospace;
}
.acard-actions { display: flex; gap: .5rem; flex-wrap: wrap; }

/* ── Empty state ───────────────────────────────────────────────────── */
.empty-state {
  text-align: center; padding: 4rem 2rem;
  background: var(--white); border-radius: var(--radius);
  border: 1px dashed var(--border);
}
.empty-icon  { font-size: 3rem; margin-bottom: 1rem; }
.empty-title { font-size: 1.1rem; font-weight: 600; color: var(--navy); }
.empty-sub   { color: var(--grey); margin-top: .4rem; }

/* ── Responsive ────────────────────────────────────────────────────── */
@media (max-width: 640px) {
  .domain-input-row { flex-direction: column; }
  .btn-launch { width: 100%; justify-content: center; }
  .steps-grid { flex-direction: column; }
  .page-header { flex-direction: column; }
}
