/* 
 * dichvuicloud.com - PREMIUM UI OVERRIDE
 * Add modern glassmorphism, soft shadows, rounded corners, and pro typography.
 */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;700&display=swap');

:root {
    --premium-radius: 16px;
    --premium-shadow: 0 8px 30px rgba(0, 0, 0, 0.04);
    --premium-shadow-hover: 0 12px 40px rgba(0, 0, 0, 0.08);
    --premium-border: rgba(0, 0, 0, 0.06);
    --premium-glass: rgba(255, 255, 255, 0.85);
}

body,
button,
input,
textarea,
select {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif !important;
}

code,
pre,
.mono {
    font-family: 'JetBrains Mono', monospace !important;
}

/* CARDS */
.card,
.cyber-card {
    background: #ffffff !important;
    border: 1px solid var(--premium-border) !important;
    border-radius: var(--premium-radius) !important;
    box-shadow: var(--premium-shadow) !important;
    transition: all 0.3s ease !important;
}

.card:hover,
.cyber-card:hover {
    transform: translateY(-3px) !important;
    box-shadow: var(--premium-shadow-hover) !important;
}

/* BUTTONS */
.btn {
    border-radius: 12px !important;
    font-weight: 600 !important;
    padding: 10px 20px !important;
    transition: all 0.2s ease !important;
}

.btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.1) !important;
}

.btn-primary {
    background: linear-gradient(135deg, #007aff, #005ce6) !important;
    border: none !important;
}

.btn-cyber {
    background: linear-gradient(135deg, #4facfe, #00f2fe) !important;
    color: #fff !important;
    border: none !important;
    box-shadow: 0 4px 15px rgba(79, 172, 254, 0.3) !important;
}

/* FORMS */
.form-control,
input,
textarea,
select {
    border-radius: 12px !important;
    border: 1px solid var(--premium-border) !important;
    background: #f8f9fa !important;
    padding: 12px 16px !important;
    transition: all 0.2s ease !important;
    font-size: 14px !important;
}

.form-control:focus,
input:focus,
textarea:focus,
select:focus {
    background: #ffffff !important;
    border-color: #007aff !important;
    box-shadow: 0 0 0 4px rgba(0, 122, 255, 0.1) !important;
    outline: none !important;
}

/* ─── AUTH PAGE EXCLUSIONS ─── */
/* Do NOT apply premium light-theme to login/register/OTP dark pages */
.auth-page .form-control,
.auth-page input,
.auth-page textarea,
.auth-page select,
.split-auth-form .form-control,
.split-auth-form input,
.split-auth-form textarea,
.split-auth-form select {
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    color: #ffffff !important;
}

.auth-page .form-control:focus,
.auth-page input:focus,
.split-auth-form .form-control:focus,
.split-auth-form input:focus {
    background: rgba(255, 255, 255, 0.1) !important;
    border-color: #007aff !important;
    box-shadow: 0 0 0 4px rgba(0, 122, 255, 0.25) !important;
    color: #ffffff !important;
}

.auth-page .form-control::placeholder,
.split-auth-form .form-control::placeholder,
.auth-page input::placeholder,
.split-auth-form input::placeholder {
    color: rgba(255, 255, 255, 0.4) !important;
}

.auth-page .glass-card,
.split-auth-form .glass-card,
.split-auth-form .auth-inner {
    background: rgba(255, 255, 255, 0.04) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
}

.auth-page label,
.split-auth-form label {
    color: rgba(255, 255, 255, 0.85) !important;
}

/* TABLES (Admin & User Dashboards) */
table {
    border-collapse: separate !important;
    border-spacing: 0 8px !important;
    width: 100% !important;
}

thead th {
    background: transparent !important;
    color: #86868b !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    border: none !important;
    padding: 0 15px 10px 15px !important;
}

tbody tr {
    background: #ffffff !important;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.02) !important;
    transition: transform 0.2s ease, box-shadow 0.2s ease !important;
}

tbody tr:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05) !important;
}

tbody td {
    padding: 16px 15px !important;
    border: none !important;
    vertical-align: middle !important;
    color: #1d1d1f !important;
}

tbody td:first-child {
    border-top-left-radius: 12px !important;
    border-bottom-left-radius: 12px !important;
}

tbody td:last-child {
    border-top-right-radius: 12px !important;
    border-bottom-right-radius: 12px !important;
}

/* BADGES */
.badge {
    padding: 6px 10px !important;
    border-radius: 8px !important;
    font-weight: 600 !important;
    font-size: 11px !important;
    letter-spacing: 0.2px !important;
}

.badge-success {
    background: rgba(52, 199, 89, 0.1) !important;
    color: #34c759 !important;
    border: 1px solid rgba(52, 199, 89, 0.2) !important;
}

.badge-warning {
    background: rgba(255, 149, 0, 0.1) !important;
    color: #ff9500 !important;
    border: 1px solid rgba(255, 149, 0, 0.2) !important;
}

.badge-danger {
    background: rgba(255, 59, 48, 0.1) !important;
    color: #ff3b30 !important;
    border: 1px solid rgba(255, 59, 48, 0.2) !important;
}

.badge-info {
    background: rgba(0, 122, 255, 0.1) !important;
    color: #007aff !important;
    border: 1px solid rgba(0, 122, 255, 0.2) !important;
}

/* NAVBAR GLASSMORPHISM */
.header {
    background: var(--premium-glass) !important;
    backdrop-filter: blur(20px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.3) !important;
}

/* SIDEBAR REFINEMENTS — only user sidebar, NOT admin */
.dashboard-layout>.sidebar:not([style*="background"]) {
    background: #ffffff !important;
    border-right: 1px solid var(--premium-border) !important;
}

.sidebar-link,
.menu-item {
    border-radius: 10px !important;
    margin-bottom: 4px !important;
    transition: all 0.2s ease !important;
}

.sidebar-link:hover,
.menu-item:hover {
    background: #f5f5f7 !important;
    transform: translateX(4px) !important;
}

.sidebar-link.active,
.menu-item.active {
    background: rgba(0, 122, 255, 0.1) !important;
    color: #007aff !important;
    font-weight: 600 !important;
}

/* SWEET ALERTS OVERRIDE */
.swal2-popup {
    border-radius: 20px !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.1) !important;
}

.swal2-confirm {
    border-radius: 12px !important;
}

/* ═══════════════════════════════════════════════
   DARK MODE
   ═══════════════════════════════════════════════ */
[data-theme="dark"] {
    --dark-bg: #0f0f1a;
    --dark-bg-2: #1a1a2e;
    --dark-bg-3: #252540;
    --card-bg: rgba(30, 30, 50, 0.95);
    --card-border: rgba(255, 255, 255, 0.06);
    --text: #e8e8ed;
    --text-muted: #8e8e93;
    --text-light: #636366;
    --premium-border: rgba(255, 255, 255, 0.06);
    --premium-glass: rgba(30, 30, 50, 0.85);
    --shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    --shadow-soft: 0 2px 10px rgba(0, 0, 0, 0.2);
}

[data-theme="dark"] body {
    background: var(--dark-bg);
    color: var(--text);
}

[data-theme="dark"] .card,
[data-theme="dark"] .cyber-card,
[data-theme="dark"] .glass-card {
    background: var(--dark-bg-2) !important;
    border-color: var(--card-border) !important;
}

[data-theme="dark"] .form-control,
[data-theme="dark"] input,
[data-theme="dark"] textarea,
[data-theme="dark"] select {
    background: var(--dark-bg-3) !important;
    border-color: rgba(255, 255, 255, 0.08) !important;
    color: var(--text) !important;
}

[data-theme="dark"] .form-control:focus,
[data-theme="dark"] input:focus,
[data-theme="dark"] textarea:focus,
[data-theme="dark"] select:focus {
    background: var(--dark-bg-2) !important;
    border-color: #007aff !important;
    color: var(--text) !important;
}

[data-theme="dark"] tbody tr {
    background: var(--dark-bg-2) !important;
}

[data-theme="dark"] tbody td {
    color: var(--text) !important;
}

[data-theme="dark"] thead th {
    color: var(--text-muted) !important;
}

[data-theme="dark"] .header {
    background: rgba(15, 15, 26, 0.9) !important;
    border-bottom-color: rgba(255, 255, 255, 0.06) !important;
}

[data-theme="dark"] .stat-item,
[data-theme="dark"] .svc-card-v2,
[data-theme="dark"] .blog-card-modern {
    background: var(--dark-bg-2) !important;
    border-color: var(--card-border) !important;
}

[data-theme="dark"] .stat-item:hover,
[data-theme="dark"] .svc-card-v2:hover,
[data-theme="dark"] .blog-card-modern:hover {
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3) !important;
}

[data-theme="dark"] .dsh-stat,
[data-theme="dark"] .dsh-card,
[data-theme="dark"] .dsh-action {
    background: var(--dark-bg-2);
    border-color: var(--card-border);
}

[data-theme="dark"] .dsh-mkp-item {
    border-color: var(--card-border);
}

[data-theme="dark"] #mobileMenu {
    background: var(--dark-bg-2) !important;
}

[data-theme="dark"] #mobileMenu a {
    color: var(--text) !important;
}

[data-theme="dark"] #mobileMenu a div:first-child {
    background: rgba(255, 255, 255, 0.06) !important;
}

/* Dashboard layout sidebar for user (only in dark mode) */
[data-theme="dark"] .dashboard-layout>.sidebar:not([style*="background"]) {
    background: var(--dark-bg-2) !important;
    border-right-color: rgba(255, 255, 255, 0.06) !important;
}

/* FAQ, trust section dark mode */
[data-theme="dark"] details {
    background: var(--dark-bg-2) !important;
    border-color: var(--card-border) !important;
}

[data-theme="dark"] details summary {
    color: var(--text) !important;
}

[data-theme="dark"] details div {
    color: var(--text-muted) !important;
}

/* Support widget dark mode */
[data-theme="dark"] .sw-panel {
    background: var(--dark-bg-2) !important;
    border-color: var(--card-border) !important;
}

[data-theme="dark"] .sw-link {
    color: var(--text) !important;
}

[data-theme="dark"] .sw-link:hover {
    background: rgba(255, 255, 255, 0.05) !important;
}

[data-theme="dark"] .sw-panel-foot {
    background: var(--dark-bg-3) !important;
    color: var(--text-muted) !important;
}

/* ─── Global Text Fix ─── */
[data-theme="dark"] h1,
[data-theme="dark"] h2,
[data-theme="dark"] h3,
[data-theme="dark"] h4,
[data-theme="dark"] h5,
[data-theme="dark"] h6 {
    color: var(--text) !important;
}

[data-theme="dark"] p {
    color: var(--text-muted) !important;
}

[data-theme="dark"] label {
    color: var(--text) !important;
}

[data-theme="dark"] a {
    color: var(--text);
}

[data-theme="dark"] .page-header h1,
[data-theme="dark"] .page-header p {
    color: var(--text) !important;
}

[data-theme="dark"] .page-header p {
    color: var(--text-muted) !important;
}

[data-theme="dark"] strong,
[data-theme="dark"] b {
    color: var(--text) !important;
}

[data-theme="dark"] small {
    color: var(--text-muted) !important;
}

[data-theme="dark"] code {
    background: var(--dark-bg-3) !important;
    color: #c4b5fd !important;
}

/* ─── Main Content Area ─── */
[data-theme="dark"] .main-content {
    color: var(--text);
}

[data-theme="dark"] .main-content h1,
[data-theme="dark"] .main-content h2,
[data-theme="dark"] .main-content h3 {
    color: var(--text) !important;
}

/* ─── Stat Cards ─── */
[data-theme="dark"] .stat-card {
    border-color: var(--card-border) !important;
}

[data-theme="dark"] .stat-value {
    color: var(--text) !important;
}

[data-theme="dark"] .stat-label {
    color: var(--text-muted) !important;
}

/* ─── Service Pages ─── */
[data-theme="dark"] .svc-header,
[data-theme="dark"] .svc-content,
[data-theme="dark"] .svc-sidebar {
    background: var(--dark-bg-2) !important;
    color: var(--text) !important;
}

[data-theme="dark"] .svc-content h1,
[data-theme="dark"] .svc-content h2,
[data-theme="dark"] .svc-content h3 {
    color: var(--text) !important;
}

[data-theme="dark"] .svc-content p,
[data-theme="dark"] .svc-content li {
    color: var(--text-muted) !important;
}

/* ─── Dashboard ─── */
[data-theme="dark"] .dashboard-layout .main-content {
    background: var(--dark-bg) !important;
}

[data-theme="dark"] .glass-card {
    background: var(--dark-bg-2) !important;
    border-color: var(--card-border) !important;
    color: var(--text) !important;
}

[data-theme="dark"] .glass-card h3,
[data-theme="dark"] .glass-card h4 {
    color: var(--text) !important;
}

[data-theme="dark"] .glass-card p {
    color: var(--text-muted) !important;
}

/* ─── Marketplace ─── */
[data-theme="dark"] .mkp-card,
[data-theme="dark"] .product-card {
    background: var(--dark-bg-2) !important;
    border-color: var(--card-border) !important;
}

[data-theme="dark"] .mkp-card-title,
[data-theme="dark"] .product-title {
    color: var(--text) !important;
}

[data-theme="dark"] .mkp-card-price {
    color: #4facfe !important;
}

/* ─── Footer ─── */
[data-theme="dark"] footer,
[data-theme="dark"] .footer {
    background: var(--dark-bg-2) !important;
    border-top-color: var(--card-border) !important;
}

[data-theme="dark"] footer a {
    color: var(--text-muted) !important;
}

[data-theme="dark"] footer h3,
[data-theme="dark"] footer h4 {
    color: var(--text) !important;
}

/* ─── Alerts ─── */
[data-theme="dark"] .alert {
    border-color: var(--card-border) !important;
}

[data-theme="dark"] .alert-info {
    background: rgba(0, 122, 255, 0.08) !important;
    color: #4facfe !important;
}

[data-theme="dark"] .alert-success {
    background: rgba(52, 199, 89, 0.08) !important;
    color: #34c759 !important;
}

[data-theme="dark"] .alert-warning {
    background: rgba(255, 149, 0, 0.08) !important;
    color: #ff9500 !important;
}

[data-theme="dark"] .alert-danger {
    background: rgba(255, 59, 48, 0.08) !important;
    color: #ff6b6b !important;
}

/* ─── Sidebar links (user) ─── */
[data-theme="dark"] .sidebar-link,
[data-theme="dark"] .menu-item {
    color: var(--text) !important;
}

[data-theme="dark"] .sidebar-link:hover,
[data-theme="dark"] .menu-item:hover {
    background: rgba(255, 255, 255, 0.04) !important;
}

[data-theme="dark"] .sidebar-link.active,
[data-theme="dark"] .menu-item.active {
    background: rgba(0, 122, 255, 0.1) !important;
    color: #4facfe !important;
}

/* ─── Messages page ─── */
[data-theme="dark"] .msg-fullscreen {
    background: var(--dark-bg) !important;
}

[data-theme="dark"] .msg-sb {
    background: var(--dark-bg-2) !important;
    border-right-color: var(--card-border) !important;
}

[data-theme="dark"] .msg-sb-title {
    color: var(--text) !important;
}

[data-theme="dark"] .msg-contact-name {
    color: var(--text) !important;
}

[data-theme="dark"] .msg-chat {
    background: var(--dark-bg-3) !important;
}

[data-theme="dark"] .msg-chat-header {
    background: var(--dark-bg-2) !important;
    border-bottom-color: var(--card-border) !important;
}

[data-theme="dark"] .msg-chat-name {
    color: var(--text) !important;
}

[data-theme="dark"] .msg-input-area {
    background: var(--dark-bg-2) !important;
    border-top-color: var(--card-border) !important;
}

[data-theme="dark"] .msg-search {
    background: var(--dark-bg-3) !important;
    border-color: var(--card-border) !important;
    color: var(--text) !important;
}

[data-theme="dark"] .msg-search-results {
    background: var(--dark-bg-2) !important;
    border-color: var(--card-border) !important;
}

[data-theme="dark"] .msg-search-item:hover {
    background: var(--dark-bg-3) !important;
}

[data-theme="dark"] .msg-contact:hover {
    background: var(--dark-bg-3) !important;
}

[data-theme="dark"] .msg-contact.active {
    background: rgba(0, 122, 255, 0.1) !important;
}

[data-theme="dark"] .msg-settings-menu {
    background: var(--dark-bg-2) !important;
    border-color: var(--card-border) !important;
}

[data-theme="dark"] .msg-settings-item {
    color: var(--text) !important;
}

[data-theme="dark"] .msg-settings-item:hover {
    background: var(--dark-bg-3) !important;
}

[data-theme="dark"] .msg-empty {
    background: var(--dark-bg) !important;
}

[data-theme="dark"] .msg-empty h2 {
    color: var(--text) !important;
}

[data-theme="dark"] .chat-row.other .chat-bubble {
    background: var(--dark-bg-2) !important;
    color: var(--text) !important;
    border: 1px solid var(--card-border) !important;
}

[data-theme="dark"] .msg-input {
    background: var(--dark-bg-3) !important;
    color: var(--text) !important;
}

/* ─── Landing page sections ─── */
[data-theme="dark"] .hero-section,
[data-theme="dark"] section {
    color: var(--text) !important;
}

[data-theme="dark"] section[style*="background: #fff;"] {
    background: var(--dark-bg) !important;
}

[data-theme="dark"] .dashboard-showcase,
[data-theme="dark"] .stat-item,
[data-theme="dark"] .svc-card-v2,
[data-theme="dark"] .blog-card-modern,
[data-theme="dark"] .trust-card,
[data-theme="dark"] .why-card {
    background: var(--dark-bg-2) !important;
    border-color: var(--card-border) !important;
}

[data-theme="dark"] .dash-header {
    background: var(--dark-bg-3) !important;
    border-color: var(--card-border) !important;
}

[data-theme="dark"] .btn-secondary[style*="background: #fff;"] {
    background: var(--dark-bg-3) !important;
    color: var(--text) !important;
    border: 1px solid var(--card-border) !important;
}

/* ─── Table fix ─── */
[data-theme="dark"] table {
    color: var(--text) !important;
}

[data-theme="dark"] .table-responsive {
    color: var(--text) !important;
}

[data-theme="dark"] .data-table {
    color: var(--text) !important;
}

/* ─── Forms / Inputs / Selects ─── */
[data-theme="dark"] .form-control,
[data-theme="dark"] input[type="text"],
[data-theme="dark"] input[type="password"],
[data-theme="dark"] input[type="email"],
[data-theme="dark"] input[type="number"],
[data-theme="dark"] textarea,
[data-theme="dark"] select {
    background: var(--dark-bg-3) !important;
    border-color: var(--card-border) !important;
    color: var(--text) !important;
}

[data-theme="dark"] .form-control:focus,
[data-theme="dark"] input:focus,
[data-theme="dark"] textarea:focus,
[data-theme="dark"] select:focus {
    background: var(--dark-bg-2) !important;
    border-color: var(--primary) !important;
    color: var(--text) !important;
}

[data-theme="dark"] ::placeholder {
    color: var(--text-muted) !important;
    opacity: 1 !important;
}

[data-theme="dark"] .input-group-text {
    background: var(--dark-bg-2) !important;
    border-color: var(--card-border) !important;
    color: var(--text) !important;
}

/* ─── CHỢ BUÔN MARKETPLACE (Chợ Tốt UI) ─── */
[data-theme="dark"] {
    --ct-bg: var(--dark-bg) !important;
    --ct-white: var(--dark-bg-2) !important;
    --ct-text: var(--text) !important;
    --ct-text-muted: var(--text-muted) !important;
    --ct-border: var(--card-border) !important;
}

[data-theme="dark"] .ct-hero {
    background: linear-gradient(135deg, #b38b00 0%, #a37500 50%, #8b5000 100%) !important;
}

[data-theme="dark"] .ct-search-wrap select {
    background-color: var(--dark-bg-3) !important;
    color: var(--text) !important;
    border-color: var(--card-border) !important;
}

[data-theme="dark"] .ct-card-img {
    background: var(--dark-bg-3) !important;
}

[data-theme="dark"] .ct-empty {
    background: var(--dark-bg-2) !important;
    border-color: var(--card-border) !important;
}

[data-theme="dark"] .ct-btn-manage {
    background: var(--dark-bg-2) !important;
    border-color: var(--card-border) !important;
    color: var(--text) !important;
}

[data-theme="dark"] .ct-sort-select {
    background: var(--dark-bg-2) !important;
    border-color: var(--card-border) !important;
    color: var(--text) !important;
}

/* ─── CHỢ BUÔN DETAIL & ORDER & CHECKOUT PAGES ─── */
[data-theme="dark"] .dt-gallery,
[data-theme="dark"] .dt-gallery-thumbs,
[data-theme="dark"] .dt-info-card,
[data-theme="dark"] .dt-rel-card,
[data-theme="dark"] .ct-comments-section,
[data-theme="dark"] .ord-banner,
[data-theme="dark"] .ord-actions,
[data-theme="dark"] .ord-chat,
[data-theme="dark"] .ord-info,
[data-theme="dark"] .co-product,
[data-theme="dark"] .co-summary {
    background: var(--dark-bg-2) !important;
    border-color: var(--card-border) !important;
}

[data-theme="dark"] .dt-seller {
    background: var(--dark-bg-3) !important;
    border-color: var(--card-border) !important;
}

[data-theme="dark"] .dt-seller:hover {
    background: var(--dark-bg) !important;
}

[data-theme="dark"] .dt-desc-content {
    background: var(--dark-bg-3) !important;
    border-color: var(--card-border) !important;
    color: var(--text-muted) !important;
}

[data-theme="dark"] .dt-gallery-main {
    background: var(--dark-bg-3) !important;
}

[data-theme="dark"] .dt-gallery-status {
    background: rgba(0, 0, 0, 0.8) !important;
}

[data-theme="dark"] .ct-c-input,
[data-theme="dark"] .ct-c-bubble {
    background: var(--dark-bg-3) !important;
    border-color: var(--card-border) !important;
    color: var(--text) !important;
}

[data-theme="dark"] .ord-chat-input input {
    background: var(--dark-bg-3) !important;
    border-color: var(--card-border) !important;
    color: var(--text) !important;
}

[data-theme="dark"] .ord-chat-input input:focus {
    background: var(--dark-bg) !important;
    border-color: var(--primary) !important;
}

[data-theme="dark"] .ord-chat-header,
[data-theme="dark"] .ord-chat-input,
[data-theme="dark"] .ord-info-addr {
    background: var(--dark-bg-3) !important;
    border-color: var(--card-border) !important;
}

[data-theme="dark"] .ord-chat-locked {
    background: var(--dark-bg-3) !important;
    border-color: var(--card-border) !important;
}