/* ==============================================
   APPLJACK V2 — Vercel-Inspired Modern Theme
   All styles scoped under html.v2
   ============================================== */

@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap");

/* ---------- Design Tokens ---------- */
html.v2 {
  --v2-bg: #ffffff;
  --v2-bg-secondary: #fafafa;
  --v2-border: #eaeaea;
  --v2-text: #171717;
  --v2-text-secondary: #666666;
  --v2-text-tertiary: #999999;
  --v2-accent: #0070f3;
  --v2-accent-light: #e8f4ff;
  --v2-accent-hover: #005bb5;
  --v2-success: #0ea371;
  --v2-success-light: #e6f9f0;
  --v2-danger: #e5484d;
  --v2-danger-light: #ffeef0;
  --v2-warning: #f5a623;
  --v2-radius: 8px;
  --v2-radius-sm: 6px;
  --v2-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
  --v2-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.08);
  --v2-font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --v2-sidebar-bg: #111111;
  --v2-sidebar-text: #a1a1a1;
  --v2-sidebar-text-hover: #ffffff;
  --v2-sidebar-active-bg: rgba(255, 255, 255, 0.08);
  --v2-header-height: 64px;
  --v2-transition: 150ms ease;
}

/* ---------- Base Overrides ---------- */
html.v2 body {
  font-family: var(--v2-font) !important;
  background-color: var(--v2-bg) !important;
  color: var(--v2-text);
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

html.v2 a {
  color: var(--v2-accent);
  text-decoration: none;
  transition: color var(--v2-transition);
}

html.v2 a:hover {
  color: var(--v2-accent-hover);
}

html.v2 h1,
html.v2 h2,
html.v2 h3,
html.v2 h4,
html.v2 h5,
html.v2 h6 {
  color: var(--v2-text);
  font-weight: 600;
}

/* ---------- Sidebar ---------- */
html.v2 #sidebar {
  background-color: var(--v2-sidebar-bg) !important;
  border-right: 1px solid rgba(255, 255, 255, 0.08);
  min-width: 240px !important;
  max-width: 240px !important;
}

html.v2 #sidebar .logo {
  padding: 20px 16px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  margin-bottom: 8px;
}

html.v2 #sidebar .logo img.logo-lg {
  width: 160px;
  opacity: 0.95;
}

html.v2 #sidebar .list-unstyled li {
  margin: 2px 8px;
}

html.v2 #sidebar .list-unstyled li a {
  color: var(--v2-sidebar-text) !important;
  padding: 8px 12px;
  border-radius: var(--v2-radius-sm);
  font-size: 13px;
  font-weight: 500;
  transition: all var(--v2-transition);
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
}

html.v2 #sidebar .list-unstyled li a:hover {
  color: var(--v2-sidebar-text-hover) !important;
  background-color: var(--v2-sidebar-active-bg);
}

html.v2 #sidebar .list-unstyled li.active > a,
html.v2 #sidebar .list-unstyled li a:focus {
  color: var(--v2-sidebar-text-hover) !important;
  background-color: var(--v2-sidebar-active-bg);
  border-left: 4px solid var(--v2-accent) !important;
  padding-left: 8px;
}

html.v2 #sidebar .list-unstyled li a span.fa,
html.v2 #sidebar .list-unstyled li a span.fas,
html.v2 #sidebar .list-unstyled li a span.far {
  width: 18px;
  text-align: center;
  font-size: 14px;
  opacity: 0.7;
}

html.v2 #sidebar #sidebarCollapse {
  background-color: rgba(255, 255, 255, 0.1) !important;
  border: 1px solid rgba(255, 255, 255, 0.15) !important;
  border-radius: var(--v2-radius-sm);
  color: var(--v2-sidebar-text);
  padding: 6px 10px;
  font-size: 12px;
}

html.v2 #sidebar #sidebarCollapse:hover {
  background-color: rgba(255, 255, 255, 0.15) !important;
  color: white;
}

/* Sidebar submenu */
html.v2 #sidebar .has-submenu .submenu {
  background: rgba(255, 255, 255, 0.03);
  border-radius: var(--v2-radius-sm);
  margin-left: 8px;
  padding-left: 12px !important;
}

html.v2 #sidebar .has-submenu .submenu li a {
  font-size: 12px;
  padding: 6px 12px;
}

html.v2 #sidebar .has-submenu .submenu-arrow {
  color: var(--v2-sidebar-text);
  opacity: 0.5;
}

/* Sidebar collapsed state */
html.v2 #sidebar.active {
  min-width: 60px !important;
  max-width: 60px !important;
}

html.v2 #sidebar.active .logo img.logo-sm {
  width: 32px;
  padding: 4px;
}

/* ---------- Page Header ---------- */
html.v2 .page-heading {
  background-color: var(--v2-bg) !important;
  border-bottom: 1px solid var(--v2-border);
  padding: 12px 24px !important;
  min-height: var(--v2-header-height);
  height: auto;
  box-shadow: none;
  position: sticky !important;
  top: 0;
}

html.v2 .page-heading h1 {
  color: var(--v2-text) !important;
  font-size: 20px !important;
  font-weight: 600;
  margin: 0;
  padding: 0 !important;
  gap: 12px;
}

html.v2 .page-heading h1 small {
  color: var(--v2-text-secondary);
  font-size: 14px;
  font-weight: 400;
}

html.v2 .header-back-link {
  color: var(--v2-accent);
  font-size: 13px;
}

html.v2 .header-back-link:hover {
  color: var(--v2-accent-hover);
}

/* V2 Header Controls — countdown, date range, notifications, profile */
html.v2 .v2-header-controls {
  gap: 16px;
}

html.v2 .v2-countdown-label {
  color: var(--v2-text-secondary);
  font-size: 13px;
  white-space: nowrap;
}

html.v2 .v2-countdown-label #countdown {
  color: var(--v2-accent);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}

html.v2 .v2-daterange-form {
  display: flex;
  align-items: center;
}

html.v2 .v2-daterange-form select {
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-sm);
  padding: 6px 12px;
  font-size: 13px;
  font-family: var(--v2-font);
  color: var(--v2-text);
  background-color: var(--v2-bg);
  width: auto;
  margin: 0;
  height: auto;
  cursor: pointer;
  transition: border-color var(--v2-transition);
}

html.v2 .v2-daterange-form select:hover {
  border-color: #ccc;
}

html.v2 .v2-daterange-form select:focus {
  border-color: var(--v2-accent);
  outline: none;
  box-shadow: 0 0 0 2px var(--v2-accent-light);
}

html.v2 .page-heading .notification_wrapper .notify_btn {
  background-color: transparent;
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-sm);
  padding: 6px 10px;
  transition: all var(--v2-transition);
}

html.v2 .page-heading .notification_wrapper .notify_btn:hover {
  background-color: var(--v2-bg-secondary);
  border-color: #ccc;
}

html.v2 .page-heading .notification_wrapper .notify_btn i {
  color: var(--v2-text-secondary) !important;
  font-size: 15px;
}

html.v2 .page-heading .notification_wrapper .notify_btn span {
  background-color: var(--v2-danger);
  font-size: 11px;
  padding: 1px 7px;
}

html.v2 .page-heading .account.dropdown {
  background-color: transparent !important;
  padding: 4px 12px;
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-sm);
  transition: all var(--v2-transition);
}

html.v2 .page-heading .account.dropdown:hover {
  background-color: var(--v2-bg-secondary) !important;
  border-color: #ccc;
}

html.v2 .page-heading .account.dropdown .btn {
  color: var(--v2-text) !important;
}

html.v2 .page-heading .account.dropdown .title {
  color: var(--v2-text);
  font-weight: 500;
}

html.v2 .page-heading .account.dropdown .subtitle {
  color: var(--v2-text-secondary);
}

html.v2 .page-heading .account.dropdown .profile_img img {
  border: 2px solid var(--v2-border);
  width: 36px;
  height: 36px;
}

html.v2 .page-heading .account.dropdown .dropdown-menu {
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius);
  box-shadow: var(--v2-shadow-md);
  overflow: hidden;
}

html.v2 .page-heading .account.dropdown .dropdown-menu .dropdown-item:hover {
  background-color: var(--v2-bg-secondary);
  color: var(--v2-text);
}

/* ---------- Main Content Area ---------- */
/* Remove fixed-header offset from all content sections */
html.v2 .main_view_note,
html.v2 .main-content,
html.v2 .job_section,
html.v2 .create_customer_sec,
html.v2 .rescources_sec,
html.v2 .login_sec {
  margin-top: 0 !important;
  padding-top: 24px;
}

html.v2 .account_master_view_sec {
  padding: 24px 24px 0;
}

html.v2 .main_view_note {
  margin-top: 0;
  background-color: var(--v2-bg-secondary);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius);
  padding: 16px 20px;
  font-size: 13px;
  color: var(--v2-text-secondary);
  line-height: 1.6;
}

html.v2 .main_view_note b {
  color: var(--v2-text);
  font-weight: 600;
}

html.v2 .main_view_note a {
  color: var(--v2-accent);
  font-weight: 500;
  word-break: break-all;
}

/* ---------- Card Styles ---------- */
html.v2 .xml_mapping_sec {
  padding: 0 0 24px;
}

html.v2 .xml_mapping_sec .card {
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius);
  box-shadow: var(--v2-shadow);
  overflow: hidden;
  background: var(--v2-bg);
}

html.v2 .xml_mapping_sec .card-title {
  background-color: var(--v2-bg) !important;
  color: var(--v2-text) !important;
  border-bottom: 1px solid var(--v2-border);
  padding: 16px 20px !important;
}

html.v2 .xml_mapping_sec .card-title h5 {
  color: var(--v2-text) !important;
  font-size: 16px;
  font-weight: 600;
  margin: 0;
}

html.v2 .xml_mapping_sec .card-title h5 span {
  color: var(--v2-text-secondary);
  font-weight: 400;
  font-size: 13px;
}

html.v2 .xml_mapping_sec .card-body {
  padding: 0;
}

/* ---------- Data Table ---------- */
html.v2 .xml_mapping_sec .table-responsive table,
html.v2 .campaign-overview-table {
  border: none !important;
  border-collapse: collapse !important;
  border-spacing: 0 !important;
  border-radius: 0 !important;
  overflow: visible;
  table-layout: fixed;
  width: 100%;
}

html.v2 table {
  border-collapse: collapse;
}

html.v2 th {
  background-color: var(--v2-bg-secondary) !important;
  color: var(--v2-text-secondary) !important;
  font-weight: 500 !important;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 10px 16px !important;
  border-bottom: 1px solid var(--v2-border) !important;
  white-space: nowrap;
}

html.v2 td {
  padding: 12px 16px !important;
  font-size: 14px;
  color: var(--v2-text);
  border-bottom: 1px solid var(--v2-border) !important;
  background-color: transparent !important;
  max-width: none;
}

html.v2 tr {
  background-color: var(--v2-bg) !important;
  transition: background-color var(--v2-transition);
}

html.v2 tbody tr:hover {
  background-color: #f0f4ff !important;
}

html.v2 tr:last-child td {
  border-bottom: none !important;
}

html.v2 td a {
  color: var(--v2-accent);
  font-weight: 500;
}

html.v2 td a:hover {
  color: var(--v2-accent-hover);
  text-decoration: underline;
}

html.v2 .custom_padding {
  padding: 0 !important;
}

/* ---------- Date Range Selector ---------- */
html.v2 .card-title form {
  display: flex;
  align-items: center;
  gap: 8px;
}

html.v2 .card-title form label {
  color: var(--v2-text-secondary);
  font-size: 13px;
  font-weight: 500;
  white-space: nowrap;
  margin: 0;
}

html.v2 .card-title form select,
html.v2 .card-title form .form-control {
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-sm);
  padding: 6px 12px;
  font-size: 13px;
  font-family: var(--v2-font);
  color: var(--v2-text);
  background-color: var(--v2-bg);
  width: auto;
  margin: 0;
  height: auto;
  transition: border-color var(--v2-transition);
  cursor: pointer;
}

html.v2 .card-title form select:hover,
html.v2 .card-title form .form-control:hover {
  border-color: #ccc;
}

html.v2 .card-title form select:focus,
html.v2 .card-title form .form-control:focus {
  border-color: var(--v2-accent);
  outline: none;
  box-shadow: 0 0 0 2px var(--v2-accent-light);
}

/* ---------- Buttons ---------- */
html.v2 .btn_green,
html.v2 .add-customer-button,
html.v2 .add-campaign-button,
html.v2 .edit-btn {
  background-color: var(--v2-text) !important;
  color: white !important;
  border: 1px solid var(--v2-text) !important;
  border-radius: var(--v2-radius-sm);
  font-size: 13px;
  font-weight: 500;
  font-family: var(--v2-font);
  padding: 8px 16px;
  transition: all var(--v2-transition);
  box-shadow: var(--v2-shadow);
}

html.v2 .btn_green:hover,
html.v2 .add-customer-button:hover,
html.v2 .add-campaign-button:hover,
html.v2 .edit-btn:hover {
  background-color: #333 !important;
  border-color: #333 !important;
  opacity: 1 !important;
}

/* Add Publisher / Add Customer button spacing */
html.v2 .card-body .add-customer-button {
  margin: 12px 16px 16px 0;
}

html.v2 .btn_green_dark {
  background-color: var(--v2-bg) !important;
  color: var(--v2-text) !important;
  border: 1px solid var(--v2-border) !important;
  border-radius: var(--v2-radius-sm);
  font-size: 13px;
  font-weight: 500;
  font-family: var(--v2-font);
  padding: 8px 16px;
  transition: all var(--v2-transition);
}

html.v2 .btn_green_dark:hover {
  background-color: var(--v2-bg-secondary) !important;
  border-color: #ccc !important;
  opacity: 1 !important;
}

html.v2 .btn_green_dark img.item-ico,
html.v2 .btn_green img.item-ico {
  display: none;
}

html.v2 .btn_green_dark,
html.v2 .btn_green {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* Color pop: Show Data button */
html.v2 button.btn_green_dark[onclick*="submit"],
html.v2 form button.btn_green,
html.v2 .card.styled button.btn_green_dark {
  background-color: var(--v2-accent) !important;
  color: white !important;
  border-color: var(--v2-accent) !important;
}

html.v2 button.btn_green_dark[onclick*="submit"]:hover,
html.v2 form button.btn_green:hover,
html.v2 .card.styled button.btn_green_dark:hover {
  background-color: var(--v2-accent-hover) !important;
  border-color: var(--v2-accent-hover) !important;
}

/* Color pop: Edit Campaign button */
html.v2 button.btn_green_dark[onclick*="editfeed"] {
  background-color: var(--v2-success) !important;
  color: white !important;
  border-color: var(--v2-success) !important;
}

html.v2 button.btn_green_dark[onclick*="editfeed"]:hover {
  background-color: #0c8b5e !important;
  border-color: #0c8b5e !important;
}

html.v2 .delete_btn,
html.v2 .delete-button-cell button[type="submit"] {
  background-color: var(--v2-bg) !important;
  color: var(--v2-danger) !important;
  border: 1px solid var(--v2-border) !important;
  border-radius: var(--v2-radius-sm);
  font-size: 12px;
  font-weight: 500;
  padding: 6px 12px;
  transition: all var(--v2-transition);
}

html.v2 .delete_btn:hover,
html.v2 .delete-button-cell button[type="submit"]:hover {
  background-color: var(--v2-danger-light) !important;
  border-color: var(--v2-danger) !important;
  color: var(--v2-danger) !important;
}

html.v2 .update_btn {
  background-color: var(--v2-text) !important;
  color: white !important;
  border: 1px solid var(--v2-text) !important;
  border-radius: var(--v2-radius-sm);
  font-size: 13px;
  font-weight: 500;
  font-family: var(--v2-font);
  padding: 8px 16px;
  transition: all var(--v2-transition);
}

html.v2 .update_btn:hover {
  background-color: #333 !important;
  color: white !important;
}

html.v2 .update_btn {
  width: auto !important;
}

html.v2 input[type="submit"],
html.v2 button[type="submit"] {
  background-color: var(--v2-text);
  color: white;
  border: 1px solid var(--v2-text);
  border-radius: var(--v2-radius-sm);
  font-size: 14px;
  font-weight: 500;
  font-family: var(--v2-font);
  padding: 10px 20px;
  transition: all var(--v2-transition);
  cursor: pointer;
  width: auto;
}

html.v2 input[type="submit"]:hover,
html.v2 button[type="submit"]:hover {
  background-color: #333;
}

/* Bootstrap button overrides */
html.v2 .btn-primary {
  background-color: var(--v2-accent) !important;
  border-color: var(--v2-accent) !important;
  color: white !important;
  width: auto;
}

html.v2 .btn-primary:hover {
  background-color: var(--v2-accent-hover) !important;
  border-color: var(--v2-accent-hover) !important;
}

html.v2 .btn-secondary {
  background-color: var(--v2-bg) !important;
  border: 1px solid var(--v2-border) !important;
  color: var(--v2-text) !important;
  width: auto;
}

html.v2 .btn-secondary:hover {
  background-color: var(--v2-bg-secondary) !important;
  border-color: #ccc !important;
}

/* ---------- Form Inputs ---------- */
html.v2 input[type="text"],
html.v2 input[type="password"],
html.v2 input[type="number"],
html.v2 input[type="email"],
html.v2 select {
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-sm);
  padding: 8px 12px;
  font-size: 14px;
  font-family: var(--v2-font);
  color: var(--v2-text);
  background-color: var(--v2-bg);
  transition: border-color var(--v2-transition);
}

html.v2 input[type="text"]:hover,
html.v2 input[type="password"]:hover,
html.v2 input[type="number"]:hover,
html.v2 input[type="email"]:hover,
html.v2 select:hover {
  border-color: #ccc;
}

html.v2 input[type="text"]:focus,
html.v2 input[type="password"]:focus,
html.v2 input[type="number"]:focus,
html.v2 input[type="email"]:focus,
html.v2 select:focus {
  border-color: var(--v2-accent);
  outline: none;
  box-shadow: 0 0 0 2px var(--v2-accent-light);
}

html.v2 label {
  color: var(--v2-text);
  font-weight: 500;
  font-size: 13px;
}

/* ---------- Edit Campaign Form ---------- */
html.v2 .add_field_form {
  background-color: var(--v2-bg) !important;
}
html.v2 .card.styled {
  background: var(--v2-bg) !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}
html.v2 .add_field_form .card-header.card-title {
  padding: 16px 20px !important;
  align-items: center;
  flex-wrap: nowrap;
}
html.v2 .card.styled h4 {
  text-align: left !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  color: var(--v2-text);
  margin-top: 24px !important;
  margin-bottom: 8px !important;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--v2-border);
}
html.v2 .card.styled h4:first-of-type {
  margin-top: 0 !important;
}

/* ---------- Notice/Alert Banner ---------- */
html.v2 .v2-notice {
  background-color: #fffbeb;
  border: 1px solid #fde68a;
  border-radius: var(--v2-radius);
  padding: 12px 16px;
  margin-bottom: 16px;
  font-size: 13px;
  color: #92400e;
}

html.v2 .v2-notice strong {
  font-weight: 600;
}

/* ---------- Footer ---------- */
html.v2 footer {
  background-color: var(--v2-bg) !important;
  color: var(--v2-text-secondary) !important;
  border-top: 1px solid var(--v2-border);
  padding: 16px 0;
  font-size: 13px;
}

html.v2 footer p {
  color: var(--v2-text-tertiary);
}

/* ---------- Countdown Timer ---------- */
html.v2 #countdown {
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  color: var(--v2-accent);
}

/* ---------- Status Badges ---------- */
html.v2 .v2-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 500;
}

html.v2 .v2-badge-active {
  background-color: var(--v2-success-light);
  color: var(--v2-success);
}

html.v2 .v2-badge-inactive {
  background-color: var(--v2-bg-secondary);
  color: var(--v2-text-tertiary);
}

html.v2 .publisher-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 500;
  background-color: var(--v2-success-light);
  color: var(--v2-success);
  text-decoration: none;
  margin: 2px 4px 2px 0;
  transition: all var(--v2-transition);
}

html.v2 .publisher-badge:hover {
  background-color: var(--v2-success);
  color: white;
  text-decoration: none;
}

/* ---------- Summary Stats Bar ---------- */
html.v2 .v2-stats-bar {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 20px;
}

html.v2 .v2-stat-card {
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius);
  padding: 16px 20px;
  background: var(--v2-bg);
  position: relative;
  overflow: hidden;
}

html.v2 .v2-stat-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 4px;
  height: 100%;
}

html.v2 .v2-stat-card.stat-spend::before {
  background: #f59e0b;
}

html.v2 .v2-stat-card.stat-clicks::before {
  background: var(--v2-accent);
}

html.v2 .v2-stat-card.stat-applies::before {
  background: #8b5cf6;
}

html.v2 .v2-stat-card.stat-conversion::before {
  background: var(--v2-success);
}

html.v2 .v2-stat-label {
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--v2-text-secondary);
  margin-bottom: 4px;
}

html.v2 .v2-stat-value {
  font-size: 24px;
  font-weight: 700;
  color: var(--v2-text);
  font-variant-numeric: tabular-nums;
}

html.v2 .v2-stat-card.stat-spend .v2-stat-value {
  color: #d97706;
}

html.v2 .v2-stat-card.stat-clicks .v2-stat-value {
  color: var(--v2-accent);
}

html.v2 .v2-stat-card.stat-applies .v2-stat-value {
  color: #7c3aed;
}

html.v2 .v2-stat-card.stat-conversion .v2-stat-value {
  color: var(--v2-success);
}

@media (max-width: 600px) {
  html.v2 .v2-stats-bar {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }

  html.v2 .v2-stat-value {
    font-size: 18px;
  }
}

/* ---------- Color-Coded Table Metrics ---------- */
html.v2 .v2-metric-green {
  color: var(--v2-success);
  font-weight: 600;
}

html.v2 .v2-metric-amber {
  color: #d97706;
  font-weight: 600;
}

html.v2 .v2-metric-red {
  color: var(--v2-danger);
  font-weight: 600;
}

html.v2 .v2-metric-muted {
  color: var(--v2-text-tertiary);
}

/* ---------- Campaign Portal: Card Header ---------- */
html.v2 .cust-campaign {
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius);
  box-shadow: var(--v2-shadow);
  overflow: hidden;
}

html.v2 .tabcontent {
  border: none !important;
  border-radius: 0 !important;
}

html.v2 .cust-campaign > .card-header {
  background-color: var(--v2-bg) !important;
  border-bottom: 1px solid var(--v2-border);
  padding: 16px 20px !important;
}

html.v2 .cust-campaign > .card-header h2 {
  color: var(--v2-text) !important;
  font-size: 16px !important;
  font-weight: 600;
  padding: 0 !important;
  margin: 0;
  white-space: nowrap;
}

/* Reset old tab button styles */
html.v2 .cust-campaign button,
html.v2 .cust-campaign a {
  border-radius: var(--v2-radius-sm) !important;
  padding: 6px 14px;
  margin-right: 0 !important;
  z-index: auto !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  transform: none !important;
  scale: none !important;
  translate: none !important;
}

/* Data source tabs — clean segmented control */
html.v2 .cust-campaign .data-tabs {
  background: var(--v2-bg-secondary);
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-sm);
  padding: 2px;
}

html.v2 .cust-campaign .data-tab-btn {
  color: var(--v2-text-secondary) !important;
  font-size: 13px;
  font-weight: 500;
  padding: 6px 14px;
  border-radius: 4px;
  background: transparent;
  border: none;
  transition: all var(--v2-transition);
}

html.v2 .cust-campaign .data-tab-btn:hover:not(.active) {
  color: var(--v2-text) !important;
  background: transparent;
}

html.v2 .cust-campaign .data-tab-btn.active {
  background: var(--v2-bg) !important;
  color: var(--v2-text) !important;
  font-weight: 600;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
}

/* Download dropdown trigger — v2 clean style */
html.v2 .cust-campaign .dropdown-trigger {
  background: var(--v2-bg) !important;
  color: var(--v2-text) !important;
  border: 1px solid var(--v2-border) !important;
  border-radius: var(--v2-radius-sm);
  padding: 6px 14px;
  font-size: 13px;
  font-weight: 500;
}

html.v2 .cust-campaign .dropdown-trigger:hover {
  background: var(--v2-bg-secondary) !important;
  border-color: #ccc !important;
}

html.v2 .cust-campaign .dropdown-trigger img {
  display: none;
}

/* Sub-tab buttons (Referrers, Inactive) — clean secondary pills */
html.v2 .v2-subtab-btn {
  background: transparent !important;
  color: var(--v2-text-secondary) !important;
  border: 1px solid var(--v2-border) !important;
  border-radius: var(--v2-radius-sm) !important;
  padding: 6px 14px !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  cursor: pointer;
  transition: all var(--v2-transition);
}

html.v2 .v2-subtab-btn:hover {
  background: var(--v2-bg-secondary) !important;
  color: var(--v2-text) !important;
  border-color: #ccc !important;
}

html.v2 .v2-subtab-btn.active {
  background: var(--v2-bg-secondary) !important;
  color: var(--v2-text) !important;
  border-color: var(--v2-text-secondary) !important;
  font-weight: 600 !important;
}

/* Add campaign button — v2 clean style */
html.v2 .cust-campaign .card-header .btn_green {
  font-size: 13px;
  padding: 6px 14px;
}

/* ---------- Campaign Portal: Table No Horizontal Scroll ---------- */
html.v2 .table-container {
  background-color: var(--v2-bg) !important;
  border-radius: var(--v2-radius);
  box-shadow: none !important;
}

/* Strip nested container styling when inside a card */
html.v2 .cust-campaign .table-container {
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}

html.v2 .cust-campaign .cust-portal {
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

/* Chart container: contain overflow and add spacing below */
html.v2 .cust-campaign .chart-container {
  overflow: hidden;
  position: relative;
  z-index: 0;
  margin-bottom: 16px;
}

html.v2 .cust-portal {
  overflow: hidden !important;
}

html.v2 .cust-portal table {
  table-layout: auto;
  width: 100%;
}

html.v2 .cust-portal th,
html.v2 .cust-portal td {
  padding: 10px 8px !important;
  font-size: 13px;
}

/* Fixed layout + column widths for applportal campaigns table (13 cols) */
html.v2 #campaignsTable {
  table-layout: fixed;
}

html.v2 #campaignsTable th.checkbox-col,
html.v2 #campaignsTable td.checkbox-col {
  width: 32px !important;
  padding: 10px 4px !important;
}

html.v2 #campaignsTable th:nth-child(2) { width: 16%; }   /* Campaign */
html.v2 #campaignsTable th:nth-child(3) { width: 9%; }    /* Campaign ID */
html.v2 #campaignsTable th:nth-child(4) { width: 7%; }    /* Status */
html.v2 #campaignsTable th:nth-child(5) { width: 8%; }    /* Mo. Budget */
html.v2 #campaignsTable th:nth-child(6) { width: 7%; }    /* Spend */
html.v2 #campaignsTable th:nth-child(7) { width: 6%; }    /* Clicks */
html.v2 #campaignsTable th:nth-child(8) { width: 6%; }    /* Applies */
html.v2 #campaignsTable th:nth-child(9) { width: 8%; }    /* Spend/Apply */
html.v2 #campaignsTable th:nth-child(10) { width: 8%; }   /* Spend/Click */
html.v2 #campaignsTable th:nth-child(11) { width: 7%; }   /* Conv. Rate */
html.v2 #campaignsTable th:nth-child(12) { width: 7%; }   /* Jobs Exported */
html.v2 #campaignsTable th:nth-child(13) { width: 8%; }   /* Actions */

html.v2 #campaignsTable td {
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Prevent status/budget/actions from wrapping */
html.v2 #campaignsTable td.status-cell,
html.v2 #campaignsTable td.budget-cell,
html.v2 #campaignsTable td.actions-cell {
  white-space: nowrap;
}

/* ---------- Data Tools: Tool Cards ---------- */
html.v2 .tool-card {
  border: 1px solid var(--v2-border);
  box-shadow: var(--v2-shadow);
  border-radius: var(--v2-radius);
}
html.v2 .tool-card:hover {
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}
html.v2 .tool-card-icon {
  color: var(--v2-accent);
}
html.v2 .tool-card-title {
  color: var(--v2-text);
}
html.v2 .tool-card-button {
  background: var(--v2-accent) !important;
  color: #fff !important;
  border-radius: var(--v2-radius-sm);
}
html.v2 .tool-card-button:hover {
  background: var(--v2-accent-hover) !important;
  color: #fff !important;
}
html.v2 .admin-badge {
  background: var(--v2-danger);
}

/* ---------- Campaign Portal: Action Buttons ---------- */
html.v2 .actions-cell {
  white-space: nowrap;
}
html.v2 .actions-cell .btn {
  background: transparent !important;
  border: 1px solid var(--v2-border) !important;
  border-radius: var(--v2-radius-sm) !important;
  padding: 5px 8px !important;
  font-size: 12px !important;
  line-height: 1 !important;
  transition: all var(--v2-transition);
  color: var(--v2-text-secondary) !important;
}

html.v2 .actions-cell .btn:hover {
  border-color: #ccc !important;
  background: var(--v2-bg-secondary) !important;
  color: var(--v2-text) !important;
}

html.v2 .actions-cell .btn i {
  color: inherit !important;
}

/* View button hover */
html.v2 .actions-cell .btn-info:hover {
  border-color: var(--v2-accent) !important;
  color: var(--v2-accent) !important;
  background: var(--v2-accent-light) !important;
}

/* Edit button hover */
html.v2 .actions-cell .btn-success:hover {
  border-color: var(--v2-success) !important;
  color: var(--v2-success) !important;
  background: var(--v2-success-light) !important;
}

/* Delete button hover */
html.v2 .actions-cell .btn-danger:hover {
  border-color: var(--v2-danger) !important;
  color: var(--v2-danger) !important;
  background: var(--v2-danger-light) !important;
}

/* ---------- Masterview: Expandable Rows ---------- */
html.v2 .expandable-parent {
  cursor: pointer;
}

html.v2 .expandable-parent:hover {
  background-color: var(--v2-accent-light) !important;
}

html.v2 .expand-toggle-cell {
  width: 40px !important;
  min-width: 40px !important;
  text-align: center;
  padding: 12px 8px !important;
}

html.v2 .expand-chevron {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 4px;
  color: var(--v2-text-tertiary);
  transition: all var(--v2-transition);
}

html.v2 .expand-chevron i {
  font-size: 12px;
  transition: transform 0.15s ease;
}

html.v2 .expandable-parent.expanded .expand-chevron i {
  transform: rotate(90deg);
}

html.v2 .expandable-parent.expanded .expand-chevron {
  color: var(--v2-accent);
}

html.v2 .expandable-child-cell {
  padding: 0 16px 16px 16px !important;
  background-color: var(--v2-bg-secondary) !important;
}

html.v2 .expandable-child-row td {
  background-color: var(--v2-bg-secondary) !important;
  font-size: 13px;
  border-bottom: 1px solid var(--v2-border) !important;
}

html.v2 .expandable-child-row .sub-row-name {
  padding-left: 32px !important;
}

html.v2 .campaign-sub-table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid var(--v2-border);
  border-radius: var(--v2-radius-sm);
  overflow: hidden;
}

html.v2 .campaign-sub-table th {
  background-color: #f0f0f0 !important;
  font-size: 11px !important;
  padding: 8px 12px !important;
  font-weight: 600;
}

html.v2 .campaign-sub-table td {
  padding: 8px 12px !important;
  font-size: 13px;
  border-bottom: 1px solid var(--v2-border) !important;
  background-color: var(--v2-bg) !important;
}

html.v2 .campaign-sub-table tr:last-child td {
  border-bottom: none !important;
}

/* ---------- Campaign Portal: Summary Alert ---------- */
html.v2 .alert-info {
  background-color: var(--v2-accent-light) !important;
  border: 1px solid #c2dbf4 !important;
  color: var(--v2-text) !important;
  border-radius: var(--v2-radius-sm);
  font-size: 13px;
}

/* ---------- Campaign Portal: Customer Info & Date Filter Row ---------- */
html.v2 .feed-url {
  background: var(--v2-bg) !important;
  border: 1px solid var(--v2-border) !important;
  box-shadow: var(--v2-shadow) !important;
}

html.v2 .feed-url .healthy-text {
  color: var(--v2-text) !important;
}

html.v2 .campaign-details-grid {
  gap: 4px 20px;
}

html.v2 .campaign-detail-item {
  font-size: 13px;
  color: var(--v2-text);
}

html.v2 .customer-filter-bar {
  border: 1px solid var(--v2-border) !important;
  box-shadow: var(--v2-shadow) !important;
}

/* ---------- AI Mode ---------- */
html.v2 .ai-header {
  background: var(--v2-bg) !important;
  border-bottom: 1px solid var(--v2-border);
  color: var(--v2-text);
}

html.v2 .ai-header h4 {
  color: var(--v2-text) !important;
}

html.v2 .ai-header .text-muted {
  color: var(--v2-text-secondary) !important;
}

html.v2 .ai-icon {
  background: var(--v2-accent-light);
  color: var(--v2-accent);
}

html.v2 .ai-header .btn-outline-secondary {
  color: var(--v2-text-secondary);
  border-color: var(--v2-border);
}

html.v2 .ai-header .btn-outline-secondary:hover {
  background: var(--v2-bg-secondary);
  border-color: #ccc;
  color: var(--v2-text);
}

html.v2 .ai-mode-container {
  border: 1px solid var(--v2-border);
  box-shadow: var(--v2-shadow);
  border-radius: var(--v2-radius);
}

/* ---------- Scrollbar ---------- */
html.v2 ::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

html.v2 ::-webkit-scrollbar-track {
  background: transparent;
}

html.v2 ::-webkit-scrollbar-thumb {
  background: #ddd;
  border-radius: 3px;
}

html.v2 ::-webkit-scrollbar-thumb:hover {
  background: #bbb;
}

/* ---------- Responsive ---------- */
@media (max-width: 600px) {
  html.v2 #sidebar {
    min-width: 0 !important;
    max-width: 52px !important;
  }

  html.v2 #sidebar .list-unstyled li a span.text {
    display: none !important;
  }

  html.v2 #sidebar .logo img {
    display: none;
  }

  html.v2 .page-heading {
    width: calc(100% - 52px) !important;
    right: 0 !important;
    padding: 0 12px !important;
  }

  html.v2 .page-heading h1 {
    font-size: 16px !important;
  }

  html.v2 .account_master_view_sec {
    margin-left: 0 !important;
    padding: 0 12px;
  }

  html.v2 .main_view_note {
    margin-top: 12px;
  }

  html.v2 #content {
    width: 100% !important;
  }
}

@media (min-width: 768px) {
  html.v2 .page-heading {
    padding-inline: 24px !important;
  }
}

/* ---------- Job Pool Analytics ---------- */
.analytics-back-link {
  color: #495057;
  text-decoration: none;
  font-size: 0.85em;
  font-weight: 600;
}

.analytics-back-link:hover {
  color: #007bff;
  text-decoration: none;
}

.analytics-back-link i {
  margin-right: 4px;
}

.analytics-stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 15px;
  margin-bottom: 25px;
}

.analytics-stat-card {
  background: #fff;
  border: 1px solid #dee2e6;
  border-radius: 8px;
  padding: 15px;
  text-align: center;
}

.analytics-stat-card .stat-value {
  font-size: 1.6em;
  font-weight: 700;
  color: #2c3e50;
}

.analytics-stat-card .stat-label {
  font-size: 0.85em;
  color: #6c757d;
  margin-top: 4px;
}

.analytics-chart-container {
  position: relative;
  height: 300px;
  margin-bottom: 20px;
}

.analytics-section {
  background: #fff;
  border: 1px solid #dee2e6;
  border-radius: 8px;
  padding: 20px;
  margin-bottom: 25px;
}

.analytics-section h5 {
  margin: 0;
  color: #2c3e50;
}

.analytics-bucket-table {
  width: 100%;
  font-size: 0.9em;
}

.analytics-bucket-table th,
.analytics-bucket-table td {
  padding: 6px 12px;
  border-bottom: 1px solid #eee;
}

.analytics-bucket-table th {
  background: #f8f9fa;
  font-weight: 600;
  text-align: left;
}

.analytics-bucket-table td:last-child {
  text-align: right;
}

.analytics-bar-fill {
  display: inline-block;
  height: 16px;
  background: #4e73df;
  border-radius: 3px;
  vertical-align: middle;
  margin-right: 8px;
}

.analytics-bar-fill.cpa {
  background: #1cc88a;
}

.analytics-bucket-controls {
  display: flex;
  align-items: center;
  gap: 10px;
}

.analytics-bucket-controls label {
  font-size: 0.85em;
  font-weight: 600;
  color: #495057;
  margin: 0;
}

.analytics-bucket-controls select {
  padding: 4px 8px;
  border: 1px solid #ced4da;
  border-radius: 4px;
  font-size: 0.85em;
}

.analytics-range-form {
  background: #fff;
  border: 1px solid #dee2e6;
  border-radius: 8px;
  padding: 20px;
  margin-bottom: 25px;
}

.analytics-range-form .range-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr) auto;
  gap: 4px 15px;
  align-items: center;
}

.analytics-range-form .range-grid label {
  font-size: 0.85em;
  font-weight: 600;
  color: #495057;
}

.analytics-range-form .range-grid input[type="number"] {
  width: 100%;
  padding: 6px 10px;
  border: 1px solid #ced4da;
  border-radius: 4px;
  font-size: 0.9em;
}

.analytics-range-form .range-grid .btn {
  white-space: nowrap;
}

.analytics-custom-result {
  margin-top: 15px;
  padding: 15px;
  background: #d4edda;
  border: 1px solid #c3e6cb;
  border-radius: 6px;
  font-size: 1.1em;
}

.analytics-custom-result strong {
  font-size: 1.3em;
  color: #155724;
}

.analytics-loading {
  text-align: center;
  padding: 40px;
  color: #6c757d;
}

.analytics-loading i {
  font-size: 1.5em;
  margin-bottom: 10px;
  display: block;
}
