/* Inter font loaded via <link rel="preconnect"> in base.html — no @import needed */

/* ═══════════════════════════════════════════════════
   space_theme.css — LikeFree Unified Dark Space Theme
   Single source of truth for all pages
   ═══════════════════════════════════════════════════ */

/* ── CSS Variables – Unified Space Palette ── */
:root {
  /* Core backgrounds */
  --bg-deep: #0a0e1a;
  --bg-sidebar: #0a0e1a;
  --bg-card: rgba(17, 24, 39, 0.85);
  --bg-navbar: rgba(10, 14, 26, 0.95);
  --bg-input: rgba(17, 24, 39, 0.6);
  --bg-input-focus: rgba(17, 24, 39, 0.8);
  --glass: rgba(255, 255, 255, 0.08);
  --bg-card-solid: rgba(255, 255, 255, 0.04);

  /* Accent colors */
  --accent-cyan: #00d4ff;
  --accent-purple: #7c3aed;
  --accent-indigo: #7c3aed;
  --accent-indigo-light: #7c3aed;
  --accent-pink: #ec4899;

  /* Text */
  --text-primary: #e2e8f0;
  --text-secondary: rgba(226, 232, 240, 0.55);
  --text-muted: rgba(226, 232, 240, 0.55);

  /* Semantic */
  --success: #10b981;
  --danger: #ef4444;
  --warning: #f59e0b;

  /* Borders */
  --border-glow: rgba(0, 212, 255, 0.15);
  --border-subtle: rgba(148, 163, 184, 0.25);

  /* Radius */
  --radius: 12px;
  --radius-sm: 8px;
  --radius-lg: 16px;

  /* Shadows */
  --shadow: 0 1px 3px rgba(0, 0, 0, .2), 0 1px 2px rgba(0, 0, 0, .15);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .3), 0 4px 6px -4px rgba(0, 0, 0, .2);
  --shadow-glow: 0 0 20px rgba(0, 212, 255, 0.05);

  /* Gradients */
  --gradient-indigo: linear-gradient(135deg, #7c3aed 0%, #7c3aed 50%, #7c3aed 100%);
  --gradient-cyan: linear-gradient(135deg, #00d4ff, #00d4ff);

  /* SMM Panel specifics */
  --smm-sidebar-w: 260px;

  /* Clone Shop specifics */
  --cs-bg-start: #0a0e1a;
  --cs-bg-mid: rgba(255, 255, 255, 0.04);
  --cs-bg-end: rgba(255, 255, 255, 0.04);
  --cs-accent-glow: rgba(124, 58, 237, 0.35);

  /* ── Consolidated Transitions ── */
  --transition-fast: all 0.2s ease;
  --transition-normal: all 0.3s ease;

  /* ── Consolidated Glow Shadows ── */
  --glow-cyan: 0 0 20px rgba(0, 212, 255, 0.3);
  --glow-cyan-sm: 0 0 15px rgba(0, 212, 255, 0.2);
  --glow-cyan-hover: 0 0 30px rgba(0, 212, 255, 0.15), inset 0 0 20px rgba(0, 212, 255, 0.03);
  --focus-ring-cyan: 0 0 0 3px rgba(0, 212, 255, 0.15);
  --glow-success: 0 0 20px rgba(16, 185, 129, 0.3);
  --glow-danger: 0 0 20px rgba(239, 68, 68, 0.3);

  /* ── Sidebar Hover (theme-able accent) ── */
  --sidebar-accent: var(--accent-cyan);
  --sidebar-hover-bg: rgba(0, 212, 255, 0.1);
  --sidebar-hover-shadow: inset 3px 0 0 var(--sidebar-accent), 0 0 15px rgba(0, 212, 255, 0.08);
  --sidebar-active-bg: rgba(0, 212, 255, 0.12);
  --sidebar-active-shadow: inset 3px 0 0 var(--sidebar-accent);
  --sidebar-text-shadow: 0 0 8px rgba(0, 212, 255, 0.3);

  /* ── Hover Elevate (2 levels) ── */
  --hover-elevate: translateY(-2px);
  --hover-elevate-sm: translateY(-1px);

  /* ── Card Hover (composite) ── */
  --card-hover-lift: translateY(-2px);
  --card-hover-glow: 0 0 30px rgba(0, 212, 255, 0.15), inset 0 0 20px rgba(0, 212, 255, 0.03);
  --card-hover-border: rgba(0, 212, 255, 0.4);

  /* ── Glassmorphism (2 levels) ── */
  --blur-glass: blur(12px);
  --blur-heavy: blur(20px);

  /* ── Active Indicator ── */
  --active-bg: rgba(0, 212, 255, 0.12);
  --active-border: var(--accent-cyan);
  --active-color: var(--accent-cyan);

  /* ── Shared Border (glass) ── */
  --border-glass: rgba(255, 255, 255, 0.1);
}

/* ── Global Reset ── */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* ── Base ── */
html,
body {
  height: 100%;
  margin: 0;
}

body {
  font-family: 'Inter', sans-serif !important; /* override Bootstrap system-ui stack */
  background-color: var(--bg-deep);
  color: var(--text-primary);
}

/* Force font on ALL elements (override Bootstrap) — exclude Font Awesome icons */
body,
body *:not([class*="fa-"]):not(.fa):not(.fas):not(.far):not(.fab):not(.fal):not(.fad):not(.fa-solid):not(.fa-regular):not(.fa-brands),
input,
button,
select,
textarea,
.form-control,
.form-select,
.btn,
.nav-link,
.navbar-brand,
.modal-content,
.alert,
.badge,
.card,
table,
th,
td,
label,
.dropdown-menu,
.tooltip,
.popover {
  font-family: 'Inter', sans-serif !important;
}

/* ══════════════════════════════════════════════════════
   NUCLEAR DARK THEME — Override ALL Bootstrap defaults
   Đảm bảo 100% nền tối + chữ sáng trên mọi component
   ──────────────────────────────────────────────────────
   TẤT CẢ !important bên dưới là CẦN THIẾT vì:
   - Bootstrap 5 CDN set styles với specificity cao
   - space_theme.css load SAU nhưng cùng specificity
   - Không dùng data-bs-theme="dark" (conflict với custom vars)
   ══════════════════════════════════════════════════════ */

/* ── Body/HTML — force dark base ── */
body,
html {
  background-color: var(--bg-deep) !important;
  color: var(--text-primary) !important;
}

/* Force ALL text elements to light color */
h1,
h2,
h3,
h4,
h5,
h6 {
  color: var(--accent-cyan) !important;
}

p,
span,
div,
li,
ol,
ul,
td,
th,
label,
legend,
figcaption,
blockquote,
dt,
dd,
small,
strong,
em,
b,
i,
mark,
del,
ins,
sub,
sup,
abbr,
address,
cite,
dfn,
kbd,
samp,
var,
pre,
code,
a {
  color: inherit;
}

body,
.container,
.container-fluid,
.row,
main,
section,
article,
aside,
footer,
header,
nav {
  color: var(--text-primary);
}

/* Bootstrap Cards — dark */
.card-body,
.card-footer,
.card-title,
.card-text {
  background-color: var(--bg-card) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-glow) !important;
}

.card-header {
  background-color: rgba(0, 212, 255, 0.05) !important;
  border-bottom-color: var(--border-subtle) !important;
}

.card-footer {
  background-color: transparent !important;
  border-top-color: var(--border-subtle) !important;
}

/* Bootstrap Tables — dark */
table,
.table {
  --bs-table-bg: transparent !important;
  --bs-table-color: var(--text-primary) !important;
  color: var(--text-primary) !important;
  background-color: transparent !important;
}

thead,
tbody,
tfoot,
tr,
th,
td {
  background-color: transparent !important;
  color: inherit !important;
  border-color: var(--border-subtle) !important;
}

.table thead th {
  background-color: rgba(0, 212, 255, 0.05) !important;
  color: var(--accent-cyan) !important;
}

.table-striped>tbody>tr:nth-of-type(odd)>* {
  --bs-table-bg-type: transparent !important;
  background-color: rgba(0, 212, 255, 0.03) !important;
}

.table-striped>tbody>tr:nth-of-type(even)>* {
  --bs-table-bg-type: transparent !important;
  background-color: transparent !important;
}

/* Bootstrap Forms — dark */
.form-control,
.form-select,
textarea,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="search"],
input[type="url"],
input[type="tel"],
input[type="date"],
input[type="time"] {
  background-color: var(--bg-input) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-subtle) !important;
}

.form-control:focus,
.form-select:focus,
textarea:focus,
input:focus {
  background-color: var(--bg-input-focus) !important;
  color: var(--text-primary) !important;
  border-color: var(--accent-cyan) !important;
  box-shadow: var(--focus-ring-cyan) !important;
}

.form-control::placeholder,
input::placeholder,
textarea::placeholder {
  color: var(--text-muted) !important;
}

.form-label,
.form-check-label,
label {
  color: var(--text-primary) !important;
}

.form-text {
  color: var(--text-muted) !important;
}

select option {
  background-color: var(--bg-card-solid) !important;
  color: var(--text-primary) !important;
}

.btn-primary,
.btn-primary:active,
.btn-primary:visited {
  background: var(--gradient-cyan) !important;
  border: none !important;
  color: #fff !important;
}

.btn-primary:hover {
  box-shadow: var(--glow-cyan) !important;
  color: #fff !important;
}

/* ── Universal Holo Button Base ── */
.btn {
  clip-path: polygon(10px 0, 100% 0,
      100% calc(100% - 10px), calc(100% - 10px) 100%,
      0 100%, 0 10px) !important;
  border-radius: 0 !important;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-weight: 600;
  position: relative;
  transition: all 0.3s ease;
}

.btn:active {
  transform: scale(0.96);
}

/* ── Universal Chamfer Accent — bright diagonal edge lines ──
   Applied to ALL chamfered components.
   Chamfer 10px → diagonal line at 7.07px offset (10 * cos45)
   Chamfer 15px → diagonal line at 10.6px offset
   Chamfer 8px  → diagonal line at 5.66px offset
   Chamfer 6px  → diagonal line at 4.24px offset */

/* Position: relative for pseudo-element support */
.btn,
.badge,
.order-status,
.alert,
.card-kpi,
.info-badge,
.server-note,
.total-payment {
  position: relative;
}

/* ── Color Variants (Holo border style) ── */
.btn-success,
.btn-success:active {
  background: rgba(16, 185, 129, 0.08) !important;
  border: 1px solid rgba(16, 185, 129, 0.5) !important;
  color: var(--success) !important;
  box-shadow: 0 0 10px rgba(16, 185, 129, 0.15) inset !important;
}

.btn-success:hover {
  background: rgba(16, 185, 129, 0.25) !important;
  border-color: var(--success) !important;
  color: #fff !important;
  box-shadow: 0 0 20px rgba(16, 185, 129, 0.4) inset, 0 0 10px rgba(16, 185, 129, 0.3) !important;
  text-shadow: 0 0 8px var(--success);
}

.btn-danger,
.btn-danger:active {
  background: rgba(239, 68, 68, 0.08) !important;
  border: 1px solid rgba(239, 68, 68, 0.5) !important;
  color: var(--danger) !important;
  box-shadow: 0 0 10px rgba(239, 68, 68, 0.15) inset !important;
}

.btn-danger:hover {
  background: rgba(239, 68, 68, 0.25) !important;
  border-color: var(--danger) !important;
  color: #fff !important;
  box-shadow: 0 0 20px rgba(239, 68, 68, 0.4) inset, 0 0 10px rgba(239, 68, 68, 0.3) !important;
  text-shadow: 0 0 8px var(--danger);
}

.btn-warning,
.btn-warning:active {
  background: rgba(245, 158, 11, 0.08) !important;
  border: 1px solid rgba(245, 158, 11, 0.5) !important;
  color: var(--warning) !important;
  box-shadow: 0 0 10px rgba(245, 158, 11, 0.15) inset !important;
}

.btn-warning:hover {
  background: rgba(245, 158, 11, 0.25) !important;
  border-color: var(--warning) !important;
  color: #fff !important;
  box-shadow: 0 0 20px rgba(245, 158, 11, 0.4) inset, 0 0 10px rgba(245, 158, 11, 0.3) !important;
  text-shadow: 0 0 8px var(--warning);
}

.btn-info,
.btn-info:active {
  background: rgba(0, 212, 255, 0.08) !important;
  border: 1px solid rgba(0, 212, 255, 0.5) !important;
  color: var(--accent-cyan) !important;
  box-shadow: 0 0 10px rgba(0, 212, 255, 0.15) inset !important;
}

.btn-info:hover {
  background: rgba(0, 212, 255, 0.25) !important;
  border-color: var(--accent-cyan) !important;
  color: #fff !important;
  box-shadow: 0 0 20px rgba(0, 212, 255, 0.4) inset, 0 0 10px rgba(0, 212, 255, 0.3) !important;
  text-shadow: 0 0 8px var(--accent-cyan);
}

.btn-secondary,
.btn-secondary:active {
  background: rgba(148, 163, 184, 0.08) !important;
  border: 1px solid rgba(148, 163, 184, 0.4) !important;
  color: var(--text-primary) !important;
  box-shadow: 0 0 10px rgba(148, 163, 184, 0.1) inset !important;
}

.btn-secondary:hover {
  background: rgba(0, 212, 255, 0.15) !important;
  border-color: var(--accent-cyan) !important;
  color: var(--accent-cyan) !important;
  box-shadow: 0 0 20px rgba(0, 212, 255, 0.3) inset !important;
}

/* ── Outline Variants (same chamfer, thinner feel) ── */
.btn-outline-primary {
  color: var(--accent-cyan) !important;
  border: 1px solid rgba(0, 212, 255, 0.4) !important;
  background: transparent !important;
}

.btn-outline-primary:hover {
  background: rgba(0, 212, 255, 0.15) !important;
  border-color: var(--accent-cyan) !important;
  color: #fff !important;
  box-shadow: 0 0 15px rgba(0, 212, 255, 0.3) inset !important;
}

.btn-outline-secondary {
  color: var(--text-muted) !important;
  border: 1px solid var(--border-subtle) !important;
  background: transparent !important;
}

.btn-outline-secondary:hover {
  background: rgba(0, 212, 255, 0.1) !important;
  border-color: var(--accent-cyan) !important;
  color: var(--accent-cyan) !important;
}

.btn-outline-danger {
  color: var(--danger) !important;
  border: 1px solid rgba(239, 68, 68, 0.4) !important;
  background: transparent !important;
}

.btn-outline-danger:hover {
  background: rgba(239, 68, 68, 0.15) !important;
  border-color: var(--danger) !important;
  color: #fff !important;
}

.btn-outline-success {
  color: var(--success) !important;
  border: 1px solid rgba(16, 185, 129, 0.4) !important;
  background: transparent !important;
}

.btn-outline-success:hover {
  background: rgba(16, 185, 129, 0.15) !important;
  border-color: var(--success) !important;
  color: #fff !important;
}

.btn-link {
  color: var(--accent-cyan) !important;
}

.btn-link:hover {
  color: #00d4ff !important;
}

.btn-close {
  filter: invert(1) grayscale(100%) brightness(200%) !important;
}

/* Bootstrap Modals — dark */
.modal-content {
  background-color: var(--bg-card-solid) !important;
  color: var(--text-primary) !important;
  border: 1px solid var(--border-glow) !important;
}

.modal-header {
  border-bottom-color: var(--border-subtle) !important;
  color: var(--text-primary) !important;
}

.modal-footer {
  border-top-color: var(--border-subtle) !important;
}

.modal-title {
  color: var(--accent-cyan) !important;
}

.modal-backdrop {
  background-color: rgba(0, 0, 0, 0.7) !important;
}

/* Bootstrap Alerts — Holo chamfer style */
.alert {
  border-radius: 0 !important;
  clip-path: polygon(15px 0, 100% 0,
      100% calc(100% - 15px), calc(100% - 15px) 100%,
      0 100%, 0 15px) !important;
}

/* Bootstrap Navbar — dark */
.navbar,
.navbar-toggler {
  background-color: var(--bg-navbar) !important;
  border-color: var(--border-glow) !important;
}

/* navbar-collapse tách riêng: KHÔNG override background
   để dropdown con không bị clip/hidden */
.navbar-collapse {
  overflow: visible !important;
}

.navbar-toggler-icon {
  filter: invert(1) !important;
}

/* Bootstrap Dropdowns — dark */
.dropdown-menu {
  background-color: var(--bg-card-solid) !important;
  border: 1px solid var(--border-subtle) !important;
  box-shadow: var(--shadow-lg) !important;
  /* Đảm bảo dropdown luôn nổi trên navbar và các layer khác */
  z-index: 1050 !important;
  position: absolute !important;
}

.dropdown-item {
  color: var(--text-primary) !important;
  /* Đảm bảo click area đủ lớn */
  display: block !important;
  pointer-events: auto !important;
}

.dropdown-item:hover,
.dropdown-item:focus {
  background-color: rgba(0, 212, 255, 0.1) !important;
  color: var(--accent-cyan) !important;
}

.dropdown-divider {
  border-color: var(--border-subtle) !important;
}

/* Bootstrap Pagination — dark */
.page-link {
  background-color: transparent !important;
  border-color: var(--border-subtle) !important;
  color: var(--accent-cyan) !important;
}

.page-link:hover {
  background-color: rgba(0, 212, 255, 0.1) !important;
  border-color: var(--accent-cyan) !important;
  color: #fff !important;
}

.page-item.active .page-link {
  background-color: var(--accent-cyan) !important;
  border-color: var(--accent-cyan) !important;
  color: var(--bg-deep) !important;
}

/* Bootstrap Badges — Holo chamfer style */
.badge {
  font-weight: 600 !important;
  border-radius: 0 !important;
  clip-path: polygon(8px 0, 100% 0,
      100% calc(100% - 8px), calc(100% - 8px) 100%,
      0 100%, 0 8px) !important;
  padding: 5px 14px !important;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  font-size: 0.7rem !important;
}

.badge.bg-primary,
.bg-primary {
  background-color: rgba(0, 212, 255, 0.1) !important;
  color: var(--accent-cyan) !important;
  border: 1px solid rgba(0, 212, 255, 0.4);
}

.badge.bg-success,
.bg-success:not(body) {
  background-color: rgba(16, 185, 129, 0.1) !important;
  color: #10b981 !important;
  border: 1px solid rgba(16, 185, 129, 0.4);
}

.badge.bg-danger,
.bg-danger:not(body) {
  background-color: rgba(239, 68, 68, 0.1) !important;
  color: #ef4444 !important;
  border: 1px solid rgba(239, 68, 68, 0.4);
}

.badge.bg-warning,
.bg-warning:not(body) {
  background-color: rgba(245, 158, 11, 0.1) !important;
  color: #f59e0b !important;
  border: 1px solid rgba(245, 158, 11, 0.4);
}

.badge.bg-info,
.bg-info:not(body) {
  background-color: rgba(0, 212, 255, 0.1) !important;
  color: var(--accent-cyan) !important;
  border: 1px solid rgba(0, 212, 255, 0.3);
}

.badge.bg-secondary {
  background-color: rgba(148, 163, 184, 0.1) !important;
  color: var(--text-secondary) !important;
  border: 1px solid rgba(148, 163, 184, 0.3);
}

.badge.bg-dark {
  background-color: rgba(0, 0, 0, 0.2) !important;
  color: var(--text-primary) !important;
  border: 1px solid rgba(148, 163, 184, 0.2);
}

/* Bootstrap List Groups — dark */
.list-group-item {
  background-color: var(--bg-card-solid) !important;
  border-color: var(--border-subtle) !important;
  color: var(--text-primary) !important;
}

.list-group-item:hover {
  background-color: rgba(0, 212, 255, 0.06) !important;
}

.list-group-item.active {
  background-color: rgba(0, 212, 255, 0.12) !important;
  border-color: var(--accent-cyan) !important;
  color: var(--accent-cyan) !important;
}

/* Bootstrap Accordion — dark */
.accordion-item {
  background-color: var(--bg-card-solid) !important;
  border-color: var(--border-subtle) !important;
}

.accordion-button {
  background-color: var(--bg-card-solid) !important;
  color: var(--text-primary) !important;
  box-shadow: none !important;
}

.accordion-button:not(.collapsed) {
  background-color: rgba(0, 212, 255, 0.08) !important;
  color: var(--accent-cyan) !important;
}

.accordion-body {
  background-color: transparent !important;
  color: var(--text-primary) !important;
}

/* Bootstrap Tabs — dark */
.nav-tabs {
  border-bottom-color: var(--border-subtle) !important;
}

.nav-tabs .nav-link {
  color: var(--text-muted) !important;
  border-color: transparent !important;
}

.nav-tabs .nav-link.active {
  background-color: transparent !important;
  color: var(--accent-cyan) !important;
  border-bottom: 2px solid var(--accent-cyan) !important;
}

.nav-tabs .nav-link:hover {
  color: var(--accent-cyan) !important;
  border-color: transparent !important;
}

.nav-pills .nav-link {
  color: var(--text-primary) !important;
}

.nav-pills .nav-link.active {
  background-color: rgba(0, 212, 255, 0.15) !important;
  color: var(--accent-cyan) !important;
}

/* Bootstrap Toasts / Tooltips / Popovers — dark */
.toast,
.toast-header,
.toast-body {
  background-color: var(--bg-card-solid) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-subtle) !important;
}

.tooltip-inner {
  background-color: var(--bg-card-solid) !important;
  color: var(--text-primary) !important;
}

.popover {
  background-color: var(--bg-card-solid) !important;
  border-color: var(--border-subtle) !important;
}

.popover-header {
  background-color: rgba(0, 212, 255, 0.08) !important;
  color: var(--accent-cyan) !important;
  border-bottom-color: var(--border-subtle) !important;
}

.popover-body {
  color: var(--text-primary) !important;
}

/* Bootstrap Progress — dark */
.progress {
  background-color: rgba(148, 163, 184, 0.2) !important;
  border-radius: 10px !important;
}

.progress-bar {
  background: var(--gradient-cyan) !important;
}

/* Bootstrap Spinner — cyan */
.spinner-border {
  color: var(--accent-cyan) !important;
}

.spinner-grow {
  color: var(--accent-cyan) !important;
}

/* Force dark on misc Bootstrap utility classes */
.bg-white,
.bg-light {
  background-color: var(--bg-sidebar) !important;
}

.bg-body {
  background-color: var(--bg-deep) !important;
}

.text-dark {
  color: var(--text-primary) !important;
}

.text-body {
  color: var(--text-primary) !important;
}

.text-muted {
  color: var(--text-muted) !important;
}

.border {
  border-color: var(--border-subtle) !important;
}

.shadow,
.shadow-sm,
.shadow-lg {
  box-shadow: var(--shadow) !important;
}

/* Scrollbar styling */
*::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

*::-webkit-scrollbar-track {
  background: transparent;
}

*::-webkit-scrollbar-thumb {
  background: rgba(0, 212, 255, 0.2);
  border-radius: 3px;
}

*::-webkit-scrollbar-thumb:hover {
  background: rgba(0, 212, 255, 0.4);
}

/* ── Links ── */
a {
  color: var(--accent-cyan);
}

a:hover {
  color: #00d4ff;
}

/* ── Cards (Glassmorphism) ── */
.card-dashboard {
  border: 1px solid var(--border-glow);
  border-radius: var(--radius);
  padding: 1.25rem;
  margin-bottom: 1rem;
  background: var(--bg-card);
  backdrop-filter: var(--blur-glass);
  box-shadow: var(--shadow-glow);
  transition: var(--transition-normal);
}

.card-dashboard:hover {
  border-color: var(--card-hover-border);
  box-shadow: var(--card-hover-glow);
  transform: var(--card-hover-lift);
}

.table thead th {
  font-size: .75rem;
  text-transform: uppercase;
  color: var(--accent-cyan);
  white-space: nowrap;
  border-bottom-color: var(--border-glow);
  opacity: 0.7;
  background-color: rgba(0, 212, 255, 0.05);
}

.table tbody td {
  font-size: .88rem;
  vertical-align: middle;
  border-bottom-color: var(--border-subtle);
}

.table-hover>tbody>tr:hover>* {
  background-color: rgba(0, 212, 255, 0.08) !important;
  --bs-table-bg-type: transparent;
  --bs-table-hover-bg: transparent;
  color: var(--accent-cyan);
}

.table> :not(caption)>*>* {
  background-color: transparent;
  box-shadow: none;
}

.btn-sm {
  font-size: 0.82rem;
}

.btn-xs {
  padding: 0.25rem 0.5rem;
  font-size: 0.85rem;
}

/* ── Alerts ── */
.alert-danger {
  background: rgba(239, 68, 68, 0.06);
  border: 1px solid rgba(239, 68, 68, 0.4);
  color: #ef4444;
}

.alert-info {
  background: rgba(0, 212, 255, 0.06);
  border: 1px solid rgba(0, 212, 255, 0.3);
  color: var(--accent-cyan);
}

.alert-success {
  background: rgba(16, 185, 129, 0.06);
  border: 1px solid rgba(16, 185, 129, 0.4);
  color: #10b981;
}

.alert-warning {
  background: rgba(245, 158, 11, 0.06);
  border: 1px solid rgba(245, 158, 11, 0.4);
  color: #f59e0b;
}

/* ── Forms (dark theme) ── */
.form-label {
  color: var(--text-primary);
  font-weight: 500;
}

.input-group-text {
  background-color: rgba(0, 212, 255, 0.08);
  border-color: var(--border-subtle);
  color: var(--accent-cyan);
}



/* ── Pagination ── */
.page-item.disabled .page-link {
  background-color: transparent;
  border-color: var(--border-subtle);
  color: var(--text-muted);
}

/* ── Badges ── */

.text-danger {
  color: var(--danger) !important;
}

code {
  color: var(--accent-cyan);
  background: rgba(0, 212, 255, 0.08);
  padding: 2px 6px;
  border-radius: 4px;
}

.small-muted {
  font-size: .8rem;
  color: var(--text-muted);
}

.btn-light {
  background: rgba(148, 163, 184, 0.08) !important;
  border: 1px solid rgba(148, 163, 184, 0.3) !important;
  color: var(--text-primary) !important;
}

.btn-light:hover {
  background: rgba(0, 212, 255, 0.15) !important;
  border-color: var(--accent-cyan) !important;
  color: var(--accent-cyan) !important;
  box-shadow: 0 0 15px rgba(0, 212, 255, 0.3) inset !important;
}


/* ── Shared Sidebar ── */
.sidebar {
  width: 220px;
  background-color: var(--bg-sidebar);
  border-right: 1px solid var(--border-glow);
  padding: 1rem;
  position: relative;
  z-index: 1;
  box-shadow: var(--shadow-glow);
}

.sidebar h5 {
  margin-bottom: 1rem;
  font-weight: 700;
  color: var(--accent-cyan);
  letter-spacing: 0.5px;
}

.sidebar .nav-link {
  color: var(--text-primary);
  margin-bottom: 0.3rem;
  border-radius: 6px;
  cursor: pointer;
  padding: 0.45rem 0.7rem;
  transition: var(--transition-fast);
  font-size: 0.88rem;
}

.sidebar .nav-link:hover {
  background-color: var(--sidebar-hover-bg);
  color: var(--sidebar-accent);
  box-shadow: var(--sidebar-hover-shadow);
  transform: translateX(3px);
  text-shadow: var(--sidebar-text-shadow);
}

.sidebar .nav-link.active {
  background-color: var(--sidebar-active-bg);
  color: var(--sidebar-accent);
  font-weight: 600;
  box-shadow: var(--sidebar-active-shadow);
}

/* ── Shared Navbar ── */
.navbar {
  border-bottom: 1px solid var(--border-glow);
  background-color: var(--bg-navbar) !important;
  backdrop-filter: var(--blur-glass);
  position: relative;
  z-index: 1030;  /* ← đủ cao để dropdown nổi trên main-content */
}

.navbar-brand,
.navbar-nav .nav-link {
  color: var(--accent-cyan) !important;
  font-weight: 600;
  cursor: pointer;
}

.navbar-nav .nav-link:hover {
  color: var(--danger) !important;
  opacity: 0.9;
}

/* ── Shared Main Content ── */
.main-content {
  flex: 1;
  padding: 2rem;
  overflow-y: auto;
  background-color: transparent;
  position: relative;
  /* z-index KHÔNG set → z-index: auto → không tạo stacking context
     Navbar (z-index: 1030) tự nhiên nổi trên, dropdown click được */
}

.space-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 2rem;
}

.space-page-header {
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--border-glow);
}

.breadcrumb-item,
.breadcrumb-item a {
  color: var(--text-secondary);
}

.breadcrumb-item.active {
  color: var(--accent-cyan);
}

.offcanvas {
  background-color: var(--bg-card-solid);
  color: var(--text-primary);
}

/* ═══════════════════════════════════════════════════
   LOGIN PAGE
   ═══════════════════════════════════════════════════ */
body.login-body {
  min-height: 100vh;
  display: flex;
  align-items: center;
}

.bg-gradient {
  background: linear-gradient(135deg, #0a0e1a, #0a0e1a, #0a0e1a);
  color: #fff;
}

.bg-gradient h1 {
  font-size: 1.75rem;
  color: var(--accent-cyan);
}

.bg-gradient p {
  color: var(--text-muted);
}


/* ═══════════════════════════════════════════════════
   DASHBOARD
   ═══════════════════════════════════════════════════ */
body.spa-body {
  display: flex;
  min-height: 100vh;
}

.sidebar-divider {
  border: 0;
  height: 1px;
  background: linear-gradient(90deg, var(--accent-cyan), transparent);
  margin: 0.7rem 0 0.4rem;
  opacity: 0.3;
}

.sidebar-group-label {
  font-size: .65rem;
  text-transform: uppercase;
  color: var(--accent-cyan);
  letter-spacing: 1px;
  padding: 0 0.5rem;
  margin-bottom: 0.2rem;
  opacity: 0.6;
}

#menu-smm-panel:hover {
  box-shadow: 0 0 25px rgba(0, 212, 255, 0.45) !important;
  transform: var(--hover-elevate-sm);
}

#menu-clone-shop:hover {
  box-shadow: 0 0 25px rgba(124, 58, 237, 0.45) !important;
  transform: var(--hover-elevate-sm);
}

.dashboard-row {
  align-items: stretch;
}

.card-col-full {
  display: flex;
  flex-direction: column;
}

.card-dashboard.flex-grow-card {
  flex-grow: 1;
}


/* ═══════════════════════════════════════════════════
   ADMIN DASHBOARD
   ═══════════════════════════════════════════════════ */
body.admin-body .sidebar h5 {
  color: var(--danger);
}

body.admin-body {
  --sidebar-accent: var(--danger);
  --sidebar-hover-bg: rgba(239, 68, 68, 0.1);
  --sidebar-hover-shadow: inset 3px 0 0 var(--danger), 0 0 15px rgba(239, 68, 68, 0.08);
  --sidebar-text-shadow: 0 0 8px rgba(239, 68, 68, 0.3);
}

body.admin-body h1,
body.admin-body h2,
body.admin-body h5 {
  color: var(--danger);
}

body.admin-body .card-dashboard {
  border: 1px solid rgba(239, 68, 68, 0.2);
  background: var(--bg-card);
  backdrop-filter: var(--blur-glass);
  box-shadow: 0 2px 12px rgba(239, 68, 68, 0.06);
  border-radius: 20px;
  padding: 32px 40px 24px 40px;
  width: 100%;
  max-width: 1200px;
  overflow-x: auto;
  margin: 30px auto 0 auto;
}

body.admin-body .card-dashboard h5 {
  color: var(--danger);
  font-size: 1.3rem;
  font-weight: bold;
  margin-bottom: 18px;
  text-align: center;
  letter-spacing: 1px;
}

body.admin-body .card-dashboard table {
  background: transparent;
}

body.admin-body .card-dashboard th,
body.admin-body .card-dashboard td {
  padding: 10px 16px;
  font-size: 1.07rem;
}

body.admin-body .card-dashboard th {
  background: rgba(239, 68, 68, 0.08);
  color: var(--danger);
  font-weight: 600;
}

body.admin-body .card-dashboard td {
  color: var(--text-primary);
  font-weight: 500;
  text-align: right;
}

body.admin-body .card-dashboard .table th,
body.admin-body .card-dashboard .table td {
  white-space: nowrap;
  word-break: normal;
  overflow-wrap: normal;
}

/* Ledger Table */
.table-ledger th,
.table-ledger td {
  white-space: nowrap;
  word-break: normal;
  overflow-wrap: normal;
}

.table-ledger th:nth-child(1),
.table-ledger td:nth-child(1),
.table-ledger th:nth-child(2),
.table-ledger td:nth-child(2) {
  text-align: left;
}

.table-ledger th:nth-child(3),
.table-ledger td:nth-child(3) {
  text-align: right;
}

.table-ledger th:nth-child(1),
.table-ledger td:nth-child(1) {
  width: 38%;
}

.table-ledger th:nth-child(2),
.table-ledger td:nth-child(2) {
  width: 42%;
}

.table-ledger th:nth-child(3),
.table-ledger td:nth-child(3) {
  width: 20%;
}


/* ═══════════════════════════════════════════════════
   PENDING TASKS
   ═══════════════════════════════════════════════════ */
.card-kpi {
  border: 1px solid rgba(0, 212, 255, 0.25);
  border-radius: 0;
  padding: 1rem;
  background: rgba(8, 14, 28, 0.6);
  height: 100%;
  transition: var(--transition-normal);
}

.card-kpi:hover {
  border-color: var(--accent-cyan);
  box-shadow: 0 0 20px rgba(0, 212, 255, 0.15) inset;
}

.fw-600 {
  font-weight: 600;
}

.form-select-sm {
  padding-top: .25rem;
  padding-bottom: .25rem;
}

/* ═══════════════════════════════════════════════════
   SERVICES PAGE
   ═══════════════════════════════════════════════════ */
.cheapest-row {
  background-color: rgba(16, 185, 129, 0.1) !important;
  font-weight: 600;
}


/* ═══════════════════════════════════════════════════
   SMM PANEL
   ═══════════════════════════════════════════════════ */
/* smm_panel.css — SMM Panel Order Page */


/* box-sizing reset — already in Global L103 */

/* ===================== SIDEBAR ===================== */
.smm-sidebar {
  width: var(--smm-sidebar-w);
  background: linear-gradient(180deg, var(--bg-sidebar) 0%, #0a0e1a 100%);
  color: var(--text-primary);
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  z-index: 1000;
  overflow-y: auto;
  transition: transform .3s ease;
}

.sidebar-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 18px 12px;
  border-bottom: 1px solid var(--border-glass);
}

.sidebar-header h5 {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 700;
  color: #fff;
}

.sidebar-balance {
  padding: 14px 18px;
  background: rgba(255, 255, 255, .06);
  border-bottom: 1px solid rgba(255, 255, 255, .08);
}

.balance-label {
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .5px;
  opacity: .7;
}

.balance-value {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--warning);
  margin-top: 2px;
}

.sidebar-categories {
  padding: 10px 0;
  flex: 1;
}

/* Platform group */
.plat-group {
  border-bottom: 1px solid rgba(255, 255, 255, .06);
}

.plat-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 18px;
  cursor: pointer;
  font-size: .92rem;
  font-weight: 600;
  color: var(--text-primary);
  transition: var(--transition-fast);
}

.plat-header:hover {
  background: rgba(255, 255, 255, .06);
  color: #fff;
}

.plat-header.open {
  background: rgba(0, 212, 255, 0.12);
  color: #fff;
}

.plat-icon {
  font-size: 1.15rem;
  width: 26px;
  text-align: center;
  flex-shrink: 0;
}

.plat-name {
  flex: 1;
}

.plat-arrow {
  font-size: .7rem;
  opacity: .5;
  transition: transform .2s;
}

/* Sub-category items */
.plat-submenu {
  background: rgba(0, 0, 0, .12);
}

.subcat-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 18px 9px 48px;
  cursor: pointer;
  font-size: .83rem;
  font-weight: 500;
  color: var(--text-secondary);
  border-left: 3px solid transparent;
  transition: var(--transition-fast);
}

.subcat-item:hover {
  background: rgba(255, 255, 255, .06);
  color: #fff;
}

.subcat-item.active {
  background: rgba(0, 212, 255, 0.15);
  border-left-color: var(--accent-cyan);
  color: #fff;
  font-weight: 600;
}

.subcat-name {
  flex: 1;
}

.subcat-count {
  font-size: .68rem;
  background: rgba(255, 255, 255, .1);
  border-radius: 20px;
  padding: 2px 7px;
  font-weight: 600;
}

/* ===================== MAIN CONTENT ===================== */
.smm-main {
  flex: 1;
  margin-left: var(--smm-sidebar-w);
  padding: 24px;
  min-height: 100vh;
}

.smm-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
  padding: 8px 0;
}

/* ===================== CARDS ===================== */
.smm-card {
  background: var(--bg-card);
  border-radius: var(--radius);
  padding: 20px 24px;
  margin-bottom: 16px;
  box-shadow: var(--shadow);
  border: 1px solid var(--border-subtle);
}

.smm-banner {
  background: var(--gradient-cyan);
  color: #fff;
  font-weight: 600;
  font-size: 1rem;
  padding: 14px 20px;
  border: none;
}

.card-title {
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: 16px;
  color: var(--text-primary);
}

/* ===================== SERVER RADIO LIST ===================== */
.server-radio {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  margin-bottom: 8px;
  border: 2px solid var(--border-subtle);
  border-radius: 10px;
  cursor: pointer;
  transition: var(--transition-fast);
}

.server-radio:hover {
  border-color: var(--accent-cyan);
  background: rgba(0, 212, 255, 0.08);
}

.server-radio.selected {
  border-color: var(--accent-cyan);
  background: rgba(0, 212, 255, 0.12);
  box-shadow: var(--focus-ring-cyan);
}

.server-radio input[type="radio"] {
  margin-top: 3px;
  accent-color: var(--accent-cyan);
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

.server-radio-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 3px 5px;
}

.server-radio-name {
  display: block;
  font-weight: 600;
  font-size: .9rem;
  color: var(--text-primary);
  word-break: break-word;
  margin-bottom: 5px;
}

.server-radio-badges {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4px;
}


.server-radio-badge {
  display: inline-block;
  font-size: .7rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 6px;
  margin-right: 6px;
  color: #fff;
}

.badge-mc {
  background: var(--accent-cyan);
}

.badge-price {
  background: linear-gradient(135deg, #10b981, #10b981);
  font-size: .75rem;
  padding: 3px 10px;
}

.badge-sale {
  display: inline-block;
  font-size: .68rem;
  font-weight: 800;
  padding: 2px 8px;
  border-radius: 6px;
  margin-right: 4px;
  letter-spacing: .4px;
  background: linear-gradient(135deg, #ef4444, #f97316);
  color: #fff;
  box-shadow: 0 2px 6px rgba(239, 68, 68, 0.4);
  animation: salePulse 2.5s ease-in-out infinite;
}

@keyframes salePulse {
  0%, 100% { box-shadow: 0 2px 6px rgba(239, 68, 68, 0.4); }
  50%       { box-shadow: 0 2px 14px rgba(249, 115, 22, 0.7); }
}


/* ── Job count badges (colored by load level) ── */
.badge-job {
  display: inline-block;
  font-size: .68rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 6px;
  margin-right: 4px;
  letter-spacing: .3px;
  vertical-align: middle;
}

.badge-job-zero {
  background: rgba(148, 163, 184, 0.15);
  color: var(--text-muted);
  border: 1px solid rgba(148, 163, 184, 0.3);
}

.badge-job-low {
  background: rgba(16, 185, 129, 0.15);
  color: #10b981;
  border: 1px solid rgba(16, 185, 129, 0.4);
}

.badge-job-mid {
  background: rgba(245, 158, 11, 0.15);
  color: #f59e0b;
  border: 1px solid rgba(245, 158, 11, 0.4);
}

.badge-job-high {
  background: rgba(239, 68, 68, 0.15);
  color: #ef4444;
  border: 1px solid rgba(239, 68, 68, 0.4);
}

/* Note text below service: "✓ X đơn hoàn thành" */
.job-count-note {
  font-size: .73rem;
  color: #10b981;
  margin-top: 4px;
  padding-left: 28px;
  opacity: 0.85;
}

.server-radio-note {
  font-size: .78rem;
  color: var(--text-muted);
  margin-top: 4px;
  padding-left: 28px;
  line-height: 1.5;
}

/* ===================== SERVER INFO GRID ===================== */
.server-info-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 10px;
  margin: 16px 0;
}

.info-badge {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(0, 212, 255, 0.2);
  border-radius: 0;
  clip-path: polygon(10px 0, 100% 0,
      100% calc(100% - 10px), calc(100% - 10px) 100%,
      0 100%, 0 10px);
  padding: 10px 14px;
}

.info-label {
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .3px;
  color: var(--text-muted);
  margin-bottom: 2px;
}

.info-value {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-primary);
}

.info-rate .info-value {
  color: var(--accent-cyan);
}

/* ===================== SERVER NOTE ===================== */
.server-note {
  background: rgba(0, 212, 255, 0.04);
  border: 1px solid rgba(0, 212, 255, 0.25);
  border-radius: 0;
  clip-path: polygon(10px 0, 100% 0,
      100% calc(100% - 10px), calc(100% - 10px) 100%,
      0 100%, 0 10px);
  padding: 10px 14px;
  font-size: .85rem;
  color: var(--accent-cyan);
  margin-bottom: 16px;
}

/* ===================== FORM SECTIONS ===================== */
.form-section {
  margin-bottom: 18px;
}

.form-section .form-label {
  color: var(--text-primary);
  font-size: .9rem;
}

.form-section .form-control {
  border-radius: 8px;
  border: 1.5px solid var(--border-subtle);
  padding: 10px 14px;
  font-size: .9rem;
  transition: border-color .2s;
  /* bg, color, focus — from shared base */
}

/* ===================== REACTION PICKER ===================== */
.reaction-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 10px 14px;
  border: 2px solid rgba(255, 255, 255, .12);
  border-radius: 12px;
  cursor: pointer;
  transition: all .2s ease;
  background: rgba(255, 255, 255, .03);
  min-width: 68px;
}
.reaction-btn:hover {
  border-color: rgba(0, 212, 255, 0.5);
  background: rgba(0, 212, 255, 0.08);
  transform: translateY(-2px);
}
.reaction-btn.selected {
  border-color: var(--accent-cyan);
  background: rgba(0, 212, 255, 0.15);
  box-shadow: 0 0 12px rgba(0, 212, 255, 0.3);
}
.reaction-btn input[type="radio"] {
  display: none;
}
.reaction-emoji {
  font-size: 1.6rem;
  line-height: 1;
}
.reaction-label {
  font-size: .72rem;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .3px;
}
.reaction-btn.selected .reaction-label {
  color: var(--accent-cyan);
}

/* ===================== TOTAL PAYMENT ===================== */
.total-payment {
  background: rgba(245, 158, 11, 0.06);
  border: 2px solid rgba(245, 158, 11, 0.4);
  border-radius: 0;
  clip-path: polygon(10px 0, 100% 0,
      100% calc(100% - 10px), calc(100% - 10px) 100%,
      0 100%, 0 10px);
  padding: 14px 18px;
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--warning);
  text-align: center;
  letter-spacing: .5px;
}

/* ===================== ORDER BUTTON ===================== */
.btn-order {
  background: var(--gradient-cyan);
  color: #fff;
  font-weight: 700;
  font-size: 1rem;
  padding: 14px;
  border: none;
  border-radius: 10px;
  transition: var(--transition-normal);
  letter-spacing: .3px;
  margin-top: 8px;
}

.btn-order:hover:not(:disabled) {
  transform: var(--hover-elevate);
  box-shadow: 0 8px 20px rgba(0, 212, 255, 0.25);
  color: #fff;
}

.btn-order:disabled {
  color: #fff;
  /* opacity, cursor, transform — from shared base */
}

/* ===================== NOTE CARD ===================== */
.smm-note-card {
  border-left: 4px solid var(--warning);
}

.note-title {
  font-weight: 700;
  color: var(--warning);
  margin-bottom: 10px;
  font-size: .95rem;
}

.note-list {
  padding-left: 18px;
  margin: 0;
}

.note-list li {
  font-size: .85rem;
  color: var(--text-muted);
  margin-bottom: 6px;
  line-height: 1.5;
}

/* ===================== STATUS FILTER ===================== */
.status-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 14px;
}

.status-btn {
  font-size: .78rem;
  font-weight: 600;
  padding: 5px 12px;
  border-radius: 20px;
  border: 1.5px solid var(--border-subtle);
  background: rgba(17, 24, 39, 0.6);
  color: var(--text-muted);
  cursor: pointer;
  transition: var(--transition-fast);
  display: flex;
  align-items: center;
  gap: 4px;
}

.status-btn:hover {
  border-color: var(--accent-cyan);
  color: var(--accent-cyan);
}

.status-btn.active {
  background: var(--accent-cyan);
  color: #fff;
  border-color: var(--accent-cyan);
}

.status-btn .cnt {
  background: rgba(0, 0, 0, .08);
  border-radius: 10px;
  padding: 1px 6px;
  font-size: .7rem;
}

.status-btn.active .cnt {
  background: rgba(255, 255, 255, .25);
}

/* ===================== TABLE ===================== */
.smm-table {
  font-size: .85rem;
  color: var(--text-primary);
  --bs-table-bg: transparent;
  --bs-table-striped-bg: transparent;
  --bs-table-hover-bg: transparent;
  background-color: transparent;
}

.smm-table> :not(caption)>*>* {
  background-color: transparent;
  box-shadow: none;
  color: var(--text-primary);
}

.smm-table thead th {
  background: rgba(0, 212, 255, 0.06);
  color: var(--text-muted);
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .5px;
  border-bottom: 2px solid var(--border-subtle);
  padding: 10px 12px;
  white-space: nowrap;
}

.smm-table tbody td {
  padding: 10px 12px;
  vertical-align: middle;
  border-bottom: 1px solid rgba(148, 163, 184, 0.15);
}

.smm-table tbody tr:hover {
  background: rgba(0, 212, 255, 0.06);
}

/* Progress bar in table */
.progress-mini {
  height: 6px;
  border-radius: 4px;
  background: rgba(148, 163, 184, 0.2);
  overflow: hidden;
  min-width: 60px;
}

.progress-mini-bar {
  height: 100%;
  border-radius: 4px;
  background: var(--gradient-cyan);
  transition: width .3s;
}

/* Status badges — Holo chamfer style */
.order-status {
  display: inline-block;
  font-size: .72rem;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 0;
  clip-path: polygon(6px 0, 100% 0,
      100% calc(100% - 6px), calc(100% - 6px) 100%,
      0 100%, 0 6px);
  text-transform: uppercase;
  letter-spacing: .3px;
  white-space: nowrap;
}

.status-pending {
  background: rgba(245, 158, 11, 0.08);
  color: #f59e0b;
  border: 1px solid rgba(245, 158, 11, 0.4);
}

.status-get_id {
  background: rgba(0, 212, 255, 0.08);
  color: var(--accent-cyan);
  border: 1px solid rgba(0, 212, 255, 0.3);
}

.status-pending_payment {
  background: rgba(236, 72, 153, 0.08);
  color: #ec4899;
  border: 1px solid rgba(236, 72, 153, 0.4);
}

.status-in_progress,
.status-processing {
  background: rgba(0, 212, 255, 0.08);
  color: var(--accent-cyan);
  border: 1px solid rgba(0, 212, 255, 0.3);
}

.status-completed {
  background: rgba(16, 185, 129, 0.08);
  color: #10b981;
  border: 1px solid rgba(16, 185, 129, 0.4);
}

.status-failed,
.status-error {
  background: rgba(239, 68, 68, 0.08);
  color: #ef4444;
  border: 1px solid rgba(239, 68, 68, 0.4);
}

.status-cancelled,
.status-canceled {
  background: rgba(148, 163, 184, 0.08);
  color: var(--text-secondary);
  border: 1px solid rgba(148, 163, 184, 0.3);
}

.status-refunded {
  background: rgba(245, 158, 11, 0.08);
  color: #f59e0b;
  border: 1px solid rgba(245, 158, 11, 0.3);
}

/* ── Pagination — shared compact style (semantic pg-* classes) ── */
.pg-container {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px;
  margin: 0.75rem 0;
}

.pg-container button {
  padding: 5px 12px;
  border-radius: 8px;
  border: 1px solid var(--border-subtle);
  background: transparent;
  color: var(--accent-cyan);
  font-size: .85rem;
  font-weight: 500;
  cursor: pointer;
  transition: var(--transition-fast);
}

.pg-container button:hover:not(:disabled) {
  background: rgba(0, 212, 255, 0.1);
  border-color: var(--accent-cyan);
  color: #fff;
}

.pg-container button.active {
  background: var(--accent-cyan);
  border-color: var(--accent-cyan);
  color: #fff;
  font-weight: 700;
}

.pg-container button:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.pg-ellipsis {
  color: var(--text-muted);
  padding: 0 4px;
  user-select: none;
}

/* ===================== MULTI ORDER STATUS ===================== */
.multi-result {
  margin-top: 12px;
  border-radius: 8px;
  padding: 10px 14px;
  font-size: .85rem;
}

.multi-result.success {
  background: rgba(16, 185, 129, 0.15);
  color: #10b981;
}

.multi-result.fail {
  background: rgba(239, 68, 68, 0.15);
  color: #ef4444;
}

/* ===================== OVERLAY (mobile) ===================== */
.sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .45);
  z-index: 999;
}

/* ===================== RESPONSIVE ===================== */
@media (max-width: 991.98px) {
  .sidebar, .smm-sidebar {
    position: fixed !important;
    top: 0;
    left: 0;
    bottom: 0;
    z-index: 1050;
    transform: translateX(-100%);
    transition: transform .3s ease;
  }

  .sidebar.open, .smm-sidebar.open {
    transform: translateX(0);
  }

  .sidebar-overlay.show {
    display: block;
  }

  .main-content, .smm-main, .main {
    margin-left: 0 !important;
    width: 100% !important;
  }
}

@media (max-width: 575.98px) {
  .smm-main {
    padding: 12px;
  }

  .smm-card {
    padding: 14px 16px;
  }

  .server-info-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.smm-card {
  animation: slideUp .35s ease-out;
}

/* Spinner */
.btn-order .spinner-border {
  width: 1rem;
  height: 1rem;
  border-width: .18em;
}


/* ═══════════════════════════════════════════════════
   CLONE SHOP
   ═══════════════════════════════════════════════════ */
/* clone_shop.css — Premium dark theme for Clone Shop */


body.clone-shop-body {
  margin: 0;
  min-height: 100vh;
  background: linear-gradient(135deg, var(--bg-deep), #0a0e1a, var(--bg-deep));
  color: var(--text-primary);
  font-family: inherit;
}

/* ── Header ─────────────────────────────────────────── */
.cs-header {
  background: var(--glass);
  backdrop-filter: var(--blur-heavy);
  -webkit-backdrop-filter: var(--blur-heavy);
  border-bottom: 1px solid var(--border-glass);
  padding: 1rem 2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: sticky;
  top: 0;
  z-index: 100;
}

.cs-header-brand {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  text-decoration: none;
  color: var(--text-primary);
  font-weight: 700;
  font-size: 1.25rem;
}

.cs-header-brand i {
  color: var(--accent-cyan);
  font-size: 1.4rem;
}

.cs-header-right {
  display: flex;
  align-items: center;
  gap: 1.25rem;
}

.cs-balance-badge {
  background: var(--gradient-cyan);
  padding: 0.5rem 1.25rem;
  border-radius: 2rem;
  font-weight: 600;
  font-size: 0.95rem;
  box-shadow: 0 0 20px rgba(0, 212, 255, 0.2);

}


.cs-btn-back {
  background: var(--glass);
  border: 1px solid var(--border-glass);
  color: var(--text-primary);
  padding: 0.5rem 1rem;
  border-radius: 0.5rem;
  text-decoration: none;
  font-size: 0.875rem;
  transition: var(--transition-fast);
}

.cs-btn-back:hover {
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
}

/* ── Tabs ────────────────────────────────────────────── */
.cs-tabs {
  display: flex;
  gap: 0;
  padding: 1rem 2rem 0;
}

.cs-tab {
  padding: 0.75rem 1.5rem;
  background: transparent;
  border: none;
  color: var(--text-secondary);
  font-size: 0.95rem;
  font-weight: 500;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  transition: var(--transition-fast);
}

.cs-tab:hover {
  color: var(--text-primary);
}

.cs-tab.active {
  color: var(--accent-cyan);
  border-bottom-color: var(--accent-cyan);
}

/* ── Main content ───────────────────────────────────── */
.cs-main {
  padding: 1.5rem 2rem 3rem;
  max-width: 1400px;
  margin: 0 auto;
}

.cs-tab-content {
  display: none;
}

.cs-tab-content.active {
  display: block;
}

/* ── Provider tabs ──────────────────────────────────── */
.cs-provider-tabs {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 1rem;
  flex-wrap: wrap;
}

.cs-provider-btn {
  padding: 0.5rem 1.25rem;
  border: 1px solid var(--border-glass);
  border-radius: 2rem;
  background: var(--glass);
  color: var(--text-secondary);
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  transition: var(--transition-fast);
}

.cs-provider-btn:hover {
  color: var(--text-primary);
  border-color: rgba(255, 255, 255, 0.2);
}

.cs-provider-btn.active {
  background: var(--gradient-cyan);
  color: #fff;
  border-color: var(--accent-cyan);
  font-weight: 600;
}

/* ── Category selector (buttons ở trên, chỉ 1 mở) ───── */
.cs-cat-selector {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin-bottom: 1.25rem;
}

.cs-cat-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  background: var(--glass);
  backdrop-filter: var(--blur-glass);
  border: 1px solid var(--border-glass);
  border-radius: 0.6rem;
  padding: 0.65rem 1rem;
  color: var(--text-primary);
  cursor: pointer;
  transition: var(--transition-fast);
  flex: 1 1 200px;
  min-width: 180px;
}

.cs-cat-btn:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.2);
}

.cs-cat-btn.active {
  background: rgba(0, 212, 255, 0.1);
  border-color: var(--accent-cyan);
  box-shadow: var(--glow-cyan-sm);
}

.cs-cat-btn-inner {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex: 1;
  min-width: 0;
}

.cs-cat-btn-name {
  font-weight: 600;
  font-size: 0.85rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cs-cat-btn-stock {
  font-size: 0.72rem;
  color: var(--text-secondary);
  white-space: nowrap;
}

.cs-cat-btn-arrow {
  font-size: 0.7rem;
  color: var(--text-secondary);
  transition: transform 0.3s;
}

.cs-cat-btn.active .cs-cat-btn-arrow {
  transform: rotate(180deg);
  color: var(--accent-cyan);
}

.cs-category-icon {
  width: 24px;
  height: 24px;
  border-radius: 4px;
  flex-shrink: 0;
}

/* ── Products table (list view) ─────────────────────── */
.cs-products-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 0.85rem;
}

.cs-products-table th {
  background: var(--glass);
  padding: 0.7rem 0.75rem;
  text-align: left;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.72rem;
  color: var(--text-secondary);
  letter-spacing: 0.04em;
  border-bottom: 1px solid var(--border-glass);
  white-space: nowrap;
}

.cs-products-table td {
  padding: 0.65rem 0.75rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  vertical-align: middle;
}

.cs-products-table tr:hover td {
  background: rgba(255, 255, 255, 0.04);
}

.cs-products-table tr.cs-row-out td {
  opacity: 0.45;
}

.cs-prod-name {
  font-weight: 600;
  font-size: 0.88rem;
  color: #fff;
  line-height: 1.35;
  margin-bottom: 0.15rem;
}

.cs-prod-id {
  font-size: 0.72rem;
  color: var(--text-secondary);
}

.cs-prod-desc-cell {
  font-size: 0.78rem;
  color: var(--text-secondary);
  max-width: 200px;
  word-break: break-all;
}

.cs-prod-price-cell {
  font-weight: 700;
  color: var(--success);
  white-space: nowrap;
  font-size: 0.95rem;
}

.cs-stock-ok {
  color: var(--success);
  font-weight: 600;
  text-align: center;
}

.cs-stock-zero {
  color: var(--danger);
  font-weight: 600;
  text-align: center;
}

.cs-prod-minmax {
  font-size: 0.78rem;
  color: var(--text-secondary);
  text-align: center;
  white-space: nowrap;
}

.cs-btn-buy-sm {
  background: var(--gradient-cyan);
  border: none;
  color: #fff;
  padding: 0.4rem 0.85rem;
  border-radius: 0.4rem;
  font-weight: 600;
  font-size: 0.8rem;
  cursor: pointer;
  transition: var(--transition-fast);
  white-space: nowrap;
}

.cs-btn-buy-sm:hover {
  box-shadow: var(--glow-cyan-sm);
  transform: var(--hover-elevate-sm);
}

/* cs-btn-buy-sm:disabled — from shared base */

/* ── Product card (kept for backward compat) ────────── */
.cs-product-card {
  background: rgba(255, 255, 255, 0.06);
  backdrop-filter: var(--blur-glass);
  border: 1px solid var(--border-glass);
  border-radius: 0.75rem;
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  transition: var(--transition-normal);
}

.cs-product-card:hover {
  transform: var(--hover-elevate);
  box-shadow: var(--card-hover-glow);
  border-color: var(--accent-cyan);
}

.cs-product-name {
  font-weight: 600;
  font-size: 0.9rem;
  line-height: 1.4;
  color: #fff;
}

.cs-product-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  font-size: 0.8rem;
}

.cs-product-meta span {
  padding: 0.25rem 0.6rem;
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.08);
}

.cs-product-price {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--success);
}

.cs-product-stock {
  font-size: 0.8rem;
  color: var(--text-secondary);
}

.cs-product-stock.out-of-stock {
  color: var(--danger);
}

.cs-product-desc {
  font-size: 0.78rem;
  color: var(--text-secondary);
  line-height: 1.4;
  word-break: break-all;
}

.cs-btn-buy {
  margin-top: auto;
  background: var(--gradient-cyan);
  border: none;
  color: #fff;
  padding: 0.6rem 1rem;
  border-radius: 0.5rem;
  font-weight: 600;
  font-size: 0.9rem;
  cursor: pointer;
  transition: var(--transition-fast);
  text-align: center;
}

.cs-btn-buy:hover {
  transform: var(--hover-elevate-sm);
  box-shadow: var(--glow-cyan-sm);
}

/* cs-btn-buy:disabled — from shared base */

/* ── Modal ──────────────────────────────────────────── */
.cs-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
  backdrop-filter: var(--blur-glass);
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: slideUp 0.2s ease-out;
}

.cs-modal {
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.04), #0a0e1a);
  border: 1px solid var(--border-glass);
  border-radius: 1rem;
  width: 90%;
  max-width: 520px;
  max-height: 90vh;
  overflow-y: auto;
  padding: 2rem;
  animation: slideUp 0.3s ease;
}

.cs-modal h3 {
  margin: 0 0 1.25rem;
  font-size: 1.15rem;
  color: #fff;
}

.cs-modal-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: none;
  border: none;
  color: var(--text-secondary);
  font-size: 1.3rem;
  cursor: pointer;
}

.cs-form-group {
  margin-bottom: 1rem;
}

.cs-form-group label {
  display: block;
  font-size: 0.85rem;
  color: var(--text-secondary);
  margin-bottom: 0.35rem;
}

.cs-form-group input {
  width: 100%;
  padding: 0.6rem 0.85rem;
  border-radius: 0.5rem;
  border: 1px solid var(--border-glass);
  font-size: 0.95rem;
  outline: none;
  transition: border-color 0.2s;
  /* bg, color, focus — from shared base */
}

.cs-form-group input:focus {
  border-color: var(--accent-cyan);
}

.cs-cost-preview {
  background: rgba(0, 212, 255, 0.1);
  border: 1px solid rgba(0, 212, 255, 0.2);
  border-radius: 0.5rem;
  padding: 0.75rem 1rem;
  margin-bottom: 1rem;
  font-size: 0.95rem;
}

.cs-cost-preview strong {
  color: var(--accent-cyan);
}

.cs-btn-confirm {
  width: 100%;
  padding: 0.75rem;
  border: none;
  border-radius: 0.5rem;
  background: linear-gradient(135deg, var(--success), #10b981);
  color: #fff;
  font-weight: 600;
  font-size: 1rem;
  cursor: pointer;
  transition: var(--transition-fast);
}

.cs-btn-confirm:hover {
  box-shadow: 0 0 20px rgba(16, 185, 129, 0.4);
}

/* cs-btn-confirm:disabled — from shared base */

.cs-btn-cancel {
  width: 100%;
  padding: 0.6rem;
  border: 1px solid var(--border-glass);
  border-radius: 0.5rem;
  background: transparent;
  color: var(--text-secondary);
  font-size: 0.9rem;
  cursor: pointer;
  margin-top: 0.5rem;
  transition: var(--transition-fast);
}

.cs-btn-cancel:hover {
  background: rgba(255, 255, 255, 0.08);
}

/* ── Results ────────────────────────────────────────── */
.cs-result-box {
  background: rgba(16, 185, 129, 0.1);
  border: 1px solid rgba(16, 185, 129, 0.3);
  border-radius: 0.75rem;
  padding: 1.25rem;
  margin-top: 1rem;
}

.cs-result-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.75rem;
}

.cs-result-header h4 {
  margin: 0;
  color: var(--success);
  font-size: 1rem;
}

.cs-btn-copy-all {
  background: var(--glass);
  border: 1px solid var(--border-glass);
  color: var(--text-primary);
  padding: 0.4rem 1rem;
  border-radius: 0.4rem;
  font-size: 0.8rem;
  cursor: pointer;
  transition: var(--transition-fast);
}

.cs-btn-copy-all:hover {
  background: rgba(255, 255, 255, 0.15);
}

.cs-result-list {
  background: rgba(0, 0, 0, 0.3);
  border-radius: 0.5rem;
  padding: 0.75rem 1rem;
  font-family: 'Fira Code', 'Consolas', monospace;
  font-size: 0.78rem;
  line-height: 1.7;
  max-height: 300px;
  overflow-y: auto;
  word-break: break-all;
}

/* ── Order groups ──────────────────────────────────── */
.cs-order-group {
  background: var(--glass);
  border: 1px solid var(--border-glass);
  border-radius: 0.75rem;
  margin-bottom: 1rem;
  overflow: hidden;
}

.cs-order-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.75rem 1rem;
  background: rgba(0, 212, 255, 0.06);
  border-bottom: 1px solid var(--border-glass);
  flex-wrap: wrap;
  gap: 0.5rem;
}

.cs-order-label {
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--accent-cyan);
  margin-right: 0.5rem;
}

.cs-order-meta {
  font-size: 0.75rem;
  color: var(--text-secondary);
}

/* ── My Clones table ───────────────────────────────── */
.cs-clones-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 0.85rem;
}

.cs-clones-table th {
  background: var(--glass);
  padding: 0.7rem 0.75rem;
  text-align: left;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.75rem;
  color: var(--text-secondary);
  letter-spacing: 0.04em;
  border-bottom: 1px solid var(--border-glass);
}

.cs-clones-table td {
  padding: 0.6rem 0.75rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  vertical-align: middle;
}

.cs-clones-table tr:hover td {
  background: rgba(255, 255, 255, 0.03);
}

.cs-clones-table .td-uid {
  font-family: 'Fira Code', monospace;
  font-weight: 500;
  color: var(--accent-cyan);
}

/* ── Spinner ────────────────────────────────────────── */
.cs-spinner {
  display: inline-block;
  width: 1.5rem;
  height: 1.5rem;
  border: 3px solid rgba(255, 255, 255, 0.1);
  border-top-color: var(--accent-purple);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

.cs-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  padding: 3rem;
  color: var(--text-secondary);
}

/* ── Alert ──────────────────────────────────────────── */
.cs-alert {
  padding: 0.75rem 1rem;
  border-radius: 0.5rem;
  margin: 1rem 0;
  font-size: 0.9rem;
}

/* cs-alert-error, cs-alert-success — fully defined in shared base */

/* ── Notice section ─────────────────────────────────── */
.cs-notice {
  background: var(--glass);
  backdrop-filter: var(--blur-glass);
  border: 1px solid rgba(245, 158, 11, 0.3);
  border-radius: 0.75rem;
  padding: 1.25rem 1.5rem;
  margin-bottom: 1.5rem;
}

.cs-notice-title {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--warning);
  margin-bottom: 0.75rem;
}

.cs-notice-title i {
  margin-right: 0.5rem;
}

.cs-notice-subtitle {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--accent-cyan);
  margin-bottom: 0.5rem;
}

.cs-notice-subtitle i {
  margin-right: 0.4rem;
}

.cs-notice-list {
  list-style: none;
  padding: 0;
  margin: 0 0 0.75rem;
}

.cs-notice-list li {
  position: relative;
  padding: 0.35rem 0 0.35rem 1.25rem;
  font-size: 0.85rem;
  line-height: 1.5;
  color: var(--text-primary);
}

.cs-notice-list li::before {
  content: '•';
  position: absolute;
  left: 0;
  color: var(--warning);
  font-weight: bold;
}

.cs-notice-warn {
  color: var(--warning) !important;
  font-weight: 600;
}

.cs-notice-danger {
  color: #ef4444 !important;
  font-weight: 600;
  font-size: 0.82rem !important;
  background: rgba(239, 68, 68, 0.1);
  border-radius: 0.4rem;
  padding: 0.5rem 0.75rem 0.5rem 1.25rem !important;
  margin-top: 0.25rem;
}

.cs-notice-promo {
  background: rgba(0, 212, 255, 0.08);
  border: 1px solid rgba(0, 212, 255, 0.15);
  border-radius: 0.5rem;
  padding: 0.75rem 1rem;
  margin-bottom: 0.75rem;
}

.cs-promo-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.cs-promo-item {
  background: rgba(0, 212, 255, 0.1);
  padding: 0.35rem 0.85rem;
  border-radius: 2rem;
  font-size: 0.82rem;
  white-space: nowrap;
}

.cs-promo-item strong {
  color: var(--accent-cyan);
}

.cs-notice-refund {
  background: rgba(239, 68, 68, 0.08);
  border: 1px solid rgba(239, 68, 68, 0.15);
  border-radius: 0.5rem;
  padding: 0.75rem 1rem;
}

.cs-notice-refund .cs-notice-list {
  margin-bottom: 0;
}

.cs-notice-refund .cs-notice-list li::before {
  color: var(--danger);
}

/* ── Animations ─────────────────────────────────────── */
/* fadeIn removed — using slideUp for all entry animations */

@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ── Responsive ─────────────────────────────────────── */
@media (max-width: 768px) {
  .cs-header {
    padding: 0.75rem 1rem;
    flex-wrap: wrap;
    gap: 0.5rem;
  }

  .cs-main {
    padding: 1rem;
  }

  .cs-tabs {
    padding: 0.5rem 1rem 0;
  }

  .cs-products-grid {
    grid-template-columns: 1fr;
  }

  .cs-modal {
    padding: 1.25rem;
    width: 95%;
  }

  .cs-clones-table {
    font-size: 0.78rem;
  }
}

/* ── Pagination ─────────────────────────────────────── */
.cs-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
  margin-top: 1.5rem;
}

.holo-service-card-icon {
  width: 40px;
  height: 40px;
  object-fit: contain;
}

.cs-pagination button {
  padding: 0.4rem 0.85rem;
  border: 1px solid var(--border-glass);
  border-radius: 0.4rem;
  background: var(--glass);
  color: var(--text-primary);
  cursor: pointer;
  font-size: 0.85rem;
  transition: var(--transition-fast);
}

.cs-pagination button:hover:not(:disabled) {
  background: rgba(255, 255, 255, 0.15);
}

.cs-pagination button:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

.cs-pagination span {
  color: var(--text-secondary);
  font-size: 0.85rem;
}


/* ═══════════════════════════════════════════════════
   FB COMMENT ORDER (scoped: .fco-page)
   ═══════════════════════════════════════════════════ */
/* fb_comment_order_web.css — FB Comment Order Tool styles */


.fco-page .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  padding-bottom: 120px;
}

.fco-page .card {
  background: var(--bg-card-solid);
  border: 1px solid var(--border-subtle);
  border-radius: 14px;
  padding: 20px 24px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.fco-page .row {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  align-items: flex-start;
  margin-bottom: 8px;
}

.fco-page .row:last-child {
  margin-bottom: 0;
}

.fco-page .row>* {
  flex: 1 1 280px;
  min-width: 0;
}

.fco-page label {
  display: block;
  font-size: 13px;
  color: var(--text-secondary);
  margin-bottom: 8px;
  font-weight: 500;
}

.fco-page input[type="text"],
.fco-page input[type="number"],
.fco-page input[type="password"],
.fco-page textarea,
.fco-page select {
  width: 100%;
  background: var(--bg-input);
  color: var(--text-primary);
  border: 1px solid var(--border-subtle);
  border-radius: 10px;
  padding: 11px 14px;
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  box-sizing: border-box;
}

.fco-page input[type="text"]:focus,
.fco-page input[type="number"]:focus,
.fco-page input[type="password"]:focus,
.fco-page textarea:focus,
.fco-page select:focus {
  border-color: var(--accent-cyan);
  box-shadow: var(--focus-ring-cyan);
}

.fco-page .fco-page textarea {
  min-height: 140px;
  resize: vertical;
}

.fco-page .inline {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 4px;
}

.fco-page .btn {
  background: var(--accent-cyan);
  color: white;
  border: none;
  border-radius: 10px;
  padding: 11px 18px;
  cursor: pointer;
  font-weight: 600;
  transition: var(--transition-fast);
  white-space: nowrap;
}

.fco-page .btn:hover:not(:disabled) {
  opacity: 0.9;
  transform: var(--hover-elevate-sm);
  box-shadow: 0 4px 12px rgba(0, 212, 255, 0.25);
}

.fco-page .btn.secondary {
  background: transparent;
  color: var(--accent-cyan);
  border: 1px solid var(--accent-cyan);
}

.fco-page .btn.secondary:hover:not(:disabled) {
  background: var(--accent-cyan);
  color: white;
}

.fco-page .btn.warn {
  background: var(--danger);
}

.fco-page .btn.warn:hover:not(:disabled) {
  box-shadow: 0 4px 12px rgba(239, 68, 68, 0.3);
}

.fco-page .btn.ok {
  background: var(--success);
}

.fco-page .btn.ok:hover:not(:disabled) {
  box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3);
}

.fco-page .btn:disabled {
  opacity: .5;
  cursor: not-allowed;
  transform: none;
}

.fco-page .hint {
  color: var(--text-secondary);
  font-size: 12px;
  line-height: 1.5;
}

.fco-page .kpi {
  font-weight: 600;
  font-size: 14px;
  margin-bottom: 6px;
}

.fco-page table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
  margin-top: 8px;
}

.fco-page th,
.fco-page td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--border-subtle);
  vertical-align: top;
}

.fco-page th {
  text-align: left;
  color: var(--text-secondary);
  font-weight: 600;
  background: rgba(0, 0, 0, 0.1);
  position: sticky;
  top: 0;
  z-index: 1;
}

.fco-page tr:hover {
  background: rgba(255, 255, 255, 0.05);
  cursor: pointer;
}

.fco-page .split {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 20px;
  align-items: start;
}

.fco-page .detail-box {
  height: 280px;
  resize: vertical;
}

.fco-page .scroll {
  overflow: auto;
  border-radius: 8px;
}

.fco-page .progress-wrap {
  display: flex;
  align-items: center;
  gap: 14px;
}

.fco-page progress {
  width: 280px;
  height: 18px;
  border-radius: 10px;
}

.fco-page .badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 12px;
  border: 1px solid var(--border-subtle);
  color: var(--text-secondary);
}

.fco-page .ok {
  color: var(--success);
  font-weight: 700;
}

.fco-page .bad {
  color: var(--danger);
  font-weight: 700;
}

.fco-page .toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.fco-page .sticky-send {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 100;
  background: var(--bg-card-solid);
  border-top: 2px solid var(--border-subtle);
  padding: 16px;
  box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.15);
}

.fco-page .sticky-send .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0;
}

.fco-page .filelabel {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border: 2px dashed var(--border-subtle);
  border-radius: 10px;
  cursor: pointer;
  color: var(--text-secondary);
  transition: var(--transition-fast);
}

.fco-page .filelabel:hover {
  border-color: var(--accent-cyan);
  color: var(--accent-cyan);
  background: rgba(0, 212, 255, 0.05);
}

.fco-page .switch {
  display: inline-flex;
  gap: 10px;
  align-items: center;
  cursor: pointer;
  user-select: none;
  padding: 4px;
}

.fco-page .switch input {
  display: none;
}

/* OFF = đỏ, ON = xanh */
.fco-page .switch .dot {
  width: 48px;
  height: 26px;
  border-radius: 999px;
  position: relative;
  border: 1px solid var(--border-subtle);
  background: var(--danger);
  transition: background .3s ease;
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.1);
}

.fco-page .switch input:checked+.dot {
  background: var(--success);
}

.fco-page .switch .dot::after {
  content: "";
  position: absolute;
  width: 22px;
  height: 22px;
  top: 1px;
  left: 2px;
  background: white;
  border-radius: 50%;
  transition: transform .3s ease;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.fco-page .switch input:checked+.dot::after {
  transform: translateX(22px);
}

/* màu chữ trạng thái */
.fco-page .switch .txt {
  margin-left: 4px;
  font-weight: 600;
  color: var(--danger);
  transition: color 0.3s ease;
}

.fco-page .switch input:checked~.txt {
  color: var(--success);
}

@media (max-width: 960px) {
  .fco-page .split {
    grid-template-columns: 1fr;
  }

  .fco-page .container {
    padding: 16px;
    padding-bottom: 100px;
  }

  .fco-page .card {
    padding: 16px 18px;
  }

  .fco-page .row {
    gap: 12px;
  }

  .fco-page .row>* {
    flex: 1 1 100%;
  }

  .fco-page .progress-wrap {
    flex-direction: column;
    align-items: flex-start;
  }

  .fco-page progress {
    width: 100%;
  }

  .fco-page .sticky-send {
    padding: 12px;
  }
}



/* ═══════════════════════════════════════════════════
   API SMM V2 DOCS (scoped: .smmdoc-page)
   ═══════════════════════════════════════════════════ */
/* api_smm_v2_docs.css — API SMM Panel v2 Documentation styles */


.smmdoc-page .layout {
  display: flex;
  min-height: 100vh;
}

.smmdoc-page .sidebar {
  width: 260px;
  min-width: 260px;
  background: linear-gradient(180deg, #0a0e1a 0%, rgba(255, 255, 255, 0.04) 100%);
  border-right: 1px solid rgba(0, 212, 255, 0.08);
  color: white;
  padding: 2rem 0;
  position: fixed !important;
  top: 0;
  left: 0;
  height: 100vh;
  overflow-y: auto;
  z-index: 100;
}

.smmdoc-page .sidebar h2 {
  padding: 0 1.5rem;
  margin-bottom: 2rem;
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--accent-cyan);
}

.smmdoc-page .sidebar .nav-link {
  color: rgba(148, 163, 184, 0.8);
  padding: 0.75rem 1.5rem;
  transition: var(--transition-normal);
  border-left: 3px solid transparent;
}

.sidebar .nav-link:hover,
.smmdoc-page .sidebar .nav-link.active {
  background-color: var(--sidebar-active-bg);
  color: var(--sidebar-accent);
  border-left-color: var(--sidebar-accent);
}

.smmdoc-page .sidebar .nav-link i {
  margin-right: 0.5rem;
  width: 20px;
}

.smmdoc-page .main {
  margin-left: 260px;
  flex: 1;
  padding: 2rem 3rem;
  max-width: 100%;
  overflow-x: hidden;
}

.smmdoc-page .hero {
  background: linear-gradient(135deg, rgba(0, 212, 255, 0.1) 0%, rgba(124, 58, 237, 0.1) 100%);
  border: 1px solid rgba(0, 212, 255, 0.15);
  color: white;
  padding: 3rem 2rem;
  border-radius: 1rem;
  margin-bottom: 2rem;
  backdrop-filter: var(--blur-glass);
}

.smmdoc-page .hero h1 {
  font-size: 2.5rem;
  font-weight: 700;
  margin-bottom: 1rem;
  color: var(--accent-cyan);
}

.smmdoc-page .hero p {
  font-size: 1.1rem;
  opacity: 0.9;
  color: var(--text-secondary);
}

.smmdoc-page section {
  background: rgba(17, 24, 39, 0.85);
  backdrop-filter: var(--blur-glass);
  padding: 2rem;
  margin-bottom: 2rem;
  border-radius: 1rem;
  border: 1px solid rgba(0, 212, 255, 0.08);
}

.smmdoc-page section h2 {
  color: var(--accent-cyan);
  font-weight: 700;
  margin-bottom: 1.5rem;
  padding-bottom: 0.75rem;
  border-bottom: 2px solid rgba(0, 212, 255, 0.2);
}

.smmdoc-page section h3 {
  color: var(--text-secondary);
  font-weight: 600;
  margin-top: 2rem;
  margin-bottom: 1rem;
}

.smmdoc-page section h4 {
  color: var(--text-muted);
  font-weight: 600;
  margin-top: 1.5rem;
  margin-bottom: 0.75rem;
  font-size: 1.1rem;
}

.smmdoc-page .badge-custom {
  padding: 0.5rem 1rem;
  border-radius: 0.5rem;
  font-weight: 600;
}

.smmdoc-page .badge-get {
  background-color: rgba(0, 212, 255, 0.15);
  color: var(--accent-cyan);
}

.smmdoc-page .badge-post {
  background-color: rgba(16, 185, 129, 0.15);
  color: var(--success);
}

.smmdoc-page pre {
  background-color: rgba(0, 0, 0, 0.3);
  border: 1px solid rgba(148, 163, 184, 0.2);
  border-radius: 0.5rem;
  padding: 1.5rem;
  overflow-x: auto;
  margin: 1rem 0;
}

.smmdoc-page code {
  color: var(--accent-cyan);
  background-color: rgba(0, 212, 255, 0.08);
  padding: 0.2rem 0.4rem;
  border-radius: 0.25rem;
  font-size: 0.9em;
}

.smmdoc-page pre code {
  color: inherit;
  background-color: transparent;
  padding: 0;
  font-size: 0.875rem;
}

.smmdoc-page .table-params {
  margin: 1rem 0;
}

.smmdoc-page .table-params th {
  background-color: rgba(0, 212, 255, 0.06);
  font-weight: 600;
  color: var(--text-secondary);
}

.smmdoc-page .table-params td {
  vertical-align: middle;
  color: var(--text-primary);
}

.smmdoc-page .table-params {
  border-color: rgba(148, 163, 184, 0.2) !important;
}

.smmdoc-page .table-params th,
.smmdoc-page .table-params td {
  border-color: rgba(148, 163, 184, 0.2) !important;
}

.smmdoc-page .alert-custom {
  border-left: 4px solid;
  border-radius: 0.5rem;
}

.smmdoc-page .alert-info {
  border-left-color: var(--accent-cyan);
  background-color: rgba(0, 212, 255, 0.06);
  color: var(--text-secondary);
}

.smmdoc-page .alert-warning {
  border-left-color: var(--warning);
  background-color: rgba(245, 158, 11, 0.06);
  color: var(--text-secondary);
}

.smmdoc-page .alert-success {
  border-left-color: var(--success);
  background-color: rgba(16, 185, 129, 0.06);
  color: var(--text-secondary);
}

.smmdoc-page .response-box {
  background-color: rgba(0, 0, 0, 0.2);
  border: 1px solid rgba(148, 163, 184, 0.2);
  border-radius: 0.5rem;
  padding: 1rem;
  margin: 1rem 0;
}

.smmdoc-page .endpoint-url {
  background-color: rgba(0, 212, 255, 0.06);
  padding: 1rem;
  border-radius: 0.5rem;
  font-family: 'Courier New', monospace;
  margin: 1rem 0;
  border-left: 4px solid var(--accent-cyan);
  color: var(--text-primary);
}

/* Scrollbar styling */
.smmdoc-page .sidebar::-webkit-scrollbar {
  width: 6px;
}

.smmdoc-page .sidebar::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.05);
}

.smmdoc-page .sidebar::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.15);
  border-radius: 3px;
}

.smmdoc-page .sidebar::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.25);
}

/* ═══════════════════════════════════════════════════
   SHARED BASE CLASSES — Cross-page pattern consolidation
   ═══════════════════════════════════════════════════ */

/* ── Table th/td base (shared across SMM, Clone Shop) ── */
.smm-table thead th,
.cs-products-table th,
.cs-clones-table th {
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-secondary);
  white-space: nowrap;
}

.smm-table tbody td,
.cs-products-table td,
.cs-clones-table td {
  vertical-align: middle;
}

.smm-table tbody tr:hover,
.cs-products-table tr:hover td,
.cs-clones-table tr:hover td {
  background: rgba(0, 212, 255, 0.04);
}

/* ── Button disabled (shared across all custom buttons) ── */
.btn-order:disabled,
.cs-btn-buy:disabled,
.cs-btn-buy-sm:disabled,
.cs-btn-confirm:disabled,
.fco-page .btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  transform: none;
}

/* ── Form input unification (cs-form-group inherits Nuclear vars) ── */
.cs-form-group input,
.fco-page input,
.fco-page textarea,
.fco-page select,
.form-section .form-control {
  background-color: var(--bg-input);
  color: var(--text-primary);
  border-color: var(--border-subtle);
}

.cs-form-group input:focus,
.fco-page input:focus,
.fco-page textarea:focus,
.form-section .form-control:focus {
  border-color: var(--accent-cyan);
  box-shadow: var(--focus-ring-cyan);
}

/* ── Alert unification (cs-alert extends global alert) ── */
.cs-alert-error,
.multi-result.fail {
  background: rgba(239, 68, 68, 0.15);
  border: 1px solid rgba(239, 68, 68, 0.3);
  color: #ef4444;
}

.cs-alert-success,
.multi-result.success {
  background: rgba(16, 185, 129, 0.15);
  border: 1px solid rgba(16, 185, 129, 0.3);
  color: #10b981;
}

/* ═══════════════════════════════════════════════════════════════
   HOLO GUI THEME — Sci-fi Holographic UI Components
   Based on HOLO GUI reference design kit
   ═══════════════════════════════════════════════════════════════ */

/* ── Holo Variables ── */
:root {
  --holo-chamfer: 25px;
  --holo-corner-size: 12px;
  --holo-corner-thickness: 2px;
  --holo-corner-color: var(--accent-cyan);
  --holo-corner-glow: 0 0 6px rgba(0, 212, 255, 0.4);
  --holo-border-color: rgba(0, 212, 255, 0.3);
  --holo-border-hover: rgba(0, 212, 255, 0.6);
  --holo-bg-window: rgba(8, 12, 24, 0.88);
  --holo-bg-inner: rgba(6, 10, 20, 0.6);
  --holo-title-glow: 0 0 12px rgba(0, 212, 255, 0.3);
  --holo-scan-opacity: 0.035;
}


/* ══════════════════════════════════════════
   1.1 — HOLO WINDOW CONTAINER
   Inherits border system from .card (PREMIUM HOLO GUI section).
   Only adds: hover glow, bracket arms, compact variant.
   ══════════════════════════════════════════ */

.holo-window {
  filter: drop-shadow(0 0 10px rgba(0, 212, 255, 0.15));
  transition: var(--transition-normal);
}

.holo-window:hover {
  filter: drop-shadow(0 0 15px rgba(0, 212, 255, 0.3));
}

/* Bracket arms — layered ON TOP of the inherited dark fill */
body .holo-window::after {
  background:
    linear-gradient(90deg, var(--accent-cyan), var(--accent-cyan)) top left / 60px 2px no-repeat,
    linear-gradient(0deg, var(--accent-cyan), var(--accent-cyan)) top left / 2px 60px no-repeat,
    linear-gradient(90deg, var(--accent-cyan), var(--accent-cyan)) bottom right / 60px 2px no-repeat,
    linear-gradient(0deg, var(--accent-cyan), var(--accent-cyan)) bottom right / 2px 60px no-repeat,
    #080c18 !important;
}

/* Compact variant (smaller padding) */
.holo-window.holo-compact {
  padding: 1rem;
}


/* ══════════════════════════════════════════
   1.2 — HOLO TITLE BAR
   Header with accent lines extending both sides
   ══════════════════════════════════════════ */

.holo-title-bar {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
  position: relative;
  background: linear-gradient(180deg, rgba(0, 212, 255, 0.05) 0%, transparent 100%);
  border-bottom: 1px solid rgba(0, 212, 255, 0.4);
  box-shadow: 0 8px 15px -8px rgba(0, 212, 255, 0.15);
}

.holo-title-bar .holo-title-text {
  text-transform: uppercase;
  font-weight: 700;
  font-size: 0.9rem;
  letter-spacing: 3px;
  color: var(--accent-cyan);
  white-space: nowrap;
  text-shadow: var(--holo-title-glow);
  position: relative;
  padding: 0 10px;
}

.holo-title-bar .holo-title-text::before,
.holo-title-bar .holo-title-text::after {
  content: '';
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 4px;
  height: 12px;
  background: var(--accent-cyan);
  box-shadow: 0 0 6px var(--accent-cyan);
}

.holo-title-bar .holo-title-text::before {
  left: -8px;
}

.holo-title-bar .holo-title-text::after {
  right: -8px;
}

/* Size variants */
.holo-title-bar.holo-title-lg .holo-title-text {
  font-size: 1rem;
  letter-spacing: 3px;
}

.holo-title-bar.holo-title-sm .holo-title-text {
  font-size: 0.72rem;
  letter-spacing: 1.5px;
}


/* ══════════════════════════════════════════
   1.3 — HOLO BUTTONS
   Tech-styled buttons with corner accents
   ══════════════════════════════════════════ */

.holo-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 24px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  font-weight: 700;
  font-size: 0.8rem;
  color: var(--accent-cyan);
  background: rgba(0, 212, 255, 0.05);
  border: 1px solid rgba(0, 212, 255, 0.3);
  clip-path: polygon(10px 0, 100% 0, 100% calc(100% - 10px), calc(100% - 10px) 100%, 0 100%, 0 10px);
  cursor: pointer;
  position: relative;
  transition: var(--transition-fast);
  text-decoration: none;
  z-index: 1;
}

.holo-btn::before {
  display: none;
}

.holo-btn::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
  background:
    /* Distance for 10px chamfer is 7.07px */
    linear-gradient(135deg, transparent 6.5px, var(--accent-cyan) 6.5px, var(--accent-cyan) 8px, transparent 8px) top left / 15px 15px no-repeat,
    linear-gradient(-45deg, transparent 6.5px, var(--accent-cyan) 6.5px, var(--accent-cyan) 8px, transparent 8px) bottom right / 15px 15px no-repeat;
  z-index: 2;
  transition: var(--transition-fast);
}

.holo-btn:hover {
  color: #fff;
  background: rgba(0, 212, 255, 0.2);
  border-color: var(--accent-cyan);
  text-shadow: 0 0 8px rgba(0, 212, 255, 0.6);
  box-shadow: inset 0 0 15px rgba(0, 212, 255, 0.3);
}

.holo-btn:active {
  transform: scale(0.96);
}

/* Filled variant */
.holo-btn-filled {
  color: #fff;
  background: rgba(0, 212, 255, 0.2);
  text-shadow: 0 0 6px rgba(0, 212, 255, 0.3);
}

.holo-btn-filled:hover {
  background: rgba(0, 212, 255, 0.4);
}

/* Success variant */
.holo-btn-success {
  color: var(--success);
  border-color: rgba(16, 185, 129, 0.4);
  background: rgba(16, 185, 129, 0.05);
}

.holo-btn-success::after {
  background:
    linear-gradient(135deg, transparent 6.5px, var(--success) 6.5px, var(--success) 8px, transparent 8px) top left / 15px 15px no-repeat,
    linear-gradient(-45deg, transparent 6.5px, var(--success) 6.5px, var(--success) 8px, transparent 8px) bottom right / 15px 15px no-repeat;
}

.holo-btn-success:hover {
  color: #fff;
  background: rgba(16, 185, 129, 0.2);
  border-color: var(--success);
  text-shadow: 0 0 8px var(--success);
  box-shadow: inset 0 0 15px rgba(16, 185, 129, 0.3);
}

/* Danger variant */
.holo-btn-danger {
  color: var(--danger);
  border-color: rgba(239, 68, 68, 0.4);
  background: rgba(239, 68, 68, 0.05);
}

.holo-btn-danger::after {
  background:
    linear-gradient(135deg, transparent 6.5px, var(--danger) 6.5px, var(--danger) 8px, transparent 8px) top left / 15px 15px no-repeat,
    linear-gradient(-45deg, transparent 6.5px, var(--danger) 6.5px, var(--danger) 8px, transparent 8px) bottom right / 15px 15px no-repeat;
}

.holo-btn-danger:hover {
  color: #fff;
  background: rgba(239, 68, 68, 0.2);
  border-color: var(--danger);
  text-shadow: 0 0 8px var(--danger);
  box-shadow: inset 0 0 15px rgba(239, 68, 68, 0.3);
}

/* Small variant */
.holo-btn-sm {
  padding: 6px 14px;
  font-size: 0.7rem;
  letter-spacing: 1px;
}

.holo-btn-sm::after {
  background:
    linear-gradient(135deg, transparent 3.8px, var(--accent-cyan) 3.8px, var(--accent-cyan) 5px, transparent 5px) top left / 10px 10px no-repeat,
    linear-gradient(-45deg, transparent 3.8px, var(--accent-cyan) 3.8px, var(--accent-cyan) 5px, transparent 5px) bottom right / 10px 10px no-repeat;
}

/* Wide variant */
.holo-btn-wide {
  width: 100%;
}


/* ══════════════════════════════════════════
   1.4 — HOLO CONTENT BOX
   Nested container inside holo-window
   ══════════════════════════════════════════ */

.holo-content-box {
  background: rgba(2, 4, 10, 0.7);
  border: 1px solid rgba(0, 212, 255, 0.08);
  border-radius: 1px;
  padding: 14px;
  margin: 0.5rem 0;
  position: relative;
  box-shadow: inset 0 0 20px rgba(0, 0, 0, 0.9);
  transition: border-color 0.3s ease, box-shadow 0.3s;
}

.holo-content-box:hover {
  border-color: rgba(0, 212, 255, 0.2);
  box-shadow: inset 0 0 15px rgba(0, 0, 0, 0.8), 0 0 8px rgba(0, 212, 255, 0.05);
}

/* Content box with label */
.holo-content-box-label {
  position: absolute;
  top: -9px;
  left: 12px;
  padding: 0 6px;
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--accent-cyan);
  background: var(--holo-bg-window);
  z-index: 1;
}

/* Code/pre inside content box */
.holo-content-box pre,
.holo-content-box code {
  background: rgba(0, 212, 255, 0.04);
  border: none;
}


/* ══════════════════════════════════════════
   1.5 — HOLO LIST (Diamond Markers)
   Custom list with diamond bullet points
   ══════════════════════════════════════════ */

.holo-list {
  list-style: none;
  padding-left: 0;
  margin: 0;
}

.holo-list li {
  position: relative;
  padding-left: 20px;
  margin-bottom: 8px;
  font-size: 0.88rem;
  color: var(--text-primary);
  line-height: 1.6;
}

.holo-list li::before {
  content: '◆';
  position: absolute;
  left: 0;
  top: 1px;
  font-size: 7px;
  color: var(--accent-cyan);
  text-shadow: 0 0 6px rgba(0, 212, 255, 0.5);
}

.holo-list li:hover::before {
  text-shadow: 0 0 10px rgba(0, 212, 255, 0.8),
    0 0 20px rgba(0, 212, 255, 0.3);
}

/* Compact variant */
.holo-list.holo-list-compact li {
  margin-bottom: 4px;
  font-size: 0.82rem;
}

/* Muted variant (secondary color markers) */
.holo-list.holo-list-muted li::before {
  color: var(--text-muted);
  text-shadow: none;
}



/* Form inputs inside holo-theme */
body.holo-theme .form-control,
body.holo-theme .form-select {
  border-radius: 1px;
  border: 1px solid rgba(0, 212, 255, 0.1);
  background: rgba(4, 6, 12, 0.6);
  color: var(--text-primary);
  box-shadow: inset 0 0 15px rgba(0, 0, 0, 0.9);
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

body.holo-theme .form-control:focus,
body.holo-theme .form-select:focus {
  border-color: var(--accent-cyan);
  background: rgba(6, 10, 18, 0.8);
  box-shadow: inset 0 0 10px rgba(0, 0, 0, 0.8), 0 0 10px rgba(0, 212, 255, 0.15);
}

body.holo-theme .form-control::placeholder {
  color: rgba(0, 212, 255, 0.3);
}

/* Modals inside holo-theme */
body.holo-theme .modal-content {
  background: var(--holo-bg-window);
  border: 1px solid var(--holo-border-color);
  border-radius: 2px;
  box-shadow: 0 0 40px rgba(0, 212, 255, 0.1);
}

body.holo-theme .modal-header {
  border-bottom: 1px solid rgba(0, 212, 255, 0.15);
}

body.holo-theme .modal-footer {
  border-top: 1px solid rgba(0, 212, 255, 0.15);
}

body.holo-theme .modal-title {
  text-transform: uppercase;
  letter-spacing: 1.5px;
  font-size: 0.85rem;
}


/* ═══════════════════════════════════════════════════════════════
   PHASE 2 — ADVANCED HOLO COMPONENTS
   ═══════════════════════════════════════════════════════════════ */


/* ══════════════════════════════════════════
   2.1 — HOLO CIRCULAR PROGRESS GAUGE
   SVG-based circular progress indicator
   ══════════════════════════════════════════ */

.holo-gauge {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100px;
  height: 100px;
}

.holo-gauge svg {
  width: 100%;
  height: 100%;
  transform: rotate(-90deg);
}

.holo-gauge-track {
  fill: none;
  stroke: rgba(0, 212, 255, 0.1);
  stroke-width: 4;
}

.holo-gauge-fill {
  fill: none;
  stroke: var(--accent-cyan);
  stroke-width: 4;
  stroke-linecap: round;
  stroke-dasharray: 283;
  stroke-dashoffset: 283;
  transition: stroke-dashoffset 1s ease-in-out;
  filter: drop-shadow(0 0 6px rgba(0, 212, 255, 0.5));
}

/* Value text in center */
.holo-gauge-value {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  line-height: 1.2;
}

.holo-gauge-value .gauge-pct {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--accent-cyan);
  text-shadow: 0 0 10px rgba(0, 212, 255, 0.4);
}

.holo-gauge-value .gauge-label {
  font-size: 0.6rem;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--text-muted);
  margin-top: 2px;
}

/* Size variants */
.holo-gauge-sm {
  width: 64px;
  height: 64px;
}

.holo-gauge-sm .gauge-pct {
  font-size: 0.85rem;
}

.holo-gauge-sm .gauge-label {
  font-size: 0.5rem;
}

.holo-gauge-lg {
  width: 140px;
  height: 140px;
}

.holo-gauge-lg .gauge-pct {
  font-size: 1.6rem;
}

/* Pulse animation for active gauges */
.holo-gauge.holo-gauge-active .holo-gauge-fill {
  animation: holo-gauge-pulse 2s ease-in-out infinite;
}

@keyframes holo-gauge-pulse {

  0%,
  100% {
    filter: drop-shadow(0 0 6px rgba(0, 212, 255, 0.5));
  }

  50% {
    filter: drop-shadow(0 0 14px rgba(0, 212, 255, 0.8));
  }
}


/* ══════════════════════════════════════════
   2.4 — HOLO LOADING BAR + SHIMMER
   Animated loading indicator with sweep effect
   ══════════════════════════════════════════ */

.holo-loading-bar {
  position: relative;
  height: 4px;
  background: rgba(0, 212, 255, 0.1);
  border-radius: 2px;
  overflow: hidden;
  margin: 1rem 0;
}

.holo-loading-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--accent-cyan), rgba(0, 212, 255, 0.6));
  border-radius: 2px;
  transition: width 0.5s ease;
  box-shadow: 0 0 8px rgba(0, 212, 255, 0.4);
}

/* Shimmer sweep effect */
.holo-loading-bar::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg,
      transparent,
      rgba(0, 212, 255, 0.3),
      rgba(255, 255, 255, 0.1),
      transparent);
  animation: holo-shimmer 2s ease-in-out infinite;
}

@keyframes holo-shimmer {
  0% {
    left: -100%;
  }

  100% {
    left: 100%;
  }
}

/* Indeterminate (continuous) variant */
.holo-loading-bar-indeterminate .holo-loading-bar-fill {
  width: 30% !important;
  animation: holo-loading-slide 1.5s ease-in-out infinite;
}

@keyframes holo-loading-slide {
  0% {
    transform: translateX(-150%);
  }

  100% {
    transform: translateX(450%);
  }
}

/* Loading text label */
.holo-loading-text {
  text-align: center;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--accent-cyan);
  margin-top: 8px;
  text-shadow: 0 0 6px rgba(0, 212, 255, 0.3);
  animation: holo-text-blink 1.5s ease-in-out infinite;
}

@keyframes holo-text-blink {

  0%,
  100% {
    opacity: 1;
  }

  50% {
    opacity: 0.5;
  }
}

/* Thick variant */
.holo-loading-bar-thick {
  height: 6px;
}

/* Full-width loading (for top of page) */
.holo-loading-top {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 9999;
  height: 3px;
  margin: 0;
  border-radius: 0;
}


/* ══════════════════════════════════════════
   2.5 — CRT SCANLINE OVERLAY
   Subtle retro-futuristic scanline effect
   ══════════════════════════════════════════ */

.holo-scanline {
  position: relative;
}

.holo-scanline::after {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: repeating-linear-gradient(0deg,
      transparent,
      transparent 2px,
      rgba(0, 0, 0, var(--holo-scan-opacity)) 2px,
      rgba(0, 0, 0, var(--holo-scan-opacity)) 4px);
  pointer-events: none;
  z-index: 9998;
}

/* Stronger scanline variant */
.holo-scanline-strong::after {
  --holo-scan-opacity: 0.06;
}

/* Lighter scanline variant */
.holo-scanline-light::after {
  --holo-scan-opacity: 0.02;
}

/* Animated flicker (optional, subtle) */
.holo-scanline-flicker::after {
  animation: holo-flicker 8s linear infinite;
}

@keyframes holo-flicker {

  0%,
  95%,
  100% {
    opacity: 1;
  }

  96% {
    opacity: 0.85;
  }

  97% {
    opacity: 1;
  }

  98% {
    opacity: 0.9;
  }
}


/* ══════════════════════════════════════════
   2.6 — HOLO FORM INPUTS (Enhanced Tech Style)
   Holographic-styled form elements
   ══════════════════════════════════════════ */

.holo-input {
  background: rgba(6, 10, 20, 0.7) !important;
  border: 1px solid rgba(0, 212, 255, 0.15) !important;
  border-radius: 2px !important;
  color: var(--text-primary) !important;
  padding: 10px 14px;
  font-size: 0.88rem;
  transition: var(--transition-fast);
  position: relative;
}

.holo-input:focus {
  border-color: var(--accent-cyan) !important;
  box-shadow: 0 0 15px rgba(0, 212, 255, 0.15),
    inset 0 0 8px rgba(0, 212, 255, 0.03) !important;
  outline: none;
}

.holo-input::placeholder {
  color: rgba(226, 232, 240, 0.35) !important;
  font-style: italic;
}

/* Holo floating label group */
.holo-form-group {
  position: relative;
  margin-bottom: 1.25rem;
}

.holo-form-label {
  display: block;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: rgba(0, 212, 255, 0.7);
  margin-bottom: 6px;
  font-weight: 600;
}

/* ══════════════════════════════════════════
   HOLO ANIMATIONS — Shared keyframes
   ══════════════════════════════════════════ */

/* Fade in from bottom */
@keyframes holo-fade-in {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.holo-fade-in {
  animation: holo-fade-in 0.4s ease-out forwards;
}
/* ═══════════════════════════════════════════════════
   PREMIUM HOLO GUI THEME (Sci-Fi Borders & Components)
   ═══════════════════════════════════════════════════ */

/* Re-style default cards to have the sci-fi border matching the image
   LAYER ORDER (stacking context via isolation:isolate):
   1. Card background  = hash-lines at corners (BOTTOM — painted first)
   2. ::before (z:-2)   = solid cyan chamfer shape (border color)
   3. ::after  (z:-1)   = dark fill, chamfer inset 2px (inner area)
   4. Content           = text/children (TOP)
   Result: hash-lines visible ONLY in the corner triangles OUTSIDE the chamfer border */
.card,
.holo-container,
.holo-window {
  position: relative !important;
  /* Hash-lines sit on the card background = bottom-most layer
     They are visible ONLY where ::before and ::after don't cover (corner triangles) */
  background:
    /* Bottom-right: 2 lines */
    linear-gradient(-45deg, transparent 4px, rgba(0, 212, 255, 0.55) 4px, rgba(0, 212, 255, 0.55) 6px, transparent 6px) bottom right / 90px 90px no-repeat,
    linear-gradient(-45deg, transparent 10px, rgba(0, 212, 255, 0.4) 10px, rgba(0, 212, 255, 0.4) 12px, transparent 12px) bottom right / 90px 90px no-repeat,
    /* Top-left: 2 lines */
    linear-gradient(135deg, transparent 4px, rgba(0, 212, 255, 0.55) 4px, rgba(0, 212, 255, 0.55) 6px, transparent 6px) top left / 90px 90px no-repeat,
    linear-gradient(135deg, transparent 10px, rgba(0, 212, 255, 0.4) 10px, rgba(0, 212, 255, 0.4) 12px, transparent 12px) top left / 90px 90px no-repeat,
    transparent !important;
  background-color: transparent !important;
  border: none !important;
  padding: 1.5rem !important;
  margin-bottom: 1.5rem !important;
  color: var(--text-primary) !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  overflow: visible !important;
  isolation: isolate;
  z-index: 0 !important;
  backdrop-filter: none !important;
  /* NO clip-path here — hash-lines must remain visible in the corner triangles */
}

/* Cyan glowing border — chamfered top-left & bottom-right
   This layer sits ABOVE card background, covers the chamfer shape area */
/* Seamless Cyan Border — SVG border-image 9-slice
   Gives a flawless, mathematically uniform stroke without glowing logic */
.card::before,
.holo-container::before,
.holo-window::before {
  content: "";
  position: absolute;
  inset: 0;
  border-style: solid;
  border-width: 30px;
  border-image-source: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100'%3E%3Cpath d='M 1 30 L 30 1 L 99 1 L 99 70 L 70 99 L 1 99 Z' fill='none' stroke='%2300d4ff' stroke-width='2' /%3E%3C/svg%3E");
  border-image-slice: 30;
  border-image-width: 30px;
  border-image-outset: 0;
  z-index: -1;
  pointer-events: none;
}

/* Dark inner fill — tightly inset to sit behind the SVG border
   Covers card background and preserves inset box-shadow */
.card::after,
.holo-container::after,
.holo-window::after {
  content: "";
  position: absolute;
  inset: 1px;
  clip-path: polygon(0 29px, 29px 0,
      100% 0,
      100% calc(100% - 29px), calc(100% - 29px) 100%,
      0 100%);
  background: #080e1c !important;
  box-shadow: inset 0 0 40px rgba(0, 212, 255, 0.06);
  z-index: -2;
  pointer-events: none;
}

/* Window Title styled like the image */
.card-header,
.holo-title {
  position: relative;
  background: rgba(0, 212, 255, 0.06) !important;
  border-bottom: 1px solid rgba(0, 212, 255, 0.2) !important;
  text-align: center;
  padding: 0.75rem 1.5rem !important;
  margin: -1.5rem -1.5rem 1.5rem -1.5rem !important;
  border-radius: 0 !important;
  color: #fff !important;
  font-weight: bold;
  letter-spacing: 2px;
  text-transform: uppercase;
}

.card-header::before,
.holo-title::before {
  display: none !important;
}

.card-header::after {
  display: none !important;
}

/* Reset border-radius on inner card elements */
.card .card-body,
.card .card-footer {
  border-radius: 0 !important;
  background: transparent !important;
}

/* Inner Text Containers from the image */
.list-group-item,
.holo-inner-box {
  background: rgba(0, 0, 0, 0.4) !important;
  border: 1px solid rgba(0, 212, 255, 0.2) !important;
  padding: 1rem !important;
  margin-bottom: 1rem !important;
  border-radius: 4px !important;
  box-shadow: inset 0 0 10px rgba(0, 0, 0, 0.5) !important;
  color: var(--text-secondary) !important;
}

.list-group-item h5,
.holo-inner-box h5,
.list-group-item h6,
.holo-inner-box h6 {
  color: var(--text-primary) !important;
  margin-bottom: 0.5rem;
}

/* Sci-Fi Button replacing primary button */
.btn-primary,
.holo-btn {
  display: inline-block;
  background: rgba(0, 212, 255, 0.1) !important;
  border: 1px solid rgba(0, 212, 255, 0.6) !important;
  color: #fff !important;
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: 0.5rem 2rem !important;
  clip-path: polygon(10px 0, 100% 0,
      100% calc(100% - 10px), calc(100% - 10px) 100%,
      0 100%, 0 10px) !important;
  transition: all 0.3s ease;
  box-shadow: 0 0 10px rgba(0, 212, 255, 0.2) inset !important;
  cursor: pointer;
  text-align: center;
  border-radius: 0 !important;
}

.btn-primary:hover,
.holo-btn:hover {
  background: rgba(0, 212, 255, 0.3) !important;
  border-color: #00d4ff !important;
  box-shadow: 0 0 20px rgba(0, 212, 255, 0.5) inset, 0 0 10px rgba(0, 212, 255, 0.4) !important;
}

/* Sci-fi Checkbox/Radio */
.form-check-input,
.holo-radio {
  appearance: none !important;
  background-color: transparent !important;
  margin: 0;
  width: 1.2rem;
  height: 1.2rem;
  border: 1px solid rgba(0, 212, 255, 0.5) !important;
  border-radius: 50% !important;
  position: relative;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  margin-right: 0.5rem;
  vertical-align: middle;
  cursor: pointer;
}

.form-check-input::before,
.holo-radio::before {
  content: "";
  position: absolute;
  width: 160%;
  height: 160%;
  border: 1px dashed rgba(0, 212, 255, 0.4);
  border-radius: 50%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
  animation: spinSlow 10s linear infinite;
}

.form-check-input:checked::after,
.holo-radio:checked::after {
  content: "";
  width: 0.5rem;
  height: 0.5rem;
  background-color: #00d4ff;
  border-radius: 50%;
  box-shadow: 0 0 8px #00d4ff;
}

.form-check-label,
.holo-radio-wrapper {
  color: var(--text-secondary) !important;
  cursor: pointer;
}

.form-check-label:hover,
.holo-radio-wrapper:hover {
  color: var(--text-primary) !important;
}

/* 19. KPI CARDS */
.card-kpi {
  background: rgba(0, 10, 30, 0.6);
  border: 1px solid rgba(0, 212, 255, 0.12);
  border-radius: 8px;
  clip-path: polygon(8px 0, 100% 0, 100% calc(100% - 8px), calc(100% - 8px) 100%, 0 100%, 0 8px);
}

/* ═══════════════════════════════════════════════════
   20. UTILITY CLASSES (Task 4 — inline style cleanup)
   ═══════════════════════════════════════════════════ */

/* Font sizes */
.fs-xxs  { font-size: 0.62rem !important; }
.fs-xs   { font-size: 0.75rem !important; }
.fs-sm   { font-size: 0.8rem  !important; }
.fs-md   { font-size: 0.82rem !important; }
.fs-base { font-size: 0.85rem !important; }
.fs-icon { font-size: 0.9rem  !important; }

/* Holo accent text colors */
.text-holo-cyan  { color: #00d4ff !important; }
.text-holo-green { color: #10b981 !important; }
.text-holo-amber { color: #f59e0b !important; }
.text-holo-red   { color: #ef4444 !important; }

/* KPI component utilities */
.kpi-label    { font-size: 0.62rem; text-transform: uppercase; }
.kpi-value    { font-size: 1.2rem;  font-weight: 700; }
.kpi-value-lg { font-size: 1.4rem;  font-weight: 700; }
.p-kpi        { padding: 0.6rem; }
.p-kpi-lg     { padding: 0.75rem; }

/* Loading bar centering */
.loading-centered    { max-width: 200px; margin: 1rem auto; }
.loading-centered-lg { max-width: 240px; margin: 2rem auto; }



/* ===================== CLONE PRODUCT CARDS ===================== */
.holo-product-card {
  background: rgba(10, 20, 40, 0.6);
  border: 1px solid var(--border-subtle);
  border-radius: 12px;
  padding: 1rem;
  height: 100%;
  display: flex;
  flex-direction: column;
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}

.holo-product-card:hover {
  border-color: var(--accent-cyan);
  box-shadow: 0 0 15px rgba(0, 212, 255, 0.2);
  transform: translateY(-2px);
}

.holo-product-card.cs-row-out {
  opacity: 0.65;
  filter: grayscale(80%);
}

.hpc-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 0.8rem;
  gap: 10px;
}

.hpc-title {
  color: var(--accent-cyan);
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.3;
}

.hpc-badges {
  display: flex;
  align-items: center;
  gap: 5px;
  flex-shrink: 0;
}

.hpc-desc {
  font-size: 0.8rem;
  color: var(--text-muted);
  margin-bottom: 1rem;
  flex-grow: 1;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.hpc-stats {
  display: flex;
  justify-content: space-between;
  background: rgba(0,0,0,0.3);
  border-radius: 8px;
  padding: 0.6rem;
  border: 1px solid rgba(255,255,255,0.05);
}

.hpc-stat-label {
  font-size: 0.65rem;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 2px;
}

.hpc-stat-val {
  font-size: 0.85rem;
  font-weight: 600;
}

.hpc-price-val {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--accent-green);
  text-shadow: 0 0 8px rgba(16, 185, 129, 0.4);
}

.hpc-price-val small {
  font-size: 0.8rem;
  font-weight: normal;
  color: var(--text-muted);
  text-shadow: none;
}

/* ===================== CLONE CATEGORY SELECTOR ===================== */
.holo-service-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.holo-service-card {
  background: rgba(10, 20, 35, 0.6);
  border: 1px solid var(--border-subtle);
  border-radius: 10px;
  padding: 1rem;
  cursor: pointer;
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}

.holo-service-card:hover {
  background: rgba(0, 212, 255, 0.05);
  border-color: var(--accent-cyan);
  box-shadow: 0 4px 15px rgba(0, 212, 255, 0.15);
  transform: translateY(-2px);
}

.holo-service-card.active {
  background: rgba(0, 212, 255, 0.15);
  border-color: var(--accent-cyan);
  box-shadow: 0 0 15px rgba(0, 212, 255, 0.3) inset, 0 0 10px rgba(0, 212, 255, 0.2);
}

.holo-service-card::after {
  content: "";
  position: absolute;
  top: 0; left: 0; width: 3px; height: 100%;
  background: var(--accent-cyan);
  opacity: 0;
  transition: opacity 0.3s ease;
  box-shadow: 0 0 8px var(--accent-cyan);
}

.holo-service-card.active::after {
  opacity: 1;
}

.holo-service-card-top {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 0.75rem;
}

.holo-service-card-name {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.3;
}

.holo-service-card-stock {
  font-size: 0.75rem;
  color: var(--text-muted);
  text-align: right;
  margin-bottom: 5px;
}

.holo-stock-gauge {
  background: rgba(255, 255, 255, 0.1);
  height: 4px;
  border-radius: 2px;
  overflow: hidden;
}

.holo-stock-gauge-fill {
  background: var(--accent-green);
  height: 100%;
  border-radius: 2px;
  box-shadow: 0 0 8px var(--accent-green);
  transition: width 0.5s ease;
}

.holo-stock-gauge-fill.low {
  background: var(--accent-amber);
  box-shadow: 0 0 8px var(--accent-amber);
}

.holo-stock-gauge-fill.empty {
  background: var(--accent-red);
  box-shadow: 0 0 8px var(--accent-red);
}

/* =====================================================================
   GLOBAL SEAMLESS CHAMFER BORDERS (Cách 1)
   Khắc phục toàn diện lỗi đứt viền do clip-path chém cạnh
   ===================================================================== */

/* 1. Nút bấm (10px Chamfer, Cyan) */
.btn-primary, .holo-btn {
  border-style: solid !important;
  border-width: 0 !important;
  border-image-source: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M 1 10 L 10 1 L 39 1 L 39 30 L 30 39 L 1 39 Z' fill='none' stroke='%2300d4ff' stroke-width='2' /%3E%3C/svg%3E") !important;
  border-image-slice: 10 !important;
  border-image-width: 10px !important;
  border-image-outset: 0 !important;
}

/* 2. Hộp KPI (8px Chamfer, Cyan) */
.card-kpi {
  border-style: solid !important;
  border-width: 0 !important;
  border-image-source: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32'%3E%3Cpath d='M 1 8 L 8 1 L 31 1 L 31 24 L 24 31 L 1 31 Z' fill='none' stroke='%2300d4ff' stroke-width='2' stroke-opacity='0.4' /%3E%3C/svg%3E") !important;
  border-image-slice: 8 !important;
  border-image-width: 8px !important;
  border-image-outset: 0 !important;
}

/* 3. Server Info & Notes (10px Chamfer, Cyan) */
.info-badge, .server-note {
  border-style: solid !important;
  border-width: 0 !important;
  border-image-source: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M 1 10 L 10 1 L 39 1 L 39 30 L 30 39 L 1 39 Z' fill='none' stroke='%2300d4ff' stroke-width='2' stroke-opacity='0.4' /%3E%3C/svg%3E") !important;
  border-image-slice: 10 !important;
  border-image-width: 10px !important;
  border-image-outset: 0 !important;
}

/* 4. Total Payment (10px Chamfer, Warning Amber) */
.total-payment {
  border-style: solid !important;
  border-width: 0 !important;
  border-image-source: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M 1 10 L 10 1 L 39 1 L 39 30 L 30 39 L 1 39 Z' fill='none' stroke='%23f59e0b' stroke-width='3' stroke-opacity='0.6' /%3E%3C/svg%3E") !important;
  border-image-slice: 10 !important;
  border-image-width: 10px !important;
  border-image-outset: 0 !important;
}

/* 5. Phù hiệu Badges (8px Chamfer) */
.badge, .badge.bg-primary, .bg-primary {
  border-style: solid !important;
  border-width: 0 !important;
  border-image-source: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32'%3E%3Cpath d='M 1 8 L 8 1 L 31 1 L 31 24 L 24 31 L 1 31 Z' fill='none' stroke='%2300d4ff' stroke-width='2' stroke-opacity='0.8' /%3E%3C/svg%3E") !important;
  border-image-slice: 8 !important;
  border-image-width: 8px !important;
  border-image-outset: 0 !important;
}

.badge.bg-success, .bg-success:not(body) {
  border-style: solid !important;
  border-width: 0 !important;
  border-image-source: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32'%3E%3Cpath d='M 1 8 L 8 1 L 31 1 L 31 24 L 24 31 L 1 31 Z' fill='none' stroke='%2310b981' stroke-width='2' stroke-opacity='0.8' /%3E%3C/svg%3E") !important;
  border-image-slice: 8 !important;
  border-image-width: 8px !important;
  border-image-outset: 0 !important;
}

.badge.bg-danger, .bg-danger {
  border-style: solid !important;
  border-width: 0 !important;
  border-image-source: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32'%3E%3Cpath d='M 1 8 L 8 1 L 31 1 L 31 24 L 24 31 L 1 31 Z' fill='none' stroke='%23ef4444' stroke-width='2' stroke-opacity='0.8' /%3E%3C/svg%3E") !important;
  border-image-slice: 8 !important;
  border-image-width: 8px !important;
  border-image-outset: 0 !important;
}

.badge.bg-warning, .bg-warning {
  border-style: solid !important;
  border-width: 0 !important;
  border-image-source: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32'%3E%3Cpath d='M 1 8 L 8 1 L 31 1 L 31 24 L 24 31 L 1 31 Z' fill='none' stroke='%23f59e0b' stroke-width='2' stroke-opacity='0.8' /%3E%3C/svg%3E") !important;
  border-image-slice: 8 !important;
  border-image-width: 8px !important;
  border-image-outset: 0 !important;
}

.badge.bg-secondary, .bg-secondary, .badge.bg-dark, .bg-dark {
  border-style: solid !important;
  border-width: 0 !important;
  border-image-source: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32'%3E%3Cpath d='M 1 8 L 8 1 L 31 1 L 31 24 L 24 31 L 1 31 Z' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-opacity='0.8' /%3E%3C/svg%3E") !important;
  border-image-slice: 8 !important;
  border-image-width: 8px !important;
  border-image-outset: 0 !important;
}

/* 6. Global Button Color Variants SVG Overrides */
.btn-outline-primary, .btn-info, .btn-info:active, .btn-outline-info {
  border-style: solid !important;
  border-width: 0 !important;
  border-image-source: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M 1 10 L 10 1 L 39 1 L 39 30 L 30 39 L 1 39 Z' fill='none' stroke='%2300d4ff' stroke-width='2' /%3E%3C/svg%3E") !important;
  border-image-slice: 10 !important;
  border-image-width: 10px !important;
  border-image-outset: 0 !important;
}

.btn-success, .btn-success:active, .btn-outline-success {
  border-style: solid !important;
  border-width: 0 !important;
  border-image-source: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M 1 10 L 10 1 L 39 1 L 39 30 L 30 39 L 1 39 Z' fill='none' stroke='%2310b981' stroke-width='2' /%3E%3C/svg%3E") !important;
  border-image-slice: 10 !important;
  border-image-width: 10px !important;
  border-image-outset: 0 !important;
}

.btn-danger, .btn-danger:active, .btn-outline-danger {
  border-style: solid !important;
  border-width: 0 !important;
  border-image-source: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M 1 10 L 10 1 L 39 1 L 39 30 L 30 39 L 1 39 Z' fill='none' stroke='%23ef4444' stroke-width='2' /%3E%3C/svg%3E") !important;
  border-image-slice: 10 !important;
  border-image-width: 10px !important;
  border-image-outset: 0 !important;
}

.btn-warning, .btn-warning:active, .btn-outline-warning {
  border-style: solid !important;
  border-width: 0 !important;
  border-image-source: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M 1 10 L 10 1 L 39 1 L 39 30 L 30 39 L 1 39 Z' fill='none' stroke='%23f59e0b' stroke-width='2' /%3E%3C/svg%3E") !important;
  border-image-slice: 10 !important;
  border-image-width: 10px !important;
  border-image-outset: 0 !important;
}

.btn-secondary, .btn-secondary:active, .btn-outline-secondary, .btn-outline-dark {
  border-style: solid !important;
  border-width: 0 !important;
  border-image-source: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M 1 10 L 10 1 L 39 1 L 39 30 L 30 39 L 1 39 Z' fill='none' stroke='%2394a3b8' stroke-width='2' /%3E%3C/svg%3E") !important;
  border-image-slice: 10 !important;
  border-image-width: 10px !important;
  border-image-outset: 0 !important;
}

/* 7. Order Status (6px Chamfer, Cyan) */
.order-status {
  border-style: solid !important;
  border-width: 0 !important;
  border-image-source: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24'%3E%3Cpath d='M 1 6 L 6 1 L 23 1 L 23 18 L 18 23 L 1 23 Z' fill='none' stroke='%2300d4ff' stroke-width='2' /%3E%3C/svg%3E") !important;
  border-image-slice: 6 !important;
  border-image-width: 6px !important;
  border-image-outset: 0 !important;
}

/* 8. Alerts (15px Chamfer) */
.alert, .alert-info, .alert-primary {
  border-style: solid !important;
  border-width: 0 !important;
  border-image-source: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='50' height='50'%3E%3Cpath d='M 1 15 L 15 1 L 49 1 L 49 35 L 35 49 L 1 49 Z' fill='none' stroke='%2300d4ff' stroke-width='2' /%3E%3C/svg%3E") !important;
  border-image-slice: 15 !important;
  border-image-width: 15px !important;
  border-image-outset: 0 !important;
}

.alert-success {
  border-style: solid !important;
  border-width: 0 !important;
  border-image-source: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='50' height='50'%3E%3Cpath d='M 1 15 L 15 1 L 49 1 L 49 35 L 35 49 L 1 49 Z' fill='none' stroke='%2310b981' stroke-width='2' /%3E%3C/svg%3E") !important;
  border-image-slice: 15 !important;
  border-image-width: 15px !important;
  border-image-outset: 0 !important;
}

.alert-danger {
  border-style: solid !important;
  border-width: 0 !important;
  border-image-source: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='50' height='50'%3E%3Cpath d='M 1 15 L 15 1 L 49 1 L 49 35 L 35 49 L 1 49 Z' fill='none' stroke='%23ef4444' stroke-width='2' /%3E%3C/svg%3E") !important;
  border-image-slice: 15 !important;
  border-image-width: 15px !important;
  border-image-outset: 0 !important;
}

.alert-warning {
  border-style: solid !important;
  border-width: 0 !important;
  border-image-source: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='50' height='50'%3E%3Cpath d='M 1 15 L 15 1 L 49 1 L 49 35 L 35 49 L 1 49 Z' fill='none' stroke='%23f59e0b' stroke-width='2' /%3E%3C/svg%3E") !important;
  border-image-slice: 15 !important;
  border-image-width: 15px !important;
  border-image-outset: 0 !important;
}
