/**
 * Admin panel: B2B SaaS dashboard — Bootstrap overrides
 */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap');

:root {
  --admin-bg: #141418;
  --admin-surface: #1b1b22;
  --admin-card: #1e1e26;
  --admin-border: rgba(255, 255, 255, 0.05);
  --admin-border-input: rgba(255, 255, 255, 0.08);
  --admin-accent: #ff6b00;
  --admin-accent-hover: #ff7a18;
  --admin-text: #ffffff;
  --admin-text-secondary: #b3b3b3;
  --admin-text-muted: #8a8a8a;
  --admin-table-header: #9c9c9c;
  --admin-row-hover: #1f1f27;
  --admin-success: #2d8a5e;
  --admin-warning: #d4a017;
  --admin-danger: #c94a4a;
}

.admin-theme,
body {
  --bs-body-bg: var(--admin-bg);
  --bs-body-color: var(--admin-text);
  --bs-primary: var(--admin-accent);
  --bs-primary-rgb: 255, 107, 0;
  --bs-secondary: var(--admin-surface);
  --bs-border-color: var(--admin-border);
  --bs-link-color: var(--admin-accent);
  --bs-link-hover-color: var(--admin-accent-hover);
}

body {
  background-color: var(--admin-bg);
  color: var(--admin-text);
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

/* Layout */
.admin-theme .container-fluid.mt-4 {
  max-width: 1400px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  padding-bottom: 1.5rem;
  margin-top: 1rem;
}

.admin-theme .container-fluid.mt-4 > .mt-4 {
  margin-top: 1rem !important;
}
.admin-theme .input-group-text {
  background-color: #1e1e26;
}
.admin-theme .btn-check:checked+.btn, .btn.active, .btn.show, .btn:first-child:active, :not(.btn-check)+.btn:active {
  color: #fff;
  background-color: var(--admin-accent);
  border-color: var(--admin-accent);
}
.form-check-input:checked {
  background-color: var(--admin-accent);
  border-color: var(--admin-accent);
}
/* Typography */
.admin-theme h1 { font-size: 1.5rem; font-weight: 600; }
.admin-theme h2 { font-size: 1.3125rem; font-weight: 600; }
.admin-theme h3,
.admin-theme .page-title {
  font-size: 1.25rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
  color: var(--admin-text);
}
.admin-theme h4 { font-size: 1.0625rem; font-weight: 500; color: var(--admin-text); }
.admin-theme h5 { font-size: 0.9375rem; font-weight: 500; color: var(--admin-text); }
.admin-theme h6 { font-size: 0.875rem; font-weight: 500; color: var(--admin-text); }

/* Page header + actions */
.d-flex.justify-content-between.align-items-center.mb-3,
.d-flex.justify-content-between.mb-3 {
  margin-bottom: 0.875rem !important;
}

.d-flex.justify-content-between.align-items-center.mb-3 h3,
.d-flex.justify-content-between.mb-3 h3 {
  margin-bottom: 0;
}

/* Login */
.login-container {
  min-height: 100vh;
  display: flex;
  justify-content: center;
  align-items: center;
  background: var(--admin-bg);
  padding: 1.5rem;
}

.login-card {
  background: var(--admin-card);
  border: 1px solid var(--admin-border);
  border-radius: 8px;
  padding: 2rem;
  width: 100%;
  max-width: 400px;
}

.login-card h2 {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--admin-text);
  margin-bottom: 1.5rem;
}

.login-card .form-label {
  color: var(--admin-text-secondary);
  font-weight: 500;
  font-size: 0.875rem;
}

.login-card .form-control {
  background: var(--admin-card);
  border: 1px solid var(--admin-border-input);
  color: var(--admin-text);
}

.login-card .form-control::placeholder {
  color: var(--admin-text-muted);
}

.login-card .form-control:focus {
  background: var(--admin-card);
  border-color: var(--admin-accent);
  color: var(--admin-text);
  box-shadow: 0 0 0 1px var(--admin-accent);
}

.login-card .form-text.text-muted {
  color: var(--admin-text-muted);
}

.login-card a {
  color: var(--admin-accent);
  text-decoration: none;
  font-size: 0.875rem;
}

.login-card a:hover {
  color: var(--admin-accent-hover);
}

/* Navbar */
.navbar.navbar-dark,
.navbar.bg-dark {
  background-color: var(--admin-surface) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  padding-top: 0.625rem;
  padding-bottom: 0.625rem;
}

.navbar .navbar-brand {
  color: var(--admin-text) !important;
  font-weight: 600;
  font-size: 1rem;
}

.navbar .text-light {
  color: var(--admin-text-secondary) !important;
  font-size: 0.8125rem;
  font-weight: 500;
}

.navbar .btn-outline-light {
  border-color: var(--admin-border);
  color: var(--admin-text-secondary);
  font-size: 0.8125rem;
  font-weight: 500;
  padding: 0.375rem 0.75rem;
  transition: border-color 0.15s ease, color 0.15s ease;
}

.navbar .btn-outline-light:hover {
  border-color: var(--admin-border);
  color: var(--admin-text);
  background: transparent;
}

/* Nav tabs */
.nav-tabs {
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  gap: 0;
  margin-bottom: 0;
}

.nav-tabs .nav-item {
  margin-bottom: -1px;
}

.nav-tabs .nav-link {
  color: var(--admin-text-muted);
  border: none;
  border-bottom: 2px solid transparent;
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: 500;
  transition: color 0.15s ease, border-color 0.15s ease;
}

.nav-tabs .nav-link:hover {
  color: var(--admin-text-secondary);
}

.nav-tabs .nav-link.active {
  color: var(--admin-text);
  background: transparent;
  border-bottom-color: var(--admin-accent);
}

/* Pagination — размер и цвета в стиле админки */
.admin-theme .pagination {
  --pagination-size: 2.25rem;
}
.admin-theme .pagination .page-link {
  min-width: var(--pagination-size);
  height: var(--pagination-size);
  padding: 0 0.5rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.875rem;
  background-color: var(--admin-surface);
  border-color: var(--admin-border);
  color: var(--admin-text);
}
.admin-theme .pagination .page-link:hover {
  background-color: var(--admin-row-hover);
  border-color: var(--admin-border);
  color: var(--admin-text);
}
.admin-theme .pagination .page-item.active .page-link {
  background-color: var(--admin-accent);
  border-color: var(--admin-accent);
  color: #fff;
}
.admin-theme .pagination .page-item.disabled .page-link {
  background-color: var(--admin-surface);
  border-color: var(--admin-border);
  color: var(--admin-text-muted);
}

/* Tables */
.table-responsive {
  background: var(--admin-surface);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 6px;
  overflow-x: auto;
  overflow-y: visible;
  -webkit-overflow-scrolling: touch;
  max-width: 100%;
}

.table {
  color: var(--admin-text);
  margin-bottom: 0;
  font-size: 0.875rem;
  font-weight: 400;
}

.table thead th {
  background: var(--admin-surface);
  color: var(--admin-table-header);
  font-weight: 500;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  padding: 0.625rem 1rem;
}

.table tbody td {
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  padding: 0.625rem 1rem;
  vertical-align: middle;
  color: var(--admin-text);
  transition: background-color 0.15s ease;
}

.table tbody tr:last-child td {
  border-bottom: none;
}

.table tbody tr:hover {
  background-color: var(--admin-row-hover);
}

.table tbody tr:hover td {
  background-color: transparent;
}

.table-striped tbody tr:nth-of-type(odd) {
  background: transparent;
}

.table-striped tbody tr:nth-of-type(odd):hover {
  background-color: var(--admin-row-hover);
}

.table-striped tbody tr:nth-of-type(odd):hover td {
  background-color: transparent;
}

.table code {
  color: var(--admin-text-muted);
  background: var(--admin-surface);
  padding: 0.2em 0.45em;
  border-radius: 4px;
  font-size: 0.75rem;
}

.table td.widget-actions,
.table td:last-child {
  white-space: nowrap;
}

.table .btn-sm {
  padding: 0.25rem 0.5rem;
  min-width: 28px;
}

.table .btn-sm + .btn-sm,
.table .btn-sm + a.btn-sm {
  margin-left: 0.25rem;
}

.widget-row-clickable:hover {
  background-color: var(--admin-row-hover) !important;
  cursor: pointer;
}

.widget-row-clickable:hover td {
  background-color: transparent !important;
}

/* Buttons */
.btn {
  font-size: 0.875rem;
  font-weight: 500;
  transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.btn-primary {
  background-color: #ff6b00;
  border-color: #ff6b00;
  color: #fff;
  padding: 0.5rem 1rem;
}

.btn-primary:hover {
  background-color: #ff7a18;
  border-color: #ff7a18;
  color: #fff;
}

.btn-secondary {
  background: transparent;
  border: 1px solid var(--admin-accent);
  color: var(--admin-accent);
  padding: 0.5rem 1rem;
}

.btn-secondary:hover {
  background: rgba(255, 107, 0, 0.08);
  border-color: var(--admin-accent-hover);
  color: var(--admin-accent-hover);
}

.btn-outline-secondary {
  border: 1px solid var(--admin-border);
  color: var(--admin-text-secondary);
  padding: 0.375rem 0.75rem;
}

.btn-outline-secondary:hover {
  border-color: var(--admin-text-muted);
  color: var(--admin-text);
  background: transparent;
}

.btn-info {
  background: transparent;
  border: 1px solid var(--admin-border);
  color: var(--admin-text);
  padding: 0.25rem 0.5rem;
}

.btn-info:hover {
  border-color: var(--admin-text-muted);
  color: var(--admin-text);
  background: rgba(255, 255, 255, 0.03);
}

.btn-danger {
  background-color: var(--admin-danger);
  border-color: var(--admin-danger);
  color: #fff;
}

.btn-danger:hover {
  background-color: #b83d3d;
  border-color: #b83d3d;
  color: #fff;
}

.btn-close {
  filter: invert(1) grayscale(100%) brightness(200%);
  opacity: 0.5;
}

.btn-close:hover {
  opacity: 0.8;
}

/* Forms */
.form-control,
.form-select {
  background-color: #1e1e26;
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: #ffffff;
  font-size: 0.875rem;
  padding: 0.5rem 0.75rem;
}

.form-control:focus,
.form-select:focus {
  background-color: #1e1e26;
  border-color: #ff6b00;
  color: #ffffff;
  box-shadow: 0 0 0 1px rgba(255, 107, 0, 0.25);
}

.form-control::placeholder {
  color: var(--admin-text-muted);
}

.form-label {
  color: var(--admin-text-secondary);
  font-weight: 500;
  font-size: 0.8125rem;
  margin-bottom: 0.375rem;
}

.form-text.text-muted {
  color: var(--admin-text-muted);
  font-size: 0.8125rem;
}

.form-select.form-select-sm {
  font-size: 0.8125rem;
  padding: 0.25rem 0.5rem;
}

/* All-orders filters: same height for all controls */
#all-orders-filters .form-select,
#all-orders-filters .form-control,
#all-orders-filters .btn-sm {
  height: 38px;
  min-height: 38px;
  box-sizing: border-box;
}
#all-orders-filters .form-select,
#all-orders-filters .form-control {
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
}

.form-control-color {
  background: #1e1e26;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 4px;
}

/* Cards */
.card {
  background: var(--admin-card);
  border: 1px solid var(--admin-border);
  border-radius: 6px;
}

.card-header {
  background: var(--admin-surface);
  border-bottom: 1px solid var(--admin-border);
  color: var(--admin-text);
  font-weight: 500;
}

/* Modals */
.modal-content {
  background: var(--admin-card);
  border: 1px solid var(--admin-border);
  border-radius: 8px;
}

.modal-header {
  border-bottom: 1px solid var(--admin-border);
  padding: 1rem 1.25rem;
}

.modal-title {
  color: var(--admin-text);
  font-size: 1rem;
  font-weight: 600;
}

.modal-body {
  padding: 1.25rem;
}

.modal-footer {
  border-top: 1px solid var(--admin-border);
  padding: 1rem 1.25rem;
}

.modal-backdrop {
  background-color: rgba(0, 0, 0, 0.6);
}

/* Badges */
.badge {
  font-weight: 500;
  font-size: 0.6875rem;
  padding: 0.25em 0.5em;
  letter-spacing: 0.02em;
}

.badge.bg-primary {
  background-color: var(--admin-accent) !important;
  color: #fff;
}

.badge.bg-danger {
  background-color: var(--admin-danger) !important;
  color: #fff;
}

.badge.bg-info,
.badge.bg-info.text-dark {
  background-color: rgba(13, 202, 240, 0.25) !important;
  color: #e0f7fc !important;
  border: 1px solid rgba(13, 202, 240, 0.4);
}

.badge-status-new,
.badge.bg-warning {
  background-color: var(--admin-accent) !important;
  color: #fff;
}

.badge-status-completed {
  background-color: var(--admin-success) !important;
  color: #fff;
}

.badge-status-processing {
  background-color: var(--admin-surface) !important;
  color: var(--admin-text-muted);
  border: 1px solid var(--admin-border);
}

.badge-status-warning {
  background-color: var(--admin-warning) !important;
  color: #1a1a1a;
}

.badge-status-cancelled {
  background-color: var(--admin-surface) !important;
  color: var(--admin-text-muted);
}

.badge-status-not-embedded {
  background-color: var(--admin-accent) !important;
  color: #fff;
}

.badge-status-live {
  background-color: #2563eb !important;
  color: #fff;
}

.badge-status-active {
  background-color: var(--admin-success) !important;
  color: #fff;
}

/* Alerts */
.alert {
  border-radius: 6px;
  border: 1px solid transparent;
  font-size: 0.875rem;
}

.alert-danger {
  background-color: rgba(201, 74, 74, 0.12);
  border-color: rgba(201, 74, 74, 0.25);
  color: #e8a0a0;
}

.alert-info {
  background-color: rgba(255, 255, 255, 0.04);
  border-color: var(--admin-border);
  color: var(--admin-text-secondary);
}

.alert-success {
  background-color: rgba(45, 138, 94, 0.12);
  border-color: rgba(45, 138, 94, 0.25);
  color: #7dd4a8;
}

.text-muted {
  color: var(--admin-text-muted) !important;
}

hr {
  border-color: var(--admin-border);
}

hr.my-4 {
  margin: 1.25rem 0 !important;
}

.input-group .form-control {
  border-right: none;
}

.input-group .btn {
  border-left: 1px solid var(--admin-border);
}

.table td div[style*="background:"] {
  border-color: var(--admin-border) !important;
}

.dropdown-menu {
  background: var(--admin-card);
  border: 1px solid var(--admin-border);
}

.dropdown-item {
  color: var(--admin-text);
}

.dropdown-item:hover {
  background: var(--admin-surface);
  color: var(--admin-text);
}

/* Remove Bootstrap blue */
a:not(.nav-link):not(.btn-primary):focus-visible,
.btn:focus-visible {
  box-shadow: 0 0 0 1px var(--admin-accent);
}

/* Onboarding banner */
.onboarding-banner {
  background: var(--admin-card);
  border: 1px solid var(--admin-border);
  border-left: 3px solid var(--admin-success);
  border-radius: 6px;
  padding: 1rem 1.25rem;
}

.onboarding-banner .btn-primary {
  background-color: var(--admin-success);
  border-color: var(--admin-success);
}

.onboarding-banner .btn-primary:hover {
  background-color: #248055;
  border-color: #248055;
}

.onboarding-accent {
  color: var(--admin-accent);
}

/* Empty state */
.empty-state {
  background: var(--admin-card);
  border: 1px solid var(--admin-border);
  border-radius: 6px;
  padding: 2rem;
  text-align: center;
}

.empty-state h4 {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
}

.empty-state p {
  color: var(--admin-text-muted);
  font-size: 0.875rem;
  margin-bottom: 1rem;
}

.empty-state .btn {
  margin-top: 0.25rem;
}

/* Admin toast notification */
.admin-toast {
  background: var(--admin-card);
  border: 1px solid var(--admin-border);
  border-left: 4px solid var(--admin-success);
  border-radius: 8px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
  color: var(--admin-text);
}

.admin-toast.admin-toast-error {
  border-left-color: var(--admin-danger);
}

.admin-toast .toast-header {
  background: transparent;
  border-bottom: 1px solid var(--admin-border);
  color: var(--admin-text-secondary);
}

.admin-toast .toast-body {
  color: var(--admin-text);
}

/* Order status badges (read-only in table) */
.badge-status-new { background-color: #fd7e14; color: #fff; }
.badge-status-processing { background-color: #0d6efd; color: #fff; }
.badge-status-completed { background-color: #198754; color: #fff; }
.badge-status-cancelled { background-color: #dc3545; color: #fff; }

/* Order detail: status block with border */
.order-detail-status-block {
  border-bottom: 1px solid var(--admin-border);
}

/* Order detail: estimated labels with tooltip */
.order-detail-estimated-label {
  cursor: help;
  border-bottom: 1px dotted var(--admin-text-muted);
  padding-bottom: 1px;
}
.order-detail-estimated-label:hover {
  border-bottom-color: var(--admin-accent);
}
/* Bootstrap tooltip styling for admin theme */
.tooltip .tooltip-inner {
  background-color: #f0f0f0;
  color: #1a1a1a;
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 8px;
  padding: 0.5rem 0.75rem;
  font-size: 0.8125rem;
  font-weight: 500;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
}
.tooltip.bs-tooltip-top .tooltip-arrow::before {
  border-top-color: #f0f0f0;
}
.tooltip.bs-tooltip-bottom .tooltip-arrow::before {
  border-bottom-color: #f0f0f0;
}
.tooltip.bs-tooltip-start .tooltip-arrow::before {
  border-left-color: #f0f0f0;
}
.tooltip.bs-tooltip-end .tooltip-arrow::before {
  border-right-color: #f0f0f0;
}

/* Logs: message column width */
#logs-errors .table th:nth-child(4),
#logs-errors .table td:nth-child(4) {
  width: 300px;
  min-width: 300px;
}

/* Logs: URI column - path on first line, each param on new line, no wrap within */
#logs-errors .table td.logs-uri-cell .logs-uri-path,
#logs-errors .table td.logs-uri-cell .logs-uri-param,
#logs-requests .table td.logs-uri-cell .logs-uri-path,
#logs-requests .table td.logs-uri-cell .logs-uri-param {
  white-space: nowrap;
}

/* Logs requests: request_body and response_body columns */
#logs-requests .table th:nth-child(8),
#logs-requests .table td:nth-child(8),
#logs-requests .table th:nth-child(9),
#logs-requests .table td:nth-child(9) {
  min-width: 300px;
}
