/* =====================================================
   Jongly Theme — Modern Hosting Dashboard
   Inspired by Vultr / Hostinger
   ===================================================== */

/* --- Variables --- */
:root {
  /* ── Layout ── */
  --sidebar-width: 236px;
  --sidebar-collapsed-width: 64px;
  --topbar-height: 60px;
  --card-radius: 12px;

  /* ── Sidebar (dark navy — intentional dark surface, not a random color) ── */
  --sidebar-bg: #0d1b2a;
  --sidebar-border: rgba(255,255,255,0.06);
  --sidebar-text: #8aa0b8;
  --sidebar-text-hover: #dde5ef;
  --sidebar-active-bg: var(--accent);
  --sidebar-active-text: #ffffff;
  --sidebar-logo-bg: #0d1b2a;

  /* ── Topbar ── */
  --topbar-bg: #ffffff;
  --topbar-border: var(--border);
  --topbar-text: var(--text-primary);

  /* ── Content background ── */
  --content-bg: #f4f6f9;
  --content-text: var(--text-primary);

  /* ── Brand accent (green) ── */
  --accent: #4a8a28;
  --accent-hover: #3d7422;
  --accent-light: #f0fdf4;
  --accent-border: #bbf7d0;

  /* ── Semantic colors (danger & warning only — no random palette) ── */
  --danger:        #dc2626;
  --danger-hover:  #b91c1c;
  --danger-light:  #fef2f2;
  --danger-border: #fecaca;

  --warning:        #d97706;
  --warning-light:  #fffbeb;
  --warning-border: #fde68a;

  /* ── Strict gray scale ── */
  --text-primary:   #0f172a;
  --text-secondary: #475569;
  --text-muted:     #64748b;
  --text-subtle:    #94a3b8;

  --border:   #e2e8f0;
  --border-strong: #cbd5e1;
  --surface:  #f8fafc;
  --surface-2: #f1f5f9;

  /* ── Cards ── */
  --card-bg: #ffffff;
  --card-border: var(--border);
  --card-shadow: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --card-shadow-hover: 0 4px 16px rgba(0,0,0,.10);

  /* ── Typography ── */
  --font: 'Poppins', 'Segoe UI', system-ui, -apple-system, sans-serif;
  --transition: all .18s ease;
}

/* --- Reset & Base --- */
*, *::before, *::after { box-sizing: border-box; }

html, body {
  height: 100%;
  margin: 0;
  padding: 0;
}

body {
  font-family: var(--font);
  font-size: 14px;
  color: var(--content-text);
  background: var(--content-bg);
  -webkit-font-smoothing: antialiased;
}

/* =====================================================
   Layout Wrapper
   ===================================================== */
.jongly-wrapper {
  display: flex;
  min-height: 100vh;
}

/* =====================================================
   Sidebar
   ===================================================== */
.jongly-sidebar {
  width: var(--sidebar-width);
  min-height: 100vh;
  background: var(--sidebar-bg);
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  position: fixed;
  top: 0; left: 0; bottom: 0;
  z-index: 1040;
  transition: width 0.2s ease;
  overflow-y: auto;
  overflow-x: hidden;
}

.jongly-sidebar::-webkit-scrollbar { width: 3px; }
.jongly-sidebar::-webkit-scrollbar-track { background: transparent; }
.jongly-sidebar::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.08); border-radius: 4px; }

/* ── Logo ── */
.sidebar-logo {
  display: flex;
  align-items: center;
  padding: 0 22px;
  height: 64px;
  min-height: 64px;
  text-decoration: none;
  flex-shrink: 0;
  margin-bottom: 4px;
}

.sidebar-logo img {
  max-height: 36px;
  max-width: 160px;
  object-fit: contain;
}

.sidebar-logo-text {
  font-size: 18px;
  font-weight: 800;
  color: #ffffff;
  letter-spacing: -0.5px;
}

.sidebar-logo-text span { color: var(--accent); }

/* ── Nav ── */
.sidebar-nav {
  flex: 1;
  padding: 4px 0 8px;
  display: flex;
  flex-direction: column;
}

.sidebar-nav-group {
  padding: 0 12px;
  margin-bottom: 4px;
}

.sidebar-nav-section {
  padding: 18px 6px 6px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: #4b6282;
  white-space: nowrap;
}

.sidebar-nav-item {
  display: block;
  margin: 2px 0;
}

.sidebar-nav-link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  color: #8aa0b8;
  text-decoration: none;
  font-size: 13.5px;
  font-weight: 500;
  border-radius: 9px;
  transition: background 0.14s, color 0.14s;
  white-space: nowrap;
}

.sidebar-nav-link:hover {
  background: rgba(255,255,255,0.06);
  color: #dde5ef;
  text-decoration: none;
}

.sidebar-nav-link:hover .sidebar-nav-icon { color: #adc3d8; }

/* Active — solid accent pill like the reference */
.sidebar-nav-link.active {
  background: var(--accent);
  color: #ffffff;
  font-weight: 600;
}

.sidebar-nav-link.active .sidebar-nav-icon { color: rgba(255,255,255,0.90); }
.sidebar-nav-link.active:hover { background: var(--accent-hover); color: #fff; }

.sidebar-nav-icon {
  width: 18px;
  text-align: center;
  font-size: 14px;
  flex-shrink: 0;
  color: #506070;
  transition: color 0.14s;
}

.sidebar-nav-label { flex: 1; line-height: 1; }

.sidebar-nav-badge {
  margin-left: auto;
  font-size: 10.5px;
  font-weight: 700;
  background: rgba(255,255,255,0.15);
  color: #fff;
  border-radius: 20px;
  padding: 2px 7px;
  min-width: 20px;
  text-align: center;
  line-height: 1.4;
}

.sidebar-nav-link.active .sidebar-nav-badge {
  background: rgba(255,255,255,0.25);
}

/* ── Footer ── */
.sidebar-footer {
  padding: 8px 12px 16px;
  border-top: 1px solid rgba(255,255,255,0.06);
  flex-shrink: 0;
}

.sidebar-footer-link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  color: #506070;
  text-decoration: none;
  font-size: 13.5px;
  font-weight: 500;
  border-radius: 9px;
  transition: background 0.14s, color 0.14s;
}

.sidebar-footer-link:hover {
  background: rgba(255,255,255,0.06);
  color: #8aa0b8;
  text-decoration: none;
}

.sidebar-footer-link .sidebar-nav-icon { color: #506070; }

/* =====================================================
   Sidebar Collapsed State (desktop)
   ===================================================== */
@media (min-width: 992px) {
  .sidebar-collapsed .jongly-sidebar { width: var(--sidebar-collapsed-width); }
  .sidebar-collapsed .jongly-main    { margin-left: var(--sidebar-collapsed-width); }

  .sidebar-collapsed .sidebar-logo { justify-content: center; padding: 0; }
  .sidebar-collapsed .sidebar-logo-text { display: none; }
  .sidebar-collapsed .sidebar-logo img { max-width: 32px; max-height: 32px; }

  .sidebar-collapsed .sidebar-nav-group { padding: 0 8px; }
  .sidebar-collapsed .sidebar-nav-section { display: none; }
  .sidebar-collapsed .sidebar-nav-link {
    justify-content: center; padding: 11px 0; gap: 0;
  }
  .sidebar-collapsed .sidebar-nav-label { display: none; }
  .sidebar-collapsed .sidebar-nav-icon { width: auto; font-size: 16px; color: #8aa0b8; }
  .sidebar-collapsed .sidebar-nav-link.active .sidebar-nav-icon { color: #fff; }
  .sidebar-collapsed .sidebar-nav-badge { display: none; }
  .sidebar-collapsed .sidebar-footer { padding: 8px 8px 16px; }
  .sidebar-collapsed .sidebar-footer-link {
    justify-content: center; padding: 11px 0; gap: 0;
  }
}

/* =====================================================
   Main Content Area
   ===================================================== */
.jongly-main {
  flex: 1;
  min-width: 0;
  margin-left: var(--sidebar-width);
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  transition: margin-left 0.2s ease;
}

/* =====================================================
   Topbar
   ===================================================== */
.jongly-topbar {
  height: var(--topbar-height);
  background: var(--topbar-bg);
  border-bottom: 1px solid var(--topbar-border);
  display: flex;
  align-items: center;
  padding: 0 28px;
  gap: 12px;
  position: sticky;
  top: 0;
  z-index: 1030;
  box-shadow: 0 1px 0 #e8edf2;
}

.topbar-toggle {
  background: none;
  border: none;
  padding: 7px 8px;
  border-radius: 7px;
  color: var(--text-subtle);
  cursor: pointer;
  font-size: 15px;
  display: flex;
  align-items: center;
  transition: background 0.14s, color 0.14s;
  margin-right: 2px;
  flex-shrink: 0;
}

.topbar-toggle:hover {
  background: var(--surface-2);
  color: var(--text-secondary);
}

/* Search */
.topbar-search {
  flex: 1;
  max-width: 340px;
}

.topbar-search .input-group {
  background: #f4f6f9;
  border: 1.5px solid #eaeff5;
  border-radius: 9px;
  overflow: hidden;
  transition: border-color 0.16s, box-shadow 0.16s;
}

.topbar-search .input-group-prepend .btn {
  background: transparent;
  border: none;
  color: #b0bec5;
  padding: 0 10px;
  font-size: 13px;
}

.topbar-search .form-control {
  background: transparent;
  border: none;
  font-size: 13px;
  color: var(--content-text);
  padding: 7px 12px 7px 0;
}

.topbar-search .form-control:focus { box-shadow: none; background: transparent; }
.topbar-search .form-control::placeholder { color: #b0bec5; }

.topbar-search .input-group:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(74,138,40,0.10);
  background: #fff;
}

.topbar-spacer { flex: 1; }

.topbar-actions {
  display: flex;
  align-items: center;
  gap: 2px;
}

/* Icon buttons */
.topbar-btn {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: transparent;
  border: none;
  color: var(--text-subtle);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  cursor: pointer;
  position: relative;
  transition: background 0.14s, color 0.14s;
  text-decoration: none;
}

.topbar-btn:hover {
  background: var(--surface-2);
  color: var(--text-secondary);
  text-decoration: none;
}

/* Remove the browser default blue focus box; show a clean accent ring on keyboard nav */
.topbar-btn:focus { outline: none; box-shadow: none; }
.topbar-btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--accent-light);
}

.topbar-btn .badge-dot {
  position: absolute;
  top: 7px; right: 7px;
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--red);
  border: 2px solid #fff;
}

/* Divider between icon buttons and user */
.topbar-actions-divider {
  width: 1px;
  height: 22px;
  background: var(--border);
  margin: 0 6px;
  flex-shrink: 0;
}

/* User menu */
.topbar-user {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 5px 10px 5px 6px;
  border-radius: 10px;
  cursor: pointer;
  border: 1.5px solid transparent;
  transition: background 0.14s, border-color 0.14s;
  text-decoration: none;
  color: var(--content-text);
  position: relative;
  margin-left: 4px;
}

.topbar-user:hover {
  background: #f4f6f9;
  border-color: var(--border);
  text-decoration: none;
  color: var(--content-text);
}

.topbar-user-avatar {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--accent), #6ab53a);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  flex-shrink: 0;
}

.topbar-user-info { display: none; flex-direction: column; }
@media (min-width: 768px) { .topbar-user-info { display: flex; } }

.topbar-user-name {
  font-size: 13px;
  font-weight: 600;
  line-height: 1.2;
  max-width: 120px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--text-primary);
}

.topbar-user-role {
  font-size: 11px;
  color: var(--text-subtle);
  line-height: 1;
}

.topbar-user-chevron {
  font-size: 10px;
  color: #b0bec5;
  margin-left: 2px;
  flex-shrink: 0;
  display: none;
}
@media (min-width: 768px) { .topbar-user-chevron { display: block; } }

/* Dropdown */
.topbar-dropdown {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 12px 40px rgba(0,0,0,0.12), 0 2px 8px rgba(0,0,0,0.06);
  min-width: 210px;
  z-index: 9999;
  overflow: hidden;
  display: none;
}

.topbar-user.open .topbar-dropdown { display: block; }

.topbar-dropdown-header {
  padding: 14px 16px 12px;
  border-bottom: 1px solid #f1f5f9;
  background: #fafbfc;
}

.topbar-dropdown-name {
  font-weight: 700;
  font-size: 13px;
  color: var(--text-primary);
  margin-bottom: 2px;
}

.topbar-dropdown-email {
  font-size: 11.5px;
  color: var(--text-subtle);
}

.topbar-dropdown-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  font-size: 13px;
  color: var(--text-secondary);
  text-decoration: none;
  transition: background 0.12s;
}

.topbar-dropdown-item:hover {
  background: #f4f6f9;
  color: var(--text-primary);
  text-decoration: none;
}

.topbar-dropdown-item i {
  width: 16px;
  text-align: center;
  font-size: 13px;
  color: var(--text-subtle);
}

.topbar-dropdown-divider {
  border: none;
  border-top: 1px solid #f1f5f9;
  margin: 4px 0;
}

/* =====================================================
   Content Area
   ===================================================== */
.jongly-content {
  flex: 1;
  padding: 28px 32px;
}

.jongly-page-header {
  margin-bottom: 24px;
}

.jongly-page-title {
  font-size: 21px;
  font-weight: 800;
  color: var(--text-primary);
  margin: 0 0 4px;
  letter-spacing: -0.3px;
}

.jongly-page-subtitle {
  font-size: 13px;
  color: var(--text-muted);
  margin: 0;
}

/* Breadcrumb — replaced by .jl-breadcrumb below */
.jongly-breadcrumb {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 0;
  margin-bottom: 20px;
  list-style: none;
  font-size: 12.5px;
}

.jongly-breadcrumb li { display: flex; align-items: center; gap: 6px; }
.jongly-breadcrumb li + li::before {
  content: '/';
  color: var(--border-strong);
}

.jongly-breadcrumb a { color: var(--text-muted); text-decoration: none; }
.jongly-breadcrumb a:hover { color: var(--accent); }
.jongly-breadcrumb .active { color: var(--text-secondary); font-weight: 600; }

/* =====================================================
   Stat Cards (Home Dashboard)
   ===================================================== */
.jongly-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 18px;
  margin-bottom: 28px;
}

.stat-card {
  background: var(--card-bg);
  border: 1.5px solid var(--card-border);
  border-radius: 14px;
  padding: 22px 20px;
  display: flex;
  align-items: flex-start;
  gap: 16px;
  text-decoration: none;
  color: inherit;
  transition: box-shadow 0.16s, transform 0.14s, border-color 0.16s;
  box-shadow: 0 1px 4px rgba(0,0,0,0.05);
  position: relative;
  overflow: hidden;
}

.stat-card:hover {
  box-shadow: 0 6px 24px rgba(0,0,0,0.10);
  transform: translateY(-2px);
  text-decoration: none;
  color: inherit;
  border-color: var(--accent);
}

.stat-card-icon {
  width: 46px;
  height: 46px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 19px;
  flex-shrink: 0;
}

.stat-card-icon.blue   { background: #eff6ff; color: #3b82f6; }
.stat-card-icon.green  { background: #f0fdf4; color: #10b981; }
.stat-card-icon.red    { background: var(--danger-light); color: #ef4444; }
.stat-card-icon.orange { background: var(--warning-light); color: #f59e0b; }
.stat-card-icon.purple { background: #f5f3ff; color: #8b5cf6; }
.stat-card-icon.indigo { background: #f0fdf4; color: #4a8a28; }

.stat-card-body { flex: 1; }

.stat-card-value {
  font-size: 30px;
  font-weight: 800;
  color: var(--text-primary);
  line-height: 1;
  margin-bottom: 5px;
  letter-spacing: -0.5px;
}

.stat-card-label {
  font-size: 12px;
  color: var(--text-subtle);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.stat-card-accent {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 3px;
  border-radius: 0 0 14px 14px;
}

.stat-card-accent.blue   { background: #3b82f6; }
.stat-card-accent.green  { background: #10b981; }
.stat-card-accent.red    { background: #ef4444; }
.stat-card-accent.orange { background: #f59e0b; }
.stat-card-accent.indigo { background: #4a8a28; }
.stat-card-accent.purple { background: #8b5cf6; }

/* =====================================================
   Content Cards
   ===================================================== */
.jongly-card {
  background: var(--card-bg);
  border: 1.5px solid var(--border);
  border-radius: 14px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
  margin-bottom: 22px;
  overflow: hidden;
}

.jongly-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 22px;
  border-bottom: 1px solid #f1f5f9;
}

.jongly-card-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0;
  display: flex;
  align-items: center;
  gap: 9px;
}

.jongly-card-title i {
  color: var(--accent);
  font-size: 14px;
}

.jongly-card-actions { display: flex; gap: 8px; }

.jongly-card-body { padding: 22px; }
.jongly-card-body-flush { padding: 0; }

.jongly-card-footer {
  padding: 12px 22px;
  border-top: 1px solid #f1f5f9;
  background: #fafbfc;
  font-size: 12.5px;
  color: var(--text-muted);
}

/* =====================================================
   List Items (services, domains, etc.)
   ===================================================== */
.jongly-list-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 13px 20px;
  border-bottom: 1px solid var(--card-border);
  transition: var(--transition);
  text-decoration: none;
  color: inherit;
}

.jongly-list-item:last-child { border-bottom: none; }

.jongly-list-item:hover {
  background: var(--surface);
  text-decoration: none;
  color: inherit;
}

.jongly-list-icon {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  background: var(--surface-2);
  color: var(--text-muted);
  flex-shrink: 0;
}

.jongly-list-info { flex: 1; overflow: hidden; }

.jongly-list-name {
  font-size: 13.5px;
  font-weight: 600;
  color: var(--content-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.jongly-list-meta {
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 2px;
}

.jongly-list-arrow {
  color: var(--border-strong);
  font-size: 12px;
}

/* Status Badges */
.jongly-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 11.5px;
  font-weight: 600;
}

.jongly-badge::before {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: currentColor;
}

.jongly-badge-active   { background: #f0fdf4; color: #16a34a; }
.jongly-badge-pending  { background: var(--warning-light); color: var(--warning); }
.jongly-badge-inactive { background: var(--surface); color: var(--text-muted); }
.jongly-badge-danger   { background: var(--danger-light); color: var(--danger); }

/* =====================================================
   Buttons
   ===================================================== */
.btn-jongly {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  border-radius: 7px;
  font-size: 13px;
  font-weight: 600;
  border: none;
  cursor: pointer;
  transition: var(--transition);
  text-decoration: none;
  line-height: 1.4;
}

.btn-jongly-primary {
  background: var(--accent);
  color: #fff;
}
.btn-jongly-primary:hover { background: var(--accent-hover); color: #fff; text-decoration: none; }

.btn-jongly-secondary {
  background: var(--surface-2);
  color: var(--text-secondary);
  border: 1px solid var(--border);
}
.btn-jongly-secondary:hover { background: #e2e8f0; color: var(--content-text); text-decoration: none; }

.btn-jongly-sm { padding: 5px 10px; font-size: 12px; }

.btn-jongly-outline {
  background: transparent;
  color: var(--accent);
  border: 1px solid var(--accent);
}
.btn-jongly-outline:hover { background: var(--accent); color: #fff; text-decoration: none; }

/* =====================================================
   Welcome Banner
   ===================================================== */
.jongly-welcome {
  background: linear-gradient(135deg, #1e4d10 0%, #2d6b1a 40%, #4a8a28 75%, #5ea832 100%);
  border-radius: 16px;
  padding: 30px 32px;
  color: #fff;
  margin-bottom: 28px;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
  box-shadow: 0 4px 20px rgba(74,138,40,0.30);
}

.jongly-welcome::before {
  content: '';
  position: absolute;
  right: -50px; top: -60px;
  width: 220px; height: 220px;
  border-radius: 50%;
  background: rgba(255,255,255,.06);
  pointer-events: none;
}

.jongly-welcome::after {
  content: '';
  position: absolute;
  right: 80px; bottom: -70px;
  width: 180px; height: 180px;
  border-radius: 50%;
  background: rgba(255,255,255,.04);
  pointer-events: none;
}

.jongly-welcome-text { position: relative; z-index: 1; }

.jongly-welcome-text h2 {
  font-size: 21px;
  font-weight: 800;
  margin: 0 0 6px;
  letter-spacing: -0.3px;
}

.jongly-welcome-text p {
  font-size: 13.5px;
  margin: 0;
  opacity: .80;
}

.jongly-welcome-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  position: relative;
  z-index: 1;
}

.btn-welcome-primary {
  background: #fff;
  color: #3d7422;
  font-weight: 700;
  padding: 9px 20px;
  border-radius: 8px;
  font-size: 13px;
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.14s, color 0.14s;
  box-shadow: 0 2px 8px rgba(0,0,0,0.12);
}

.btn-welcome-primary:hover { background: #f0fdf4; color: #2d5a1b; text-decoration: none; }

.btn-welcome-outline {
  background: rgba(255,255,255,0.12);
  color: #fff;
  font-weight: 700;
  padding: 9px 20px;
  border-radius: 8px;
  font-size: 13px;
  border: 1.5px solid rgba(255,255,255,.40);
  cursor: pointer;
  text-decoration: none;
  transition: background 0.14s, border-color 0.14s;
}

.btn-welcome-outline:hover {
  border-color: rgba(255,255,255,.75);
  background: rgba(255,255,255,.20);
  color: #fff;
  text-decoration: none;
}

/* =====================================================
   Quick Actions Grid
   ===================================================== */
.quick-actions {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: 14px;
}

.quick-action-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 20px 12px;
  background: var(--card-bg);
  border: 1.5px solid var(--border);
  border-radius: 12px;
  text-decoration: none;
  color: var(--text-secondary);
  font-size: 12.5px;
  font-weight: 600;
  transition: border-color 0.14s, box-shadow 0.14s, transform 0.12s, color 0.14s;
  box-shadow: 0 1px 4px rgba(0,0,0,0.04);
  text-align: center;
}

.quick-action-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
  box-shadow: 0 4px 16px rgba(74,138,40,0.12);
  text-decoration: none;
  transform: translateY(-2px);
}

.quick-action-btn i {
  font-size: 22px;
  color: var(--accent);
}

/* =====================================================
   Forms
   ===================================================== */
.form-control {
  border: 1.5px solid var(--border);
  border-radius: 8px;
  padding: 9px 12px;
  font-size: 13.5px;
  color: var(--content-text);
  background: #fff;
  transition: border-color 0.15s, box-shadow 0.15s;
}

.form-control:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(74,138,40,0.10);
  outline: none;
}

.form-label {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 5px;
  display: block;
}

/* =====================================================
   Alerts / Flash Messages
   ===================================================== */
.alert {
  border-radius: 8px;
  border: none;
  padding: 13px 16px;
  font-size: 13.5px;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 16px;
}

.alert-success { background: #f0fdf4; color: #166534; }
.alert-danger   { background: var(--danger-light); color: #991b1b; }
.alert-warning  { background: var(--warning-light); color: #92400e; }
.alert-info     { background: #eff6ff; color: #1e40af; }

.alert-dismissible .close {
  padding: 10px 12px;
  color: inherit;
  opacity: .5;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  background: none;
  border: none;
  position: absolute;
  top: 0;
  right: 0;
}

/* =====================================================
   Tables
   ===================================================== */
.jongly-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13.5px;
}

.jongly-table thead th {
  padding: 11px 16px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text-muted);
  background: var(--surface);
  border-bottom: 1px solid var(--card-border);
  text-align: left;
}

.jongly-table tbody td {
  padding: 13px 16px;
  border-bottom: 1px solid #f1f5f9;
  color: var(--content-text);
  vertical-align: middle;
}

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

.jongly-table tbody tr:hover td { background: var(--surface); }

/* =====================================================
   Notification Panel
   ===================================================== */

/* Bell wrapper — position anchor for the dropdown */
.notif-wrapper {
  position: relative;
}

/* Count badge on the bell */
.notif-btn { position: relative; }

.notif-count-badge {
  position: absolute;
  top: 2px; right: 2px;
  min-width: 17px; height: 17px;
  box-sizing: border-box;
  background: var(--red);
  color: #fff;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 700;
  line-height: 13px;
  text-align: center;
  padding: 0 4px;
  border: 2px solid #fff;
  pointer-events: none;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  box-shadow: 0 1px 3px rgba(0,0,0,0.18);
}

/* Panel */
.notif-panel {
  display: none;
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  width: 340px;
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  box-shadow: 0 16px 48px rgba(0,0,0,0.14), 0 2px 8px rgba(0,0,0,0.06);
  z-index: 9999;
  overflow: hidden;
  animation: notifFadeIn 0.15s ease;
}

.notif-panel.open { display: flex; flex-direction: column; }

@keyframes notifFadeIn {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Panel header */
.notif-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px 12px;
  border-bottom: 1.5px solid #f1f5f9;
  background: #fafbfc;
  flex-shrink: 0;
}

.notif-panel-title {
  font-size: 13.5px;
  font-weight: 700;
  color: var(--text-primary);
  display: flex;
  align-items: center;
  gap: 7px;
}

.notif-panel-title i { color: var(--accent); font-size: 13px; }

.notif-panel-count {
  background: var(--accent);
  color: #fff;
  font-size: 10px;
  font-weight: 800;
  padding: 1px 6px;
  border-radius: 20px;
  line-height: 1.5;
}

.notif-dismiss-all {
  background: none;
  border: none;
  color: var(--accent);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 6px;
  transition: background 0.12s;
}

.notif-dismiss-all:hover { background: var(--accent-light); }

/* Scrollable list */
.notif-list {
  max-height: 340px;
  overflow-y: auto;
  flex: 1;
}

.notif-list::-webkit-scrollbar { width: 4px; }
.notif-list::-webkit-scrollbar-track { background: transparent; }
.notif-list::-webkit-scrollbar-thumb { background: #e2e8f0; border-radius: 4px; }

/* Individual item */
.notif-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 13px 16px;
  border-bottom: 1px solid #f8fafc;
  transition: background 0.12s;
  position: relative;
  text-decoration: none;
  color: inherit;
}

.notif-item:hover { text-decoration: none; }

.notif-item:last-child { border-bottom: none; }
.notif-item:hover { background: var(--surface); }

/* Left-border accent per type */
.notif-item::before {
  content: '';
  position: absolute;
  left: 0; top: 10px; bottom: 10px;
  width: 3px; border-radius: 0 3px 3px 0;
}

.notif-type-warning::before { background: #f59e0b; }
.notif-type-danger::before  { background: #ef4444; }
.notif-type-info::before    { background: #3b82f6; }
.notif-type-success::before { background: #10b981; }

/* Icon circle per type */
.notif-item-icon {
  width: 34px; height: 34px;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; flex-shrink: 0;
}

.notif-type-warning .notif-item-icon { background: var(--warning-light); color: var(--warning); }
.notif-type-danger  .notif-item-icon { background: var(--danger-light); color: var(--danger); }
.notif-type-info    .notif-item-icon { background: #eff6ff; color: #2563eb; }
.notif-type-success .notif-item-icon { background: #f0fdf4; color: #16a34a; }

.notif-item-body { flex: 1; min-width: 0; }

.notif-item-msg {
  font-size: 12.5px;
  color: var(--text-secondary);
  line-height: 1.5;
  word-break: break-word;
}

.notif-item-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11.5px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  margin-top: 5px;
}

.notif-item-link:hover { color: var(--accent-hover); text-decoration: underline; }
.notif-item-link i { font-size: 9px; }

/* Dismiss X button */
.notif-item-dismiss {
  background: none;
  border: none;
  color: var(--border-strong);
  font-size: 11px;
  cursor: pointer;
  padding: 2px 4px;
  border-radius: 4px;
  flex-shrink: 0;
  transition: color 0.12s, background 0.12s;
  margin-top: 1px;
}

.notif-item-dismiss:hover { color: var(--text-muted); background: var(--surface-2); }
.notif-item-dismiss { position: relative; z-index: 2; }

/* Full-item click overlay (marks read + follows link) */
.notif-item-hit {
  position: absolute;
  inset: 0;
  z-index: 1;
}

/* Optional bold heading for admin-broadcast notices */
.notif-item-title {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 2px;
  word-break: break-word;
}

/* Unread emphasis: tinted row + a dot on the icon */
.notif-item.notif-unread { background: var(--accent-light); }
.notif-item.notif-unread .notif-item-icon::after {
  content: '';
  position: absolute;
  top: -2px; right: -2px;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--red);
  border: 2px solid #fff;
}
.notif-item.notif-unread .notif-item-icon { position: relative; }

/* Empty state */
.notif-empty {
  padding: 40px 20px;
  text-align: center;
}

.notif-empty-icon {
  font-size: 36px;
  color: #e2e8f0;
  margin-bottom: 12px;
}

.notif-empty-text {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-secondary);
  margin-bottom: 4px;
}

.notif-empty-sub {
  font-size: 12.5px;
  color: var(--text-subtle);
}

/* Panel footer */
.notif-panel-footer {
  padding: 10px 16px;
  border-top: 1px solid #f1f5f9;
  background: #fafbfc;
  flex-shrink: 0;
}

.notif-footer-link {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--text-muted);
  text-decoration: none;
  transition: color 0.12s;
}

.notif-footer-link:hover { color: var(--accent); text-decoration: none; }
.notif-footer-link i { font-size: 12px; }

/* =====================================================
   Footer
   ===================================================== */
.jl-footer {
  margin-top: 8px;
  padding: 20px 24px;
  border-top: 1px solid var(--card-border);
  background: var(--topbar-bg);
  text-align: center;
}
.jl-footer-links {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 6px 20px;
  margin-bottom: 10px;
}
.jl-footer-links a {
  font-size: 12.5px;
  color: var(--text-secondary);
  text-decoration: none;
  transition: color .15s;
}
.jl-footer-links a:hover { color: var(--accent); text-decoration: none; }
.jl-footer-copy {
  font-size: 12px;
  color: var(--text-subtle);
  margin: 0;
}

/* =====================================================
   Sidebar Overlay (mobile)
   ===================================================== */
.sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.5);
  z-index: 1039;
}

/* =====================================================
   Responsive
   ===================================================== */
@media (max-width: 991px) {
  .jongly-sidebar {
    transform: translateX(-100%);
  }

  .jongly-sidebar.sidebar-open {
    transform: translateX(0);
  }

  .sidebar-overlay.active {
    display: block;
  }

  .jongly-main {
    margin-left: 0;
  }

  .jongly-content {
    padding: 16px;
  }

  .jongly-stats {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 575px) {
  .jongly-stats {
    grid-template-columns: 1fr 1fr;
  }

  .jongly-welcome {
    padding: 20px;
  }

  .jongly-welcome-text h2 {
    font-size: 16px;
  }
}

/* =====================================================
   Override Bootstrap defaults
   ===================================================== */
.card {
  border: 1px solid var(--card-border);
  border-radius: var(--card-radius);
  box-shadow: var(--card-shadow);
}

.card-header {
  background: #fff;
  border-bottom: 1px solid var(--card-border);
  font-weight: 600;
  font-size: 14px;
}

.btn-primary {
  background: var(--accent);
  border-color: var(--accent);
}
.btn-primary:hover, .btn-primary:focus {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
}

.btn-default {
  background: var(--surface-2);
  border-color: var(--border);
  color: var(--text-secondary);
}
.btn-default:hover {
  background: #e2e8f0;
  border-color: var(--border-strong);
  color: var(--content-text);
}

a { color: var(--accent); }
a:hover { color: var(--accent-hover); }

/* Notifications popover */
#accountNotificationsContent { display: none; }

/* Sidebar included in existing panel system */
.primary-content { width: 100%; }

/* Login page center */
body.login-page {
  background: var(--content-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
}

.jongly-login-card {
  width: 100%;
  max-width: 440px;
  background: #fff;
  border: 1px solid var(--card-border);
  border-radius: 16px;
  box-shadow: 0 8px 40px rgba(0,0,0,.10);
  padding: 44px 40px;
  margin: auto;
}

.jongly-login-logo {
  text-align: center;
  margin-bottom: 24px;
}

.jongly-login-title {
  font-size: 24px;
  font-weight: 700;
  text-align: center;
  margin-bottom: 6px;
  color: var(--content-text);
  letter-spacing: -0.3px;
}

.jongly-login-subtitle {
  font-size: 13.5px;
  color: var(--text-muted);
  text-align: center;
  margin-bottom: 28px;
}

/* Login form fields */
.login-form .form-control {
  height: 42px;
  font-size: 14px;
}

.login-form .form-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 6px;
}

/* Login button full width */
.login-form .btn-jongly-primary,
#login.btn-jongly-primary {
  width: 100%;
  height: 44px;
  font-size: 14.5px;
  justify-content: center;
  border-radius: 8px;
  letter-spacing: .01em;
}

/* Input group — keep append inline */
.input-group { flex-wrap: nowrap; }

/* Fullpage overlay */
#fullpage-overlay {
  position: fixed;
  inset: 0;
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(4px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
}
#fullpage-overlay.w-hidden { display: none !important; }
#fullpage-overlay .outer-wrapper { text-align: center; }

/* WHMCS uses `w-hidden` as a generic "hidden" utility (modal errors/loaders,
   sort-value spans, etc.) but the jongly theme never defined it, so those
   elements leaked into view. Define it here — excluding <table> so the
   DataTables `.show()` reveal flow is untouched. */
.w-hidden:not(table) { display: none; }

/* Notifications */
.client-alerts { list-style: none; padding: 0; margin: 0; min-width: 280px; }
.client-alerts li a {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 14px;
  font-size: 13px;
  color: var(--content-text);
  text-decoration: none;
  border-bottom: 1px solid var(--card-border);
}
.client-alerts li a:hover { background: var(--surface); }
.client-alerts li.none { padding: 12px 16px; font-size: 13px; color: var(--text-muted); }

/* ============================================================
   Modals — unified jongly theme (generate-password, 2FA,
   confirmation, generic modal.tpl, card-header modals, etc.)
   ============================================================ */
.modal-content {
  border-radius: 16px;
  border: none;
  box-shadow: 0 24px 70px rgba(15,23,42,.28), 0 6px 16px rgba(15,23,42,.12);
  overflow: hidden;
}

/* Green branded header (overrides Bootstrap bg-primary / #eee / card-header) */
.modal-header,
.modal-header.bg-primary,
.modal-header.card-header,
.modal-header.card-header.bg-primary {
  background: linear-gradient(135deg, var(--accent) 0%, #3d7422 100%) !important;
  color: #fff !important;
  border-bottom: none !important;
  padding: 16px 22px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  text-align: left !important;
}

.modal-title {
  color: #fff !important;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.4;
  margin: 0;
}

/* Close (×) button on the green header */
.modal-header .close {
  color: #fff;
  opacity: .8;
  text-shadow: none;
  font-size: 24px;
  font-weight: 400;
  margin: 0;
  padding: 0 4px;
  line-height: 1;
  transition: opacity .14s;
}
.modal-header .close:hover,
.modal-header .close:focus { color: #fff; opacity: 1; }

.modal-body { padding: 22px; color: var(--text-secondary); }
.modal-body label,
.modal-body .col-form-label { color: var(--text-primary); font-weight: 600; }

.modal-footer {
  border-top: 1px solid var(--border);
  background: var(--surface);
  padding: 14px 22px;
  gap: 8px;
}

/* Inputs inside modals pick up the themed control look */
.modal-body .form-control {
  border-radius: 8px;
  border: 1.5px solid var(--border);
}
.modal-body .form-control:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-light);
}

/* Dialog vertical centering + small-screen fit */
.modal.show, .modal.in { align-items: flex-start; justify-content: center; }
.modal-dialog { margin-top: 6vh; }

/* Network issues bar */
.network-issues-notifications {
  background: var(--warning-light);
  border-bottom: 1px solid #fef3c7;
  padding: 10px 24px;
  font-size: 13px;
  color: #92400e;
  display: flex;
  align-items: center;
  gap: 8px;
}

/* Return to admin button */
.btn-return-to-admin {
  position: fixed !important;
  bottom: 20px !important;
  right: 20px !important;
  top: auto !important;
  left: auto !important;
  background: #1e293b !important;
  color: #fff !important;
  border-radius: 8px !important;
  padding: 8px 14px !important;
  font-size: 13px !important;
  text-decoration: none !important;
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  z-index: 9998 !important;
  box-shadow: 0 4px 12px rgba(0,0,0,.2) !important;
  width: auto !important;
  height: auto !important;
  writing-mode: horizontal-tb !important;
  transform: none !important;
}
.btn-return-to-admin:hover { background: #334155 !important; color: #fff !important; text-decoration: none !important; }

/* Hide return-to-admin on guest/not-logged-in pages */
body.guest-page .btn-return-to-admin { display: none !important; }

/* Sidebar has children = WHMCS sidebar panels */
.jongly-sidebar-panels {
  padding: 16px;
}

.jongly-sidebar-panels .sidebar-widget {
  background: rgba(255,255,255,.04);
  border: 1px solid var(--sidebar-border);
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 12px;
}

.jongly-sidebar-panels .list-group-item {
  background: transparent;
  border-color: var(--sidebar-border);
  color: var(--sidebar-text);
  font-size: 13px;
  padding: 9px 14px;
}

.jongly-sidebar-panels .list-group-item:hover,
.jongly-sidebar-panels .list-group-item.active {
  background: var(--sidebar-active-bg);
  color: var(--sidebar-text-hover);
}

/* Panel cards on dashboard pages */
.card.card-accent-blue   { border-top: 3px solid #3b82f6; }
.card.card-accent-green  { border-top: 3px solid #10b981; }
.card.card-accent-red    { border-top: 3px solid #ef4444; }
.card.card-accent-gold   { border-top: 3px solid #f59e0b; }
.card.card-accent-purple { border-top: 3px solid #4a8a28; }

/* =====================================================
   Modal Safety Net
   Bootstrap modals must always be hidden until opened.
   theme.min.css should cover this, but belt-and-braces.
   ===================================================== */
.modal         { display: none; }
.modal.show    { display: flex; }
.modal.in      { display: flex; }
.modal-backdrop         { display: none; }
.modal-backdrop.show    { display: block; }
.modal-backdrop.in      { display: block; }

/* Hide generate-password and language modal content outside modals */
#generate-password { display: none; }
#generate-password.show { display: block; }

/* Shopping cart badge */
#cartItemCount {
  background: var(--accent);
  border-radius: 20px;
  font-size: 11px;
  padding: 2px 6px;
}

/* =====================================================
   Guest / Not Logged In Layout
   No sidebar — main fills full width
   ===================================================== */
.jongly-main-guest {
  margin-left: 0 !important;
  background: var(--content-bg);
}

.jongly-main-guest .jongly-topbar {
  background: #ffffff;
  border-bottom: 1px solid var(--topbar-border);
}

.jongly-main-guest .jongly-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-height: calc(100vh - var(--topbar-height) - 56px);
}

/* Guest topbar: show logo/brand since no sidebar */
.jongly-topbar-brand {
  display: none;
  align-items: center;
  gap: 10px;
  font-size: 17px;
  font-weight: 700;
  color: var(--content-text);
  text-decoration: none;
  margin-right: 16px;
}
.jongly-topbar-brand:hover { text-decoration: none; color: var(--content-text); }
.jongly-topbar-brand img { max-height: 28px; }

.jongly-main-guest .jongly-topbar-brand {
  display: flex;
}

@media (max-width: 991px) {
  .jongly-main-guest {
    margin-left: 0 !important;
  }
}

/* =====================================================
   DASHBOARD MODERNIZATION — Full Layout Override
   ===================================================== */

/* --- Hide WHMCS left widget column, make content full width --- */
.jongly-content .col-lg-3,
.jongly-content .col-sm-3 {
  display: none !important;
}
.jongly-content .col-lg-9,
.jongly-content .col-sm-9 {
  flex: 0 0 100% !important;
  max-width: 100% !important;
  width: 100% !important;
  padding: 0 !important;
}
.jongly-content .d-lg-none.col-12 {
  display: none !important;
}
.jongly-content .row {
  margin: 0;
}

/* --- Modern Card Overrides --- */
.jongly-content .card {
  background: #fff;
  border: 1px solid var(--card-border);
  border-radius: var(--card-radius);
  box-shadow: var(--card-shadow);
  margin-bottom: 20px;
  overflow: visible;
}
.jongly-content .card-header,
.jongly-content .card-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--content-text);
  background: #fff;
  border-bottom: 1px solid var(--card-border);
  padding: 16px 20px;
  margin: 0;
  border-radius: var(--card-radius) var(--card-radius) 0 0;
}
.jongly-content .card-body {
  padding: 20px;
}
.jongly-content .card-footer {
  background: var(--surface);
  border-top: 1px solid var(--card-border);
  padding: 12px 20px;
  font-size: 13px;
  color: var(--text-muted);
}

/* --- Modern Table --- */
.jongly-content .table,
.jongly-content table.dataTable {
  width: 100% !important;
  border-collapse: collapse;
  font-size: 13.5px;
  background: #fff;
  border-radius: var(--card-radius);
  overflow: hidden;
}
.jongly-content .table thead th,
.jongly-content table.dataTable thead th {
  padding: 11px 16px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text-muted);
  background: var(--surface);
  border-bottom: 2px solid var(--card-border);
  border-top: none;
  white-space: nowrap;
  cursor: pointer;
}
.jongly-content .table thead th:hover { background: var(--surface-2); }
.jongly-content .table tbody td,
.jongly-content table.dataTable tbody td {
  padding: 13px 16px;
  border-bottom: 1px solid #f1f5f9;
  border-top: none;
  color: var(--content-text);
  vertical-align: middle;
}
.jongly-content .table tbody tr:last-child td { border-bottom: none; }
.jongly-content .table tbody tr:hover td { background: var(--surface); }
.jongly-content .table-container {
  background: #fff;
  border: 1px solid var(--card-border);
  border-radius: var(--card-radius);
  box-shadow: var(--card-shadow);
  overflow: hidden;
}

/* DataTables controls */
.dataTables_wrapper .dataTables_length select,
.dataTables_wrapper .dataTables_filter input {
  border: 1px solid var(--card-border);
  border-radius: 7px;
  padding: 6px 10px;
  font-size: 13px;
  background: #fff;
  color: var(--content-text);
  outline: none;
}
.dataTables_wrapper .dataTables_filter input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(99,102,241,.12);
}
.dataTables_wrapper .dataTables_length,
.dataTables_wrapper .dataTables_filter,
.dataTables_wrapper .dataTables_info,
.dataTables_wrapper .dataTables_paginate {
  font-size: 13px;
  color: var(--text-muted);
  padding: 12px 16px;
}
.dataTables_wrapper .dataTables_paginate .paginate_button {
  border-radius: 6px !important;
  padding: 5px 10px !important;
  font-size: 13px !important;
  color: var(--text-secondary) !important;
  border: 1px solid transparent !important;
  cursor: pointer;
}
.dataTables_wrapper .dataTables_paginate .paginate_button:hover {
  background: var(--surface-2) !important;
  border-color: var(--card-border) !important;
  color: var(--content-text) !important;
}
.dataTables_wrapper .dataTables_paginate .paginate_button.current {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: #fff !important;
  font-weight: 600;
}
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled {
  opacity: .4;
  cursor: not-allowed !important;
}

/* --- Status / Label Badges --- */
.jongly-content .label,
.jongly-content span.label {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 11.5px;
  font-weight: 600;
  text-transform: capitalize;
  letter-spacing: .01em;
}
.jongly-content .label::before {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
}
.jongly-content .label.status-active,
.jongly-content .status-active    { background: #f0fdf4; color: #16a34a; }
.jongly-content .label.status-paid,
.jongly-content .status-paid      { background: #f0fdf4; color: #16a34a; }
.jongly-content .label.status-pending,
.jongly-content .status-pending   { background: var(--warning-light); color: var(--warning); }
.jongly-content .label.status-unpaid,
.jongly-content .status-unpaid    { background: var(--danger-light); color: var(--danger); }
.jongly-content .label.status-cancelled,
.jongly-content .status-cancelled { background: var(--surface); color: var(--text-muted); }
.jongly-content .label.status-suspended,
.jongly-content .status-suspended { background: var(--danger-light); color: var(--danger); }
.jongly-content .label.status-overdue,
.jongly-content .status-overdue   { background: #fff7ed; color: #c2410c; }
.jongly-content .label.status-draft,
.jongly-content .status-draft     { background: #f0fdf4; color: #4a8a28; }
.jongly-content .label.label-success { background: #f0fdf4; color: #16a34a; }
.jongly-content .label.label-danger  { background: var(--danger-light); color: var(--danger); }
.jongly-content .label.label-warning { background: var(--warning-light); color: var(--warning); }
.jongly-content .label.label-default { background: var(--surface); color: var(--text-muted); }
.jongly-content .label.label-info    { background: #eff6ff; color: #2563eb; }

/* --- Form Groups & Controls --- */
.jongly-content .form-group {
  margin-bottom: 16px;
}
.jongly-content .col-form-label,
.jongly-content label.col-form-label,
.jongly-content .control-label {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 5px;
  display: block;
}
.jongly-content .form-control {
  border: 1px solid var(--border);
  border-radius: 7px;
  padding: 9px 12px;
  font-size: 13.5px;
  color: var(--content-text);
  background: #fff;
  transition: border-color .15s, box-shadow .15s;
  height: auto;
}
.jongly-content .form-control:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(99,102,241,.12);
  outline: none;
}
.jongly-content .form-control:disabled,
.jongly-content .form-control[readonly] {
  background: var(--surface);
  color: var(--text-subtle);
  cursor: not-allowed;
}
.jongly-content select.form-control {
  cursor: pointer;
}
.jongly-content .input-group .form-control { border-radius: 7px 0 0 7px; }
.jongly-content .input-group { align-items: stretch; }
.jongly-content .input-group .input-group-append { display: flex; align-items: stretch; }
.jongly-content .input-group .input-group-append .btn { display: flex; align-items: center; height: 100%; }

/* Attachment group — equalise all elements to same height */
.attachment-group { align-items: stretch !important; display: flex !important; }
.attachment-group .custom-file { height: 40px !important; flex: 1; }
.attachment-group .custom-file-label {
  height: 40px !important;
  line-height: 40px !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  display: flex !important;
  align-items: center !important;
}
.attachment-group .custom-file-label::after {
  height: 38px !important;
  line-height: 38px !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  display: flex !important;
  align-items: center !important;
}
.attachment-group .input-group-append { display: flex !important; }
.attachment-group .input-group-append .btn {
  height: 40px !important;
  display: flex !important;
  align-items: center !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}
.jongly-content .input-group-append .btn,
.jongly-content .input-group-text {
  border: 1px solid var(--border);
  border-left: none;
  border-radius: 0 7px 7px 0;
  background: var(--surface);
  align-self: stretch;
  height: auto;
  color: var(--text-muted);
  font-size: 13px;
  padding: 9px 14px;
}

/* --- Buttons --- */
.jongly-content .btn {
  border-radius: 7px;
  font-size: 13px;
  font-weight: 600;
  padding: 8px 18px;
  border: none;
  transition: all .15s;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  line-height: 1.4;
}
.jongly-content .btn-primary,
.jongly-content .btn-success {
  background: var(--accent);
  color: #fff;
  border: none;
}
.jongly-content .btn-primary:hover,
.jongly-content .btn-success:hover {
  background: var(--accent-hover);
  color: #fff;
}
.jongly-content .btn-default,
.jongly-content .btn-secondary,
.jongly-content .btn-light {
  background: var(--surface-2);
  color: var(--text-secondary);
  border: 1px solid var(--border);
}
.jongly-content .btn-default:hover,
.jongly-content .btn-secondary:hover,
.jongly-content .btn-light:hover {
  background: #e2e8f0;
  color: var(--content-text);
}
.jongly-content .btn-danger {
  background: #ef4444;
  color: #fff;
  border: none;
}
.jongly-content .btn-danger:hover { background: #dc2626; color: #fff; }
.jongly-content .btn-sm { padding: 5px 12px; font-size: 12px; }
.jongly-content .btn-lg { padding: 11px 24px; font-size: 15px; }

/* --- Nav Tabs (used on services, invoices detail pages) --- */
.jongly-content .nav-tabs {
  border-bottom: 2px solid var(--card-border);
  gap: 4px;
  margin-bottom: 20px;
}
.jongly-content .nav-tabs .nav-item .nav-link {
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  padding: 10px 16px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-muted);
  border-radius: 0;
  background: transparent;
  transition: color .15s, border-color .15s;
}
.jongly-content .nav-tabs .nav-item .nav-link:hover {
  color: var(--content-text);
  border-bottom-color: var(--border-strong);
  background: transparent;
}
.jongly-content .nav-tabs .nav-item .nav-link.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
  background: transparent;
}

/* --- Page heading / filter panel at top --- */
.jongly-content .panel-heading,
.jongly-content .panel-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--content-text);
  padding: 16px 20px;
  background: #fff;
  border-bottom: 1px solid var(--card-border);
  margin: 0;
}
.jongly-content .panel,
.jongly-content .panel-default {
  border: 1px solid var(--card-border);
  border-radius: var(--card-radius);
  box-shadow: var(--card-shadow);
  background: #fff;
  margin-bottom: 20px;
}
.jongly-content .panel-body { padding: 20px; }

/* --- Breadcrumb modernize (legacy Bootstrap fallback) --- */
.jongly-content ol.breadcrumb {
  background: transparent;
  padding: 0;
  margin-bottom: 16px;
  font-size: 12.5px;
}
.jongly-content .breadcrumb-item a { color: var(--text-muted); text-decoration: none; }
.jongly-content .breadcrumb-item a:hover { color: var(--accent); }
.jongly-content .breadcrumb-item.active { color: var(--content-text); font-weight: 500; }
.jongly-content .breadcrumb-item + .breadcrumb-item::before { color: var(--border-strong); }

/* ============================================================
   BREADCRUMB — jl-breadcrumb
   ============================================================ */

.jl-breadcrumb {
  display: flex;
  align-items: center;
  gap: 0;
  margin-bottom: 18px;
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 10px;
  padding: 9px 16px;
  font-size: 12.5px;
  line-height: 1;
}

/* Home (first item) */
.jl-breadcrumb-home {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--text-muted);
  text-decoration: none;
  font-weight: 600;
  transition: color .13s;
  white-space: nowrap;
}
.jl-breadcrumb-home i {
  font-size: 12px;
  color: var(--accent);
}
.jl-breadcrumb-home:hover { color: var(--accent); text-decoration: none; }

/* Chevron separator */
.jl-breadcrumb-sep {
  display: inline-flex;
  align-items: center;
  margin: 0 8px;
  color: var(--border-strong);
  font-size: 9px;
}

/* Middle links */
.jl-breadcrumb-link {
  display: inline-flex;
  align-items: center;
  color: var(--text-muted);
  font-weight: 500;
  text-decoration: none;
  white-space: nowrap;
  transition: color .13s;
}
.jl-breadcrumb-link:hover { color: var(--accent); text-decoration: none; }

/* Current / last item */
.jl-breadcrumb-current {
  display: inline-flex;
  align-items: center;
  color: var(--text-primary);
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 280px;
}

/* --- Well (used in some WHMCS pages) --- */
.jongly-content .well {
  background: var(--surface);
  border: 1px solid var(--card-border);
  border-radius: var(--card-radius);
  padding: 16px 20px;
  box-shadow: none;
  color: var(--content-text);
  font-size: 13.5px;
}

/* --- Toggle/accordion (WHMCS collapsible widget) --- */
.jongly-content .panel-collapse .panel-body,
.jongly-content .collapse-content { padding: 16px 20px; }

/* --- Icon list (domain/service feature list) --- */
.jongly-content .list-group-item {
  border-color: var(--card-border);
  font-size: 13.5px;
  padding: 11px 16px;
  color: var(--content-text);
  background: #fff;
  transition: background .12s;
}
.jongly-content .list-group-item:hover { background: var(--surface); }
.jongly-content .list-group-item.active {
  background: var(--accent-light);
  color: var(--accent);
  border-color: var(--accent);
  font-weight: 600;
}

/* --- Text utilities --- */
.jongly-content h3.card-title { font-size: 16px; font-weight: 700; color: var(--content-text); }
.jongly-content h4 { font-size: 15px; font-weight: 700; }
.jongly-content small, .jongly-content .text-muted { color: var(--text-muted) !important; font-size: 12px; }
.jongly-content .text-success { color: #16a34a !important; }
.jongly-content .text-danger  { color: var(--danger) !important; }
.jongly-content .text-warning { color: var(--warning) !important; }
.jongly-content .text-info    { color: #2563eb !important; }

/* --- Clickable table rows --- */
.jongly-content .table tbody tr[onclick] { cursor: pointer; }
.jongly-content .table tbody tr[onclick]:hover td { background: #f0f7ff; }

/* --- Empty state message --- */
.jongly-content .text-center > p i.fa-spinner {
  color: var(--accent);
}

/* --- Inline action icons on table rows --- */
.jongly-content .btn-xs {
  padding: 3px 8px;
  font-size: 11px;
  border-radius: 5px;
}

/* --- Modernize the page-level layout container --- */
.jongly-content section > div > .row {
  display: block;
}

/* --- DataTable sort icons --- */
.jongly-content table.dataTable thead .sorting::after,
.jongly-content table.dataTable thead .sorting_asc::after,
.jongly-content table.dataTable thead .sorting_desc::after {
  opacity: .5;
  font-size: 10px;
}
.jongly-content table.dataTable thead .sorting_asc::after { opacity: 1; color: var(--accent); }
.jongly-content table.dataTable thead .sorting_desc::after { opacity: 1; color: var(--accent); }

/* --- Scrollable table wrapper on mobile --- */
@media (max-width: 768px) {
  .jongly-content .table-container { overflow-x: auto; }
}

/* =========================================================
   Dashboard Redesign
   ========================================================= */

/* Quick Access Shortcut Bar */
.jl-shortcut-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 24px;
}
.jl-shortcut {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 7px 14px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 20px;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--text-secondary);
  text-decoration: none;
  transition: border-color .15s, box-shadow .15s, transform .12s;
  white-space: nowrap;
}
.jl-shortcut:hover {
  border-color: var(--accent);
  box-shadow: 0 2px 8px rgba(74,138,40,.14);
  transform: translateY(-1px);
  text-decoration: none;
  color: #111;
}
.jl-shortcut-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* Dashboard Grid */
.jl-dash-grid {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 20px;
  align-items: start;
}
.jl-dash-main { display: flex; flex-direction: column; gap: 20px; }
.jl-dash-side  { display: flex; flex-direction: column; gap: 20px; }

/* Panel Card */
.jl-panel {
  background: #fff;
  border: 1px solid #e8edf3;
  border-radius: 12px;
  box-shadow: 0 1px 4px rgba(0,0,0,.05);
  overflow: hidden;
}
.jl-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid #f1f5f9;
}
.jl-panel-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary);
}
.jl-panel-icon {
  width: 32px; height: 32px;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; flex-shrink: 0;
}
.jl-panel-link {
  font-size: 12px; font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  display: flex; align-items: center; gap: 5px;
}
.jl-panel-link:hover { text-decoration: underline; color: var(--accent); }
.jl-panel-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 12px;
  background: var(--accent); color: #fff;
  border-radius: 6px;
  font-size: 12px; font-weight: 600;
  text-decoration: none;
  transition: background .15s;
}
.jl-panel-btn:hover { background: #3a7020; text-decoration: none; color: #fff; }
.jl-panel-body { padding: 16px 20px; }
.jl-panel-body > p { margin: 0; font-size: 13.5px; color: var(--text-secondary); line-height: 1.6; }

/* Service Row */
.jl-service-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 20px;
  text-decoration: none;
  color: var(--text-primary);
  border-bottom: 1px solid #f8fafc;
  transition: background .12s;
}
.jl-service-row:last-child { border-bottom: none; }
.jl-service-row:hover { background: var(--surface); text-decoration: none; color: var(--text-primary); }
.jl-service-icon {
  width: 32px; height: 32px;
  background: var(--surface-2);
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; color: var(--text-muted);
  flex-shrink: 0;
}
.jl-service-info { flex: 1; min-width: 0; }
.jl-service-name {
  font-size: 13.5px; font-weight: 600; color: var(--text-primary);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.jl-service-meta { font-size: 11.5px; color: var(--text-subtle); margin-top: 1px; }
.jl-service-arrow { font-size: 10px; color: var(--border-strong); flex-shrink: 0; }

/* Ticket Row */
.jl-ticket-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 20px;
  text-decoration: none;
  color: var(--text-primary);
  border-bottom: 1px solid #f8fafc;
  transition: background .12s;
}
.jl-ticket-row:last-child { border-bottom: none; }
.jl-ticket-row:hover { background: var(--surface); text-decoration: none; color: var(--text-primary); }
.jl-ticket-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: #f59e0b; flex-shrink: 0;
  box-shadow: 0 0 0 3px #fef3c7;
}
.jl-ticket-info { flex: 1; min-width: 0; }
.jl-ticket-subj {
  font-size: 13px; font-weight: 600; color: var(--text-primary);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.jl-ticket-meta { font-size: 11.5px; color: var(--text-subtle); margin-top: 1px; }

/* News Row */
.jl-news-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 20px;
  text-decoration: none;
  color: var(--text-primary);
  border-bottom: 1px solid #f8fafc;
  transition: background .12s;
}
.jl-news-row:last-child { border-bottom: none; }
.jl-news-row:hover { background: var(--surface); text-decoration: none; color: var(--text-primary); }
.jl-news-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: #4a8a28; flex-shrink: 0;
}
.jl-news-info { flex: 1; min-width: 0; }
.jl-news-title {
  font-size: 13px; font-weight: 600; color: var(--text-primary);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.jl-news-date { font-size: 11px; color: var(--text-subtle); margin-top: 2px; }

/* Account Quick Links */
.jl-acct-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 20px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-secondary);
  text-decoration: none;
  border-bottom: 1px solid #f8fafc;
  transition: background .12s, color .12s;
}
.jl-acct-link:last-child { border-bottom: none; }
.jl-acct-link i { width: 16px; text-align: center; color: var(--text-subtle); transition: color .12s; }
.jl-acct-link:hover { background: var(--surface); color: var(--accent); text-decoration: none; }
.jl-acct-link:hover i { color: var(--accent); }

/* Clickable service rows (data-href) */
.jl-service-row--clickable { cursor: pointer; }
.jl-service-row--link:hover { background: var(--surface); }

/* WHMCS Active Products services (.div-service-item) styled as rows */
.jl-services-body .jl-whmcs-panel-body { padding: 0; }
.jl-services-body .div-service-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 20px;
  border-bottom: 1px solid #f8fafc;
  cursor: pointer;
  transition: background .12s;
}
.jl-services-body .div-service-item:last-child { border-bottom: none; }
.jl-services-body .div-service-item:hover { background: var(--surface); }
.jl-services-body .div-service-name {
  flex: 1; min-width: 0;
}
.jl-services-body .div-service-name .font-weight-bold {
  display: block;
  font-size: 13.5px; font-weight: 600; color: var(--text-primary);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.jl-services-body .div-service-name .text-domain {
  display: block;
  font-size: 11.5px; color: var(--text-subtle); margin-top: 1px;
}
/* Style the WHMCS-rendered icon as a box */
.jl-services-body .div-service-item > i,
.jl-services-body .div-service-item > span.fa,
.jl-services-body .div-service-item > span[class*="fa-"] {
  width: 32px; height: 32px;
  background: #eff6ff; color: #2563eb;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; flex-shrink: 0;
}

.jl-services-body .div-service-status { order: 3; }
.jl-services-body .div-service-status .label-placeholder { display: none; }
.jl-services-body .div-service-status .label {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 20px;
  font-size: 11px; font-weight: 600;
}
.jl-services-body .div-service-status .label-success { background: #dcfce7; color: #16a34a; }
.jl-services-body .div-service-status .label-danger  { background: #fee2e2; color: var(--danger); }
.jl-services-body .div-service-status .label-warning { background: #fef3c7; color: var(--warning); }
.jl-services-body .div-service-status .label-default { background: var(--surface-2); color: var(--text-muted); }
.jl-services-body .div-service-buttons { display: none; } /* hide action buttons in summary view */
/* Chevron at end */
.jl-services-body .div-service-item::after {
  content: '\f054';
  font-family: 'Font Awesome 5 Free'; font-weight: 900;
  font-size: 10px; color: var(--border-strong);
  margin-left: auto; flex-shrink: 0;
}
/* View More link */
.jl-services-body .jl-whmcs-panel-body > a {
  display: block;
  text-align: right;
  padding: 10px 20px;
  font-size: 12px; font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  border-top: 1px solid #f1f5f9;
}
.jl-services-body .jl-whmcs-panel-body > a:hover { text-decoration: underline; }

/* WHMCS pre-rendered panel body */
.jl-whmcs-panel-body {
  padding: 0;
}
.jl-whmcs-panel-body .active-products-services-item,
.jl-whmcs-panel-body .list-group-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 20px;
  border: none;
  border-bottom: 1px solid #f8fafc;
  border-radius: 0;
  background: #fff;
  color: var(--text-primary);
  font-size: 13.5px;
  text-decoration: none;
  transition: background .12s;
}
.jl-whmcs-panel-body .list-group-item:last-child { border-bottom: none; }
.jl-whmcs-panel-body .list-group-item:hover { background: var(--surface); }
.jl-whmcs-panel-body .list-group-flush { margin: 0; }
.jl-whmcs-panel-body .view-more {
  display: block;
  text-align: right;
  padding: 10px 20px;
  font-size: 12px;
  color: var(--accent);
  text-decoration: none;
  border-top: 1px solid #f1f5f9;
}
.jl-whmcs-panel-body .view-more:hover { text-decoration: underline; }
/* Hide any internal card styling WHMCS adds */
.jl-whmcs-panel-body .card { border: none; box-shadow: none; margin: 0; }
.jl-whmcs-panel-body .card-body { padding: 0; }

/* Domain Search Panel — Redesigned */
.jl-domain-panel { overflow: hidden; }

/* Hero header */
.jl-domain-hero {
  position: relative;
  padding: 20px 20px 18px;
  overflow: hidden;
}
.jl-domain-hero-bg {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, #0f4c1e 0%, #1a7a36 50%, #22c55e 100%);
  opacity: .92;
}
.jl-domain-hero-content {
  position: relative;
  display: flex; align-items: center; gap: 14px;
}
.jl-domain-hero-icon {
  width: 44px; height: 44px;
  background: rgba(255,255,255,.15);
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; color: #fff;
  flex-shrink: 0;
  backdrop-filter: blur(4px);
}
.jl-domain-hero-title {
  font-size: 15px; font-weight: 700; color: #fff;
  line-height: 1.2;
}
.jl-domain-hero-sub {
  font-size: 11.5px; color: rgba(255,255,255,.7);
  margin-top: 2px;
}

/* Search body */
.jl-domain-search-body { padding: 18px 18px 14px; }

.jl-domain-search-form { display: flex; flex-direction: column; gap: 10px; }

.jl-domain-search-wrap {
  display: flex; align-items: center;
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: 10px;
  padding: 0 14px;
  gap: 8px;
  transition: border-color .15s, box-shadow .15s;
}
.jl-domain-search-wrap:focus-within {
  border-color: #16a34a;
  box-shadow: 0 0 0 3px rgba(22,163,74,.12);
  background: #fff;
}
.jl-domain-search-at {
  font-size: 16px; font-weight: 600;
  color: var(--text-subtle);
  flex-shrink: 0;
  user-select: none;
}
.jl-domain-search-input {
  flex: 1;
  height: 42px;
  border: none;
  background: transparent;
  font-size: 14px; font-weight: 500;
  color: var(--text-primary);
  outline: none;
  min-width: 0;
}
.jl-domain-search-input::placeholder { color: var(--text-subtle); font-weight: 400; }

.jl-domain-action-row { display: flex; gap: 8px; }
.jl-domain-action-btn {
  flex: 1;
  height: 38px;
  border: none; border-radius: 8px;
  font-size: 13px; font-weight: 600;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 6px;
  transition: background .15s, transform .1s, box-shadow .15s;
}
.jl-domain-action-btn:hover { transform: translateY(-1px); }
.jl-domain-action-btn--primary {
  background: #16a34a; color: #fff;
  box-shadow: 0 2px 6px rgba(22,163,74,.3);
}
.jl-domain-action-btn--primary:hover { background: #15803d; box-shadow: 0 4px 10px rgba(22,163,74,.4); }
.jl-domain-action-btn--ghost {
  background: var(--surface-2); color: var(--text-secondary);
  border: 1.5px solid var(--border);
}
.jl-domain-action-btn--ghost:hover { background: #e2e8f0; }

/* Popular TLDs */
.jl-tld-bar {
  display: flex; align-items: center;
  gap: 6px; flex-wrap: wrap;
  padding-top: 6px;
  border-top: 1px solid #f1f5f9;
  margin-top: 4px;
}
.jl-tld-label {
  font-size: 11px; font-weight: 600;
  color: var(--text-subtle); text-transform: uppercase;
  letter-spacing: .04em; flex-shrink: 0;
}
.jl-tld {
  display: inline-block;
  padding: 3px 8px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: 5px;
  font-size: 11.5px; font-weight: 600;
  color: var(--text-secondary);
  text-decoration: none;
  transition: background .12s, color .12s, border-color .12s;
}
.jl-tld:hover {
  background: #dcfce7; border-color: #86efac;
  color: #15803d; text-decoration: none;
}

/* Empty state */
.jl-empty-state {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 32px 20px; text-align: center;
}
.jl-empty-icon {
  width: 48px; height: 48px;
  background: #f0f7ee;
  color: var(--accent);
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; margin-bottom: 12px;
}
.jl-empty-title {
  font-size: 14px; font-weight: 700;
  color: var(--text-primary); margin-bottom: 4px;
}
.jl-empty-desc { font-size: 12.5px; color: var(--text-subtle); margin-bottom: 14px; }
.jl-empty-btn {
  display: inline-block;
  padding: 8px 18px;
  background: var(--accent); color: #fff;
  border-radius: 7px;
  font-size: 12.5px; font-weight: 600;
  text-decoration: none;
  transition: background .15s;
}
.jl-empty-btn:hover { background: #3a7020; color: #fff; text-decoration: none; }

/* Responsive */
@media (max-width: 1100px) {
  .jl-dash-grid { grid-template-columns: 1fr 300px; }
}
@media (max-width: 768px) {
  .jl-dash-grid { grid-template-columns: 1fr; }
  .jl-shortcut-bar { gap: 6px; }
}

/* =========================================================
   Security Page
   ========================================================= */
.jl-security-page { display: flex; flex-direction: column; gap: 20px; }

.jl-sec-card {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: var(--card-radius);
  box-shadow: var(--card-shadow);
  overflow: hidden;
}

.jl-sec-card-header {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 20px 24px;
  border-bottom: 1px solid var(--card-border);
  background: #fafbfc;
}

.jl-sec-icon {
  width: 40px; height: 40px;
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.jl-sec-icon--blue   { background: #eff6ff; color: #2563eb; }
.jl-sec-icon--green  { background: #f0fdf4; color: #16a34a; }
.jl-sec-icon--purple { background: #f0fdf4; color: #4a8a28; }
.jl-sec-icon--amber  { background: var(--warning-light); color: var(--warning); }

.jl-sec-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--content-text);
  margin: 0 0 2px;
}
.jl-sec-subtitle {
  font-size: 12.5px;
  color: var(--text-muted);
  margin: 0;
}

.jl-sec-card-body { padding: 22px 24px; }

.jl-form-label {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 6px;
  display: block;
}
.jl-form-control {
  height: 40px;
  font-size: 13.5px;
  border-color: #d1d5db;
  border-radius: 8px;
  transition: border-color .15s, box-shadow .15s;
}
.jl-form-control:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(74,138,40,.12);
}

.jl-sec-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 9px 20px;
  border: none; border-radius: 8px;
  font-size: 13.5px; font-weight: 600;
  cursor: pointer;
  transition: background .15s, transform .1s;
}
.jl-sec-btn--primary {
  background: var(--accent);
  color: #fff;
}
.jl-sec-btn--primary:hover { background: #3a7020; transform: translateY(-1px); color: #fff; text-decoration: none; }

.jl-sec-btn--success { background: #16a34a; color: #fff; }
.jl-sec-btn--success:hover { background: #15803d; transform: translateY(-1px); color: #fff; text-decoration: none; }

.jl-sec-btn--danger { background: var(--danger); color: #fff; }
.jl-sec-btn--danger:hover { background: var(--danger-hover); transform: translateY(-1px); color: #fff; text-decoration: none; }

.jl-sec-btn--ghost { background: var(--surface-2); color: var(--text-secondary); }
.jl-sec-btn--ghost:hover { background: var(--border); color: var(--text-primary); text-decoration: none; }

/* 2FA status badge */
.jl-2fa-status {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 5px 12px; border-radius: 999px;
  font-size: 12.5px; font-weight: 700; margin-bottom: 14px;
}
.jl-2fa-status::before {
  content: ''; width: 8px; height: 8px; border-radius: 50%;
}
.jl-2fa-status--on  { background: var(--accent-light); color: #15803d; }
.jl-2fa-status--on::before  { background: #16a34a; }
.jl-2fa-status--off { background: var(--surface-2); color: var(--text-muted); }
.jl-2fa-status--off::before { background: var(--text-subtle); }
.jl-sec-btn-row { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 4px; }

/* Password strength + tips (full width, below the inputs row) */
.jl-pw-strength { margin: 2px 0 18px; }
.jl-pw-strength > br:first-child { display: none; }
.jl-pw-strength .progress {
  height: 6px; border-radius: 999px;
  background: var(--surface-2); margin-bottom: 14px; overflow: hidden;
}
.jl-pw-strength .progress-bar { border-radius: 999px; transition: width .25s ease; }
.jl-pw-strength .alert {
  border-radius: 10px; border: 1px solid var(--border);
  background: var(--surface); color: var(--text-secondary);
  font-size: 12.5px; line-height: 1.6; padding: 12px 16px; max-width: 680px; margin: 0;
}
.jl-pw-strength .alert i { color: var(--accent); }

/* Security tips list */
.jl-sec-tips { display: flex; flex-direction: column; gap: 16px; }
.jl-sec-tip  { display: flex; align-items: flex-start; gap: 12px; }
.jl-sec-tip-icon {
  width: 24px; height: 24px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; margin-top: 1px;
}
.jl-sec-tip-icon--green { background: #dcfce7; color: #16a34a; }
.jl-sec-tip-icon--amber { background: #fef3c7; color: var(--warning); }
.jl-sec-tip-title { font-size: 13.5px; font-weight: 600; color: var(--content-text); }
.jl-sec-tip-desc  { font-size: 12px; color: var(--text-muted); margin-top: 1px; }

/* Activity row */
.jl-sec-activity-row {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 0;
  border-bottom: 1px solid var(--card-border);
  margin-bottom: 14px;
}
.jl-sec-activity-dot {
  width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0;
}
.jl-sec-activity-dot--green { background: #22c55e; box-shadow: 0 0 0 3px #dcfce7; }
.jl-sec-activity-label { font-size: 13.5px; font-weight: 600; color: var(--content-text); }
.jl-sec-activity-meta  { font-size: 12px; color: var(--text-muted); }
.jl-sec-activity-badge {
  margin-left: auto;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 11.5px; font-weight: 600;
}
.jl-sec-activity-badge--green { background: #dcfce7; color: #16a34a; }
.jl-sec-activity-hint {
  display: flex; align-items: flex-start; gap: 7px;
  font-size: 12px; color: var(--text-muted);
}
.jl-sec-activity-hint svg { flex-shrink: 0; margin-top: 1px; }
.jl-sec-activity-hint a { color: var(--accent); font-weight: 600; }

@media (max-width: 576px) {
  .jl-sec-card-header { flex-direction: column; }
  .jl-sec-card-body   { padding: 16px; }
}

/* =====================================================
   SUPPORT TICKET STEP PAGES
   ===================================================== */

.jl-ticket-page {
  max-width: 720px;
  margin: 0 auto;
  padding-bottom: 40px;
}

/* Hero */
.jl-ticket-hero {
  display: flex;
  align-items: center;
  gap: 18px;
  background: linear-gradient(135deg, #1e293b 0%, #334155 100%);
  border-radius: 14px;
  padding: 28px 32px;
  margin-bottom: 28px;
  color: #fff;
}
.jl-ticket-hero-icon {
  width: 56px;
  height: 56px;
  background: rgba(255,255,255,0.12);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  flex-shrink: 0;
  color: #7dd3fc;
}
.jl-ticket-hero-title {
  font-size: 20px;
  font-weight: 700;
  margin: 0 0 4px;
  color: #fff;
}
.jl-ticket-hero-sub {
  font-size: 13.5px;
  color: var(--text-subtle);
  margin: 0;
}

/* Step indicator */
.jl-ticket-steps {
  display: flex;
  align-items: center;
  margin-bottom: 28px;
  gap: 0;
}
.jl-ticket-step {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}
.jl-ticket-step-num {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: #e2e8f0;
  color: var(--text-subtle);
  font-size: 13px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.jl-ticket-step.active .jl-ticket-step-num {
  background: var(--accent);
  color: #fff;
}
.jl-ticket-step.done .jl-ticket-step-num {
  background: #22c55e;
  color: #fff;
}
.jl-ticket-step-label {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--text-subtle);
  white-space: nowrap;
}
.jl-ticket-step.active .jl-ticket-step-label {
  color: var(--accent);
}
.jl-ticket-step.done .jl-ticket-step-label {
  color: #22c55e;
}
.jl-ticket-step-line {
  flex: 1;
  height: 2px;
  background: #e2e8f0;
  margin: 0 12px;
}
.jl-ticket-step-line.active {
  background: #22c55e;
}

/* Step 1 — Department cards */
.jl-dept-grid {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.jl-dept-card {
  display: flex;
  align-items: center;
  gap: 16px;
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 12px;
  padding: 18px 22px;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.18s, box-shadow 0.18s, transform 0.12s;
}
.jl-dept-card:hover {
  border-color: var(--accent);
  box-shadow: 0 4px 18px rgba(74,138,40,0.10);
  transform: translateY(-1px);
  text-decoration: none;
  color: inherit;
}
.jl-dept-card-icon {
  width: 46px;
  height: 46px;
  background: #f0fdf4;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  color: var(--accent);
  flex-shrink: 0;
}
.jl-dept-card-body {
  flex: 1;
}
.jl-dept-card-name {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 3px;
}
.jl-dept-card-desc {
  font-size: 13px;
  color: var(--text-muted);
}
.jl-dept-card-arrow {
  color: var(--border-strong);
  font-size: 13px;
  flex-shrink: 0;
  transition: color 0.18s, transform 0.18s;
}
.jl-dept-card:hover .jl-dept-card-arrow {
  color: var(--accent);
  transform: translateX(3px);
}

/* Step 2 — Form card */
.jl-ticket-form-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
}
.jl-ticket-section {
  padding: 22px 28px;
  border-bottom: 1px solid #f1f5f9;
}
.jl-ticket-section:last-of-type {
  border-bottom: none;
}
.jl-ticket-section-title {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  color: var(--text-subtle);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 7px;
}
.jl-ticket-row-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.jl-ticket-row-3 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 16px;
}
.jl-ticket-label {
  display: block;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 6px;
}
.jl-ticket-input,
.jl-ticket-select,
.jl-ticket-textarea {
  width: 100%;
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: 8px;
  padding: 9px 13px;
  font-size: 13.5px;
  color: var(--text-primary);
  outline: none;
  transition: border-color 0.18s, box-shadow 0.18s;
  font-family: inherit;
}
.jl-ticket-input:focus,
.jl-ticket-select:focus,
.jl-ticket-textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(74,138,40,0.10);
  background: #fff;
}
.jl-ticket-input-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  background: var(--surface-2);
}
.jl-ticket-textarea {
  resize: vertical;
  min-height: 180px;
}
.jl-ticket-attach-hint {
  font-size: 12px;
  color: var(--text-subtle);
  margin-top: 8px;
}

/* ---- Rich HTML composer (self-contained WYSIWYG) -------------------------- */
.jl-composer {
  border: 1.5px solid var(--border);
  border-radius: 8px;
  background: #fff;
  overflow: hidden;
  transition: border-color 0.18s, box-shadow 0.18s;
}
.jl-composer.is-focused {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(74,138,40,0.10);
}
.jl-composer-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 2px;
  padding: 6px 8px;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
}
.jl-composer-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 30px;
  border: none;
  background: transparent;
  color: var(--text-secondary);
  border-radius: 6px;
  cursor: pointer;
  font-size: 13px;
  transition: background 0.12s, color 0.12s;
}
.jl-composer-btn:hover {
  background: var(--border);
  color: var(--text-primary);
}
.jl-composer-btn.is-active {
  background: var(--accent-light, rgba(74,138,40,0.14));
  color: var(--accent);
}
.jl-composer-sep {
  width: 1px;
  background: var(--border);
  margin: 4px 4px;
}
.jl-composer-area {
  min-height: 180px;
  max-height: 460px;
  overflow-y: auto;
  padding: 12px 14px;
  font-size: 13.5px;
  line-height: 1.6;
  color: var(--text-primary);
  outline: none;
}
.jl-composer-area:empty::before {
  content: attr(data-placeholder);
  color: var(--text-subtle);
}
.jl-composer-area p { margin: 0 0 10px; }
.jl-composer-area ul,
.jl-composer-area ol { margin: 0 0 10px 22px; }
.jl-composer-area a { color: var(--accent); }
.jl-composer-reply .jl-composer-area { min-height: 130px; }
.jl-ticket-optional {
  font-weight: 400;
  color: var(--border-strong);
  text-transform: none;
  letter-spacing: 0;
  font-size: 11px;
}
.jl-ticket-alert {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 14px 18px;
  border-radius: 10px;
  margin-bottom: 20px;
  font-size: 13.5px;
}
.jl-ticket-alert-error {
  background: var(--danger-light);
  border: 1px solid #fecaca;
  color: var(--danger);
}
.jl-ticket-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  padding: 20px 28px;
  background: var(--surface);
  border-top: 1px solid #e2e8f0;
}
.jl-ticket-btn-submit {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 10px 22px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.18s, transform 0.12s;
}
.jl-ticket-btn-submit:hover {
  background: #3d7422;
  color: #fff;
  text-decoration: none;
  transform: translateY(-1px);
}
.jl-ticket-btn-cancel {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: transparent;
  color: var(--text-muted);
  border: 1.5px solid var(--border);
  border-radius: 8px;
  padding: 9px 18px;
  font-size: 13.5px;
  font-weight: 500;
  cursor: pointer;
  text-decoration: none;
  transition: border-color 0.18s, color 0.18s;
}
.jl-ticket-btn-cancel:hover {
  border-color: var(--text-subtle);
  color: var(--text-secondary);
  text-decoration: none;
}

/* Step 3 — Confirmation */
.jl-ticket-confirm-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  padding: 48px 32px;
  text-align: center;
}
.jl-ticket-confirm-icon {
  font-size: 52px;
  color: #22c55e;
  margin-bottom: 18px;
}
.jl-ticket-confirm-title {
  font-size: 22px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0 0 10px;
}
.jl-ticket-confirm-sub {
  font-size: 14px;
  color: var(--text-muted);
  margin: 0 0 22px;
}
.jl-ticket-confirm-num {
  display: inline-block;
  background: #f0fdf4;
  border: 1.5px solid #bbf7d0;
  border-radius: 8px;
  padding: 8px 22px;
  font-size: 15px;
  font-weight: 700;
  color: #15803d;
  margin-bottom: 28px;
}
.jl-ticket-confirm-num a {
  color: #15803d;
  text-decoration: none;
}
.jl-ticket-confirm-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}

/* Empty state */
.jl-ticket-empty {
  text-align: center;
  padding: 48px 24px;
  color: var(--text-subtle);
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 12px;
}
.jl-ticket-empty i {
  font-size: 36px;
  margin-bottom: 12px;
  display: block;
}

@media (max-width: 640px) {
  .jl-ticket-hero { padding: 20px; gap: 14px; }
  .jl-ticket-hero-title { font-size: 17px; }
  .jl-ticket-step-label { display: none; }
  .jl-ticket-row-2,
  .jl-ticket-row-3 { grid-template-columns: 1fr; }
  .jl-ticket-section { padding: 18px; }
  .jl-ticket-actions { flex-direction: column-reverse; }
  .jl-ticket-btn-submit,
  .jl-ticket-btn-cancel { width: 100%; justify-content: center; }
}

/* =====================================================
   VIEW TICKET PAGE
   ===================================================== */

.jl-vt-wrap {
  max-width: 720px;
  margin: 0 auto;
  padding-bottom: 40px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* Error state */
.jl-vt-error {
  text-align: center;
  padding: 56px 24px;
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  color: var(--text-muted);
}
.jl-vt-error i { font-size: 40px; color: #ef4444; margin-bottom: 14px; display: block; }
.jl-vt-error h3 { font-size: 18px; font-weight: 700; color: var(--text-primary); margin: 0 0 8px; }
.jl-vt-error p { margin: 0 0 20px; }

/* Notices */
.jl-vt-notice {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 13px 18px;
  border-radius: 10px;
  font-size: 13.5px;
  max-width: 720px;
  margin: 0 auto 4px;
}
.jl-vt-notice--warning { background: var(--warning-light); border: 1px solid #fde68a; color: #92400e; }
.jl-vt-notice--error   { background: var(--danger-light); border: 1px solid #fecaca; color: var(--danger); }

/* Header */
.jl-vt-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  background: linear-gradient(135deg, #1e293b 0%, #334155 100%);
  border-radius: 14px;
  padding: 22px 28px;
  color: #fff;
  flex-wrap: wrap;
}
.jl-vt-header-left {
  display: flex;
  align-items: center;
  gap: 16px;
}
.jl-vt-header-icon {
  width: 48px; height: 48px;
  background: rgba(255,255,255,0.12);
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; color: #7dd3fc; flex-shrink: 0;
}
.jl-vt-title {
  font-size: 17px; font-weight: 700; color: #fff; margin-bottom: 3px;
}
.jl-vt-subject {
  font-size: 13px; color: var(--text-subtle);
}
.jl-vt-header-right {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.jl-vt-status {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 14px; border-radius: 20px; font-size: 12px; font-weight: 600;
}
.jl-vt-status--closed { background: #374151; color: #9ca3af; }
.jl-vt-close-btn {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(239,68,68,0.15); color: #fca5a5;
  border: 1px solid rgba(239,68,68,0.3);
  border-radius: 8px; padding: 7px 14px;
  font-size: 12.5px; font-weight: 600; cursor: pointer;
  transition: background 0.18s;
}
.jl-vt-close-btn:hover { background: rgba(239,68,68,0.25); }

/* Thread */
.jl-vt-thread {
  display: flex; flex-direction: column; gap: 12px;
}

/* Reply card */
.jl-vt-reply {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
}
.jl-vt-reply--staff {
  border-color: #bfdbfe;
  background: #f8fbff;
}

.jl-vt-reply-meta {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 20px;
  border-bottom: 1px solid #f1f5f9;
}
.jl-vt-reply--staff .jl-vt-reply-meta { border-bottom-color: #e0ecff; }

.jl-vt-avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--accent);
  color: #fff; font-size: 13px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.jl-vt-avatar--staff { background: #3b82f6; }

.jl-vt-reply-info { flex: 1; }
.jl-vt-reply-name { font-size: 13.5px; font-weight: 700; color: var(--text-primary); display: block; }
.jl-vt-reply-date { font-size: 12px; color: var(--text-subtle); }

.jl-vt-badge {
  font-size: 11px; font-weight: 700;
  padding: 3px 10px; border-radius: 20px;
  display: inline-flex; align-items: center; gap: 4px;
}
.jl-vt-badge--owner { background: #dcfce7; color: #16a34a; }
.jl-vt-badge--staff { background: #dbeafe; color: #2563eb; }

.jl-vt-reply-body {
  padding: 18px 20px;
  font-size: 14px; line-height: 1.7; color: var(--text-secondary);
}
.jl-vt-ip {
  margin-top: 14px; padding-top: 12px;
  border-top: 1px solid #f1f5f9;
  font-size: 12px; color: var(--text-subtle);
}
.jl-vt-rating-wrap { margin-top: 14px; }
.jl-vt-rated { font-size: 12px; color: var(--text-subtle); margin-left: 6px; }

/* Attachments */
.jl-vt-attachments {
  padding: 12px 20px;
  border-top: 1px solid #f1f5f9;
  background: var(--surface);
}
.jl-vt-attach-label {
  font-size: 12px; font-weight: 700; color: var(--text-muted);
  margin-bottom: 10px; display: flex; align-items: center; gap: 6px;
}
.jl-vt-attach-list { display: flex; flex-wrap: wrap; gap: 8px; }
.jl-vt-attach-item {
  display: inline-flex; align-items: center; gap: 7px;
  background: #fff; border: 1.5px solid var(--border);
  border-radius: 8px; padding: 7px 12px;
  font-size: 12.5px; color: var(--text-secondary); text-decoration: none;
  transition: border-color 0.18s;
}
a.jl-vt-attach-item:hover { border-color: var(--accent); color: var(--accent); text-decoration: none; }
.jl-vt-attach-item--removed { color: var(--text-subtle); border-style: dashed; }

/* Reply form */
.jl-vt-reply-form {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  padding: 24px 28px;
}

@media (max-width: 640px) {
  .jl-vt-header { padding: 18px; }
  .jl-vt-title { font-size: 15px; }
  .jl-vt-reply-meta { padding: 12px 14px; }
  .jl-vt-reply-body { padding: 14px; }
  .jl-vt-reply-form { padding: 18px; }
  .jl-ticket-row-2 { grid-template-columns: 1fr; }
}

/* =====================================================
   SUPPORT TICKETS LIST PAGE — Modern Redesign
   ===================================================== */

.jl-stlist-wrap {
  max-width: 1060px;
  margin: 0 auto;
  padding-bottom: 48px;
}

/* ── Header ── */
.jl-stlist-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 24px;
  flex-wrap: wrap;
}
.jl-stlist-header-left { display: flex; align-items: center; gap: 16px; }
.jl-stlist-header-icon {
  width: 50px; height: 50px;
  background: linear-gradient(135deg, var(--accent), #6ab53a);
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  font-size: 21px; color: #fff; flex-shrink: 0;
  box-shadow: 0 4px 14px rgba(74,138,40,0.32);
}
.jl-stlist-title {
  font-size: 22px; font-weight: 800; color: var(--text-primary); margin: 0 0 3px; letter-spacing: -0.3px;
}
.jl-stlist-sub { font-size: 13px; color: var(--text-muted); margin: 0; }
.jl-stlist-btn-new {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--accent); color: #fff;
  border-radius: 10px; padding: 11px 22px;
  font-size: 13.5px; font-weight: 700;
  text-decoration: none; white-space: nowrap;
  box-shadow: 0 2px 10px rgba(74,138,40,0.30);
  transition: background 0.18s, box-shadow 0.18s, transform 0.12s;
}
.jl-stlist-btn-new:hover {
  background: var(--accent-hover); color: #fff; text-decoration: none;
  transform: translateY(-1px); box-shadow: 0 4px 18px rgba(74,138,40,0.40);
}

/* ── Card ── */
.jl-stlist-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 28px rgba(0,0,0,0.06);
}

/* ── Toolbar ── */
.jl-stlist-toolbar {
  display: flex; align-items: center;
  justify-content: space-between;
  padding: 16px 24px;
  background: #fff;
  border-bottom: 1.5px solid #f1f5f9;
  gap: 12px; flex-wrap: wrap;
}

/* Search */
.jl-stlist-search-wrap .dataTables_filter { margin: 0; }
.jl-stlist-search-wrap .dataTables_filter label {
  display: flex; align-items: center; margin: 0; position: relative;
}
.jl-stlist-search-wrap .dataTables_filter label::before {
  content: '\f002';
  font-family: 'Font Awesome 5 Free'; font-weight: 900;
  position: absolute; left: 12px;
  color: var(--text-subtle); font-size: 12px;
  pointer-events: none; z-index: 1;
}
.jl-stlist-search-wrap .dataTables_filter label > span { display: none; }
.jl-stlist-search-wrap .dataTables_filter input {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: 9px;
  padding: 9px 14px 9px 34px;
  font-size: 13.5px; outline: none;
  transition: all 0.18s;
  width: 290px; color: var(--text-primary);
  margin-left: 0 !important;
}
.jl-stlist-search-wrap .dataTables_filter input::placeholder { color: #b0bec5; }
.jl-stlist-search-wrap .dataTables_filter input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(74,138,40,0.10);
  background: #fff;
}

/* Show entries */
.jl-stlist-show-wrap .dataTables_length { margin: 0; }
.jl-stlist-show-wrap .dataTables_length label {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--text-muted); margin: 0;
}
.jl-stlist-show-wrap .dataTables_length select {
  background: var(--surface); border: 1.5px solid var(--border);
  border-radius: 9px; padding: 8px 12px;
  font-size: 13px; outline: none; cursor: pointer; color: var(--text-primary);
}

/* ── Loading ── */
.jl-stlist-loading {
  padding: 40px; text-align: center;
  color: var(--text-subtle); font-size: 13.5px;
}

/* ── Table ── */
.jl-stlist-table-wrap { overflow-x: auto; padding: 0 16px; }
.jl-stlist-table {
  width: 100% !important;
  border-collapse: collapse;
  margin: 0 !important;
  table-layout: auto;
}
.jl-stlist-table thead tr th {
  background: var(--surface);
  border-bottom: 1.5px solid #e8edf2;
  border-top: none;
  padding: 12px 24px;
  font-size: 11px; font-weight: 800;
  text-transform: uppercase; letter-spacing: 0.7px;
  color: var(--text-subtle); white-space: nowrap;
}
.jl-stlist-table thead tr th:before,
.jl-stlist-table thead tr th:after { color: var(--border-strong); opacity: 0.6; }

/* Rows */
.jl-stlist-row {
  border-bottom: 1px solid #f1f5f9;
  cursor: pointer;
  transition: background 0.12s;
}
.jl-stlist-row:last-child { border-bottom: none; }
.jl-stlist-row:hover { background: #f6fef7; }
.jl-stlist-row:hover .jl-stlist-subject { color: var(--accent); }
.jl-stlist-row td {
  padding: 16px 24px;
  font-size: 13.5px; color: var(--text-secondary);
  vertical-align: middle;
  border-top: none !important;
  white-space: nowrap;
}

/* Dept */
.jl-stlist-dept {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 13px; font-weight: 500; color: var(--text-muted);
}
.jl-stlist-dept i { color: var(--accent); font-size: 12px; }

/* Subject */
.jl-stlist-subject-link {
  display: flex; align-items: center; gap: 10px;
  text-decoration: none; color: inherit;
}
.jl-stlist-subject-link:hover { text-decoration: none; color: inherit; }
.jl-stlist-tid {
  font-size: 11px; font-weight: 800;
  color: var(--accent);
  background: var(--accent-light);
  padding: 3px 9px; border-radius: 20px;
  white-space: nowrap; flex-shrink: 0;
  letter-spacing: 0.3px;
  border: 1px solid rgba(74,138,40,0.15);
}
.jl-stlist-subject {
  font-size: 14px; font-weight: 600; color: var(--text-primary);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 380px; transition: color 0.12s;
}
.jl-stlist-unread { font-weight: 800; }
.jl-stlist-new-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--accent); flex-shrink: 0;
  box-shadow: 0 0 0 2px rgba(74,138,40,0.2);
}

/* Status badges */
.jl-stlist-status {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 12px; border-radius: 20px;
  font-size: 11.5px; font-weight: 700; white-space: nowrap;
}
.jl-stlist-status::before {
  content: ''; width: 6px; height: 6px; border-radius: 50%;
  display: inline-block; flex-shrink: 0;
}
.jl-status-open        { background: #dcfce7; color: #16a34a; }
.jl-status-open::before { background: #16a34a; }
.jl-status-answered    { background: #dbeafe; color: #2563eb; }
.jl-status-answered::before { background: #2563eb; }
.jl-status-inprogress  { background: #fef9c3; color: #a16207; }
.jl-status-inprogress::before { background: #a16207; }
.jl-status-onhold      { background: #fff7ed; color: #c2410c; }
.jl-status-onhold::before { background: #c2410c; }
.jl-status-closed      { background: var(--surface-2); color: var(--text-muted); }
.jl-status-closed::before { background: #94a3b8; }

/* Date */
.jl-stlist-date { font-size: 13px; color: var(--text-subtle); white-space: nowrap; }

/* ── Footer / Pagination ── */
.jl-stlist-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 24px;
  background: #fafbfc;
  border-top: 1.5px solid var(--surface-2);
  flex-wrap: wrap; gap: 10px;
}
.jl-stlist-footer .dataTables_info { font-size: 12.5px; color: var(--text-subtle); }
.jl-stlist-footer .dataTables_paginate { display: flex; align-items: center; gap: 4px; }
.jl-stlist-footer .paginate_button {
  padding: 6px 13px; border-radius: 8px;
  font-size: 13px; font-weight: 600;
  color: var(--text-secondary) !important; cursor: pointer;
  border: 1.5px solid var(--border) !important;
  background: #fff !important;
  transition: all 0.15s; line-height: 1.4;
}
.jl-stlist-footer .paginate_button:hover:not(.disabled) {
  border-color: var(--accent) !important;
  color: var(--accent) !important;
  background: var(--accent-light) !important;
}
.jl-stlist-footer .paginate_button.current,
.jl-stlist-footer .paginate_button.current:hover {
  background: var(--accent) !important; color: #fff !important;
  border-color: var(--accent) !important;
  box-shadow: 0 2px 8px rgba(74,138,40,0.25);
}
.jl-stlist-footer .paginate_button.disabled { opacity: 0.35; cursor: default; pointer-events: none; }

@media (max-width: 700px) {
  .jl-stlist-header { flex-direction: column; align-items: flex-start; }
  .jl-stlist-toolbar { flex-direction: column; align-items: flex-start; }
  .jl-stlist-search-wrap .dataTables_filter input { width: 100%; }
  .jl-stlist-row td { padding: 12px 14px; }
  .jl-stlist-subject { max-width: 180px; }
}

/* =====================================================
   SERVICES LIST PAGE
   ===================================================== */

.jl-svclist-wrap {
  max-width: 1060px;
  margin: 0 auto;
  padding-bottom: 48px;
}

/* ── Header ── */
.jl-svclist-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 24px;
  flex-wrap: wrap;
}
.jl-svclist-header-left { display: flex; align-items: center; gap: 16px; }
.jl-svclist-header-icon {
  width: 50px; height: 50px;
  background: linear-gradient(135deg, var(--accent), #6ab53a);
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  font-size: 21px; color: #fff; flex-shrink: 0;
  box-shadow: 0 4px 14px rgba(74,138,40,0.32);
}
.jl-svclist-title {
  font-size: 22px; font-weight: 800; color: var(--text-primary); margin: 0 0 3px; letter-spacing: -0.3px;
}
.jl-svclist-sub { font-size: 13px; color: var(--text-muted); margin: 0; }
.jl-svclist-btn-new {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--accent); color: #fff;
  border-radius: 10px; padding: 11px 22px;
  font-size: 13.5px; font-weight: 700;
  text-decoration: none; white-space: nowrap;
  box-shadow: 0 2px 10px rgba(74,138,40,0.30);
  transition: background 0.18s, box-shadow 0.18s, transform 0.12s;
}
.jl-svclist-btn-new:hover {
  background: var(--accent-hover); color: #fff; text-decoration: none;
  transform: translateY(-1px); box-shadow: 0 4px 18px rgba(74,138,40,0.40);
}

/* ── Card ── */
.jl-svclist-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 28px rgba(0,0,0,0.06);
}

/* ── Toolbar ── */
.jl-svclist-toolbar {
  display: flex; align-items: center;
  justify-content: space-between;
  padding: 16px 24px;
  background: #fff;
  border-bottom: 1.5px solid #f1f5f9;
  gap: 12px; flex-wrap: wrap;
}
.jl-svclist-search-wrap .dataTables_filter { margin: 0; }
.jl-svclist-search-wrap .dataTables_filter label {
  display: flex; align-items: center; margin: 0; position: relative;
}
.jl-svclist-search-wrap .dataTables_filter label::before {
  content: '\f002';
  font-family: 'Font Awesome 5 Free'; font-weight: 900;
  position: absolute; left: 12px;
  color: var(--text-subtle); font-size: 12px;
  pointer-events: none; z-index: 1;
}
.jl-svclist-search-wrap .dataTables_filter label > span { display: none; }
.jl-svclist-search-wrap .dataTables_filter input {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: 9px;
  padding: 9px 14px 9px 34px;
  font-size: 13.5px; outline: none;
  transition: all 0.18s;
  width: 290px; color: var(--text-primary);
  margin-left: 0 !important;
}
.jl-svclist-search-wrap .dataTables_filter input::placeholder { color: #b0bec5; }
.jl-svclist-search-wrap .dataTables_filter input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(74,138,40,0.10);
  background: #fff;
}
.jl-svclist-show-wrap .dataTables_length { margin: 0; }
.jl-svclist-show-wrap .dataTables_length label {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--text-muted); margin: 0;
}
.jl-svclist-show-wrap .dataTables_length select {
  background: var(--surface); border: 1.5px solid var(--border);
  border-radius: 9px; padding: 8px 12px;
  font-size: 13px; outline: none; cursor: pointer; color: var(--text-primary);
}

/* ── Loading ── */
.jl-svclist-loading {
  padding: 40px; text-align: center;
  color: var(--text-subtle); font-size: 13.5px;
}

/* ── Table ── */
.jl-svclist-table-wrap { overflow-x: auto; padding: 0 16px; }
.jl-svclist-table {
  width: 100% !important;
  border-collapse: collapse;
  margin: 0 !important;
  table-layout: auto;
}
.jl-svclist-table thead tr th {
  background: var(--surface);
  border-bottom: 1.5px solid #e8edf2;
  border-top: none;
  padding: 12px 24px;
  font-size: 11px; font-weight: 800;
  text-transform: uppercase; letter-spacing: 0.7px;
  color: var(--text-subtle); white-space: nowrap;
}
.jl-svclist-table thead tr th:before,
.jl-svclist-table thead tr th:after { color: var(--border-strong); opacity: 0.6; }

/* Rows */
.jl-svclist-row {
  border-bottom: 1px solid #f1f5f9;
  cursor: pointer;
  transition: background 0.12s;
}
.jl-svclist-row:last-child { border-bottom: none; }
.jl-svclist-row:hover { background: #f6fef7; }
.jl-svclist-row:hover .jl-svclist-product { color: var(--accent); }
.jl-svclist-row td {
  padding: 16px 24px;
  font-size: 13.5px; color: var(--text-secondary);
  vertical-align: middle;
  border-top: none !important;
  white-space: nowrap;
}

/* Icon cell */
.jl-svclist-icon-cell { width: 48px; text-align: center; padding: 16px 12px !important; }
.jl-svclist-srv-icon {
  width: 34px; height: 34px;
  background: var(--accent-light);
  border-radius: 9px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 14px; color: var(--accent);
  border: 1px solid rgba(74,138,40,0.15);
}

/* Product cell */
.jl-svclist-product {
  font-size: 14px; font-weight: 600; color: var(--text-primary);
  transition: color 0.12s; margin-bottom: 3px;
}
.jl-svclist-domain {
  font-size: 12.5px; color: var(--text-muted); text-decoration: none;
  display: inline-flex; align-items: center; gap: 4px;
}
.jl-svclist-domain i { font-size: 10px; }
.jl-svclist-domain:hover { color: var(--accent); text-decoration: none; }
.jl-svclist-domain-none { font-size: 13px; color: var(--border-strong); }

/* Price cell */
.jl-svclist-amount { font-size: 14px; font-weight: 700; color: var(--text-primary); }
.jl-svclist-cycle  { font-size: 11.5px; color: var(--text-subtle); margin-top: 2px; }

/* Date */
.jl-svclist-date { font-size: 13px; color: var(--text-muted); }

/* Status badges */
.jl-svclist-status {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 12px; border-radius: 20px;
  font-size: 11.5px; font-weight: 700; white-space: nowrap;
}
.jl-svclist-status::before {
  content: ''; width: 6px; height: 6px; border-radius: 50%;
  display: inline-block; flex-shrink: 0;
}
.jl-svc-status-active      { background: #dcfce7; color: #16a34a; }
.jl-svc-status-active::before { background: #16a34a; }
.jl-svc-status-suspended   { background: #fff7ed; color: #c2410c; }
.jl-svc-status-suspended::before { background: #c2410c; }
.jl-svc-status-cancelled   { background: var(--surface-2); color: var(--text-muted); }
.jl-svc-status-cancelled::before { background: #94a3b8; }
.jl-svc-status-terminated  { background: var(--danger-light); color: var(--danger); }
.jl-svc-status-terminated::before { background: #dc2626; }
.jl-svc-status-pending     { background: #fef9c3; color: #a16207; }
.jl-svc-status-pending::before { background: #a16207; }

/* ── Footer / Pagination ── */
.jl-svclist-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 24px;
  background: #fafbfc;
  border-top: 1.5px solid var(--surface-2);
  flex-wrap: wrap; gap: 10px;
}
.jl-svclist-footer .dataTables_info { font-size: 12.5px; color: var(--text-subtle); }
.jl-svclist-footer .dataTables_paginate { display: flex; align-items: center; gap: 4px; }
.jl-svclist-footer .paginate_button {
  padding: 6px 13px; border-radius: 8px;
  font-size: 13px; font-weight: 600;
  color: var(--text-secondary) !important; cursor: pointer;
  border: 1.5px solid var(--border) !important;
  background: #fff !important;
  transition: all 0.15s; line-height: 1.4;
}
.jl-svclist-footer .paginate_button:hover:not(.disabled) {
  border-color: var(--accent) !important;
  color: var(--accent) !important;
  background: var(--accent-light) !important;
}
.jl-svclist-footer .paginate_button.current,
.jl-svclist-footer .paginate_button.current:hover {
  background: var(--accent) !important; color: #fff !important;
  border-color: var(--accent) !important;
  box-shadow: 0 2px 8px rgba(74,138,40,0.25);
}
.jl-svclist-footer .paginate_button.disabled { opacity: 0.35; cursor: default; pointer-events: none; }

@media (max-width: 700px) {
  .jl-svclist-header { flex-direction: column; align-items: flex-start; }
  .jl-svclist-toolbar { flex-direction: column; align-items: flex-start; }
  .jl-svclist-search-wrap .dataTables_filter input { width: 100%; }
  .jl-svclist-row td { padding: 12px 14px; }
}

/* =====================================================
   SHARED LIST PAGE SYSTEM
   (Invoices · Quotes · Domains)
   ===================================================== */

.jl-list-wrap {
  max-width: 1060px;
  margin: 0 auto;
  padding-bottom: 48px;
}

/* ── Header ── */
.jl-list-header {
  display: flex; align-items: center;
  justify-content: space-between;
  gap: 16px; margin-bottom: 24px; flex-wrap: wrap;
}
.jl-list-header-left { display: flex; align-items: center; gap: 16px; }

.jl-list-header-icon {
  width: 50px; height: 50px; border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  font-size: 21px; color: #fff; flex-shrink: 0;
}
.jl-list-icon-blue   { background: linear-gradient(135deg, #2563eb, #60a5fa); box-shadow: 0 4px 14px rgba(37,99,235,0.30); }
.jl-list-icon-purple { background: linear-gradient(135deg, #7c3aed, #a78bfa); box-shadow: 0 4px 14px rgba(124,58,237,0.30); }
.jl-list-icon-teal   { background: linear-gradient(135deg, #0d9488, #34d399); box-shadow: 0 4px 14px rgba(13,148,136,0.30); }

.jl-list-title {
  font-size: 22px; font-weight: 800; color: var(--text-primary);
  margin: 0 0 3px; letter-spacing: -0.3px;
}
.jl-list-sub { font-size: 13px; color: var(--text-muted); margin: 0; }

.jl-list-header-alert {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--danger-light); color: var(--danger);
  padding: 8px 14px; border-radius: 10px;
  font-size: 13px; font-weight: 600;
  border: 1px solid #fecaca;
}
.jl-list-header-alert i { font-size: 13px; }

.jl-list-btn-new {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--accent); color: #fff;
  border-radius: 10px; padding: 11px 22px;
  font-size: 13.5px; font-weight: 700;
  text-decoration: none; white-space: nowrap;
  box-shadow: 0 2px 10px rgba(74,138,40,0.30);
  transition: background 0.18s, box-shadow 0.18s, transform 0.12s;
}
.jl-list-btn-new:hover {
  background: var(--accent-hover); color: #fff; text-decoration: none;
  transform: translateY(-1px); box-shadow: 0 4px 18px rgba(74,138,40,0.40);
}

/* ── Card ── */
.jl-list-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 28px rgba(0,0,0,0.06);
}

/* ── Toolbar ── */
.jl-list-toolbar {
  display: flex; align-items: center;
  justify-content: space-between;
  padding: 16px 24px;
  background: #fff;
  border-bottom: 1.5px solid #f1f5f9;
  gap: 12px; flex-wrap: wrap;
}
.jl-list-search-wrap .dataTables_filter { margin: 0; }
.jl-list-search-wrap .dataTables_filter label {
  display: flex; align-items: center; margin: 0; position: relative;
}
.jl-list-search-wrap .dataTables_filter label::before {
  content: '\f002'; font-family: 'Font Awesome 5 Free'; font-weight: 900;
  position: absolute; left: 12px; color: var(--text-subtle); font-size: 12px;
  pointer-events: none; z-index: 1;
}
.jl-list-search-wrap .dataTables_filter label > span { display: none; }
.jl-list-search-wrap .dataTables_filter input {
  background: var(--surface); border: 1.5px solid var(--border); border-radius: 9px;
  padding: 9px 14px 9px 34px; font-size: 13.5px; outline: none;
  transition: all 0.18s; width: 290px; color: var(--text-primary); margin-left: 0 !important;
}
.jl-list-search-wrap .dataTables_filter input::placeholder { color: #b0bec5; }
.jl-list-search-wrap .dataTables_filter input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(74,138,40,0.10);
  background: #fff;
}
.jl-list-show-wrap .dataTables_length { margin: 0; }
.jl-list-show-wrap .dataTables_length label {
  display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--text-muted); margin: 0;
}
.jl-list-show-wrap .dataTables_length select {
  background: var(--surface); border: 1.5px solid var(--border); border-radius: 9px;
  padding: 8px 12px; font-size: 13px; outline: none; cursor: pointer; color: var(--text-primary);
}

/* ── Loading ── */
.jl-list-loading { padding: 40px; text-align: center; color: var(--text-subtle); font-size: 13.5px; }

/* ── Table ── */
.jl-list-table-wrap { overflow-x: auto; padding: 0 16px; }
.jl-list-table {
  width: 100% !important; border-collapse: collapse;
  margin: 0 !important; table-layout: auto;
}
.jl-list-table thead tr th {
  background: var(--surface); border-bottom: 1.5px solid #e8edf2; border-top: none;
  padding: 12px 24px; font-size: 11px; font-weight: 800;
  text-transform: uppercase; letter-spacing: 0.7px; color: var(--text-subtle); white-space: nowrap;
}
.jl-list-table thead tr th:before,
.jl-list-table thead tr th:after { color: var(--border-strong); opacity: 0.6; }

.jl-list-row {
  border-bottom: 1px solid #f1f5f9; cursor: pointer; transition: background 0.12s;
}
.jl-list-row:last-child { border-bottom: none; }
.jl-list-row:hover { background: #f6fef7; }
.jl-list-row td {
  padding: 15px 24px; font-size: 13.5px; color: var(--text-secondary);
  vertical-align: middle; border-top: none !important; white-space: nowrap;
}

/* ── Shared date style ── */
.jl-list-date { font-size: 13px; color: var(--text-muted); }

/* ── Shared status badge ── */
.jl-list-status {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 12px; border-radius: 20px;
  font-size: 11.5px; font-weight: 700; white-space: nowrap;
}
.jl-list-status::before {
  content: ''; width: 6px; height: 6px; border-radius: 50%;
  display: inline-block; flex-shrink: 0;
}

/* ── Footer / Pagination ── */
.jl-list-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 24px; background: #fafbfc;
  border-top: 1.5px solid var(--surface-2); flex-wrap: wrap; gap: 10px;
}
.jl-list-footer .dataTables_info { font-size: 12.5px; color: var(--text-subtle); }
.jl-list-footer .dataTables_paginate { display: flex; align-items: center; gap: 4px; }
.jl-list-footer .paginate_button {
  padding: 6px 13px; border-radius: 8px; font-size: 13px; font-weight: 600;
  color: var(--text-secondary) !important; cursor: pointer;
  border: 1.5px solid var(--border) !important; background: #fff !important;
  transition: all 0.15s; line-height: 1.4;
}
.jl-list-footer .paginate_button:hover:not(.disabled) {
  border-color: var(--accent) !important; color: var(--accent) !important;
  background: var(--accent-light) !important;
}
.jl-list-footer .paginate_button.current,
.jl-list-footer .paginate_button.current:hover {
  background: var(--accent) !important; color: #fff !important;
  border-color: var(--accent) !important;
  box-shadow: 0 2px 8px rgba(74,138,40,0.25);
}
.jl-list-footer .paginate_button.disabled { opacity: 0.35; cursor: default; pointer-events: none; }

/* =====================================================
   PAGE STATS — shared across Services / Domains /
                Quotes / Tickets / Invoices
   ===================================================== */
.jl-page-stats {
  display: grid;
  gap: 14px;
  margin-bottom: 20px;
}
.jl-page-stats-4 { grid-template-columns: repeat(4, 1fr); }
.jl-page-stats-3 { grid-template-columns: repeat(3, 1fr); }

.jl-page-stat {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  padding: 18px 20px;
  display: flex;
  align-items: center;
  gap: 14px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
  transition: box-shadow 0.14s, transform 0.12s;
}
.jl-page-stat:hover {
  box-shadow: 0 4px 18px rgba(0,0,0,0.09);
  transform: translateY(-1px);
}

.jl-page-stat-icon {
  width: 44px; height: 44px;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; flex-shrink: 0;
}

.jl-page-stat-value {
  font-size: 26px;
  font-weight: 800;
  color: var(--text-primary);
  line-height: 1;
  margin-bottom: 3px;
  letter-spacing: -0.5px;
}

.jl-page-stat-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-subtle);
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

@media (max-width: 700px) {
  .jl-page-stats-4 { grid-template-columns: repeat(2, 1fr); }
  .jl-page-stats-3 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 420px) {
  .jl-page-stats-4,
  .jl-page-stats-3 { grid-template-columns: 1fr 1fr; }
}

/* =====================================================
   INVOICE STATS (legacy — replaced by jl-page-stats)
   ===================================================== */
.jl-inv-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 20px;
}

.jl-inv-stat {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  padding: 18px 20px;
  display: flex;
  align-items: center;
  gap: 14px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
  transition: box-shadow 0.14s, transform 0.12s;
}

.jl-inv-stat:hover {
  box-shadow: 0 4px 16px rgba(0,0,0,0.09);
  transform: translateY(-1px);
}

.jl-inv-stat-icon {
  width: 42px; height: 42px;
  border-radius: 11px;
  display: flex; align-items: center; justify-content: center;
  font-size: 17px; flex-shrink: 0;
}

.jl-inv-stat-all    { background: #eff6ff; color: #2563eb; }
.jl-inv-stat-paid   { background: #dcfce7; color: #16a34a; }
.jl-inv-stat-unpaid { background: #fef9c3; color: #a16207; }
.jl-inv-stat-overdue{ background: var(--danger-light); color: var(--danger); }

.jl-inv-stat-value {
  font-size: 26px;
  font-weight: 800;
  color: var(--text-primary);
  line-height: 1;
  margin-bottom: 3px;
  letter-spacing: -0.5px;
}

.jl-inv-stat-label {
  font-size: 11.5px;
  font-weight: 600;
  color: var(--text-subtle);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

@media (max-width: 640px) {
  .jl-inv-stats { grid-template-columns: repeat(2, 1fr); }
}

/* =====================================================
   INVOICES
   ===================================================== */
.jl-inv-num {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 13px; font-weight: 700; color: #2563eb;
  background: #eff6ff; padding: 3px 10px; border-radius: 20px;
  border: 1px solid rgba(37,99,235,0.15);
}
.jl-inv-num i { font-size: 10px; }
.jl-inv-amount { font-size: 14px; font-weight: 700; color: var(--text-primary); }

/* Invoice status */
.jl-inv-status-paid       { background: #dcfce7; color: #16a34a; }
.jl-inv-status-paid::before { background: #16a34a; }
.jl-inv-status-unpaid     { background: var(--danger-light); color: var(--danger); }
.jl-inv-status-unpaid::before { background: #dc2626; }
.jl-inv-status-overdue    { background: var(--danger-light); color: #b91c1c; }
.jl-inv-status-overdue::before { background: #b91c1c; }
.jl-inv-status-cancelled  { background: var(--surface-2); color: var(--text-muted); }
.jl-inv-status-cancelled::before { background: #94a3b8; }
.jl-inv-status-draft      { background: #fef9c3; color: #a16207; }
.jl-inv-status-draft::before { background: #a16207; }
.jl-inv-status-refunded   { background: #f5f3ff; color: #7c3aed; }
.jl-inv-status-refunded::before { background: #7c3aed; }
.jl-inv-status-collections { background: #fff7ed; color: #c2410c; }
.jl-inv-status-collections::before { background: #c2410c; }

/* =====================================================
   QUOTES
   ===================================================== */
.jl-qt-subject {
  font-size: 14px; font-weight: 600; color: var(--text-primary);
  max-width: 340px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  display: block;
}

/* Quote status */
.jl-qt-status-draft     { background: #fef9c3; color: #a16207; }
.jl-qt-status-draft::before { background: #a16207; }
.jl-qt-status-delivered { background: #dbeafe; color: #2563eb; }
.jl-qt-status-delivered::before { background: #2563eb; }
.jl-qt-status-accepted  { background: #dcfce7; color: #16a34a; }
.jl-qt-status-accepted::before { background: #16a34a; }
.jl-qt-status-cancelled { background: var(--surface-2); color: var(--text-muted); }
.jl-qt-status-cancelled::before { background: #94a3b8; }

/* Download button */
.jl-dl-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; border-radius: 8px;
  background: var(--surface-2); border: 1.5px solid var(--border);
  color: var(--text-muted); font-size: 13px; cursor: pointer;
  transition: all 0.14s;
}
.jl-dl-btn:hover { background: var(--accent-light); border-color: var(--accent); color: var(--accent); }

/* =====================================================
   DOMAINS
   ===================================================== */

/* Bulk action bar */
.jl-domain-bulk-bar {
  display: flex; align-items: center;
  gap: 8px; margin-bottom: 14px; flex-wrap: wrap;
}
.jl-bulk-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px; border-radius: 9px;
  background: #fff; border: 1.5px solid var(--border);
  color: var(--text-secondary); font-size: 13px; font-weight: 600;
  cursor: pointer; transition: all 0.14s; white-space: nowrap;
}
.jl-bulk-btn:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-light); }
.jl-bulk-btn i { font-size: 12px; }

.jl-bulk-dropdown { position: relative; }
.jl-bulk-more i { font-size: 10px; margin-left: 2px; }
.jl-bulk-menu {
  display: none; position: absolute; top: calc(100% + 6px); left: 0;
  background: #fff; border: 1.5px solid var(--border); border-radius: 10px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.10); min-width: 200px; z-index: 200;
  overflow: hidden;
}
.jl-bulk-menu.open { display: block; }
.jl-bulk-menu-item {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 16px; font-size: 13px; color: var(--text-secondary);
  text-decoration: none; transition: background 0.12s;
}
.jl-bulk-menu-item:hover { background: #f4f6f9; color: var(--accent); text-decoration: none; }
.jl-bulk-menu-item i { font-size: 12px; color: var(--text-subtle); width: 14px; }

/* Domain specific columns */
.jl-dom-check-col { width: 40px; padding: 15px 10px !important; }
.jl-dom-ssl-col   { width: 40px; padding: 15px 10px !important; text-align: center; }
.jl-dom-check { width: 16px; height: 16px; cursor: pointer; accent-color: var(--accent); }

.jl-dom-name {
  font-size: 14px; font-weight: 600; color: var(--text-primary);
  text-decoration: none; display: inline-flex; align-items: center; gap: 5px;
  margin-bottom: 3px; transition: color 0.12s;
}
.jl-dom-name i { font-size: 10px; color: var(--text-subtle); }
.jl-dom-name:hover { color: var(--accent); text-decoration: none; }

.jl-dom-autorenew {
  font-size: 12px; color: var(--text-subtle);
  display: flex; align-items: center; gap: 4px;
}
.jl-dom-renew-on  { color: #16a34a; }
.jl-dom-renew-off { color: var(--danger); }
.jl-dom-expiring  {
  display: inline-flex; align-items: center; gap: 3px;
  color: var(--warning); font-weight: 600; margin-left: 8px;
}
.jl-dom-expiring i { font-size: 10px; }

/* Domain status */
.jl-dom-status-active     { background: #dcfce7; color: #16a34a; }
.jl-dom-status-active::before { background: #16a34a; }
.jl-dom-status-expired    { background: var(--danger-light); color: var(--danger); }
.jl-dom-status-expired::before { background: #dc2626; }
.jl-dom-status-cancelled  { background: var(--surface-2); color: var(--text-muted); }
.jl-dom-status-cancelled::before { background: #94a3b8; }
.jl-dom-status-pending    { background: #fef9c3; color: #a16207; }
.jl-dom-status-pending::before { background: #a16207; }
.jl-dom-status-transferred { background: #f5f3ff; color: #7c3aed; }
.jl-dom-status-transferred::before { background: #7c3aed; }

/* Hover row — domain name gets accent */
.jl-list-row:hover .jl-dom-name { color: var(--accent); }

@media (max-width: 700px) {
  .jl-list-header { flex-direction: column; align-items: flex-start; }
  .jl-list-toolbar { flex-direction: column; align-items: flex-start; }
  .jl-list-search-wrap .dataTables_filter input { width: 100%; }
  .jl-list-row td { padding: 12px 14px; }
  .jl-qt-subject { max-width: 180px; }
}

/* ============================================================
   KNOWLEDGE BASE — jl-kb-*
   ============================================================ */

.jl-kb-wrap {
  max-width: 1060px;
  margin: 0 auto;
}

/* Page header (reuses .jl-list-header pattern) */
.jl-kb-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
  gap: 14px;
}
.jl-kb-header-left {
  display: flex;
  align-items: center;
  gap: 14px;
}
.jl-kb-header-icon {
  width: 46px;
  height: 46px;
  border-radius: 12px;
  background: #f0fdf4;
  color: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
}
.jl-kb-title {
  font-size: 20px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0;
  line-height: 1.2;
}
.jl-kb-sub {
  font-size: 13px;
  color: var(--text-muted);
  margin: 2px 0 0;
}

/* Search bar */
.jl-kb-search-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  padding: 22px 24px;
  margin-bottom: 20px;
}
.jl-kb-search-inner {
  display: flex;
  gap: 10px;
  align-items: center;
}
.jl-kb-search-input {
  flex: 1;
  height: 42px;
  border: 1.5px solid var(--border);
  border-radius: 9px;
  padding: 0 14px 0 38px;
  font-size: 14px;
  color: var(--text-primary);
  background: var(--surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='%2394a3b8' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001c.03.04.062.078.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1.007 1.007 0 0 0-.115-.099zm-5.242 1.156a5.5 5.5 0 1 1 0-11 5.5 5.5 0 0 1 0 11z'/%3E%3C/svg%3E") no-repeat 12px center;
  outline: none;
  transition: border-color .15s;
}
.jl-kb-search-input:focus { border-color: var(--accent); background-color: #fff; }
.jl-kb-search-btn {
  height: 42px;
  padding: 0 20px;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: 9px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s;
  white-space: nowrap;
}
.jl-kb-search-btn:hover { background: var(--accent-hover); }

/* Category grid */
.jl-kb-cats-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  margin-bottom: 20px;
}
.jl-kb-cat-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  padding: 20px 22px;
  display: flex;
  align-items: flex-start;
  gap: 14px;
  text-decoration: none;
  transition: border-color .15s, box-shadow .15s, transform .15s;
  color: inherit;
}
.jl-kb-cat-card:hover {
  border-color: var(--accent);
  box-shadow: 0 4px 16px rgba(74,138,40,.10);
  transform: translateY(-2px);
  text-decoration: none;
  color: inherit;
}
.jl-kb-cat-icon {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  background: #f0fdf4;
  color: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
}
.jl-kb-cat-body { flex: 1; min-width: 0; }
.jl-kb-cat-name {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0 0 4px;
  line-height: 1.3;
}
.jl-kb-cat-desc {
  font-size: 12.5px;
  color: var(--text-muted);
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.jl-kb-cat-badge {
  flex-shrink: 0;
  background: #f0fdf4;
  color: var(--accent);
  font-size: 11px;
  font-weight: 700;
  padding: 3px 9px;
  border-radius: 20px;
  white-space: nowrap;
}

/* Articles list card */
.jl-kb-articles-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  margin-bottom: 20px;
}
.jl-kb-articles-head {
  padding: 16px 22px;
  border-bottom: 1px solid #f1f5f9;
  display: flex;
  align-items: center;
  gap: 10px;
}
.jl-kb-articles-head-icon {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: #fef9c3;
  color: #a16207;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
}
.jl-kb-articles-head-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0;
}
.jl-kb-article-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 13px 22px;
  border-bottom: 1px solid #f8fafc;
  text-decoration: none;
  color: var(--text-primary);
  transition: background .13s;
}
.jl-kb-article-item:last-child { border-bottom: none; }
.jl-kb-article-item:hover { background: var(--surface); text-decoration: none; color: var(--text-primary); }
.jl-kb-article-item-icon {
  width: 28px;
  height: 28px;
  border-radius: 7px;
  background: var(--surface-2);
  color: var(--text-muted);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  flex-shrink: 0;
}
.jl-kb-article-item:hover .jl-kb-article-item-icon { background: #f0fdf4; color: var(--accent); }
.jl-kb-article-item-body { flex: 1; min-width: 0; }
.jl-kb-article-item-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  margin: 0 0 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.jl-kb-article-item-excerpt {
  font-size: 12px;
  color: var(--text-subtle);
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.jl-kb-article-item-arrow {
  color: var(--border-strong);
  font-size: 12px;
  flex-shrink: 0;
}
.jl-kb-article-item:hover .jl-kb-article-item-arrow { color: var(--accent); }
.jl-kb-empty {
  padding: 36px 22px;
  text-align: center;
  color: var(--text-subtle);
  font-size: 13px;
}

/* KB Article detail */
.jl-kb-article-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  margin-bottom: 20px;
}
.jl-kb-article-header {
  padding: 24px 28px 20px;
  border-bottom: 1px solid #f1f5f9;
}
.jl-kb-article-title {
  font-size: 22px;
  font-weight: 800;
  color: var(--text-primary);
  margin: 0 0 12px;
  line-height: 1.3;
  letter-spacing: -0.3px;
}
.jl-kb-article-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}
.jl-kb-article-tag {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: #eff6ff;
  color: #2563eb;
  font-size: 11.5px;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 20px;
}
.jl-kb-article-votes {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: var(--text-muted);
  font-size: 12px;
}
.jl-kb-article-print {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 5px 13px;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--text-secondary);
  cursor: pointer;
  text-decoration: none;
  transition: background .13s, color .13s;
}
.jl-kb-article-print:hover { background: var(--surface-2); color: var(--text-primary); text-decoration: none; }
.jl-kb-article-content {
  padding: 26px 28px;
  font-size: 14.5px;
  line-height: 1.75;
  color: var(--text-primary);
}
.jl-kb-article-content h1,
.jl-kb-article-content h2,
.jl-kb-article-content h3 { color: var(--text-primary); margin-top: 1.4em; }
.jl-kb-article-content a { color: var(--accent); }
.jl-kb-article-content pre,
.jl-kb-article-content code { background: var(--surface); border-radius: 6px; }
.jl-kb-article-vote-bar {
  padding: 18px 28px;
  border-top: 1px solid #f1f5f9;
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.jl-kb-article-vote-label {
  font-size: 13.5px;
  font-weight: 600;
  color: var(--text-secondary);
}
.jl-kb-vote-yes,
.jl-kb-vote-no {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  height: 36px;
  padding: 0 18px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: all .15s;
}
.jl-kb-vote-yes {
  background: #f0fdf4;
  color: #16a34a;
  border-color: #bbf7d0;
}
.jl-kb-vote-yes:hover { background: #dcfce7; border-color: #86efac; }
.jl-kb-vote-no {
  background: var(--danger-light);
  color: var(--danger);
  border-color: #fecaca;
}
.jl-kb-vote-no:hover { background: #fee2e2; border-color: #fca5a5; }

/* Back link */
.jl-back-link {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--text-muted);
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  transition: color .13s;
  margin-bottom: 4px;
}
.jl-back-link:hover { color: var(--accent); text-decoration: none; }

/* Edit link */
.jl-edit-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  float: right;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 5px 13px;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--text-secondary);
  text-decoration: none;
  transition: background .13s;
}
.jl-edit-link:hover { background: var(--surface-2); color: var(--text-primary); text-decoration: none; }

/* ============================================================
   ANNOUNCEMENTS — jl-ann-*
   ============================================================ */

.jl-ann-wrap {
  max-width: 1060px;
  margin: 0 auto;
}

/* Page header */
.jl-ann-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
  gap: 14px;
}
.jl-ann-header-left {
  display: flex;
  align-items: center;
  gap: 14px;
}
.jl-ann-header-icon {
  width: 46px;
  height: 46px;
  border-radius: 12px;
  background: #eff6ff;
  color: #2563eb;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
}
.jl-ann-title {
  font-size: 20px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0;
  line-height: 1.2;
}
.jl-ann-sub {
  font-size: 13px;
  color: var(--text-muted);
  margin: 2px 0 0;
}

/* Announcement item card */
.jl-ann-item {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  margin-bottom: 16px;
  transition: border-color .15s, box-shadow .15s;
}
.jl-ann-item:hover {
  border-color: var(--border-strong);
  box-shadow: 0 4px 16px rgba(0,0,0,.06);
}
.jl-ann-item-header {
  padding: 18px 24px 14px;
  border-bottom: 1px solid #f1f5f9;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.jl-ann-item-title {
  font-size: 17px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0 0 6px;
  line-height: 1.35;
}
.jl-ann-item-title a {
  color: var(--text-primary);
  text-decoration: none;
  transition: color .13s;
}
.jl-ann-item-title a:hover { color: var(--accent); }
.jl-ann-item-date {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11.5px;
  font-weight: 600;
  color: var(--text-subtle);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.jl-ann-item-body {
  padding: 16px 24px;
  font-size: 14px;
  line-height: 1.7;
  color: var(--text-secondary);
}
.jl-ann-item-body article p:last-child { margin-bottom: 0; }
.jl-ann-item-footer {
  padding: 12px 24px;
  border-top: 1px solid #f8fafc;
  display: flex;
  align-items: center;
  gap: 10px;
}
.jl-ann-read-more {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: #f0fdf4;
  color: var(--accent);
  font-size: 12.5px;
  font-weight: 700;
  padding: 6px 14px;
  border-radius: 8px;
  border: 1.5px solid #bbf7d0;
  text-decoration: none;
  transition: background .13s, border-color .13s;
}
.jl-ann-read-more:hover { background: #dcfce7; border-color: #86efac; text-decoration: none; color: var(--accent); }

/* Announcement detail */
.jl-ann-detail-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  margin-bottom: 20px;
}
.jl-ann-detail-header {
  padding: 26px 28px 20px;
  border-bottom: 1px solid #f1f5f9;
}
.jl-ann-detail-title {
  font-size: 24px;
  font-weight: 800;
  color: var(--text-primary);
  margin: 0 0 12px;
  line-height: 1.3;
  letter-spacing: -0.3px;
}
.jl-ann-detail-meta {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}
.jl-ann-detail-meta-item {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 12.5px;
  color: var(--text-muted);
  font-weight: 500;
}
.jl-ann-detail-meta-item i { color: var(--text-subtle); }
.jl-ann-detail-content {
  padding: 26px 28px;
  font-size: 14.5px;
  line-height: 1.8;
  color: var(--text-primary);
}
.jl-ann-detail-content h1,
.jl-ann-detail-content h2,
.jl-ann-detail-content h3 { color: var(--text-primary); margin-top: 1.4em; }
.jl-ann-detail-content a { color: var(--accent); }
.jl-ann-detail-content img { max-width: 100%; border-radius: 8px; }
.jl-ann-detail-content p:last-child { margin-bottom: 0; }

/* Pagination */
.jl-ann-pagination {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-top: 10px;
  flex-wrap: wrap;
}
.jl-ann-page-item {
  display: inline-flex;
}
.jl-ann-page-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 10px;
  border-radius: 8px;
  border: 1.5px solid var(--border);
  background: #fff;
  color: var(--text-secondary);
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  transition: all .13s;
}
.jl-ann-page-link:hover { border-color: var(--accent); color: var(--accent); background: #f0fdf4; text-decoration: none; }
.jl-ann-page-item.active .jl-ann-page-link { background: var(--accent); border-color: var(--accent); color: #fff; }
.jl-ann-page-item.disabled .jl-ann-page-link { opacity: .4; pointer-events: none; }

/* Voted success alert */
.jl-kb-voted-alert {
  background: #f0fdf4;
  border: 1.5px solid #bbf7d0;
  border-radius: 12px;
  padding: 13px 18px;
  margin-bottom: 18px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13.5px;
  font-weight: 600;
  color: #16a34a;
}
.jl-kb-voted-alert i { font-size: 16px; }

@media (max-width: 700px) {
  .jl-kb-cats-grid { grid-template-columns: 1fr; }
  .jl-kb-article-header,
  .jl-kb-article-content,
  .jl-kb-article-vote-bar { padding-left: 18px; padding-right: 18px; }
  .jl-ann-item-header,
  .jl-ann-item-body,
  .jl-ann-item-footer { padding-left: 16px; padding-right: 16px; }
  .jl-ann-detail-header,
  .jl-ann-detail-content { padding-left: 18px; padding-right: 18px; }
  .jl-kb-header, .jl-ann-header { flex-direction: column; align-items: flex-start; }
}

/* ============================================================
   SERVICE DETAILS PAGE — jl-sd-*
   ============================================================ */

/* wrapper + two-column grid */
.jl-sd-wrap { max-width: 1060px; margin: 0 auto; }
.jl-sd-layout {
  display: grid;
  grid-template-columns: 1fr 256px;
  gap: 18px;
  align-items: start;
}

/* ── Inline alerts ── */
.jl-sd-alert {
  display: flex; align-items: center; gap: 12px;
  padding: 13px 18px; border-radius: 12px;
  font-size: 13.5px; font-weight: 500; margin-bottom: 16px;
  border: 1.5px solid transparent;
}
.jl-sd-alert-danger  { background:#fef2f2; color:#dc2626; border-color:#fecaca; }
.jl-sd-alert-warning { background:#fffbeb; color:#b45309; border-color:#fde68a; }
.jl-sd-alert i { font-size:16px; flex-shrink:0; }
.jl-sd-alert-cta {
  margin-left:auto; display:inline-flex; align-items:center; gap:5px;
  background:#fff; border:1.5px solid currentColor; border-radius:8px;
  padding:5px 12px; font-size:12px; font-weight:700;
  text-decoration:none; color:inherit; white-space:nowrap;
}
.jl-sd-alert-cta:hover { opacity:.8; text-decoration:none; color:inherit; }

/* ── Hero card ── */
.jl-sd-hero {
  position: relative;
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  margin-bottom: 14px;
}
.jl-sd-hero-accent {
  position: absolute; top: 0; left: 0; right: 0; height: 4px;
  background: linear-gradient(90deg, var(--accent), #6ab53a);
}
.jl-sd-hero-inner {
  display: flex; align-items: flex-start;
  gap: 18px; padding: 22px 22px 18px; flex-wrap: wrap;
}
.jl-sd-hero-icon {
  width: 54px; height: 54px; border-radius: 14px;
  background: linear-gradient(135deg, var(--accent), #6ab53a);
  color: #fff; display: flex; align-items: center; justify-content: center;
  font-size: 24px; flex-shrink: 0;
  box-shadow: 0 4px 16px rgba(74,138,40,.30);
}
.jl-sd-hero-info { flex: 1; min-width: 0; }
.jl-sd-hero-row {
  display: flex; align-items: center;
  gap: 10px; flex-wrap: wrap; margin-bottom: 5px;
}
.jl-sd-hero-name {
  font-size: 20px; font-weight: 800; color: var(--text-primary);
  margin: 0; letter-spacing: -0.3px; line-height: 1.2;
}
.jl-sd-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 12px; border-radius: 20px;
  font-size: 12px; font-weight: 700; white-space: nowrap;
}
.jl-sd-hero-group { font-size: 13px; color: var(--text-muted); margin: 0 0 5px; }
.jl-sd-hero-domain {
  font-size: 13px; margin: 0;
  display: flex; align-items: center; gap: 6px;
}
.jl-sd-hero-domain i { color: var(--accent); font-size: 12px; }
.jl-sd-domain-link { color: var(--accent); text-decoration: none; font-weight: 600; }
.jl-sd-domain-link:hover { text-decoration: underline; }
.jl-sd-hero-btns {
  display: flex; align-items: center; gap: 8px;
  flex-wrap: wrap; width: 100%;
}

/* ── Shared buttons ── */
.jl-sd-btn {
  display: inline-flex; align-items: center; gap: 7px;
  height: 36px; padding: 0 16px;
  border-radius: 9px; font-size: 13px; font-weight: 600;
  border: 1.5px solid transparent; cursor: pointer;
  text-decoration: none; transition: all .15s; white-space: nowrap;
  background: none;
}
.jl-sd-btn-primary  { background:var(--accent); color:#fff; border-color:var(--accent); }
.jl-sd-btn-primary:hover { background:var(--accent-hover); color:#fff; text-decoration:none; }
.jl-sd-btn-success  { background:#16a34a; color:#fff; border-color:#16a34a; }
.jl-sd-btn-success:hover { background:#15803d; color:#fff; text-decoration:none; }
.jl-sd-btn-danger   { background:#fef2f2; color:#dc2626; border-color:#fecaca; }
.jl-sd-btn-danger:hover { background:#fee2e2; color:#dc2626; text-decoration:none; }
.jl-sd-btn-danger.disabled { opacity:.5; pointer-events:none; }
.jl-sd-btn-outline  { background:#fff; color:#475569; border-color:#e2e8f0; }
.jl-sd-btn-outline:hover { border-color:var(--accent); color:var(--accent); background:#f0fdf4; text-decoration:none; }

/* ── Billing info grid ── */
.jl-sd-info-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 10px; margin-bottom: 14px;
}
.jl-sd-info-card {
  background: #fff; border: 1.5px solid var(--border);
  border-radius: 12px; padding: 13px 14px;
  display: flex; align-items: center; gap: 12px;
}
.jl-sd-info-icon {
  width: 36px; height: 36px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; flex-shrink: 0;
}
.jl-sd-info-label {
  font-size: 10.5px; font-weight: 700; color: var(--text-subtle);
  text-transform: uppercase; letter-spacing: 0.07em; margin-bottom: 3px;
}
.jl-sd-info-val { font-size: 14px; font-weight: 700; color: var(--text-primary); }

/* ── Generic card ── */
.jl-sd-card {
  background: #fff; border: 1.5px solid var(--border);
  border-radius: 14px; overflow: hidden; margin-bottom: 14px;
}
.jl-sd-card-section { margin-top: 14px; }

/* ── Section header ── */
.jl-sd-section-hd {
  display: flex; align-items: center; gap: 9px;
  padding: 13px 18px; border-bottom: 1.5px solid #f1f5f9;
  font-size: 13px; font-weight: 700; color: var(--text-primary);
}
.jl-sd-section-hd i { color: var(--accent); }
.jl-sd-section-body { padding: 14px 18px; }

/* ── Tabs ── */
.jl-sd-tab-nav {
  display: flex; border-bottom: 1.5px solid #f1f5f9;
  overflow-x: auto; scrollbar-width: none;
}
.jl-sd-tab-nav::-webkit-scrollbar { display: none; }
.jl-sd-tab {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 12px 16px; font-size: 13px; font-weight: 600;
  color: var(--text-muted); background: none; border: none;
  border-bottom: 2.5px solid transparent; cursor: pointer;
  white-space: nowrap; transition: color .13s, border-color .13s;
  margin-bottom: -1.5px;
}
.jl-sd-tab:hover { color: var(--accent); }
.jl-sd-tab:focus { outline: none; box-shadow: none; }
.jl-sd-tab.active { color: var(--accent); border-bottom-color: var(--accent); }
.jl-sd-tab i { font-size: 12px; }
.jl-sd-pane { display: none; }
.jl-sd-pane.active { display: block; }

/* ── KV rows ── */
.jl-sd-kv { margin: 0; padding: 4px 0; }
.jl-sd-kv-row {
  display: flex; align-items: flex-start; gap: 16px;
  padding: 11px 20px; border-bottom: 1px solid #f8fafc;
}
.jl-sd-kv-row:last-child { border-bottom: none; }
.jl-sd-kv dt {
  flex: 0 0 155px; font-size: 12px; font-weight: 700;
  color: var(--text-muted); font-style: normal; padding-top: 1px;
}
.jl-sd-kv dd {
  flex: 1; font-size: 13.5px; font-weight: 500;
  color: var(--text-primary); margin: 0; word-break: break-all;
}
.jl-sd-mono { font-family: 'SFMono-Regular',Consolas,monospace; font-size: 12.5px; }
.jl-sd-ip { color: var(--text-subtle); font-size: 11px; }
.jl-sd-pane-footer {
  display: flex; align-items: center; gap: 10px;
  padding: 13px 20px; border-top: 1px solid #f1f5f9; flex-wrap: wrap;
}
.jl-sd-module { padding: 18px 20px; }

/* ── Resource usage ── */
.jl-sd-usage {
  display: flex; gap: 32px; justify-content: center; padding: 20px 20px 8px;
}
.jl-sd-usage-item { text-align: center; }
.jl-sd-usage-lbl {
  font-size: 11px; font-weight: 700; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 10px;
}
.jl-sd-usage-sub { font-size: 11.5px; color: var(--text-subtle); margin: 6px 0 0; }
.jl-sd-usage-ts {
  text-align: center; font-size: 11.5px; color: var(--text-subtle);
  padding: 0 20px 16px; margin: 0;
}

/* ── Downloads ── */
.jl-sd-dl-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 14px; padding: 10px 0; border-bottom: 1px solid #f8fafc;
}
.jl-sd-dl-row:last-child { border-bottom: none; }
.jl-sd-dl-title { font-size: 13.5px; font-weight: 700; color: var(--text-primary); margin: 0 0 3px; }
.jl-sd-dl-desc  { font-size: 12px; color: var(--text-muted); margin: 0; }

/* ── Addons ── */
.jl-sd-addon-row { padding: 12px 0; border-bottom: 1px solid #f8fafc; }
.jl-sd-addon-row:last-child { border-bottom: none; }
.jl-sd-addon-hd { display: flex; align-items: center; gap: 10px; margin-bottom: 4px; }
.jl-sd-addon-name { font-size: 13.5px; font-weight: 700; color: var(--text-primary); }
.jl-sd-addon-meta { font-size: 12px; color: var(--text-muted); margin: 0 0 6px; }
.jl-sd-addon-actions { display: flex; gap: 8px; flex-wrap: wrap; }

/* ── Change Password ── */
.jl-sd-form-row { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.jl-sd-label { font-size: 12px; font-weight: 700; color: var(--text-secondary); }
.jl-sd-input {
  width: 100%; height: 40px; border: 1.5px solid var(--border);
  border-radius: 9px; padding: 0 14px; font-size: 13.5px;
  color: var(--text-primary); background: var(--surface); outline: none;
  transition: border-color .15s;
}
.jl-sd-input:focus { border-color: var(--accent); background: #fff; }
.jl-sd-pw-row { display: flex; gap: 10px; align-items: flex-start; }
.jl-sd-form-actions { display: flex; gap: 10px; flex-wrap: wrap; }

/* ════════════════════════════════════════
   SERVICE ASIDE PANEL — jl-sd-panel-*
   ════════════════════════════════════════ */
.jl-sd-aside { display: flex; flex-direction: column; gap: 14px; }

.jl-sd-panel {
  background: #fff; border: 1.5px solid var(--border);
  border-radius: 14px; overflow: hidden;
}
.jl-sd-panel-hd {
  display: flex; align-items: center; gap: 9px;
  padding: 12px 14px;
  font-size: 11px; font-weight: 800; color: var(--text-primary);
  text-transform: uppercase; letter-spacing: 0.07em;
  border-bottom: 1.5px solid #f1f5f9; background: var(--surface);
}
.jl-sd-panel-hd i { color: var(--accent); font-size: 12px; }
.jl-sd-panel-badge {
  margin-left: auto; background: var(--accent); color: #fff;
  font-size: 10px; font-weight: 800; padding: 2px 7px; border-radius: 20px;
}
.jl-sd-panel-html { padding: 10px 14px; font-size: 13px; color: var(--text-secondary); }
.jl-sd-panel-footer-html { padding: 9px 14px; border-top: 1px solid #f1f5f9; font-size: 12px; }

.jl-sd-panel-nav { display: flex; flex-direction: column; }
.jl-sd-panel-link {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; font-size: 13px; font-weight: 500;
  color: var(--text-secondary); text-decoration: none;
  border-bottom: 1px solid #f8fafc; transition: background .12s, color .12s;
  cursor: pointer;
}
.jl-sd-panel-link:last-child { border-bottom: none; }
.jl-sd-panel-link:hover { background: var(--surface); color: var(--accent); text-decoration: none; }
.jl-sd-panel-link:hover .jl-sd-panel-link-icon { background: #dcfce7; color: var(--accent); }
.jl-sd-panel-link:hover .jl-sd-panel-link-arr { color: var(--accent); }
.jl-sd-panel-link.is-current { background: #f0fdf4; color: var(--accent); font-weight: 700; }
.jl-sd-panel-link.is-current .jl-sd-panel-link-icon { background: #dcfce7; color: var(--accent); }
.jl-sd-panel-link.is-disabled { opacity: .45; pointer-events: none; }
.jl-sd-panel-link-static { cursor: default; }
.jl-sd-panel-link-static:hover { background: none; color: var(--text-secondary); }

.jl-sd-panel-link-icon {
  width: 28px; height: 28px; border-radius: 7px; background: var(--surface-2);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 11px; color: var(--text-muted); flex-shrink: 0; transition: background .12s, color .12s;
}
.jl-sd-panel-link-label { flex: 1; }
.jl-sd-panel-link-badge {
  background: var(--surface-2); color: var(--text-muted); font-size: 10px;
  font-weight: 700; padding: 2px 6px; border-radius: 20px; flex-shrink: 0;
}
.jl-sd-panel-link-arr { font-size: 9px; color: var(--border-strong); flex-shrink: 0; transition: color .12s; }

/* ============================================================
   CANCEL REQUEST PAGE — jl-cx-*   (premium redesign)
   ============================================================ */

.jl-cx-wrap { max-width: 640px; margin: 0 auto; }

/* ── Top back link ── */
.jl-cx-topbar { margin-bottom: 20px; }
.jl-cx-topbar-back {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 13px; font-weight: 600; color: var(--text-muted);
  text-decoration: none; transition: color .15s;
}
.jl-cx-topbar-back:hover { color: var(--text-primary); text-decoration: none; }
.jl-cx-topbar-back i { font-size: 11px; }

/* ── Hero ── */
.jl-cx-hero {
  display: flex; align-items: center; gap: 18px;
  background: linear-gradient(135deg, #1e0a0a 0%, #3b0d0d 100%);
  border-radius: 18px; padding: 28px 26px; margin-bottom: 20px;
  position: relative; overflow: hidden;
}
.jl-cx-hero::before {
  content: ''; position: absolute;
  top: -40px; right: -40px;
  width: 180px; height: 180px;
  background: radial-gradient(circle, rgba(220,38,38,.25) 0%, transparent 70%);
  pointer-events: none;
}
.jl-cx-hero-icon {
  width: 58px; height: 58px; border-radius: 16px; flex-shrink: 0;
  background: rgba(220,38,38,.18); border: 1.5px solid rgba(220,38,38,.35);
  display: flex; align-items: center; justify-content: center;
  font-size: 24px; color: #f87171;
}
.jl-cx-hero-title {
  font-size: 22px; font-weight: 800; color: #fff;
  margin: 0 0 5px; letter-spacing: -.3px;
}
.jl-cx-hero-meta {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  font-size: 13px; color: rgba(255,255,255,.6); margin: 0;
}
.jl-cx-hero-product { color: rgba(255,255,255,.85); font-weight: 600; }
.jl-cx-hero-dot { color: rgba(255,255,255,.3); }
.jl-cx-hero-domain { display: flex; align-items: center; gap: 5px; }
.jl-cx-hero-domain i { font-size: 11px; }

/* ── Error alert ── */
.jl-cx-alert-err {
  display: flex; align-items: center; gap: 10px;
  background: var(--danger-light); border: 1.5px solid var(--danger-border);
  border-radius: 11px; padding: 13px 16px;
  font-size: 13.5px; font-weight: 600; color: var(--danger);
  margin-bottom: 16px;
}
.jl-cx-alert-err i { font-size: 15px; flex-shrink: 0; }

/* ── Form sections ── */
.jl-cx-section {
  background: #fff; border: 1.5px solid var(--border);
  border-radius: 14px; padding: 20px 22px; margin-bottom: 14px;
}
.jl-cx-section-label {
  display: flex; align-items: center; gap: 8px;
  font-size: 11.5px; font-weight: 700; color: var(--text-subtle);
  text-transform: uppercase; letter-spacing: .6px;
  margin: 0 0 14px;
}
.jl-cx-section-label i { color: var(--accent); font-size: 11px; }

/* ── Type selector cards ── */
.jl-cx-type-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.jl-cx-type-item {
  display: block; cursor: pointer; margin: 0;
  position: relative;
}
.jl-cx-type-item input[type=radio] {
  position: absolute; opacity: 0; pointer-events: none;
}
.jl-cx-type-body {
  border: 1.5px solid var(--border); border-radius: 12px;
  padding: 16px 16px 14px; background: var(--surface);
  transition: border-color .15s, background .15s, box-shadow .15s;
  cursor: pointer; height: 100%;
}
.jl-cx-type-item.selected .jl-cx-type-body,
.jl-cx-type-item input:checked ~ .jl-cx-type-body {
  border-color: var(--accent); background: #f0fdf4;
  box-shadow: 0 0 0 3px rgba(74,138,40,.1);
}
.jl-cx-type-item:has(input[value="Immediate"]).selected .jl-cx-type-body,
.jl-cx-type-item:has(input[value="Immediate"]) input:checked ~ .jl-cx-type-body {
  border-color: var(--danger); background: var(--danger-light);
  box-shadow: 0 0 0 3px rgba(220,38,38,.1);
}
.jl-cx-type-top {
  display: flex; align-items: center; gap: 8px; margin-bottom: 8px;
}
.jl-cx-type-dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
}
.jl-cx-type-dot-green { background: #16a34a; }
.jl-cx-type-dot-red   { background: #dc2626; }
.jl-cx-type-name {
  font-size: 13.5px; font-weight: 700; color: var(--text-primary); flex: 1;
}
.jl-cx-type-check {
  font-size: 15px; color: var(--border-strong); transition: color .15s;
}
.jl-cx-type-item.selected .jl-cx-type-check { color: var(--accent); }
.jl-cx-type-item:has(input[value="Immediate"]).selected .jl-cx-type-check { color: var(--danger); }
.jl-cx-type-desc {
  font-size: 12px; color: var(--text-muted); margin: 0 0 10px;
  line-height: 1.55;
}
.jl-cx-type-tag {
  display: inline-flex; align-items: center;
  font-size: 10.5px; font-weight: 700; letter-spacing: .3px;
  padding: 2px 9px; border-radius: 20px;
}
.jl-cx-type-tag-green { background: #dcfce7; color: #15803d; }
.jl-cx-type-tag-red   { background: #fee2e2; color: #b91c1c; }

/* ── Textarea ── */
.jl-cx-textarea {
  width: 100%; border: 1.5px solid var(--border);
  border-radius: 10px; padding: 12px 14px;
  font-size: 13.5px; color: var(--text-primary); background: var(--surface);
  resize: vertical; outline: none; transition: border-color .15s, background .15s;
  font-family: inherit; line-height: 1.6; box-sizing: border-box;
}
.jl-cx-textarea:focus { border-color: var(--accent); background: #fff; }
.jl-cx-textarea::placeholder { color: var(--text-subtle); }

/* ── Domain block ── */
.jl-cx-domain-block {
  background: #fff7ed; border: 1.5px solid #fdba74;
  border-radius: 13px; padding: 18px 20px; margin-bottom: 14px;
}
.jl-cx-domain-head {
  display: flex; align-items: center; gap: 9px;
  font-size: 13.5px; font-weight: 700; color: #9a3412; margin-bottom: 8px;
}
.jl-cx-domain-head i { color: #ea580c; }
.jl-cx-domain-body { font-size: 13px; color: #c2410c; margin: 0 0 14px; }
.jl-cx-domain-check {
  display: flex; align-items: center; gap: 10px;
  font-size: 13px; font-weight: 600; color: #7c2d12; cursor: pointer;
}
.jl-cx-domain-check-box {
  width: 17px; height: 17px; border-radius: 5px; flex-shrink: 0;
  border: 2px solid #ea580c; background: #fff;
  display: flex; align-items: center; justify-content: center;
  transition: background .13s;
}
input#canceldomain:checked ~ .jl-cx-domain-check-box { background: #ea580c; }

/* ── Warning strip ── */
.jl-cx-warn-strip {
  display: flex; align-items: center; gap: 11px;
  background: var(--warning-light); border: 1.5px solid var(--warning-border);
  border-radius: 11px; padding: 13px 16px; margin-bottom: 18px;
  font-size: 12.5px; color: #92400e; line-height: 1.5;
}
.jl-cx-warn-strip i { color: var(--warning); font-size: 15px; flex-shrink: 0; }

/* ── Action buttons ── */
.jl-cx-actions {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
}
.jl-cx-submit-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: #dc2626; color: #fff;
  border: none; border-radius: 11px;
  padding: 13px 28px; font-size: 14px; font-weight: 700;
  cursor: pointer; transition: background .15s, box-shadow .15s;
  text-decoration: none; line-height: 1;
}
.jl-cx-submit-btn:hover { background: #b91c1c; box-shadow: 0 4px 14px rgba(220,38,38,.35); }
.jl-cx-submit-btn i { font-size: 13px; }
.jl-cx-keep-btn {
  display: inline-flex; align-items: center;
  padding: 12px 22px; border-radius: 11px;
  border: 1.5px solid var(--border); background: #fff;
  font-size: 13.5px; font-weight: 600; color: var(--text-secondary);
  text-decoration: none; transition: border-color .15s, color .15s;
}
.jl-cx-keep-btn:hover { border-color: var(--accent); color: var(--accent); text-decoration: none; }

/* ── State screens (success / invalid) ── */
.jl-cx-state {
  display: flex; flex-direction: column; align-items: center; text-align: center;
  padding: 60px 40px; border-radius: 18px; gap: 12px;
  background: #fff; border: 1.5px solid var(--border);
}
.jl-cx-state-gfx { font-size: 56px; line-height: 1; }
.jl-cx-state-success .jl-cx-state-gfx { color: #16a34a; }
.jl-cx-state-error   .jl-cx-state-gfx { color: var(--danger); }
.jl-cx-state-title { font-size: 22px; font-weight: 800; color: var(--text-primary); margin: 0; }
.jl-cx-state-body { font-size: 14px; color: var(--text-muted); margin: 0; max-width: 360px; line-height: 1.6; }
.jl-cx-back-btn {
  display: inline-flex; align-items: center; gap: 7px;
  margin-top: 6px; padding: 11px 24px;
  background: var(--accent); color: #fff;
  border-radius: 10px; font-size: 13.5px; font-weight: 700;
  text-decoration: none; transition: opacity .15s;
}
.jl-cx-back-btn:hover { opacity: .85; text-decoration: none; color: #fff; }

/* ── Responsive ── */
@media (max-width: 600px) {
  .jl-cx-type-grid { grid-template-columns: 1fr; }
  .jl-cx-actions { flex-direction: column; }
  .jl-cx-submit-btn, .jl-cx-keep-btn { width: 100%; justify-content: center; }
  .jl-cx-hero { padding: 22px 18px; }
  .jl-cx-hero-icon { width: 48px; height: 48px; font-size: 20px; }
}

/* Service ID tag */
.jl-sd-id-tag {
  text-align: center; font-size: 12px; color: var(--text-subtle);
  padding: 8px 14px; background: var(--surface);
  border: 1.5px solid var(--border); border-radius: 10px;
}
.jl-sd-id-tag strong { color: var(--text-secondary); }

/* ── Responsive ── */
@media (max-width: 900px) {
  .jl-sd-layout { grid-template-columns: 1fr; }
  .jl-sd-aside { display: grid; grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 600px) {
  .jl-sd-info-grid { grid-template-columns: repeat(2,1fr); }
  .jl-sd-aside { grid-template-columns: 1fr; }
  .jl-sd-hero-inner { flex-direction: column; }
  .jl-sd-hero-btns .jl-sd-btn { width: 100%; justify-content: center; }
}

/* ── Legacy svcdetail classes (kept for back-compat) ── */
.jl-svcdetail-layout {
  display: grid;
  grid-template-columns: 1fr 264px;
  gap: 20px;
  align-items: start;
}

/* ── Alerts ── */
.jl-svc-alert {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 13px 18px;
  border-radius: 12px;
  font-size: 13.5px;
  font-weight: 500;
  margin-bottom: 16px;
  border: 1.5px solid transparent;
}
.jl-svc-alert-danger {
  background: var(--danger-light); color: var(--danger); border-color: #fecaca;
}
.jl-svc-alert-warning {
  background: var(--warning-light); color: #b45309; border-color: #fde68a;
}
.jl-svc-alert i { font-size: 16px; flex-shrink: 0; }
.jl-svc-alert-btn {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #fff;
  border: 1.5px solid currentColor;
  border-radius: 8px;
  padding: 5px 13px;
  font-size: 12.5px;
  font-weight: 700;
  text-decoration: none;
  color: inherit;
  white-space: nowrap;
  transition: opacity .13s;
}
.jl-svc-alert-btn:hover { opacity: .8; text-decoration: none; color: inherit; }

/* ── Hero card ── */
.jl-svcdetail-hero {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  padding: 22px 24px;
  display: flex;
  align-items: flex-start;
  gap: 18px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.jl-svcdetail-hero-icon {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--accent), #6ab53a);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  flex-shrink: 0;
  box-shadow: 0 4px 14px rgba(74,138,40,.28);
}
.jl-svcdetail-hero-body { flex: 1; min-width: 0; }
.jl-svcdetail-hero-top {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 4px;
}
.jl-svcdetail-hero-name {
  font-size: 20px;
  font-weight: 800;
  color: var(--text-primary);
  margin: 0;
  letter-spacing: -0.3px;
  line-height: 1.2;
}
.jl-svcdetail-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}
.jl-svcdetail-hero-group {
  font-size: 13px;
  color: var(--text-muted);
  margin: 0 0 4px;
}
.jl-svcdetail-hero-domain {
  font-size: 13.5px;
  margin: 0;
}
.jl-svcdetail-domain-link {
  color: var(--accent);
  text-decoration: none;
  font-weight: 600;
}
.jl-svcdetail-domain-link:hover { text-decoration: underline; color: var(--accent-hover); }
.jl-svcdetail-hero-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 2px;
  width: 100%;
}

/* ── Shared buttons ── */
.jl-svc-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  height: 36px;
  padding: 0 16px;
  border-radius: 9px;
  font-size: 13px;
  font-weight: 600;
  border: 1.5px solid transparent;
  cursor: pointer;
  text-decoration: none;
  transition: all .15s;
  white-space: nowrap;
}
.jl-svc-btn-primary { background: var(--accent); color: #fff; border-color: var(--accent); }
.jl-svc-btn-primary:hover { background: var(--accent-hover); color: #fff; border-color: var(--accent-hover); text-decoration: none; }
.jl-svc-btn-success { background: #16a34a; color: #fff; border-color: #16a34a; }
.jl-svc-btn-success:hover { background: #15803d; color: #fff; text-decoration: none; }
.jl-svc-btn-danger { background: var(--danger-light); color: var(--danger); border-color: #fecaca; }
.jl-svc-btn-danger:hover { background: #fee2e2; text-decoration: none; color: var(--danger); }
.jl-svc-btn-danger.disabled { opacity: .5; pointer-events: none; }
.jl-svc-btn-outline { background: #fff; color: var(--text-secondary); border-color: var(--border); }
.jl-svc-btn-outline:hover { border-color: var(--accent); color: var(--accent); background: #f0fdf4; text-decoration: none; }

/* ── Billing info grid ── */
.jl-svcdetail-info-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 16px;
}
.jl-svcdetail-info-item {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 12px;
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.jl-svcdetail-info-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-subtle);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  display: flex;
  align-items: center;
  gap: 5px;
}
.jl-svcdetail-info-label i { color: var(--border-strong); }
.jl-svcdetail-info-value {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary);
}

/* ── Hook output ── */
.jl-svcdetail-hook {
  margin-bottom: 16px;
}

/* ── Tabs card ── */
.jl-svcdetail-tabs-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
}
.jl-svcdetail-tab-nav {
  display: flex;
  border-bottom: 1.5px solid #f1f5f9;
  overflow-x: auto;
  scrollbar-width: none;
}
.jl-svcdetail-tab-nav::-webkit-scrollbar { display: none; }
.jl-svcdetail-tab-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 13px 18px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-muted);
  background: none;
  border: none;
  border-bottom: 2.5px solid transparent;
  cursor: pointer;
  white-space: nowrap;
  transition: color .13s, border-color .13s;
  margin-bottom: -1.5px;
}
.jl-svcdetail-tab-btn:hover { color: var(--accent); }
.jl-svcdetail-tab-btn.active { color: var(--accent); border-bottom-color: var(--accent); }
.jl-svcdetail-tab-body { padding: 0; }
.jl-svcdetail-tab-pane { display: none; }
.jl-svcdetail-tab-pane.active { display: block; }

/* section head (downloads, addons, changepw) */
.jl-svcdetail-section-head {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 14px 20px;
  border-bottom: 1.5px solid #f1f5f9;
  font-size: 13.5px;
  font-weight: 700;
  color: var(--text-primary);
}
.jl-svcdetail-section-head i { color: var(--accent); }

/* ── KV list (domain/server info rows) ── */
.jl-svcdetail-kv-list { padding: 8px 0; }
.jl-svcdetail-kv-item {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 12px 22px;
  border-bottom: 1px solid #f8fafc;
}
.jl-svcdetail-kv-item:last-child { border-bottom: none; }
.jl-svcdetail-kv-key {
  flex: 0 0 160px;
  font-size: 12.5px;
  font-weight: 700;
  color: var(--text-muted);
  padding-top: 1px;
}
.jl-svcdetail-kv-val {
  flex: 1;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--text-primary);
  word-break: break-all;
}
.jl-svcdetail-mono { font-family: 'SFMono-Regular', Consolas, monospace; font-size: 12.5px; }
.jl-svcdetail-tab-footer {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 22px;
  border-top: 1px solid #f1f5f9;
  flex-wrap: wrap;
}

/* ── Resource usage ── */
.jl-svcdetail-usage-grid {
  display: flex;
  gap: 28px;
  justify-content: center;
  padding: 24px 22px 10px;
}
.jl-svcdetail-usage-item { text-align: center; }
.jl-svcdetail-usage-label {
  font-size: 12px;
  font-weight: 700;
  color: var(--text-muted);
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.jl-svcdetail-usage-sub { font-size: 12px; color: var(--text-subtle); margin: 6px 0 0; }
.jl-svcdetail-usage-updated {
  text-align: center;
  font-size: 12px;
  color: var(--text-subtle);
  padding: 0 22px 16px;
  margin: 0;
}

/* ── Downloads ── */
.jl-svcdetail-download-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 0;
  border-bottom: 1px solid #f8fafc;
}
.jl-svcdetail-download-item:last-child { border-bottom: none; }
.jl-svcdetail-download-title { font-size: 14px; font-weight: 700; color: var(--text-primary); margin: 0 0 4px; }
.jl-svcdetail-download-desc  { font-size: 12.5px; color: var(--text-muted); margin: 0; }

/* ── Addons ── */
.jl-svcdetail-addon-item {
  padding: 14px 0;
  border-bottom: 1px solid #f8fafc;
}
.jl-svcdetail-addon-item:last-child { border-bottom: none; }
.jl-svcdetail-addon-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 4px;
}
.jl-svcdetail-addon-name { font-size: 14px; font-weight: 700; color: var(--text-primary); }
.jl-svcdetail-addon-detail { font-size: 12.5px; color: var(--text-muted); margin: 0 0 8px; }
.jl-svcdetail-addon-actions a,
.jl-svcdetail-addon-actions button { @extend .jl-svc-btn; }

/* ── Change Password form ── */
.jl-form-row {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 14px;
}
.jl-form-label {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--text-secondary);
}
.jl-form-input {
  width: 100%;
  height: 40px;
  border: 1.5px solid var(--border);
  border-radius: 9px;
  padding: 0 14px;
  font-size: 13.5px;
  color: var(--text-primary);
  background: var(--surface);
  outline: none;
  transition: border-color .15s;
}
.jl-form-input:focus { border-color: var(--accent); background: #fff; }

/* ════════════════════════════════════
   SERVICE PANEL SIDEBAR — jl-svcpanel-*
   ════════════════════════════════════ */

.jl-svcpanel-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  margin-bottom: 14px;
}
.jl-svcpanel-card:last-child { margin-bottom: 0; }

.jl-svcpanel-head {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 13px 16px;
  font-size: 12.5px;
  font-weight: 800;
  color: var(--text-primary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  border-bottom: 1.5px solid #f1f5f9;
  background: var(--surface);
}
.jl-svcpanel-head i { color: var(--accent); font-size: 13px; }

.jl-svcpanel-badge {
  margin-left: auto;
  background: var(--accent);
  color: #fff;
  font-size: 10px;
  font-weight: 800;
  padding: 2px 7px;
  border-radius: 20px;
}

.jl-svcpanel-body-html { padding: 12px 16px; font-size: 13px; color: var(--text-secondary); }
.jl-svcpanel-footer-html { padding: 10px 16px; border-top: 1px solid #f1f5f9; font-size: 12.5px; }

.jl-svcpanel-links { display: flex; flex-direction: column; }

.jl-svcpanel-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 16px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-secondary);
  text-decoration: none;
  border-bottom: 1px solid #f8fafc;
  transition: background .12s, color .12s;
  cursor: pointer;
}
.jl-svcpanel-link:last-child { border-bottom: none; }
.jl-svcpanel-link:hover { background: var(--surface); color: var(--accent); text-decoration: none; }
.jl-svcpanel-link:hover .jl-svcpanel-link-arrow { color: var(--accent); }
.jl-svcpanel-link.current { background: #f0fdf4; color: var(--accent); font-weight: 700; }
.jl-svcpanel-link.disabled { opacity: .45; pointer-events: none; }
.jl-svcpanel-link-static { cursor: default; }
.jl-svcpanel-link-static:hover { background: none; color: var(--text-secondary); }

.jl-svcpanel-link-icon {
  width: 28px;
  height: 28px;
  border-radius: 7px;
  background: var(--surface-2);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  color: var(--text-muted);
  flex-shrink: 0;
  transition: background .12s, color .12s;
}
.jl-svcpanel-link:hover .jl-svcpanel-link-icon { background: #dcfce7; color: var(--accent); }
.jl-svcpanel-link.current .jl-svcpanel-link-icon { background: #dcfce7; color: var(--accent); }

.jl-svcpanel-link span { flex: 1; }

.jl-svcpanel-link-badge {
  background: var(--surface-2);
  color: var(--text-muted);
  font-size: 10.5px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 20px;
  flex-shrink: 0;
}

.jl-svcpanel-link-arrow {
  font-size: 9px;
  color: var(--border-strong);
  flex-shrink: 0;
  transition: color .12s;
}

@media (max-width: 900px) {
  .jl-svcdetail-layout {
    grid-template-columns: 1fr;
  }
  .jl-svcdetail-sidebar {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }
  .jl-svcpanel-card { margin-bottom: 0; }
}
@media (max-width: 600px) {
  .jl-svcdetail-info-grid { grid-template-columns: repeat(2, 1fr); }
  .jl-svcdetail-sidebar { grid-template-columns: 1fr; }
  .jl-svcdetail-hero { flex-direction: column; }
  .jl-svcdetail-hero-actions { flex-direction: column; }
  .jl-svc-btn { width: 100%; justify-content: center; }
}

/* ============================================================
   Affiliates  (affiliates.tpl + affiliatessignup.tpl)
   ============================================================ */

/* Flash */
.aff-flash {
  display: flex; align-items: center; gap: 10px;
  padding: 13px 18px; border-radius: 10px;
  font-size: 13.5px; font-weight: 600; margin-bottom: 20px;
}
.aff-flash i { font-size: 16px; }
.aff-flash-success { background: var(--accent-light); color: #15803d; border: 1px solid var(--accent-border); }

/* ---- Hero with referral link ---- */
.aff-hero {
  background: linear-gradient(135deg, #1e4d10 0%, #2d6b1a 40%, #4a8a28 78%, #5ea832 100%);
  border-radius: 16px;
  padding: 28px 30px;
  color: #fff;
  margin-bottom: 24px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(74,138,40,0.30);
}
.aff-hero::before {
  content: ''; position: absolute; right: -60px; top: -70px;
  width: 230px; height: 230px; border-radius: 50%;
  background: rgba(255,255,255,.06); pointer-events: none;
}
.aff-hero-head { display: flex; align-items: center; gap: 16px; position: relative; z-index: 1; }
.aff-hero-icon {
  width: 52px; height: 52px; flex-shrink: 0;
  border-radius: 14px; background: rgba(255,255,255,.14);
  display: flex; align-items: center; justify-content: center; font-size: 22px;
}
.aff-hero-head h2 { font-size: 21px; font-weight: 800; margin: 0 0 4px; letter-spacing: -0.3px; }
.aff-hero-head p { font-size: 13.5px; margin: 0; opacity: .82; }

.aff-reflink { position: relative; z-index: 1; margin-top: 22px; }
.aff-reflink label {
  display: block; font-size: 11.5px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .6px; opacity: .8; margin-bottom: 8px;
}
.aff-reflink-row { display: flex; gap: 10px; }
.aff-reflink-input {
  flex: 1; min-width: 0;
  background: rgba(255,255,255,.96); color: #0f172a;
  border: none; border-radius: 9px;
  padding: 12px 16px; font-size: 13.5px; font-family: var(--font);
  box-shadow: inset 0 1px 2px rgba(0,0,0,.06);
}
.aff-reflink-input:focus { outline: none; box-shadow: 0 0 0 3px rgba(255,255,255,.35); }
.aff-copy-btn {
  flex-shrink: 0; background: #fff; color: #2d5a1b;
  border: none; border-radius: 9px; padding: 0 18px;
  font-size: 13px; font-weight: 700; cursor: pointer;
  display: inline-flex; align-items: center; gap: 7px;
  transition: background .14s, color .14s; box-shadow: 0 2px 8px rgba(0,0,0,.14);
}
.aff-copy-btn:hover { background: #f0fdf4; }
.aff-copy-btn.aff-copied { background: #15803d; color: #fff; }

/* ---- Stats spacing ---- */
.aff-stats { margin-bottom: 24px; }

/* ---- Earnings ---- */
.aff-earnings {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 16px; margin-bottom: 22px;
}
.aff-earning-card {
  background: var(--card-bg); border: 1px solid var(--card-border);
  border-radius: var(--card-radius); padding: 20px 22px;
  box-shadow: var(--card-shadow);
}
.aff-earning-label {
  font-size: 12.5px; font-weight: 600; color: var(--text-muted);
  display: flex; align-items: center; gap: 7px; margin-bottom: 10px;
}
.aff-earning-label i { color: var(--text-subtle); }
.aff-earning-value { font-size: 24px; font-weight: 800; color: var(--text-primary); letter-spacing: -0.5px; }
.aff-earning-highlight {
  background: linear-gradient(135deg, var(--accent-light) 0%, #fff 100%);
  border-color: var(--accent-border);
}
.aff-earning-highlight .aff-earning-label,
.aff-earning-highlight .aff-earning-label i { color: var(--accent); }
.aff-earning-highlight .aff-earning-value { color: var(--accent-hover); }

/* ---- Withdraw ---- */
.aff-withdraw { text-align: center; margin: 4px 0 30px; }
.aff-withdraw-btn { font-size: 14px; padding: 11px 26px; }
.aff-withdraw-btn.disabled { opacity: .5; cursor: not-allowed; }
.aff-withdraw-hint { margin-top: 12px; font-size: 12.5px; color: var(--text-muted); }

/* ---- Sections (referrals, banners) ---- */
.aff-section {
  background: var(--card-bg); border: 1px solid var(--card-border);
  border-radius: var(--card-radius); padding: 22px 24px;
  box-shadow: var(--card-shadow); margin-bottom: 22px;
}
.aff-section-head { margin-bottom: 16px; }
.aff-section-head h3 {
  font-size: 15.5px; font-weight: 700; color: var(--text-primary);
  margin: 0; display: flex; align-items: center; gap: 9px;
}
.aff-section-head h3 i { color: var(--accent); font-size: 14px; }
.aff-empty { text-align: center; color: var(--text-muted); padding: 26px 0; }
.aff-banners { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; justify-content: center; }
.aff-banners img { max-width: 100%; }

/* ============================================================
   Affiliate signup / activation
   ============================================================ */
.aff-signup {
  max-width: 760px; margin: 0 auto;
  background: var(--card-bg); border: 1px solid var(--card-border);
  border-radius: 16px; box-shadow: var(--card-shadow); overflow: hidden;
}
.aff-signup-hero {
  text-align: center; padding: 40px 30px 30px;
  background: linear-gradient(135deg, #1e4d10 0%, #2d6b1a 40%, #4a8a28 78%, #5ea832 100%);
  color: #fff; position: relative; overflow: hidden;
}
.aff-signup-hero::before {
  content: ''; position: absolute; left: 50%; top: -120px; transform: translateX(-50%);
  width: 320px; height: 320px; border-radius: 50%;
  background: rgba(255,255,255,.06); pointer-events: none;
}
.aff-signup-badge {
  width: 64px; height: 64px; margin: 0 auto 16px;
  border-radius: 18px; background: rgba(255,255,255,.16);
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; position: relative; z-index: 1;
}
.aff-signup-hero h2 { font-size: 24px; font-weight: 800; margin: 0 0 8px; position: relative; z-index: 1; }
.aff-signup-intro {
  font-size: 14px; opacity: .85; margin: 0 auto; max-width: 520px;
  line-height: 1.6; position: relative; z-index: 1;
}
.aff-signup-benefits {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 18px; padding: 30px;
}
.aff-benefit { text-align: center; }
.aff-benefit-icon {
  width: 48px; height: 48px; margin: 0 auto 12px;
  border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 19px;
}
.aff-benefit-icon.green  { background: #f0fdf4; color: #16a34a; }
.aff-benefit-icon.blue   { background: #eff6ff; color: #2563eb; }
.aff-benefit-icon.indigo { background: var(--accent-light); color: var(--accent); }
.aff-benefit p { font-size: 13px; color: var(--text-secondary); line-height: 1.55; margin: 0; }
.aff-signup-cta { text-align: center; padding: 6px 30px 38px; }
.aff-signup-btn { font-size: 15px; padding: 13px 38px; }

/* ---- Responsive ---- */
@media (max-width: 768px) {
  .aff-earnings { grid-template-columns: 1fr; }
  .aff-signup-benefits { grid-template-columns: 1fr; }
  .aff-reflink-row { flex-direction: column; }
  .aff-copy-btn { padding: 11px; justify-content: center; }
}

/* ============================================================
   Homepage domain search (includes/domain-search.tpl)
   ============================================================ */
.jl-hsearch{ margin:0 0 22px; }
.jl-hsearch-card{
  background:#fff;
  border:1px solid var(--card-border);
  border-radius:16px;
  box-shadow:0 8px 30px rgba(20,40,10,0.06);
  padding:30px 28px 24px;
  max-width:860px;
  margin:0 auto;
  text-align:center;
}
.jl-hsearch-head{ margin-bottom:20px; }
.jl-hsearch-badge{
  width:52px; height:52px; margin:0 auto 12px;
  display:flex; align-items:center; justify-content:center;
  border-radius:14px;
  background:linear-gradient(135deg,#2d6b1a 0%,#4a8a28 70%,#5ea832 100%);
  color:#fff; font-size:22px;
  box-shadow:0 6px 16px rgba(74,138,40,0.30);
}
.jl-hsearch-title{ font-size:24px; font-weight:800; color:var(--text-primary); margin:0 0 6px; letter-spacing:-.4px; }
.jl-hsearch-sub{ font-size:14px; color:var(--text-muted); margin:0; }

.jl-hsearch-bar{
  display:flex; align-items:stretch; gap:8px;
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:12px;
  padding:7px;
  transition:border-color .18s, box-shadow .18s;
}
.jl-hsearch-bar:focus-within{ border-color:var(--accent); box-shadow:0 0 0 4px rgba(74,138,40,0.10); background:#fff; }
.jl-hsearch-bar-icon{ display:flex; align-items:center; padding:0 6px 0 12px; color:var(--text-subtle); font-size:14px; }
.jl-hsearch-input{
  flex:1 1 auto; min-width:0;
  border:none; background:transparent; outline:none;
  font-size:15px; color:var(--text-primary); padding:0 6px;
}
.jl-hsearch-input::placeholder{ color:var(--text-subtle); }
.jl-hsearch-btn{
  display:inline-flex; align-items:center; gap:7px;
  border:1px solid transparent; border-radius:9px;
  padding:11px 20px; font-size:14px; font-weight:700;
  cursor:pointer; white-space:nowrap; transition:all .14s; text-decoration:none;
}
.jl-hsearch-btn--primary{ background:var(--accent); color:#fff; border-color:var(--accent); }
.jl-hsearch-btn--primary:hover{ background:var(--accent-hover); border-color:var(--accent-hover); }
.jl-hsearch-btn--ghost{ background:#fff; color:var(--text-secondary); border-color:var(--border); }
.jl-hsearch-btn--ghost:hover{ background:var(--surface-2); color:var(--text-primary); }

.jl-hsearch-captcha{ margin-top:14px; display:flex; justify-content:center; }

.jl-hsearch-tlds{
  list-style:none; padding:0; margin:18px 0 0;
  display:flex; flex-wrap:wrap; justify-content:center; gap:8px;
}
.jl-hsearch-tld{
  display:inline-flex; align-items:center; gap:7px;
  background:var(--surface); border:1px solid var(--border);
  border-radius:999px; padding:6px 14px; font-size:12.5px;
}
.jl-hsearch-tld-name{ font-weight:700; color:var(--accent); }
.jl-hsearch-tld-price{ color:var(--text-muted); }

.jl-hsearch-pricing{
  display:inline-flex; align-items:center; gap:6px;
  margin-top:16px; font-size:13px; font-weight:600;
  color:var(--text-muted); text-decoration:none;
}
.jl-hsearch-pricing:hover{ color:var(--accent); }

@media (max-width:620px){
  .jl-hsearch-card{ padding:24px 18px; }
  .jl-hsearch-bar{ flex-wrap:wrap; }
  .jl-hsearch-input{ flex:1 1 100%; padding:8px 6px; }
  .jl-hsearch-btn{ flex:1 1 auto; justify-content:center; }
}

/* ============================================================
   Homepage / theme index (homepage.tpl)
   ============================================================ */
.jl-home{ display:flex; flex-direction:column; width:100%; }

/* Full-width: cancel .jongly-content padding, guest centering,
   theme.min.css #main-body padding and Bootstrap col gutters */
.page-homepage .jongly-content{ padding:0; align-items:stretch; }
.page-homepage #main-body{ width:100%; padding:0 !important; margin:0 !important; }
.page-homepage #main-body .row{ margin:0 !important; }
.page-homepage #main-body .primary-content{ padding:0 !important; }
.page-homepage .jl-breadcrumb{ display:none; }
.page-homepage .jongly-content > .alert{ margin:16px 32px 0; }

/* Centered inner container */
.jl-home-container{
  width:100%; max-width:1200px; margin:0 auto;
  padding:0 32px 72px;
}

/* ---------- Hero ---------- */
.jl-home-hero{
  position:relative; overflow:hidden;
  background:#0b2105;
  background:radial-gradient(ellipse 80% 60% at 70% -10%, #1e4d10 0%, #0b2105 55%);
  padding:88px 32px 64px;
  color:#fff;
}
.jl-home-hero-glow{
  position:absolute; border-radius:50%; filter:blur(90px); pointer-events:none;
}
.jl-home-hero-glow--1{
  width:520px; height:520px; right:-140px; top:-200px;
  background:rgba(94,168,50,.22);
}
.jl-home-hero-glow--2{
  width:420px; height:420px; left:-160px; bottom:-220px;
  background:rgba(45,107,26,.25);
}
.jl-home-hero-grid{
  position:absolute; inset:0; pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.10) 1px, transparent 1px);
  background-size:28px 28px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,.5), transparent 70%);
  -webkit-mask-image:linear-gradient(to bottom, rgba(0,0,0,.5), transparent 70%);
}
.jl-home-hero-inner{
  position:relative; z-index:1;
  max-width:860px; margin:0 auto; text-align:center;
}
.jl-home-hero-badge{
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.16);
  padding:7px 16px; border-radius:999px; font-size:12.5px; font-weight:600;
  margin-bottom:26px; color:rgba(255,255,255,.85);
  backdrop-filter:blur(6px);
}
.jl-home-hero-badge-dot{
  width:7px; height:7px; border-radius:50%; background:#6ee84a;
  box-shadow:0 0 0 3px rgba(110,232,74,.22);
  animation:jl-pulse 2.2s ease-in-out infinite;
}
@keyframes jl-pulse{
  0%,100%{ box-shadow:0 0 0 3px rgba(110,232,74,.22); }
  50%{ box-shadow:0 0 0 6px rgba(110,232,74,.08); }
}
.jl-home-hero h1{
  font-size:52px; font-weight:800; letter-spacing:-1.8px; line-height:1.08;
  margin:0 0 20px;
}
.jl-home-hero h1 em{
  font-style:normal;
  background:linear-gradient(90deg,#8fe05c,#5ea832);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
}
.jl-home-hero > .jl-home-hero-inner > p,
.jl-home-hero-inner > p{
  font-size:17px; color:rgba(255,255,255,.65); margin:0 auto 36px;
  line-height:1.65; max-width:560px;
}
.jl-home-hero-actions{ display:flex; justify-content:center; gap:12px; flex-wrap:wrap; }

/* Domain search embedded in hero — strip the card chrome */
.jl-home-hero-search{ max-width:660px; margin:0 auto; }
.jl-home-hero-search .jl-hsearch{ margin:0; }
.jl-home-hero-search .jl-hsearch-card{
  background:transparent; border:none; box-shadow:none; padding:0; max-width:none;
}
.jl-home-hero-search .jl-hsearch-head{ display:none; }
.jl-home-hero-search .jl-hsearch-bar{
  background:#fff; border-color:transparent; border-radius:14px; padding:6px;
  box-shadow:0 18px 50px rgba(0,0,0,.35);
}
.jl-home-hero-search .jl-hsearch-btn--ghost{ border-color:var(--card-border); }
.jl-home-hero-search .jl-hsearch-tlds{ margin-top:18px; }
.jl-home-hero-search .jl-hsearch-tld{
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.85);
}
.jl-home-hero-search .jl-hsearch-tld-name{ color:#fff; }
.jl-home-hero-search .jl-hsearch-tld-price{ color:rgba(255,255,255,.55); }
.jl-home-hero-search .jl-hsearch-pricing{ color:rgba(255,255,255,.6); }
.jl-home-hero-search .jl-hsearch-pricing:hover{ color:#8fe05c; }

/* Inline trust row */
.jl-home-trust{
  display:flex; justify-content:center; flex-wrap:wrap; gap:10px 28px;
  margin-top:34px; font-size:13px; color:rgba(255,255,255,.55); font-weight:500;
}
.jl-home-trust i{ color:#6ee84a; margin-right:7px; font-size:11px; }

/* ---------- Buttons ---------- */
.jl-home-btn{
  display:inline-flex; align-items:center; gap:9px; cursor:pointer;
  padding:13px 28px; border-radius:11px; font-size:14px; font-weight:700;
  text-decoration:none; transition:all .15s;
}
.jl-home-btn--light{ background:#fff; color:#173d0b; box-shadow:0 2px 12px rgba(0,0,0,.2); }
.jl-home-btn--light:hover{ background:#f0fdf4; color:#0b2105; text-decoration:none; transform:translateY(-1px); }
.jl-home-btn--ghost{ background:rgba(255,255,255,.08); color:#fff; border:1.5px solid rgba(255,255,255,.3); }
.jl-home-btn--ghost:hover{ background:rgba(255,255,255,.16); border-color:rgba(255,255,255,.6); color:#fff; text-decoration:none; }
.jl-home-btn--dark{ background:#13380a; color:#fff; }
.jl-home-btn--dark:hover{ background:#1e4d10; color:#fff; text-decoration:none; transform:translateY(-1px); }

/* ---------- Section scaffolding ---------- */
.jl-home-section{ margin-top:72px; }
.jl-home-eyebrow{
  display:inline-block; font-size:11.5px; font-weight:800; letter-spacing:1.8px;
  text-transform:uppercase; color:var(--accent); margin-bottom:10px;
}
.jl-home-sechead{
  display:flex; align-items:flex-end; justify-content:space-between; gap:20px;
  margin-bottom:30px;
}
.jl-home-sechead h2{
  font-size:30px; font-weight:800; color:var(--text-primary);
  letter-spacing:-.8px; margin:0; line-height:1.15;
}
.jl-home-sechead-link{
  font-size:13.5px; font-weight:700; color:var(--accent); text-decoration:none;
  display:inline-flex; align-items:center; gap:7px; white-space:nowrap; padding-bottom:4px;
}
.jl-home-sechead-link:hover{ color:#1e4d10; text-decoration:none; }
.jl-home-sechead-link i{ font-size:11px; transition:transform .15s; }
.jl-home-sechead-link:hover i{ transform:translateX(3px); }

/* ---------- Product cards ---------- */
.jl-home-grid{
  display:grid; grid-template-columns:repeat(auto-fill,minmax(270px,1fr)); gap:16px;
}
.jl-home-card{
  display:flex; flex-direction:column;
  background:var(--card-bg); border:1px solid var(--card-border); border-radius:16px;
  padding:26px; text-decoration:none;
  transition:transform .18s, box-shadow .18s, border-color .18s;
}
.jl-home-card:hover{
  transform:translateY(-4px);
  box-shadow:0 16px 40px rgba(20,40,10,.10);
  border-color:var(--accent-border); text-decoration:none;
}
.jl-home-card-top{
  display:flex; align-items:center; justify-content:space-between; margin-bottom:20px;
}
.jl-home-card-icon{
  width:46px; height:46px; border-radius:12px;
  display:flex; align-items:center; justify-content:center; font-size:18px;
  background:#f0fdf4; color:#1e4d10;
}
.jl-home-card-arrow{
  font-size:13px; color:var(--text-subtle);
  transition:transform .18s, color .18s;
}
.jl-home-card:hover .jl-home-card-arrow{ transform:translateX(4px); color:var(--accent); }
.jl-home-card h3{ font-size:16.5px; font-weight:700; color:var(--text-primary); margin:0 0 7px; letter-spacing:-.2px; }
.jl-home-card p{ font-size:13px; color:var(--text-secondary); line-height:1.6; margin:0; }

/* ---------- Why-us split ---------- */
.jl-home-split{
  display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center;
}
.jl-home-split-text h2{
  font-size:30px; font-weight:800; color:var(--text-primary);
  letter-spacing:-.8px; margin:0 0 14px; line-height:1.15;
}
.jl-home-split-text > p{
  font-size:14.5px; color:var(--text-secondary); line-height:1.7; margin:0 0 22px;
}
.jl-home-checks{ list-style:none; margin:0 0 28px; padding:0; display:flex; flex-direction:column; gap:12px; }
.jl-home-checks li{
  font-size:14px; font-weight:600; color:var(--text-primary);
  display:flex; align-items:center; gap:11px;
}
.jl-home-checks i{ color:var(--accent); font-size:15px; }
.jl-home-split-cards{
  display:grid; grid-template-columns:1fr 1fr; gap:14px;
}
.jl-home-mini{
  background:var(--card-bg); border:1px solid var(--card-border); border-radius:16px;
  padding:26px 22px;
}
.jl-home-mini:nth-child(2){ transform:translateY(14px); }
.jl-home-mini:nth-child(4){ transform:translateY(14px); }
.jl-home-mini-value{
  font-size:28px; font-weight:800; letter-spacing:-1px; color:var(--text-primary);
  margin-bottom:6px;
}
.jl-home-mini-label{ font-size:12.5px; color:var(--text-muted); line-height:1.5; }

/* ---------- Resources ---------- */
.jl-home-res{
  display:grid; grid-template-columns:1fr 1fr; gap:14px;
}
.jl-home-res-card{
  display:flex; align-items:center; gap:18px;
  background:var(--card-bg); border:1px solid var(--card-border); border-radius:16px;
  padding:22px 24px; text-decoration:none;
  transition:transform .18s, box-shadow .18s, border-color .18s;
}
.jl-home-res-card:hover{
  transform:translateY(-2px); box-shadow:0 12px 30px rgba(20,40,10,.08);
  border-color:var(--accent-border); text-decoration:none;
}
.jl-home-res-icon{
  width:46px; height:46px; border-radius:12px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:18px;
  background:#f0fdf4; color:#1e4d10;
}
.jl-home-res-text{ flex:1; min-width:0; }
.jl-home-res-text h4{ font-size:14.5px; font-weight:700; color:var(--text-primary); margin:0 0 3px; }
.jl-home-res-text p{ font-size:12.5px; color:var(--text-muted); margin:0; line-height:1.5; }
.jl-home-res-arrow{
  font-size:12px; color:var(--text-subtle); transition:transform .18s, color .18s;
}
.jl-home-res-card:hover .jl-home-res-arrow{ transform:translateX(4px); color:var(--accent); }

/* ---------- CTA ---------- */
.jl-home-cta{
  position:relative; overflow:hidden;
  background:#0b2105;
  background:radial-gradient(ellipse 70% 90% at 30% 0%, #1e4d10 0%, #0b2105 60%);
  border-radius:22px; padding:52px 56px; color:#fff;
  display:flex; align-items:center; justify-content:space-between; gap:28px; flex-wrap:wrap;
}
.jl-home-cta-glow{
  position:absolute; width:380px; height:380px; right:-100px; top:-160px;
  border-radius:50%; background:rgba(94,168,50,.2); filter:blur(80px); pointer-events:none;
}
.jl-home-cta-text{ position:relative; }
.jl-home-cta-text h2{ font-size:28px; font-weight:800; letter-spacing:-.8px; margin:0 0 8px; }
.jl-home-cta-text p{ font-size:14px; color:rgba(255,255,255,.6); margin:0; }
.jl-home-cta-actions{ position:relative; display:flex; gap:12px; flex-wrap:wrap; }

/* ---------- Responsive ---------- */
@media (max-width:991px){
  .jl-home-hero h1{ font-size:38px; letter-spacing:-1.2px; }
  .jl-home-split{ grid-template-columns:1fr; gap:36px; }
  .jl-home-res{ grid-template-columns:1fr; }
}
@media (max-width:640px){
  .jl-home-hero{ padding:56px 20px 44px; }
  .jl-home-hero h1{ font-size:30px; }
  .jl-home-container{ padding:0 16px 48px; }
  .jl-home-section{ margin-top:48px; }
  .jl-home-sechead{ flex-direction:column; align-items:flex-start; gap:8px; }
  .jl-home-sechead h2, .jl-home-split-text h2{ font-size:24px; }
  .jl-home-split-cards{ grid-template-columns:1fr 1fr; gap:10px; }
  .jl-home-mini{ padding:20px 16px; }
  .jl-home-mini-value{ font-size:22px; }
  .jl-home-cta{ padding:36px 26px; }
}

/* ============================================================
   SupportPal tickets (supportpal-tickets / viewticket / submitticket)
   ============================================================ */
.jl-tkt{ display:flex; flex-direction:column; gap:18px; }
.jl-tkt-head{ display:flex; justify-content:space-between; align-items:flex-start; gap:16px; flex-wrap:wrap; }
.jl-tkt-title{ font-size:20px; font-weight:800; color:var(--text-primary); margin:0; display:flex; align-items:center; gap:10px; }
.jl-tkt-title i{ color:var(--accent); font-size:18px; }
.jl-tkt-sub{ font-size:13.5px; color:var(--text-muted); margin:4px 0 0; }
.jl-tkt-back{ font-size:13px; font-weight:600; color:var(--text-muted); text-decoration:none; display:inline-flex; align-items:center; gap:7px; }
.jl-tkt-back:hover{ color:var(--accent); }

.jl-tkt-btn{ display:inline-flex; align-items:center; gap:7px; cursor:pointer; padding:10px 18px; border-radius:9px; font-size:13px; font-weight:700; text-decoration:none; border:1px solid var(--border); background:#fff; color:var(--text-secondary); transition:all .14s; }
.jl-tkt-btn--primary{ background:var(--accent); border-color:var(--accent); color:#fff; }
.jl-tkt-btn--primary:hover{ background:var(--accent-hover); border-color:var(--accent-hover); color:#fff; text-decoration:none; }
.jl-tkt-btn--ghost{ background:var(--surface-2); }
.jl-tkt-btn--ghost:hover{ background:var(--border); color:var(--text-primary); text-decoration:none; }

.jl-tkt-card{ background:var(--card-bg); border:1px solid var(--card-border); border-radius:var(--card-radius); box-shadow:var(--card-shadow); }

.jl-tkt-alert{ padding:13px 18px; border-radius:10px; font-size:13.5px; font-weight:600; }
.jl-tkt-alert--danger{ background:var(--danger-light); color:#b91c1c; border:1px solid var(--danger-border); }
.jl-tkt-alert--success{ background:var(--accent-light); color:#15803d; border:1px solid var(--accent-border); }

/* List table */
.jl-tkt-table{ width:100%; border-collapse:collapse; }
.jl-tkt-table thead th{ text-align:left; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.5px; color:var(--text-subtle); padding:13px 18px; border-bottom:1px solid var(--border); background:var(--surface); }
.jl-tkt-row{ cursor:pointer; transition:background .12s; }
.jl-tkt-row:hover{ background:var(--surface); }
.jl-tkt-row td{ padding:14px 18px; border-bottom:1px solid var(--border); font-size:13.5px; color:var(--text-secondary); vertical-align:middle; }
.jl-tkt-row:last-child td{ border-bottom:none; }
.jl-tkt-row--closed .jl-tkt-link{ color:var(--text-muted); }
.jl-tkt-link{ font-weight:600; color:var(--text-primary); text-decoration:none; }
.jl-tkt-link:hover{ color:var(--accent); }
.jl-tkt-meta{ font-size:12px; color:var(--text-subtle); margin-top:3px; }
.jl-tkt-date{ white-space:nowrap; color:var(--text-muted); font-size:12.5px; }
.jl-tkt-go{ text-align:right; color:var(--text-subtle); width:30px; }
.jl-tkt-status{ display:inline-block; padding:4px 11px; border-radius:999px; font-size:11.5px; font-weight:700; white-space:nowrap; }
.jl-tkt-status--lg{ padding:6px 14px; font-size:12.5px; }

/* Empty */
.jl-tkt-empty{ text-align:center; padding:56px 20px; background:var(--card-bg); border:1px solid var(--card-border); border-radius:var(--card-radius); }
.jl-tkt-empty-icon{ font-size:40px; color:var(--text-subtle); opacity:.5; margin-bottom:14px; }
.jl-tkt-empty-title{ font-size:16px; font-weight:700; color:var(--text-primary); }
.jl-tkt-empty-sub{ font-size:13.5px; color:var(--text-muted); margin:6px 0 18px; }

/* Ticket head */
.jl-tkt-ticket-head{ display:flex; justify-content:space-between; align-items:center; gap:16px; padding:20px 24px; flex-wrap:wrap; }
.jl-tkt-ticket-headmain .jl-tkt-title{ font-size:18px; }

/* Thread */
.jl-tkt-thread{ display:flex; flex-direction:column; gap:16px; }
.jl-tkt-msg{ display:flex; gap:12px; align-items:flex-start; }
.jl-tkt-msg--staff{ flex-direction:row-reverse; }
.jl-tkt-avatar{ width:40px; height:40px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:15px; background:#eff6ff; color:#2563eb; }
.jl-tkt-avatar--staff{ background:var(--accent-light); color:var(--accent); }
.jl-tkt-bubble{ flex:1; background:var(--card-bg); border:1px solid var(--card-border); border-radius:14px; box-shadow:var(--card-shadow); padding:14px 18px; max-width:80%; }
.jl-tkt-msg--staff .jl-tkt-bubble{ background:var(--accent-light); border-color:var(--accent-border); }
.jl-tkt-msg-head{ display:flex; justify-content:space-between; align-items:center; gap:12px; margin-bottom:8px; }
.jl-tkt-msg-author{ font-weight:700; font-size:13.5px; color:var(--text-primary); }
.jl-tkt-staff-tag{ font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.5px; background:var(--accent); color:#fff; padding:1px 7px; border-radius:999px; margin-left:6px; }
.jl-tkt-msg-date{ font-size:12px; color:var(--text-subtle); white-space:nowrap; }
.jl-tkt-msg-body{ font-size:13.5px; color:var(--text-secondary); line-height:1.65; word-break:break-word; }
.jl-tkt-msg-body p{ margin:0 0 8px; }

.jl-tkt-reopen{ padding:14px 18px; font-size:13px; color:var(--text-muted); display:flex; align-items:center; gap:9px; }
.jl-tkt-reopen i{ color:var(--text-subtle); }

/* Reply / form */
.jl-tkt-replybox, .jl-tkt-formcard{ padding:22px 24px; }
.jl-tkt-reply-title{ font-size:15px; font-weight:700; color:var(--text-primary); margin:0 0 14px; }
.jl-tkt-textarea, .jl-tkt-input{ width:100%; border:1.5px solid var(--border); border-radius:9px; padding:11px 14px; font-size:13.5px; font-family:var(--font); color:var(--text-primary); background:#fff; }
.jl-tkt-textarea:focus, .jl-tkt-input:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-light); }
.jl-tkt-reply-foot{ display:flex; justify-content:space-between; align-items:center; gap:12px; margin-top:14px; flex-wrap:wrap; }
.jl-tkt-file{ display:inline-flex; align-items:center; gap:8px; font-size:13px; font-weight:600; color:var(--text-muted); cursor:pointer; padding:8px 14px; border:1.5px dashed var(--border); border-radius:9px; }
.jl-tkt-file:hover{ border-color:var(--accent); color:var(--accent); }
.jl-tkt-file input[type=file]{ display:none; }
.jl-tkt-file--block{ width:100%; justify-content:center; }

.jl-tkt-form-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.jl-tkt-field{ margin-bottom:16px; }
.jl-tkt-field > label{ display:block; font-size:12.5px; font-weight:600; color:var(--text-primary); margin-bottom:7px; }
.jl-tkt-req{ color:var(--danger); }
.jl-tkt-form-actions{ display:flex; justify-content:flex-end; gap:10px; margin-top:4px; }

@media (max-width:640px){
  .jl-tkt-table .hide-sm{ display:none; }
  .jl-tkt-form-row{ grid-template-columns:1fr; }
  .jl-tkt-bubble{ max-width:100%; }
}
