.admin-body { margin: 0; font-family: system-ui, -apple-system, sans-serif; background: #f4f6f8; color: #1f2937; }
.admin-sidebar { position: fixed; inset: 0 auto 0 0; width: 240px; background: #1b2631; color: #fff; padding: 24px 16px; display: flex; flex-direction: column; }
.admin-brand { font-size: 18px; font-weight: 800; margin-bottom: 24px; }
.admin-nav { display: flex; flex-direction: column; gap: 8px; flex: 1; }
.admin-nav-link { color: #cbd5e1; text-decoration: none; padding: 10px 12px; border-radius: 8px; font-size: 14px; }
.admin-nav-link:hover { background: rgba(255,255,255,0.08); color: #fff; }
.admin-sidebar-footer { margin-top: auto; }
.admin-link { color: #e06820; font-weight: 600; text-decoration: none; }
.admin-link:hover { text-decoration: underline; }
.admin-link-btn {
  background: none; border: none; color: #64748b; cursor: pointer; padding: 0;
  font-size: 13px; font-weight: 600; font-family: inherit; line-height: 1.25;
  text-decoration: none; display: inline-flex; align-items: center;
}
.admin-link-btn:hover { text-decoration: underline; }
.admin-main { margin-left: 240px; padding: 32px; max-width: none; }
.admin-flash { padding: 12px 16px; border-radius: 8px; margin-bottom: 16px; font-size: 14px; }
.admin-flash--notice { background: #ecfdf5; color: #065f46; border: 1px solid #a7f3d0; }
.admin-flash--alert { background: #fef2f2; color: #991b1b; border: 1px solid #fecaca; }
.admin-image-preview { display: block; max-width: 220px; max-height: 140px; object-fit: cover; border-radius: 8px; border: 1px solid #e5e7eb; margin-top: 8px; }
.admin-form--inline-filters { display: flex; flex-wrap: wrap; gap: 16px; margin-bottom: 24px; padding: 16px; background: #fff; border: 1px solid #e5e7eb; border-radius: 12px; max-width: none; align-items: flex-end; }
.admin-table-panel { background: #fff; border: 1px solid #e5e7eb; border-radius: 12px; overflow: hidden; box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04); }
.admin-table-panel--scroll { overflow-x: auto; }
.admin-table-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 16px;
  align-items: flex-end;
  padding: 14px 16px;
  background: #f8fafc;
  border-bottom: 1px solid #e2e8f0;
}
.admin-table-toolbar__field { flex: 1 1 160px; min-width: 0; max-width: 220px; }
.admin-table-toolbar__label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #64748b;
  margin-bottom: 6px;
}
.admin-table-form { margin: 0; }
.admin-table-panel .admin-table { border: none; border-radius: 0; box-shadow: none; width: 100%; min-width: 1080px; table-layout: auto; }
.admin-table-panel .admin-table.admin-table--leads { min-width: 0; table-layout: fixed; }
.admin-table--leads th,
.admin-table--leads td { padding: 10px 12px; font-size: 13px; }
.admin-table--leads th { white-space: normal; line-height: 1.3; }
.admin-col--lead-name { width: 11%; }
.admin-col--lead-email { width: 17%; }
.admin-col--lead-phone { width: 11%; }
.admin-col--lead-zip { width: 8%; }
.admin-col--lead-source { width: 10%; }
.admin-col--lead-reason { width: 15%; }
.admin-col--lead-status { width: 12%; }
.admin-col--lead-date { width: 10%; }
.admin-col--lead-changes { width: 7%; }
.admin-col--lead-actions { width: 7%; }
.admin-cell--truncate {
  max-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.admin-cell--nowrap { white-space: nowrap; }
.admin-cell--reason { font-size: 12px; line-height: 1.35; word-break: break-word; }
.admin-cell--status {
  max-width: 0;
  overflow: hidden;
}
.admin-cell--status .admin-badge {
  display: block;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  box-sizing: border-box;
}
.admin-table--filterable .admin-table__labels th { padding-bottom: 8px; border-bottom: none; vertical-align: bottom; white-space: nowrap; }
.admin-table--filterable .admin-table__filters th { padding-top: 0; padding-bottom: 10px; background: #f8fafc; border-bottom: 1px solid #e2e8f0; font-weight: 400; vertical-align: middle; }
.admin-table--filterable .admin-table__filters th:empty { padding: 0; }
.admin-th--supplier { min-width: 148px; }
.admin-th--region { min-width: 168px; }
.admin-th--group { width: 96px; }
.admin-th--client { min-width: 128px; }
.admin-th--energy { min-width: 112px; }
.admin-th--value { width: 88px; }
.admin-th--status { width: 104px; }
.admin-th--actions { width: 108px; }
.admin-table-input { display: block; width: 100%; min-width: 0; padding: 7px 8px; border: 1px solid #cbd5e1; border-radius: 6px; font-size: 13px; font-family: inherit; color: #1e293b; background: #fff; box-sizing: border-box; }
.admin-table-input--narrow { padding-right: 22px; }
.admin-table-input:focus { outline: none; border-color: #e06820; box-shadow: 0 0 0 2px rgba(224, 104, 32, 0.12); }
.admin-range-inputs { display: grid; grid-template-columns: 1fr auto 1fr; gap: 4px; align-items: center; }
.admin-range-sep { color: #94a3b8; font-size: 12px; text-align: center; line-height: 1; }
.admin-table__filter-actions { white-space: nowrap; vertical-align: middle !important; }
.admin-table__filter-actions-inner { display: flex; flex-direction: column; align-items: stretch; gap: 6px; }
.admin-table__filter-actions .admin-btn--sm { padding: 7px 10px; font-size: 12px; width: 100%; }
.admin-link--sm { font-size: 12px; text-align: center; line-height: 1.2; }
.admin-table--filterable .admin-table__filters th.admin-table__filters-spacer { background: #f8fafc; padding: 0; border-bottom: 1px solid #e2e8f0; }
.admin-th--lead-name { min-width: 120px; }
.admin-th--lead-email { min-width: 180px; }
.admin-th--lead-phone { min-width: 120px; }
.admin-th--lead-zip { width: 100px; }
.admin-th--lead-source { min-width: 130px; }
.admin-th--lead-reason { min-width: 150px; }
.admin-th--lead-status { min-width: 120px; }
.admin-th--lead-date { min-width: 130px; }
.admin-th--lead-changes { width: 100px; }
.admin-table-empty-cell { padding: 32px 14px !important; text-align: center; color: #64748b; font-size: 14px; background: #fff; }
.admin-cep-lookup { margin: 0; }
.admin-cep-lookup__bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px 24px;
  padding: 12px 14px;
  background: #f8fafc;
  border-bottom: 1px solid #e2e8f0;
  flex-wrap: wrap;
}
.admin-table-panel--compact .admin-cep-lookup__bar { border-bottom: none; border-radius: 12px; }
.admin-cep-lookup__intro { flex: 1 1 280px; min-width: 0; }
.admin-cep-lookup__title {
  display: block;
  font-size: 13px;
  font-weight: 700;
  color: #334155;
  margin-bottom: 4px;
}
.admin-cep-lookup__help {
  margin: 0;
  font-size: 12px;
  line-height: 1.5;
  color: #64748b;
}
.admin-cep-lookup__controls {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto;
}
.admin-cep-lookup__zip { width: 140px; flex: 0 0 auto; }
.admin-table-panel--compact { margin-bottom: 0; }
.admin-link-city-form { margin: 0; border-bottom: 1px solid #e2e8f0; }
.admin-link-city-form__bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px 24px;
  padding: 12px 14px;
  background: #fff;
  flex-wrap: wrap;
}
.admin-link-city-form__intro { flex: 1 1 240px; min-width: 0; }
.admin-link-city-form__intro strong { display: block; font-size: 13px; color: #334155; margin-bottom: 4px; }
.admin-link-city-form__intro .admin-field-hint { margin: 0; }
.admin-link-city-form__controls { display: flex; align-items: center; gap: 10px; flex: 1 1 320px; max-width: 480px; }
.admin-link-city-form__select { flex: 1; min-width: 0; }
.admin-section-divider { display: flex; align-items: center; gap: 16px; margin: 28px 0 20px; color: #64748b; font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; }
.admin-section-divider::before,
.admin-section-divider::after { content: ""; flex: 1; height: 1px; background: #e2e8f0; }
.admin-field--compact { margin-bottom: 0; min-width: 220px; }
.admin-field--compact-block { margin-top: 20px; margin-bottom: 0; }
.admin-badge--waitlist { background: #fff7ed; color: #c2410c; }
.admin-row--waitlist { background: #fffbf7; }
.admin-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 24px; gap: 16px; flex-wrap: wrap; }
.admin-header-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.admin-header-actions form { display: inline; margin: 0; }
.admin-btn--whatsapp { background: #128C7E; }
.admin-btn--whatsapp:hover { background: #0f7668; }
.admin-grid--2col { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.admin-card-title { font-size: 15px; font-weight: 700; margin: 0 0 16px; color: #334155; letter-spacing: -0.01em; }
.admin-field-hint { font-size: 12px; color: #64748b; margin-top: 6px; line-height: 1.5; }
.admin-section-intro { margin: -8px 0 16px; }
.admin-section { margin-top: 20px; }
.admin-copy-input { width: 100%; padding: 10px 12px; border: 1px solid #e2e8f0; border-radius: 8px; font-size: 13px; background: #f8fafc; color: #475569; box-sizing: border-box; }
.admin-detail-list { margin: 0; padding: 0; }
.admin-detail-row { display: grid; grid-template-columns: minmax(120px, 38%) 1fr; gap: 12px 16px; padding: 11px 0; border-bottom: 1px solid #f1f5f9; align-items: start; }
.admin-detail-row:last-of-type { border-bottom: none; }
.admin-detail-row dt { margin: 0; font-size: 12px; font-weight: 600; color: #64748b; line-height: 1.4; }
.admin-detail-row dd { margin: 0; font-size: 14px; color: #1e293b; line-height: 1.5; word-break: break-word; }
.admin-timeline { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 0; }
.admin-timeline-item { padding: 14px 0; border-bottom: 1px solid #f1f5f9; }
.admin-timeline-item:last-child { border-bottom: none; padding-bottom: 0; }
.admin-timeline-item strong { display: block; font-size: 14px; font-weight: 600; color: #1e293b; }
.admin-timeline-item span { display: block; font-size: 12px; color: #64748b; margin-top: 4px; }
.admin-timeline-item p { margin: 8px 0 0; font-size: 14px; color: #475569; line-height: 1.5; }
@media (max-width: 960px) {
  .admin-grid--2col { grid-template-columns: 1fr; }
  .admin-main { margin-left: 0; padding: 20px 16px 40px; }
  .admin-sidebar { position: static; width: auto; }
  .admin-detail-row { grid-template-columns: 1fr; gap: 4px; }
}
.admin-title { font-size: 24px; font-weight: 800; margin: 0; color: #0f172a; letter-spacing: -0.02em; }
.admin-btn { display: inline-flex; align-items: center; justify-content: center; background: #e06820; color: #fff; text-decoration: none; padding: 10px 16px; border-radius: 8px; border: none; cursor: pointer; font-size: 14px; font-weight: 600; line-height: 1.2; font-family: inherit; }
.admin-btn:hover { filter: brightness(0.95); }
.admin-btn--sm { padding: 8px 14px; font-size: 13px; }
.admin-btn--secondary { background: #64748b; }
.admin-btn--danger { background: #dc2626; }
.admin-btn--success { background: #059669; }
.admin-btn--outline { background: #fff; color: #475569; border: 1px solid #cbd5e1; }
.admin-btn--outline:hover { background: #f8fafc; }
.admin-link-btn--danger { color: #dc2626; }
.admin-link-btn--success { color: #059669; }
.admin-table-actions {
  display: flex; gap: 12px; align-items: center; flex-wrap: wrap; white-space: nowrap;
}
.admin-table-actions .admin-link,
.admin-table-actions .admin-link-btn {
  font-size: 13px; line-height: 1.25;
}
.admin-table-actions form,
.admin-table-actions .admin-inline-form {
  display: inline-flex; align-items: center; margin: 0; padding: 0;
}
.admin-badge--success { background: #ecfdf5; color: #065f46; }
.admin-badge--inactive { background: #f1f5f9; color: #64748b; }
.admin-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 16px; margin-bottom: 32px; }
.admin-card { background: #fff; border: 1px solid #e5e7eb; border-radius: 12px; padding: 20px 22px; box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04); }
.admin-card--form { max-width: 480px; padding: 22px 24px; }
.admin-card-intro { margin: 0 0 20px; font-size: 13px; line-height: 1.5; color: #64748b; }
.admin-actions--split { justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; margin-top: 4px; padding-top: 16px; border-top: 1px solid #f1f5f9; }
.admin-actions__group { display: flex; gap: 10px; flex-wrap: wrap; }
.admin-card-label { font-size: 12px; text-transform: uppercase; color: #64748b; margin-bottom: 8px; }
.admin-card-value { font-size: 32px; font-weight: 800; }
.admin-table { width: 100%; border-collapse: collapse; background: #fff; border-radius: 12px; overflow: hidden; border: 1px solid #e5e7eb; box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04); }
.admin-table th, .admin-table td { padding: 12px 14px; border-bottom: 1px solid #f1f5f9; text-align: left; font-size: 14px; vertical-align: middle; }
.admin-table th { background: #f8fafc; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; color: #64748b; }
.admin-table__head-actions { text-align: right; width: 1%; white-space: nowrap; font-weight: 400; text-transform: none; letter-spacing: normal; }
.admin-table tbody tr:last-child td { border-bottom: none; }
.admin-table a { color: #e06820; font-weight: 600; text-decoration: none; font-size: 13px; }
.admin-table a:hover { text-decoration: underline; }
.admin-table a.admin-btn,
.admin-table a.admin-btn:hover { color: #fff; text-decoration: none; }
.admin-form { background: #fff; border: 1px solid #e5e7eb; border-radius: 14px; padding: 0; width: 100%; max-width: none; box-sizing: border-box; box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06); overflow: hidden; }
.admin-form--embedded { background: transparent; border: none; border-radius: 0; padding: 0; max-width: none; box-shadow: none; overflow: visible; }
.admin-form__body { padding: 24px 28px; display: grid; grid-template-columns: 1fr; gap: 16px; }
.admin-form__body--paired {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: start;
}
.admin-form__footer {
  display: flex; gap: 10px; flex-wrap: wrap; align-items: center;
  padding: 16px 28px; background: #f8fafc; border-top: 1px solid #e2e8f0;
}
.admin-form-section {
  margin: 0; padding: 20px 22px; border: 1px solid #e2e8f0; border-radius: 12px;
  background: #fafbfc; height: 100%; box-sizing: border-box;
}
.admin-form-section + .admin-form-section { margin-top: 0; }
.admin-form-section__head { margin-bottom: 16px; }
.admin-form-section__title {
  display: block; font-size: 15px; font-weight: 700; color: #0f172a; margin: 0 0 4px;
  letter-spacing: -0.01em;
}
.admin-form-section__desc { margin: 0; font-size: 13px; line-height: 1.5; color: #64748b; }
.admin-form-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(min(260px, 100%), 1fr)); gap: 14px 16px;
}
.admin-form-grid--3 { grid-template-columns: repeat(auto-fit, minmax(min(200px, 100%), 1fr)); }
.admin-form-grid .admin-field { margin-bottom: 0; }
.admin-field--full { grid-column: 1 / -1; }
.admin-field-row { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; margin-top: 4px; }
.admin-field--inline { margin-bottom: 0; width: auto; }
.admin-field { margin-bottom: 16px; }
.admin-field label {
  display: block; font-size: 11px; font-weight: 700; margin-bottom: 6px; color: #64748b;
  text-transform: uppercase; letter-spacing: 0.04em;
}
.admin-field input, .admin-field select, .admin-field textarea {
  width: 100%; padding: 10px 12px; border: 1px solid #cbd5e1; border-radius: 8px;
  font-size: 14px; font-family: inherit; color: #1e293b; background: #fff; box-sizing: border-box;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.admin-field-input { width: 100%; padding: 10px 12px; border: 1px solid #cbd5e1; border-radius: 8px; font-size: 14px; font-family: inherit; color: #1e293b; background: #fff; box-sizing: border-box; }
.admin-field-input:focus { outline: none; border-color: #e06820; box-shadow: 0 0 0 3px rgba(224, 104, 32, 0.12); }
.admin-field--checkbox {
  display: flex; align-items: center; gap: 10px; padding: 12px 14px;
  background: #fff; border: 1px solid #e2e8f0; border-radius: 8px;
}
.admin-field--checkbox input { width: 16px; height: 16px; margin: 0; accent-color: #e06820; }
.admin-field--checkbox label { margin: 0; text-transform: none; letter-spacing: normal; font-size: 14px; color: #334155; }
.admin-field--switch { margin-bottom: 0; }
.admin-media-row {
  display: grid; grid-template-columns: 120px 1fr; gap: 16px; align-items: start;
  padding: 14px; background: #fff; border: 1px solid #e2e8f0; border-radius: 10px;
}
.admin-media-row + .admin-media-row { margin-top: 10px; }
.admin-media-row__preview { width: 120px; }
.admin-media-row__preview .admin-image-preview { max-width: 120px; max-height: 80px; margin-top: 0; }
.admin-media-row__fields .admin-field { margin-bottom: 10px; }
.admin-media-row__fields .admin-field:last-child { margin-bottom: 0; }
.admin-form-section .admin-info-box { margin-top: 14px; margin-bottom: 0; }
.admin-form-errors { margin-bottom: 0; }
.admin-form-errors ul { margin: 0; padding-left: 18px; }
.admin-field input:focus, .admin-field select:focus, .admin-field textarea:focus { outline: none; border-color: #e06820; box-shadow: 0 0 0 3px rgba(224, 104, 32, 0.12); }
.admin-field textarea { resize: vertical; min-height: 88px; }
.admin-file-input { padding: 8px 0; border: none; background: transparent; font-size: 13px; }
.admin-actions { display: flex; gap: 10px; margin-top: 8px; padding-top: 4px; }
.admin-form__footer .admin-actions { margin: 0; padding: 0; }
@media (max-width: 960px) {
  .admin-form__body--paired { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  .admin-form__body, .admin-form__footer { padding-left: 18px; padding-right: 18px; }
  .admin-form-grid, .admin-form-grid--3 { grid-template-columns: 1fr; }
}

.admin-workflow {
  margin-bottom: 20px; padding: 18px 20px; background: #fff;
  border: 1px solid #e2e8f0; border-radius: 12px;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
.admin-workflow__title {
  margin: 0 0 14px; font-size: 12px; font-weight: 700; color: #64748b;
  text-transform: uppercase; letter-spacing: 0.05em;
}
.admin-workflow__steps {
  list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px;
}
.admin-workflow__step {
  display: flex; gap: 10px; align-items: flex-start; padding: 12px;
  border: 1px solid #e2e8f0; border-radius: 10px; background: #f8fafc;
}
.admin-workflow__step--current {
  border-color: rgba(224, 104, 32, 0.45); background: #fff7ed;
  box-shadow: 0 0 0 1px rgba(224, 104, 32, 0.12);
}
.admin-workflow__step--done { background: #f0fdf4; border-color: #bbf7d0; }
.admin-workflow__badge {
  flex: 0 0 24px; width: 24px; height: 24px; border-radius: 999px;
  background: #e2e8f0; color: #475569; font-size: 12px; font-weight: 800;
  display: inline-flex; align-items: center; justify-content: center;
}
.admin-workflow__step--current .admin-workflow__badge { background: #e06820; color: #fff; }
.admin-workflow__step--done .admin-workflow__badge { background: #059669; color: #fff; }
.admin-workflow__content { min-width: 0; }
.admin-workflow__content strong { display: block; font-size: 13px; color: #0f172a; margin-bottom: 2px; }
.admin-workflow__content span { display: block; font-size: 12px; line-height: 1.45; color: #64748b; }
.admin-workflow__note {
  margin: 14px 0 0; padding-top: 14px; border-top: 1px solid #e2e8f0;
  font-size: 13px; line-height: 1.5; color: #475569;
}

.admin-form-section--optional { background: #fff; }
.admin-next-step {
  margin-top: 16px; padding: 14px 16px; border-radius: 10px;
  background: #eff6ff; border: 1px solid #bfdbfe;
}
.admin-next-step strong { display: block; font-size: 14px; color: #1e3a8a; margin-bottom: 6px; }
.admin-next-step p { margin: 0 0 10px; font-size: 13px; line-height: 1.5; color: #1e40af; }
.admin-next-step .admin-field-hint { margin: 0; color: #475569; }

.admin-file-upload { min-width: 0; }
.admin-file-upload__label {
  display: block; font-size: 11px; font-weight: 700; color: #64748b;
  text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 4px;
}
.admin-file-upload__hint { margin: 0 0 8px; }
.admin-file-upload__drop {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 10px; min-height: 160px; padding: 16px; border: 1.5px dashed #cbd5e1;
  border-radius: 10px; background: #fff; cursor: pointer; transition: 0.15s;
  position: relative; text-align: center; overflow: hidden;
}
.admin-file-upload__drop:hover { border-color: #e06820; background: #fffbf7; }
.admin-file-upload--selected .admin-file-upload__drop {
  border-color: #86efac; border-style: solid; background: #f0fdf4;
}
.admin-file-upload--selected .admin-file-upload__action {
  background: #dcfce7; color: #166534; max-width: 100%;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.admin-file-upload__drop > *:not(.admin-file-upload__input) { pointer-events: none; }
.admin-file-upload__input {
  position: absolute; inset: 0; opacity: 0; cursor: pointer; width: 100%; height: 100%;
  z-index: 2; font-size: 0;
}
.admin-file-upload__placeholder { display: flex; flex-direction: column; align-items: center; gap: 6px; color: #64748b; font-size: 13px; }
.admin-file-upload__icon {
  width: 36px; height: 36px; border-radius: 999px; background: #f1f5f9; color: #64748b;
  display: inline-flex; align-items: center; justify-content: center; font-size: 22px; font-weight: 300;
}
.admin-file-upload__preview .admin-image-preview { max-width: 100%; max-height: 120px; margin: 0; }
.admin-file-upload__action {
  display: inline-flex; padding: 7px 12px; border-radius: 6px; background: #f1f5f9;
  color: #334155; font-size: 12px; font-weight: 700;
}
.admin-file-upload__filename {
  margin: 0; max-width: 100%; font-size: 12px; font-weight: 600; color: #334155;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

@media (max-width: 960px) {
  .admin-workflow__steps { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
  .admin-workflow__steps { grid-template-columns: 1fr; }
}

.admin-readonly-field {
  padding: 12px 14px; background: #fff; border: 1px solid #e2e8f0; border-radius: 8px;
}
.admin-readonly-field__label {
  display: block; font-size: 11px; font-weight: 700; color: #64748b;
  text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 6px;
}

.admin-header--supplier { align-items: flex-start; margin-bottom: 20px; }
.admin-header__intro { min-width: 0; }
.admin-header__meta {
  margin: 8px 0 0; display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
  font-size: 13px; color: #64748b;
}
.admin-header__meta-sep { color: #cbd5e1; }
.admin-header__meta-text { color: #475569; }

.admin-setup-card {
  margin-bottom: 24px; background: #fff; border: 1px solid #e2e8f0; border-radius: 12px;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04); overflow: hidden;
}
.admin-setup-progress {
  padding: 16px 20px; background: #f8fafc; border-bottom: 1px solid #e2e8f0;
}
.admin-setup-progress__list {
  list-style: none; margin: 0; padding: 0; display: flex; align-items: flex-start; gap: 0;
}
.admin-setup-progress__item { flex: 1 1 0; min-width: 0; position: relative; }
.admin-setup-progress__item:not(:last-child)::after {
  content: ""; position: absolute; top: 14px; left: calc(50% + 18px); right: calc(-50% + 18px);
  height: 2px; background: #e2e8f0; z-index: 0;
}
.admin-setup-progress__item--done:not(:last-child)::after { background: #86efac; }
.admin-setup-progress__link {
  position: relative; z-index: 1; display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 0 8px; text-decoration: none; color: inherit;
}
.admin-setup-progress__link--static { cursor: default; }
.admin-setup-progress__marker {
  width: 28px; height: 28px; border-radius: 999px; border: 2px solid #cbd5e1; background: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 800; color: #64748b;
}
.admin-setup-progress__label {
  font-size: 12px; font-weight: 600; color: #64748b; text-align: center; line-height: 1.3;
}
.admin-setup-progress__item--done .admin-setup-progress__marker {
  border-color: #059669; background: #059669; color: #fff;
}
.admin-setup-progress__item--done .admin-setup-progress__label { color: #334155; }
.admin-setup-progress__item--current .admin-setup-progress__marker {
  border-color: #e06820; background: #fff; color: #c2410c;
  box-shadow: 0 0 0 3px rgba(224, 104, 32, 0.15);
}
.admin-setup-progress__item--current .admin-setup-progress__label { color: #0f172a; font-weight: 700; }
.admin-setup-progress__item--upcoming .admin-setup-progress__link:hover .admin-setup-progress__marker {
  border-color: #94a3b8;
}
.admin-setup-progress__item--upcoming .admin-setup-progress__link:hover .admin-setup-progress__label { color: #334155; }

.admin-setup-card__body {
  padding: 22px 24px;
}
.admin-setup-card__eyebrow {
  margin: 0 0 6px; font-size: 11px; font-weight: 700; color: #64748b;
  text-transform: uppercase; letter-spacing: 0.06em;
}
.admin-setup-card__title {
  margin: 0 0 8px; font-size: 20px; font-weight: 800; color: #0f172a; letter-spacing: -0.02em;
}
.admin-setup-card__desc {
  margin: 0 0 14px; max-width: 520px; font-size: 14px; line-height: 1.55; color: #475569;
}
.admin-setup-card__links { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 8px; }
.admin-setup-card__links-sep { color: #cbd5e1; font-size: 12px; }
.admin-setup-card__hint {
  margin: 0; max-width: 520px; font-size: 12px; line-height: 1.45; color: #94a3b8;
}

@media (max-width: 640px) {
  .admin-setup-progress__list { flex-direction: column; gap: 12px; }
  .admin-setup-progress__item:not(:last-child)::after { display: none; }
  .admin-setup-progress__link { flex-direction: row; justify-content: flex-start; padding: 0; }
  .admin-setup-progress__label { text-align: left; }
}

.admin-section-head {
  display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px;
}
.admin-section-head .admin-card-title { margin: 0; }
.admin-badge--changes { background: #fff7ed; color: #c2410c; }
.admin-alert { border-radius: 12px; padding: 16px 18px; margin-bottom: 20px; border: 1px solid transparent; }
.admin-alert--info { background: #fff7ed; border-color: rgba(224, 104, 32, 0.2); color: #9a3412; }
.admin-alert strong { display: block; font-size: 14px; margin-bottom: 6px; }
.admin-alert p { margin: 0 0 12px; font-size: 13px; line-height: 1.5; }
.admin-change-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.admin-change-list li { display: grid; grid-template-columns: 130px 160px 1fr; gap: 12px; align-items: start; padding: 10px 12px; background: rgba(255,255,255,0.7); border-radius: 8px; font-size: 13px; }
.admin-change-date { color: #64748b; white-space: nowrap; }
.admin-change-field { font-weight: 600; color: #334155; }
.admin-change-values { color: #1e293b; word-break: break-word; }
@media (max-width: 960px) { .admin-change-list li { grid-template-columns: 1fr; gap: 4px; } }
.admin-badge { display: inline-block; padding: 4px 10px; border-radius: 999px; font-size: 11px; font-weight: 700; background: #eef2ff; color: #3730a3; white-space: nowrap; }
.admin-info-box { background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 10px; padding: 14px 16px; margin-bottom: 20px; }
.admin-info-box strong { display: block; font-size: 14px; margin-bottom: 8px; color: #334155; }
.admin-info-list { margin: 0 0 10px 18px; padding: 0; color: #475569; font-size: 13px; line-height: 1.6; }
.admin-coverage-preview { display: flex; flex-direction: column; gap: 4px; background: #fff7ed; border: 1px solid rgba(224, 104, 32, 0.2); border-radius: 10px; padding: 12px 14px; margin-bottom: 18px; font-size: 13px; color: #9a3412; }
.admin-coverage-preview strong { color: #c2410c; }
.admin-table-subtext { font-size: 12px; color: #64748b; margin-top: 4px; font-weight: 400; }

/* Admin sign-in */
.admin-auth-body {
  margin: 0;
  min-height: 100vh;
  font-family: system-ui, -apple-system, sans-serif;
  background: linear-gradient(160deg, #eef2f7 0%, #f8fafc 45%, #fff7ed 100%);
  color: #1f2937;
}
.admin-auth-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px 16px;
  box-sizing: border-box;
}
.admin-auth-card {
  width: 100%;
  max-width: 420px;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  padding: 36px 32px 28px;
  box-shadow: 0 12px 40px rgba(15, 23, 42, 0.08);
  box-sizing: border-box;
}
.admin-auth-brand { text-align: center; margin-bottom: 20px; }
.admin-auth-logo { height: 42px; width: auto; display: inline-block; }
.admin-auth-kicker {
  margin: 10px 0 0;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #64748b;
}
.admin-auth-title {
  margin: 0 0 8px;
  font-size: 24px;
  font-weight: 800;
  line-height: 1.2;
  text-align: center;
  color: #0f172a;
}
.admin-auth-subtitle {
  margin: 0 0 24px;
  font-size: 14px;
  line-height: 1.5;
  text-align: center;
  color: #64748b;
}
.admin-auth-alert {
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #991b1b;
  padding: 12px 14px;
  border-radius: 8px;
  margin-bottom: 16px;
  font-size: 14px;
  line-height: 1.4;
}
.admin-auth-notice {
  background: #ecfdf5;
  border: 1px solid #a7f3d0;
  color: #065f46;
  padding: 12px 14px;
  border-radius: 8px;
  margin-bottom: 16px;
  font-size: 14px;
  line-height: 1.4;
}
.admin-auth-form { margin-top: 4px; }
.admin-auth-form .admin-field label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #64748b;
}
.admin-auth-remember { margin-bottom: 20px; }
.admin-auth-submit { width: 100%; margin-top: 4px; padding: 12px 16px; }
.admin-auth-foot { margin-top: 22px; padding-top: 18px; border-top: 1px solid #f1f5f9; text-align: center; }
.admin-auth-back { font-size: 13px; font-weight: 600; color: #64748b; text-decoration: none; }
.admin-auth-back:hover { color: #e06820; }

@media (max-width: 640px) {
  .admin-auth-card { padding: 28px 20px 22px; }
  .admin-auth-title { font-size: 22px; }
}
