/*! Zender Tosca Skin v2 — Polish layer (loaded AFTER tosca-skin.css)
 *  Fixes: brand area, inline-color overrides, top navbar, dashboard widgets,
 *  status pills, CTA card, footer, compact spacing. */

/* ---------- Brand/Logo area cleanup ---------- */
.app-sidebar__logo, .main-sidebar .brand-link {
  border-bottom: 1px solid var(--border) !important;
  padding: 14px 18px !important;
  height: 64px;
  display: flex !important; align-items: center !important;
  position: relative;
}
.app-sidebar__logo .header-brand,
.main-sidebar .brand-link {
  border-bottom: 0 !important;
  padding: 0 !important;
  display: inline-flex !important; align-items: center; gap: 10px;
  width: 100%; text-decoration: none !important;
}
/* Hide old colored brand image, replace with text logotype */
.app-sidebar__logo .header-brand-img,
.main-sidebar .brand-link .brand-image { display:none !important; }
.app-sidebar__logo .header-brand::before,
.main-sidebar .brand-link::before {
  content: "Z";
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--tosca-500), var(--tosca-700));
  color: #fff; font-weight: 800; font-size: 1.1rem;
  border-radius: 10px; box-shadow: 0 4px 10px -3px rgba(20,168,168,.5);
  font-family: 'Plus Jakarta Sans', var(--font);
  flex-shrink: 0;
}
.app-sidebar__logo .header-brand::after,
.main-sidebar .brand-link::after {
  content: "Zender";
  font-family: 'Plus Jakarta Sans', var(--font);
  font-weight: 800; font-size: 1.18rem; letter-spacing: -.025em;
  color: var(--ink-900);
}
.main-sidebar .brand-link .brand-text { display:none !important; }

/* Remove extra divider lines between brand and first menu item */
.app-sidebar .side-menu, .main-sidebar .nav-sidebar { border-top: 0 !important; padding-top: 8px !important; }

/* ---------- Sidebar icon color normalization (defeat inline style) ---------- */
.app-sidebar .side-menu__icon,
.app-sidebar .side-menu__icon[style],
.app-sidebar .nav-link i,
.app-sidebar .nav-link i[style],
.app-sidebar .slide-item i,
.app-sidebar .slide-item i[style] {
  color: var(--tosca-600) !important;
  font-size: .95rem !important;
  width: 22px; text-align: center;
}
.app-sidebar .side-menu__item.active .side-menu__icon,
.app-sidebar .side-menu__item.active .side-menu__icon[style],
.app-sidebar .slide.is-expanded > .side-menu__item .side-menu__icon,
.app-sidebar [aria-current="page"] .side-menu__icon {
  color: #fff !important;
}

/* Sidebar section heading "AKUN" / "KREDIT SMS" */
.app-sidebar .side-menu .side-menu__label.heading,
.app-sidebar .sub-category, .app-sidebar .side-menu li.sub-category h3,
.app-sidebar .menu-header, .app-sidebar .navhead, .app-sidebar .nav-header {
  display:block; padding: 16px 18px 6px !important;
  text-transform: uppercase; letter-spacing: .08em;
  font-size: .68rem !important; color: var(--ink-400) !important;
  font-weight: 700;
}

/* Sidebar bottom promo (Paket Uji Coba) */
.app-sidebar .side-app + div, .app-sidebar .upgrade-btn,
.app-sidebar .side-app .upgrade,
aside .side-app .ad,
.side-bar-footer, .sidebar-promo {
  margin: 14px 14px 18px !important;
  padding: 14px !important;
  background: linear-gradient(135deg, var(--tosca-50), #ffffff);
  border: 1px solid var(--tosca-100);
  border-radius: 12px !important;
  font-size: .8rem;
}
/* If theme uses generic last-child wrapper for the CTA */
.app-sidebar > div:last-child:not(.side-menu):not(.app-sidebar__logo) {
  margin: 12px 14px !important;
  padding: 14px !important;
  background: linear-gradient(135deg, var(--tosca-50), #ffffff) !important;
  border: 1px solid var(--tosca-100) !important;
  border-radius: 12px !important;
}

/* ---------- Top navbar polish ---------- */
.main-header.navbar { padding: 0 24px !important; }
.main-header .nav-link[data-widget="pushmenu"] {
  width: 40px; height: 40px; border-radius: 10px;
  display: inline-flex !important; align-items: center; justify-content: center;
  background: var(--tosca-50);
  margin-right: 6px;
}
.main-header .nav-link[data-widget="pushmenu"]:hover { background: var(--tosca-100); }
.main-header .nav-link[data-widget="pushmenu"] i { color: var(--tosca-700) !important; font-size: .95rem; }

/* User avatar */
.user-image, img.user-image, .nav-img img {
  width: 38px !important; height: 38px !important;
  border: 2px solid #fff !important;
  box-shadow: 0 0 0 2px var(--tosca-300), 0 4px 8px -2px rgba(20,168,168,.25) !important;
}

/* Language flag dropdown */
.main-header .nav-item.dropdown > a img[alt*="lag"],
.main-header .nav-item.dropdown > a img[src*="flag"] {
  width: 22px; height: 16px; border-radius: 3px; box-shadow: 0 1px 2px rgba(0,0,0,.15);
}

/* ---------- Dashboard widget cards (4-up) ---------- */
.card.overflow-hidden, .small-box, .info-box {
  border-radius: 14px !important;
  box-shadow: 0 1px 3px rgba(15,23,42,.04), 0 4px 12px -4px rgba(15,23,42,.06) !important;
  border: 1px solid var(--border) !important;
  transition: transform .15s, box-shadow .2s;
}
.card.overflow-hidden:hover, .small-box:hover { transform: translateY(-2px); box-shadow: 0 8px 20px -4px rgba(20,168,168,.18) !important; }

/* Big number */
.card-body h2.mb-0, .card-body h3.mb-0,
.number-font-chars {
  font-family: 'Plus Jakarta Sans', var(--font) !important;
  font-weight: 800 !important;
  font-size: 1.85rem !important;
  color: var(--ink-900) !important;
  letter-spacing: -.02em;
}
/* Widget icon: shrink + tosca-tinted bg pill */
.card-body i.fs-35, .card-body i.fa-rocket, .card-body i.fa-download,
.card-body i.fa-circle-xmark, .card-body i.fa-triangle-exclamation,
.card-body i.fa-play, .card-body i.fa-mobile, .card-body i.fa-mobile-screen,
.card-body i.fa-address-book, .card-body i.fa-people-group,
.card-body .fa-solid.float-right, .card-body .fa-regular.float-right {
  font-size: 1.1rem !important;
  width: 44px !important; height: 44px !important;
  display: inline-flex !important; align-items: center; justify-content: center;
  background: var(--tosca-50) !important;
  color: var(--tosca-600) !important;
  border-radius: 12px !important;
  margin: 0 !important;
  float: right;
  text-shadow: none !important;
}
/* Variant icon coloring by adjacent text */
.card-body i.text-blue, .card-body i.text-info, .card-body i.text-primary { background: var(--tosca-50) !important; color: var(--tosca-600) !important; }
.card-body i.text-success, .card-body i.text-green { background: #ecfdf5 !important; color:#059669 !important; }
.card-body i.text-danger, .card-body i.text-red { background: #fef2f2 !important; color:#e11d48 !important; }
.card-body i.text-warning, .card-body i.text-orange, .card-body i.text-yellow { background: #fffbeb !important; color:#d97706 !important; }
.card-body i.text-purple, .card-body i.text-violet { background: #f5f3ff !important; color:#7c3aed !important; }

/* Widget label */
.card-body p.fs-12, .card-body p.font-weight-bold {
  color: var(--ink-500) !important;
  font-size: .8rem !important;
  font-weight: 600 !important;
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-bottom: 14px !important;
}

/* ---------- Status text → pill badge ---------- */
/* Common Laravel patterns: <span><i class="fa fa-clock"></i> accepted</span> */
.text-success, span.text-success, td .text-success, td > span.text-success,
.badge-pill-status-accepted, .status-accepted {
  /* keep .text-success as inline color, but if it's a status word, style as pill via :is selectors below */
}
/* Style status texts in tables: any td with only a single status word */
.table td .text-warning,
.table td .text-success,
.table td .text-danger,
.table td .text-info,
.table td .text-primary,
.table td .text-muted {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 10px; border-radius: 999px;
  font-size: .73rem !important; font-weight: 700 !important;
  text-transform: uppercase; letter-spacing: .04em;
  line-height: 1;
}
.table td .text-success { background: #d1fae5 !important; color: #047857 !important; }
.table td .text-warning { background: #fef3c7 !important; color: #92400e !important; }
.table td .text-danger  { background: #fee2e2 !important; color: #991b1b !important; }
.table td .text-info, .table td .text-primary { background: var(--tosca-100) !important; color: var(--tosca-700) !important; }
.table td .text-muted   { background: var(--ink-100) !important; color: var(--ink-600) !important; }
.table td .text-success i, .table td .text-warning i,
.table td .text-danger i, .table td .text-info i { font-size: .7rem; }

/* ---------- Footer ---------- */
.main-footer, footer.main-footer, .copyright {
  background: transparent !important;
  border-top: 1px solid var(--border) !important;
  text-align: center !important;
  font-size: .8rem !important;
  color: var(--ink-500) !important;
  padding: 16px 26px !important;
}
.main-footer a, .main-footer strong { color: var(--tosca-700) !important; font-weight: 700 !important; }

/* ---------- Page header / breadcrumb compact ---------- */
.page-header, .content-header {
  padding: 22px 26px 6px !important;
  background: transparent !important; border-bottom: 0 !important;
}
.page-title, .content-header h1, .content-header .page-title {
  font-family: 'Plus Jakarta Sans', var(--font) !important;
  font-size: 1.4rem !important; font-weight: 800 !important;
  color: var(--ink-900) !important; letter-spacing: -.02em; margin: 0 0 4px !important;
}
.breadcrumb { padding: 0 !important; margin: 0 !important; background: transparent !important; font-size: .8rem !important; }
.breadcrumb-item, .breadcrumb-item a { color: var(--ink-500) !important; font-weight: 500; }
.breadcrumb-item a i { color: var(--tosca-600) !important; margin-right: 4px; }
.breadcrumb-item + .breadcrumb-item::before { content: "›" !important; color: var(--ink-300) !important; padding: 0 8px; font-weight: 600; }
.breadcrumb-item.active { color: var(--tosca-600) !important; font-weight: 600; }
.breadcrumb-item.active a { color: var(--tosca-600) !important; pointer-events: none; }

/* ---------- Card spacing tighter ---------- */
.row > [class*="col-"] { margin-bottom: 1rem; }
.card-body { padding: 18px 20px !important; }
.card-header { padding: 15px 20px !important; }

/* ---------- Tables: index column with # ---------- */
.table td:first-child { color: var(--ink-500); font-weight: 600; font-size: .85rem; }

/* ---------- Sidebar brand area: hide horizontal scroll line ---------- */
.app-sidebar { overflow-x: hidden; }
.app-sidebar__logo + .side-menu { border-top: 0 !important; }
.app-sidebar__logo, .main-sidebar .brand-link {
  box-shadow: 0 1px 0 var(--border);
}

/* Active item: remove the gradient half-cut at top (the white sliver) */
.app-sidebar .side-menu > .slide:first-child { margin-top: 4px; }
.app-sidebar .side-menu__item.active::before, .app-sidebar .side-menu__item.active::after { display:none !important; }

/* ---------- Buttons inside table action column ---------- */
.table td .btn-sm, .table td .btn { margin: 0 2px; }
.table td .badge { margin-right: 4px; }

/* ---------- Misc cleanup ---------- */
.page-leftheader h4, .page-leftheader .page-title { margin-bottom: 4px !important; }
.mt-5-7, .mt-5\\.7 { margin-top: 0 !important; }
.row.h-100vh, .h-100vh { height: auto !important; }

/* Profile dropdown header */
.dropdown-menu.dropdown-profile { min-width: 240px; padding: 0 !important; overflow:hidden; }
.dropdown-menu.dropdown-profile .user-header { padding: 18px !important; text-align:center; }
.dropdown-menu.dropdown-profile .user-header img { width:64px; height:64px; }
.dropdown-menu.dropdown-profile .user-header p { color:#fff; margin:10px 0 0; font-weight:600; }
.dropdown-menu.dropdown-profile .user-header small { color: rgba(255,255,255,.8); display:block; font-weight:500; }
.dropdown-menu.dropdown-profile .user-footer { padding:12px !important; gap:8px; display:flex; }
.dropdown-menu.dropdown-profile .user-footer .btn { flex:1; padding: 7px 10px !important; font-size:.82rem !important; }

/* Anti-jitter on initial load */
.content-wrapper { animation: none !important; }

/* ========== v2.1 patch ========== */

/* Status pill: catch div-based layouts (billing order uses .billing-card not .table) */
.billing-card .text-warning, .billing-card .text-success, .billing-card .text-danger, .billing-card .text-info,
.text-warning.light, .text-success.light, .text-danger.light, .text-info.light {
  display: inline-flex !important; align-items: center; gap: 5px;
  padding: 5px 12px !important; border-radius: 999px !important;
  font-size: .73rem !important; font-weight: 700 !important;
  text-transform: uppercase; letter-spacing: .04em; line-height: 1;
}
.billing-card .text-warning, .text-warning.light { background: #fef3c7 !important; color: #92400e !important; }
.billing-card .text-success, .text-success.light { background: #d1fae5 !important; color: #047857 !important; }
.billing-card .text-danger,  .text-danger.light  { background: #fee2e2 !important; color: #991b1b !important; }
.billing-card .text-info,    .text-info.light    { background: var(--tosca-100) !important; color: var(--tosca-700) !important; }
.billing-card .text-warning i, .billing-card .text-success i,
.text-warning.light i, .text-success.light i { font-size: .7rem; }

/* Footer: theme uses .footer not .main-footer */
footer.footer, .footer {
  background: transparent !important;
  border-top: 1px solid var(--border) !important;
  padding: 16px 26px !important;
  font-size: .8rem !important;
  color: var(--ink-500) !important;
  text-align: center;
}
footer.footer a, .footer a {
  color: var(--tosca-700) !important;
  font-weight: 700 !important;
  text-decoration: none !important;
}
footer.footer a:hover, .footer a:hover { color: var(--tosca-800) !important; text-decoration: underline !important; }
footer.footer .text-info, .footer .text-info {
  background: transparent !important; color: var(--ink-400) !important; padding: 0 !important;
  font-size: .68rem !important; text-transform: none; letter-spacing: 0;
  display: inline !important;
}

/* Billing card wrapper itself: border + radius */
.billing-card {
  border-bottom: 1px solid var(--border);
  padding: 14px 4px !important;
}
.billing-card .billing-data {
  color: var(--ink-700);
  font-weight: 500;
  font-size: .9rem;
}
/* Header row of billing list (No / Plan / Amount / Payment Status / Purchase Date) */
.row > .col-lg-1 > .billing-data:first-child:not(:has(*)),
.billing-header .billing-data {
  color: var(--ink-500) !important;
  font-size: .72rem !important; text-transform: uppercase;
  letter-spacing: .06em; font-weight: 700 !important;
}

/* Order# col: tosca chip */
.billing-card .col-lg-1 .billing-data {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 36px; height: 28px; padding: 0 8px;
  background: var(--tosca-50); color: var(--tosca-700) !important;
  border-radius: 8px; font-weight: 700 !important; font-size: .8rem !important;
}
