:root{--brand:#5b4bff;--brand-dark:#4438ca;--auth-bg-1:#eef2ff;--auth-bg-2:#f8fafc;}
*{box-sizing:border-box}
body{background:#f5f7fb;color:#1f2937;font-family:system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif}
.app-shell{display:flex;min-height:100vh}
.sidebar{width:280px;background:linear-gradient(180deg,#111827,#1f2937);color:#fff;position:fixed;inset:0 auto 0 0;padding:18px;overflow-y:auto;z-index:20}
.brand-box{display:flex;align-items:center;gap:12px;margin-bottom:24px;min-width:0}
.brand-logo{width:44px;height:44px;min-width:44px;border-radius:14px;background:var(--brand);display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;box-shadow:0 10px 24px rgba(91,75,255,.28)}
.brand-logo-img{width:44px;height:44px;min-width:44px;border-radius:14px;object-fit:contain;background:#fff;padding:4px;box-shadow:0 10px 24px rgba(0,0,0,.18)}
.brand-title{font-weight:800;line-height:1.1;max-width:175px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff}
.brand-box small{display:block;color:#b7c1d4;margin-top:3px}
.menu-heading{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:#8ea0bd;margin:18px 8px 8px}
.nav-link{display:flex;gap:10px;align-items:center;padding:10px 12px;border-radius:12px;color:#dbe4f6;text-decoration:none;margin-bottom:4px}
.nav-link:hover,.nav-link.active{background:rgba(255,255,255,.12);color:#fff}
.nav-ico{width:24px;text-align:center}
.main-content{margin-left:280px;min-height:100vh;width:calc(100% - 280px)}
.topbar{height:72px;background:#fff;display:flex;align-items:center;gap:16px;padding:0 24px;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:10}
.topbar-logo{width:34px;height:34px;border-radius:10px;object-fit:contain;background:#fff;border:1px solid #e5e7eb;padding:3px}
.content-wrap{padding:24px}.card-soft{border:0;border-radius:22px;box-shadow:0 12px 30px rgba(15,23,42,.06)}
.stat-card{background:#fff;border-radius:22px;padding:22px;box-shadow:0 12px 30px rgba(15,23,42,.06);position:relative;overflow:hidden}
.stat-card:after{content:"";position:absolute;width:90px;height:90px;right:-30px;top:-30px;border-radius:50%;background:var(--brand);opacity:.12}
.stat-icon{width:44px;height:44px;border-radius:14px;background:rgba(91,75,255,.1);display:flex;align-items:center;justify-content:center;color:var(--brand);font-size:22px}
.btn-brand{background:var(--brand)!important;border-color:var(--brand)!important;color:#fff!important;font-weight:700;border-radius:14px;box-shadow:0 10px 22px rgba(91,75,255,.22)}
.btn-brand:hover{background:var(--brand-dark)!important;border-color:var(--brand-dark)!important;color:#fff!important;filter:none;transform:translateY(-1px)}
.table thead th{background:#f8fafc;color:#475569}.form-control,.form-select{border-radius:12px}.modal-content{border-radius:20px}
.auth-page{min-height:100vh;background:radial-gradient(circle at top left,rgba(91,75,255,.14),transparent 34%),linear-gradient(135deg,var(--auth-bg-1),var(--auth-bg-2));display:flex;align-items:center;justify-content:center;padding:24px}
.auth-card{width:min(480px,100%);background:#fff;border-radius:26px;box-shadow:0 20px 60px rgba(15,23,42,.12);padding:34px}
.auth-brand{text-align:center;margin-bottom:18px}.auth-logo{width:70px;height:70px;border-radius:20px;object-fit:contain;background:#fff;border:1px solid #e5e7eb;padding:6px;box-shadow:0 12px 28px rgba(15,23,42,.10)}
.auth-card h3{font-weight:800;letter-spacing:.02em}.auth-card .form-label,.auth-card label{font-weight:650;margin-bottom:8px}.auth-card .form-control{height:48px;background:#f8fafc;border-color:#dbe3ef}.auth-card .form-control:focus{border-color:var(--brand);box-shadow:0 0 0 .2rem rgba(91,75,255,.12)}
.auth-card .btn-brand{height:50px;font-size:16px;margin-top:6px;display:block;opacity:1;visibility:visible}.auth-links{margin-top:18px;text-align:center}.auth-links a{font-weight:600;text-decoration:none}
.settings-preview{width:96px;height:70px;object-fit:contain;border:1px solid #e5e7eb;border-radius:14px;background:#fff;padding:6px}.favicon-preview{width:42px;height:42px;object-fit:contain;border:1px solid #e5e7eb;border-radius:10px;background:#fff;padding:4px}
@media(max-width:991px){.sidebar{transform:translateX(-100%);transition:.25s}.sidebar.show{transform:none}.main-content{margin-left:0;width:100%}.topbar{padding:0 14px}.content-wrap{padding:16px}}

/* v2.1.6: button hover + customer branding fix */
.btn-brand,
.btn-brand:link,
.btn-brand:visited{
  background:var(--brand,#5b4bff)!important;
  border-color:var(--brand,#5b4bff)!important;
  color:#fff!important;
}
.btn-brand:hover,
.btn-brand:focus,
.btn-brand:active,
.btn-brand.active,
.btn-brand:first-child:active,
.show>.btn-brand.dropdown-toggle{
  background:var(--brand-dark,#4438ca)!important;
  border-color:var(--brand-dark,#4438ca)!important;
  color:#fff!important;
  box-shadow:0 12px 26px rgba(68,56,202,.28)!important;
}
.auth-card .btn-brand,
.auth-card .auth-submit,
.auth-card .btn-brand:hover,
.auth-card .btn-brand:focus,
.auth-card .btn-brand:active{
  color:#fff!important;
  opacity:1!important;
  visibility:visible!important;
  text-shadow:none!important;
}
.auth-card .auth-submit:hover{transform:translateY(-1px)}
.auth-card .auth-links a:hover{color:var(--brand-dark,#4438ca)!important;text-decoration:underline}

/* v2.1.8 final auth submit button visibility fix */
.auth-card .auth-submit,
.auth-card button.auth-submit,
.auth-card button[type="submit"].auth-submit,
.auth-card .btn-brand.auth-submit {
  display: block !important;
  width: 100% !important;
  min-height: 50px !important;
  background: linear-gradient(135deg, var(--brand, #5b4bff), var(--brand-dark, #4438ca)) !important;
  background-color: var(--brand, #5b4bff) !important;
  border: 0 !important;
  border-color: transparent !important;
  color: #ffffff !important;
  opacity: 1 !important;
  visibility: visible !important;
  font-weight: 800 !important;
  border-radius: 14px !important;
  box-shadow: 0 12px 28px rgba(91, 75, 255, .28) !important;
  text-shadow: none !important;
  transition: transform .15s ease, box-shadow .15s ease, filter .15s ease !important;
}
.auth-card .auth-submit:hover,
.auth-card button.auth-submit:hover,
.auth-card button[type="submit"].auth-submit:hover,
.auth-card .btn-brand.auth-submit:hover,
.auth-card .auth-submit:focus,
.auth-card button.auth-submit:focus,
.auth-card button[type="submit"].auth-submit:focus,
.auth-card .btn-brand.auth-submit:focus,
.auth-card .auth-submit:active,
.auth-card button.auth-submit:active,
.auth-card button[type="submit"].auth-submit:active,
.auth-card .btn-brand.auth-submit:active {
  background: linear-gradient(135deg, var(--brand-dark, #4438ca), var(--brand, #5b4bff)) !important;
  background-color: var(--brand-dark, #4438ca) !important;
  border: 0 !important;
  border-color: transparent !important;
  color: #ffffff !important;
  opacity: 1 !important;
  visibility: visible !important;
  filter: none !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 14px 32px rgba(68, 56, 202, .35) !important;
  text-decoration: none !important;
  outline: none !important;
}
.auth-card .auth-submit:disabled,
.auth-card button.auth-submit:disabled,
.auth-card button[type="submit"].auth-submit:disabled,
.auth-card .btn-brand.auth-submit:disabled {
  background: linear-gradient(135deg, #94a3b8, #64748b) !important;
  background-color: #64748b !important;
  color: #ffffff !important;
  opacity: 1 !important;
  border: 0 !important;
  box-shadow: none !important;
  cursor: not-allowed !important;
}

/* =========================================================
   v2.2.0 LOADED GLOBAL BUTTON FIX
   This is inside assets/css/app.css, the file already loaded
   by every admin panel page.
   ========================================================= */
:root{
  --brand-dark: #4438ca;
  --btn-primary-bg: var(--brand, #5b4bff);
  --btn-primary-hover: var(--brand-dark, #4438ca);
  --btn-success-bg: #16a34a;
  --btn-success-hover: #15803d;
  --btn-danger-bg: #dc2626;
  --btn-danger-hover: #b91c1c;
  --btn-warning-bg: #f59e0b;
  --btn-warning-hover: #d97706;
  --btn-info-bg: #0891b2;
  --btn-info-hover: #0e7490;
  --btn-secondary-bg: #475569;
  --btn-secondary-hover: #334155;
}

.btn,
button,
input[type="button"],
input[type="submit"],
input[type="reset"],
.dt-button{
  transition: background-color .15s ease, border-color .15s ease, color .15s ease, box-shadow .15s ease, transform .15s ease !important;
}

/* Brand / primary / submit buttons */
.btn-brand,
.btn-primary,
button.btn-brand,
button.btn-primary,
a.btn-brand,
a.btn-primary,
input.btn-brand,
input.btn-primary,
input[type="submit"],
form button:not(.btn-light):not(.btn-link):not(.btn-outline-danger):not(.btn-outline-primary):not(.btn-outline-secondary):not(.btn-outline-success):not(.btn-outline-warning):not(.btn-outline-info),
.card form button[type="submit"],
.modal form button[type="submit"]{
  background: var(--btn-primary-bg) !important;
  background-color: var(--btn-primary-bg) !important;
  border-color: var(--btn-primary-bg) !important;
  color: #ffffff !important;
  background-image: none !important;
  opacity: 1 !important;
  visibility: visible !important;
  text-shadow: none !important;
}

.btn-brand:hover,.btn-brand:focus,.btn-brand:active,.btn-brand.active,
.btn-primary:hover,.btn-primary:focus,.btn-primary:active,.btn-primary.active,
button.btn-brand:hover,button.btn-brand:focus,button.btn-brand:active,
button.btn-primary:hover,button.btn-primary:focus,button.btn-primary:active,
a.btn-brand:hover,a.btn-brand:focus,a.btn-brand:active,
a.btn-primary:hover,a.btn-primary:focus,a.btn-primary:active,
input.btn-brand:hover,input.btn-brand:focus,input.btn-brand:active,
input.btn-primary:hover,input.btn-primary:focus,input.btn-primary:active,
input[type="submit"]:hover,input[type="submit"]:focus,input[type="submit"]:active,
form button:not(.btn-light):not(.btn-link):not(.btn-outline-danger):not(.btn-outline-primary):not(.btn-outline-secondary):not(.btn-outline-success):not(.btn-outline-warning):not(.btn-outline-info):hover,
form button:not(.btn-light):not(.btn-link):not(.btn-outline-danger):not(.btn-outline-primary):not(.btn-outline-secondary):not(.btn-outline-success):not(.btn-outline-warning):not(.btn-outline-info):focus,
form button:not(.btn-light):not(.btn-link):not(.btn-outline-danger):not(.btn-outline-primary):not(.btn-outline-secondary):not(.btn-outline-success):not(.btn-outline-warning):not(.btn-outline-info):active,
.card form button[type="submit"]:hover,
.card form button[type="submit"]:focus,
.card form button[type="submit"]:active,
.modal form button[type="submit"]:hover,
.modal form button[type="submit"]:focus,
.modal form button[type="submit"]:active,
.show > .btn-primary.dropdown-toggle,
.show > .btn-brand.dropdown-toggle{
  background: var(--btn-primary-hover) !important;
  background-color: var(--btn-primary-hover) !important;
  border-color: var(--btn-primary-hover) !important;
  color: #ffffff !important;
  background-image: none !important;
  opacity: 1 !important;
  visibility: visible !important;
  text-shadow: none !important;
  text-decoration: none !important;
  filter: none !important;
  outline: none !important;
}

/* Bootstrap color buttons */
.btn-success{background-color:var(--btn-success-bg)!important;border-color:var(--btn-success-bg)!important;color:#fff!important;background-image:none!important}
.btn-success:hover,.btn-success:focus,.btn-success:active,.show>.btn-success.dropdown-toggle{background-color:var(--btn-success-hover)!important;border-color:var(--btn-success-hover)!important;color:#fff!important;background-image:none!important;opacity:1!important}
.btn-danger{background-color:var(--btn-danger-bg)!important;border-color:var(--btn-danger-bg)!important;color:#fff!important;background-image:none!important}
.btn-danger:hover,.btn-danger:focus,.btn-danger:active,.show>.btn-danger.dropdown-toggle{background-color:var(--btn-danger-hover)!important;border-color:var(--btn-danger-hover)!important;color:#fff!important;background-image:none!important;opacity:1!important}
.btn-warning{background-color:var(--btn-warning-bg)!important;border-color:var(--btn-warning-bg)!important;color:#111827!important;background-image:none!important}
.btn-warning:hover,.btn-warning:focus,.btn-warning:active,.show>.btn-warning.dropdown-toggle{background-color:var(--btn-warning-hover)!important;border-color:var(--btn-warning-hover)!important;color:#fff!important;background-image:none!important;opacity:1!important}
.btn-info{background-color:var(--btn-info-bg)!important;border-color:var(--btn-info-bg)!important;color:#fff!important;background-image:none!important}
.btn-info:hover,.btn-info:focus,.btn-info:active,.show>.btn-info.dropdown-toggle{background-color:var(--btn-info-hover)!important;border-color:var(--btn-info-hover)!important;color:#fff!important;background-image:none!important;opacity:1!important}
.btn-secondary{background-color:var(--btn-secondary-bg)!important;border-color:var(--btn-secondary-bg)!important;color:#fff!important;background-image:none!important}
.btn-secondary:hover,.btn-secondary:focus,.btn-secondary:active,.show>.btn-secondary.dropdown-toggle{background-color:var(--btn-secondary-hover)!important;border-color:var(--btn-secondary-hover)!important;color:#fff!important;background-image:none!important;opacity:1!important}
.btn-light{background-color:#f8fafc!important;border-color:#cbd5e1!important;color:#0f172a!important;background-image:none!important}
.btn-light:hover,.btn-light:focus,.btn-light:active{background-color:#e2e8f0!important;border-color:#94a3b8!important;color:#0f172a!important;background-image:none!important;opacity:1!important}

/* Outline buttons become readable on hover */
.btn-outline-primary:hover,.btn-outline-primary:focus,.btn-outline-primary:active{background-color:var(--btn-primary-bg)!important;border-color:var(--btn-primary-bg)!important;color:#fff!important}
.btn-outline-success:hover,.btn-outline-success:focus,.btn-outline-success:active{background-color:var(--btn-success-bg)!important;border-color:var(--btn-success-bg)!important;color:#fff!important}
.btn-outline-danger:hover,.btn-outline-danger:focus,.btn-outline-danger:active{background-color:var(--btn-danger-bg)!important;border-color:var(--btn-danger-bg)!important;color:#fff!important}
.btn-outline-warning:hover,.btn-outline-warning:focus,.btn-outline-warning:active{background-color:var(--btn-warning-bg)!important;border-color:var(--btn-warning-bg)!important;color:#111827!important}
.btn-outline-info:hover,.btn-outline-info:focus,.btn-outline-info:active{background-color:var(--btn-info-bg)!important;border-color:var(--btn-info-bg)!important;color:#fff!important}
.btn-outline-secondary:hover,.btn-outline-secondary:focus,.btn-outline-secondary:active{background-color:var(--btn-secondary-bg)!important;border-color:var(--btn-secondary-bg)!important;color:#fff!important}

/* DataTables buttons and pagination */
.dt-button,
button.dt-button,
div.dt-buttons .dt-button{
  background:var(--btn-primary-bg)!important;
  background-color:var(--btn-primary-bg)!important;
  border-color:var(--btn-primary-bg)!important;
  color:#fff!important;
  background-image:none!important;
  opacity:1!important;
}
.dt-button:hover,.dt-button:focus,.dt-button:active,
button.dt-button:hover,button.dt-button:focus,button.dt-button:active,
div.dt-buttons .dt-button:hover,div.dt-buttons .dt-button:focus,div.dt-buttons .dt-button:active{
  background:var(--btn-primary-hover)!important;
  background-color:var(--btn-primary-hover)!important;
  border-color:var(--btn-primary-hover)!important;
  color:#fff!important;
  background-image:none!important;
  opacity:1!important;
}
.page-item.active .page-link{background-color:var(--btn-primary-bg)!important;border-color:var(--btn-primary-bg)!important;color:#fff!important}
.page-link:hover,.page-link:focus{background-color:var(--brand-soft,#dbeafe)!important;color:#0f172a!important;box-shadow:none!important}

/* Disabled buttons stay visible */
.btn:disabled,.btn.disabled,button:disabled,input[type="submit"]:disabled,.dt-button.disabled{
  background:#94a3b8!important;
  background-color:#94a3b8!important;
  border-color:#94a3b8!important;
  color:#fff!important;
  opacity:1!important;
  visibility:visible!important;
  cursor:not-allowed!important;
  box-shadow:none!important;
}

/* Icon/text inside buttons */
.btn i,.btn svg,.dt-button i,.dt-button svg{color:inherit!important;fill:currentColor!important;stroke:currentColor!important}
.btn:hover i,.btn:focus i,.btn:active i,.btn:hover svg,.btn:focus svg,.btn:active svg{color:inherit!important;fill:currentColor!important;stroke:currentColor!important}

/* Emergency protection against any theme making button text/background invisible */
[class~="btn"]:hover,[class~="btn"]:focus,[class~="btn"]:active{
  opacity:1!important;
  visibility:visible!important;
  text-decoration:none!important;
}
