/*!
 * Skin Purple - Modern Edition
 * Base Color: #7813d7
 * Framework: Bootstrap 3.3.6 + AdminLTE 2.3.6
 * Font: Roboto Flex
 * Author: Custom Design
 */

/* ========================================
   IMPORTS & FONTS
   ======================================== */
@import url('https://fonts.googleapis.com/css2?family=Roboto+Flex:opsz,wght@8..144,100..1000&display=swap');
/*@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@100..900&display=swap');*/

/* ========================================
   CSS VARIABLES - Color Palette
   ======================================== */
:root {
  /* Primary Purple Palette */
  --primary-color: #7813d7;
  --primary-dark: #5a0ea4;
  --primary-darker: #430880;
  --primary-light: #9845f5;
  --primary-lighter: #b276eb;
  --primary-lightest: #d4b8f7;
  
  /* Sidebar Colors */
  --sidebar-bg: #8533dd;
  --sidebar-dark: #6a1fb8;
  --sidebar-menu-hover: #1e282c;
  --sidebar-header: #6a1fb8;
  --sidebar-submenu: #6a1fb8;
  
  /* Status Colors - Modern Palette */
  --success-color: #3bcc8b;
  --success-dark: #2fa571;
  --info-color: #89d6e9;
  --info-dark: #5bbad3;
  --warning-color: #e8c183;
  --warning-dark: #d4a35b;
  --danger-color: #dd7466;
  --danger-dark: #c95b4e;
  
  /* Additional Colors */
  --blue-color: #5fb9ed;
  --teal-color: #60efef;
  --orange-color: #f99543;
  --fuchsia-color: #e744c1;
  --maroon-color: #e3437d;
  
  /* Neutral Colors */
  --bg-light: #ecf0f5;
  --bg-white: #ffffff;
  --border-color: #d8d0df;
  --border-light: #d2d6de;
  --text-dark: #333333;
  --text-medium: #666666;
  --text-light: #999999;
  
  /* UI Elements */
  --border-radius-sm: 8px;
  --border-radius-md: 10px; /*12*/
  --border-radius-lg: 12px; /*15*/
  --border-radius-xl: 14px; /*20*/
  
  /* Shadows */
  --shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.08);
  --shadow-md: 0 4px 8px rgba(0, 0, 0, 0.12);
  --shadow-lg: 0 8px 16px rgba(0, 0, 0, 0.15);
  --shadow-xl: 0 12px 24px rgba(0, 0, 0, 0.18);
}

/* ========================================
   BASE & RESET
   ======================================== */
html,
body {
  min-height: 100%;
  font-size: 10px; /* Base font size */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  font-family: "Roboto Flex", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 200;
  font-style: normal;
  overflow-x: hidden;
  overflow-y: auto;
  line-height: 1.6;
  color: var(--text-dark);
  background-color: var(--bg-light);
}

/* ========================================
   RESPONSIVE TYPOGRAPHY
   ======================================== */

/* Mobile First - Small devices (phones, < 768px) */
body {
  font-size: 1.1rem; /* 11px */
}

h1, .h1 {
  font-size: 2.2rem; /* 22px */
  font-weight: 600;
  line-height: 1.3;
  margin-bottom: 1.2rem;
}

h2, .h2 {
  font-size: 1.9rem; /* 19px */
  font-weight: 600;
  line-height: 1.3;
  margin-bottom: 1rem;
}

h3, .h3 {
  font-size: 1.6rem; /* 16px */
  font-weight: 600;
  line-height: 1.4;
  margin-bottom: 0.8rem;
}

h4, .h4 {
  font-size: 1.4rem; /* 14px */
  font-weight: 600;
  line-height: 1.4;
  margin-bottom: 0.7rem;
}

h5, .h5 {
  font-size: 1.2rem; /* 12px */
  font-weight: 600;
  line-height: 1.5;
  margin-bottom: 0.5rem;
}

h6, .h6 {
  font-size: 1.1rem; /* 11px */
  font-weight: 600;
  line-height: 1.5;
  margin-bottom: 0.4rem;
}

/* Tablet - Medium devices (≥768px) */
@media (min-width: 768px) {
  body {
    font-size: 1.2rem; /* 12px */
  }
  
  h1, .h1 { font-size: 2.4rem; /* 24px */ }
  h2, .h2 { font-size: 2rem; /* 20px */ }
  h3, .h3 { font-size: 1.7rem; /* 17px */ }
  h4, .h4 { font-size: 1.4rem; /* 14px */ }
  h5, .h5 { font-size: 1.3rem; /* 13px */ }
  h6, .h6 { font-size: 1.2rem; /* 12px */ }
}

/* Desktop - Large devices (≥992px) */
@media (min-width: 992px) {
  body {
    font-size: 1.2rem; /* 12px */
  }
  
  h1, .h1 { font-size: 2.6rem; /* 26px */ }
  h2, .h2 { font-size: 2.2rem; /* 22px */ }
  h3, .h3 { font-size: 1.8rem; /* 18px */ }
  h4, .h4 { font-size: 1.5rem; /* 15px */ }
  h5, .h5 { font-size: 1.3rem; /* 13px */ }
  h6, .h6 { font-size: 1.2rem; /* 12px */ }
}

/* Large Desktop - Extra large devices (≥1200px) */
@media (min-width: 1200px) {
  body {
    font-size: 1.3rem; /* 13px */
  }
  
  h1, .h1 { font-size: 2.8rem; /* 28px */ }
  h2, .h2 { font-size: 2.4rem; /* 24px */ }
  h3, .h3 { font-size: 2rem; /* 20px */ }
  h4, .h4 { font-size: 1.6rem; /* 16px */ }
  h5, .h5 { font-size: 1.4rem; /* 14px */ }
  h6, .h6 { font-size: 1.3rem; /* 13px */ }
}

/* Extra Large Desktop (≥1920px - Full HD+) */
@media (min-width: 1920px) {
  body {
    font-size: 1.4rem; /* 14px */
  }
  
  h1, .h1 { font-size: 3rem; /* 30px */ }
  h2, .h2 { font-size: 2.6rem; /* 26px */ }
  h3, .h3 { font-size: 2.2rem; /* 22px */ }
  h4, .h4 { font-size: 1.8rem; /* 18px */ }
  h5, .h5 { font-size: 1.5rem; /* 15px */ }
  h6, .h6 { font-size: 1.4rem; /* 14px */ }
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  font-family: "Roboto Flex", sans-serif;
  color: var(--text-dark);
  font-variation-settings:
    "slnt" 0,
    "wdth" 100,
    "GRAD" 0;
}

/* Text Utilities */
.text-sm {
  font-size: 1rem !important; /* 10px */
}

.text-md {
  font-size: 1.2rem !important; /* 12px */
}

.text-lg {
  font-size: 1.4rem !important; /* 14px */
}

.text-xl {
  font-size: 1.6rem !important; /* 16px */
}

.text-bold,
.text-bold.table td,
.text-bold.table th {
  font-weight: 700 !important;
}

.text-light {
  font-weight: 300 !important;
}

.text-normal {
  font-weight: 400 !important;
}

.text-medium {
  font-weight: 500 !important;
}

/* ========================================
   LAYOUT & STRUCTURE
   ======================================== */

/* Wrapper */
.wrapper {
  min-height: 100%;
  position: relative;
  overflow: hidden;
}

.wrapper:before,
.wrapper:after {
  content: " ";
  display: table;
}

.wrapper:after {
  clear: both;
}

.skin-purple .wrapper,
.skin-purple .main-sidebar,
.skin-purple .left-side {
  background-color: var(--sidebar-bg);
}

/* Boxed Layout */
.layout-boxed html,
.layout-boxed body {
  height: 100%;
}

.layout-boxed .wrapper {
  max-width: 1250px;
  margin: 0 auto;
  min-height: 100%;
  box-shadow: var(--shadow-xl);
  position: relative;
}

.layout-boxed {
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
}

/* Content Wrapper */
.content-wrapper,
.right-side,
.main-footer {
  -webkit-transition: -webkit-transform 0.3s ease-in-out, margin 0.3s ease-in-out;
  -moz-transition: -moz-transform 0.3s ease-in-out, margin 0.3s ease-in-out;
  -o-transition: -o-transform 0.3s ease-in-out, margin 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out, margin 0.3s ease-in-out;
  margin-left: 230px;
  z-index: 820;
}

.layout-top-nav .content-wrapper,
.layout-top-nav .right-side,
.layout-top-nav .main-footer {
  margin-left: 0;
}

@media (max-width: 767px) {
  .content-wrapper,
  .right-side,
  .main-footer {
    margin-left: 0;
  }
}

@media (min-width: 768px) {
  .sidebar-collapse .content-wrapper,
  .sidebar-collapse .right-side,
  .sidebar-collapse .main-footer {
    margin-left: 0;
  }
}

@media (max-width: 767px) {
  .sidebar-open .content-wrapper,
  .sidebar-open .right-side,
  .sidebar-open .main-footer {
    -webkit-transform: translate(230px, 0);
    -ms-transform: translate(230px, 0);
    -o-transform: translate(230px, 0);
    transform: translate(230px, 0);
  }
}

.content-wrapper,
.right-side {
  min-height: 100%;
  background-color: var(--bg-light);
  z-index: 800;
}

/* Content */
.content {
  min-height: 250px;
  padding: 15px;
  margin-right: auto;
  margin-left: auto;
  padding-left: 15px;
  padding-right: 15px;
}

@media (min-width: 768px) {
  .content {
    padding: 20px;
  }
}

@media (min-width: 1200px) {
  .content {
    padding: 25px;
  }
}

/* Content Header */
.skin-purple .content-header {
  background: transparent;
  padding: 15px;
}

.page-header {
  margin: 10px 0 20px 0;
  font-size: 2.2rem;
}

.page-header > small {
  color: var(--text-medium);
  display: block;
  margin-top: 5px;
  font-size: 1.3rem;
}

/* Footer */
.main-footer {
  background: var(--bg-white);
  padding: 15px;
  color: var(--text-dark);
  border-top: 1px solid var(--border-light);
}

/* Fixed Layout */
.fixed .main-header,
.fixed .main-sidebar,
.fixed .left-side {
  position: fixed;
}

.fixed .main-header {
  top: 0;
  right: 0;
  left: 0;
}

.fixed .content-wrapper,
.fixed .right-side {
  padding-top: 50px;
}

@media (max-width: 767px) {
  .fixed .content-wrapper,
  .fixed .right-side {
    padding-top: 100px;
  }
}

.fixed.layout-boxed .wrapper {
  max-width: 100%;
}

body.hold-transition .content-wrapper,
body.hold-transition .right-side,
body.hold-transition .main-footer,
body.hold-transition .main-sidebar,
body.hold-transition .left-side,
body.hold-transition .main-header .navbar,
body.hold-transition .main-header .logo {
  -webkit-transition: none;
  -o-transition: none;
  transition: none;
}

/* ========================================
   MAIN HEADER
   ======================================== */
.main-header {
  position: relative;
  max-height: 100px;
  z-index: 1030;
}

.main-header .navbar {
  -webkit-transition: margin-left 0.3s ease-in-out;
  -o-transition: margin-left 0.3s ease-in-out;
  transition: margin-left 0.3s ease-in-out;
  margin-bottom: 0;
  margin-left: 230px;
  border: none;
  min-height: 50px;
  border-radius: 0;
  box-shadow: var(--shadow-sm);
}

.layout-top-nav .main-header .navbar {
  margin-left: 0;
}

/* Navbar - Purple Skin */
.skin-purple .main-header .navbar {
  background-color: var(--primary-color);
  background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-light) 100%);
}

.skin-purple .main-header .navbar .nav > li > a {
  color: #ffffff;
  transition: all 0.3s ease;
  font-size: 1.4rem;
}

.skin-purple .main-header .navbar .nav > li > a:hover,
.skin-purple .main-header .navbar .nav > li > a:active,
.skin-purple .main-header .navbar .nav > li > a:focus,
.skin-purple .main-header .navbar .nav .open > a,
.skin-purple .main-header .navbar .nav .open > a:hover,
.skin-purple .main-header .navbar .nav .open > a:focus,
.skin-purple .main-header .navbar .nav > .active > a {
  background: rgba(0, 0, 0, 0.15);
  color: #f6f6f6;
}

.skin-purple .main-header .navbar .nav > li > a > .label {
  position: absolute;
  top: 9px;
  right: 7px;
  text-align: center;
  font-size: 0.9rem;
  padding: 2px 3px;
  line-height: .9;
  border-radius: var(--border-radius-sm);
}

/* Sidebar Toggle */
.main-header .sidebar-toggle {
  float: left;
  background-color: transparent;
  background-image: none;
  padding: 15px 15px;
  font-family: "Roboto Flex", sans-serif;
  transition: all 0.3s ease;
}

.main-header .sidebar-toggle:before {
  content: "\f0c9";
  font-family: fontAwesome;
}

.skin-purple .main-header .navbar .sidebar-toggle {
  color: #ffffff;
}

.skin-purple .main-header .navbar .sidebar-toggle:hover {
  color: #f6f6f6;
  background: rgba(0, 0, 0, 0.15);
}

.main-header .sidebar-toggle:focus,
.main-header .sidebar-toggle:active {
  background: transparent;
}

.main-header .sidebar-toggle .icon-bar {
  display: none;
}

/* Logo */
.main-header .logo {
  -webkit-transition: width 0.3s ease-in-out;
  -o-transition: width 0.3s ease-in-out;
  transition: width 0.3s ease-in-out;
  display: block;
  float: left;
  height: 50px;
  font-size: 2rem;
  line-height: 50px;
  text-align: center;
  width: 230px;
  font-family: "Roboto Flex", sans-serif;
  padding: 0 15px;
  font-weight: 600;
  overflow: hidden;
}

.skin-purple .main-header .logo {
  background-color: var(--primary-color);
  color: #ffffff;
  border-bottom: 0 solid transparent;
  box-shadow: var(--shadow-sm);
}

.skin-purple .main-header .logo:hover {
  background-color: var(--primary-dark);
}

.main-header .logo .logo-lg {
  display: block;
}

.main-header .logo .logo-mini {
  display: none;
}

.main-header .navbar-brand {
  color: #fff;
}

/* User Header */
.skin-purple .main-header li.user-header {
  background-color: var(--primary-color);
}

/* Navbar Search */
.main-header #navbar-search-input.form-control {
  background: rgba(255, 255, 255, 0.2);
  border-color: transparent;
  color: #ffffff;
  border-radius: var(--border-radius-md);
}

.main-header #navbar-search-input.form-control:focus,
.main-header #navbar-search-input.form-control:active {
  border-color: rgba(0, 0, 0, 0.1);
  background: rgba(255, 255, 255, 0.9);
  color: var(--text-dark);
}

.main-header #navbar-search-input.form-control::-moz-placeholder {
  color: rgba(255, 255, 255, 0.7);
  opacity: 1;
}

.main-header #navbar-search-input.form-control:-ms-input-placeholder {
  color: rgba(255, 255, 255, 0.7);
}

.main-header #navbar-search-input.form-control::-webkit-input-placeholder {
  color: rgba(255, 255, 255, 0.7);
}

/* Navbar Custom Menu */
.main-header .navbar-custom-menu,
.main-header .navbar-right {
  float: right;
}

@media (max-width: 991px) {
  .main-header .navbar-custom-menu a,
  .main-header .navbar-right a {
    color: inherit;
    background: transparent;
  }
}

@media (max-width: 767px) {
  .main-header .navbar-right {
    float: none;
  }
  .navbar-collapse .main-header .navbar-right {
    margin: 7.5px -15px;
  }
  .main-header .navbar-right > li {
    color: inherit;
    border: 0;
  }
  
  .skin-purple .main-header .navbar .dropdown-menu li.divider {
    background-color: rgba(255, 255, 255, 0.1);
  }
  .skin-purple .main-header .navbar .dropdown-menu li a {
    color: #fff;
  }
  .skin-purple .main-header .navbar .dropdown-menu li a:hover {
    background: var(--primary-light);
  }
}

/* ========================================
   SIDEBAR
   ======================================== */

/* User Panel */
.skin-purple .user-panel > .info,
.skin-purple .user-panel > .info > a {
  color: #fff;
  font-size: 1.4rem;
}

/* Sidebar Menu Header */
.skin-purple .sidebar-menu > li.header {
  color: #000000;
  background: var(--sidebar-header);
  font-size: 1.2rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 10px 15px;
  font-weight: 600;
}

/* Sidebar Menu Items */
.skin-purple .sidebar-menu > li > a {
  border-left: 3px solid transparent;
  transition: all 0.3s ease;
  font-size: 1.4rem;
  padding: 12px 15px;
}

.skin-purple .sidebar-menu > li:hover > a,
.skin-purple .sidebar-menu > li.active > a {
  color: #ffffff;
  background: var(--sidebar-menu-hover);
  border-left-color: var(--primary-color);
  box-shadow: inset 3px 0 0 var(--primary-color);
}

.skin-purple .sidebar-menu > li > .treeview-menu {
  margin: 0 1px;
  background: var(--sidebar-submenu);
}
.sidebar-menu .treeview-menu > li {
  padding: 3px;
}

.skin-purple .sidebar a {
  color: #ffffff;
}

.skin-purple .sidebar a:hover {
  text-decoration: none;
}

.skin-purple .treeview-menu > li > a {
  color: #ffffff;
  font-size: 1.3rem;
  padding: 2px 2px 2px 2px;
  transition: all 0.3s ease;
}

.skin-purple .treeview-menu > li.active > a,
.skin-purple .treeview-menu > li > a:hover {
  color: #ffffff;
}

/* Sidebar Search Form */
.skin-purple .sidebar-form {
  border-radius: var(--border-radius-md);
  border: 1px solid #374850;
  margin: 10px 10px;
  overflow: hidden;
}

.skin-purple .sidebar-form input[type="text"],
.skin-purple .sidebar-form .btn {
  box-shadow: none;
  background-color: #374850;
  border: 1px solid transparent;
  height: 35px;
  transition: all 0.3s ease;
}

.skin-purple .sidebar-form input[type="text"] {
  color: #666;
  border-top-left-radius: var(--border-radius-md);
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: var(--border-radius-md);
}

.skin-purple .sidebar-form input[type="text"]:focus,
.skin-purple .sidebar-form input[type="text"]:focus + .input-group-btn .btn {
  background-color: #fff;
  color: #666;
}

.skin-purple .sidebar-form input[type="text"]:focus + .input-group-btn .btn {
  border-left-color: #fff;
}

.skin-purple .sidebar-form .btn {
  color: #999;
  border-top-left-radius: 0;
  border-top-right-radius: var(--border-radius-md);
  border-bottom-right-radius: var(--border-radius-md);
  border-bottom-left-radius: 0;
}

/* ========================================
   BOXES & PANELS - Modern Design
   ======================================== */

/* Small Box (Info Widget) */
.small-box {
  border-radius: var(--border-radius-lg);
  position: relative;
  display: block;
  margin-bottom: 20px;
  box-shadow: var(--shadow-md);
  transition: all 0.3s ease;
  overflow: hidden;
}

.small-box:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-lg);
}

.small-box.bg-purple {
  background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-light) 100%);
  color: #fff;
}

.small-box p {
  font-size: 1.4rem;
  margin: 0;
}

.small-box h3 {
  font-size: 3.2rem;
  font-weight: 700;
  margin: 0 0 10px 0;
}

.small-box .icon {
  font-size: 70px;
  transition: all 0.3s ease;
  position: absolute;
  top: 10px;
  right: 15px;
  opacity: 0.15;
}

.small-box:hover .icon {
  font-size: 80px;
  opacity: 0.25;
}

.small-box .small-box-footer {
  display: block;
  padding: 10px;
  text-align: center;
  background: rgba(0, 0, 0, 0.1);
  color: rgba(255, 255, 255, 0.8);
  text-decoration: none;
  font-size: 1.3rem;
  transition: all 0.3s ease;
}

.small-box .small-box-footer:hover {
  background: rgba(0, 0, 0, 0.2);
  color: #fff;
}

/* Info Box */
.info-box {
  border-radius: var(--border-radius-lg);
  display: flex;
  min-height: 90px;
  background: #fff;
  margin-bottom: 20px;
  box-shadow: var(--shadow-md);
  transition: all 0.3s ease;
  overflow: hidden;
}

.info-box:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-lg);
}

.info-box-icon {
  border-top-left-radius: var(--border-radius-lg);
  border-bottom-left-radius: var(--border-radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 90px;
  font-size: 4rem;
  color: #fff;
}

.info-box-content {
  padding: 10px 15px;
  flex: 1;
}

.info-box-text {
  font-size: 1.3rem;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--text-medium);
  margin-bottom: 5px;
}

.info-box-number {
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--text-dark);
}

.progress-description {
  font-size: 1.2rem;
  color: var(--text-light);
  margin-top: 5px;
}

/* Standard Box */
.box {
  border-radius: var(--border-radius-lg);
  border: 1px solid var(--border-color);
  background: #fff;
  margin-bottom: 20px;
  box-shadow: var(--shadow-md);
  position: relative;
  transition: all 0.3s ease;
}

.box:hover {
  box-shadow: var(--shadow-lg);
}

.box-header {
  padding: 15px 20px;
  border-bottom: 1px solid var(--border-light);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.box.box-solid.box-default > .box-header {
  border-top-right-radius: var(--border-radius-lg);
  border-top-left-radius: var(--border-radius-lg);
  background-color: var(--primary-lighter);
  color: #fff;
  border-bottom: none;
}

.box-header > .fa,
.box-header > .glyphicon,
.box-header > .ion,
.box-header .box-title {
  display: inline-block;
  font-size: 1.6rem;
  /*margin-left: 10px;*/
  line-height: 1;
  font-weight: 400;
}

.box-body {
  padding: 10px;
}

.box-footer {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: var(--border-radius-lg);
  border-bottom-left-radius: var(--border-radius-lg);
  border-top: 1px solid var(--border-light);
  padding: 15px 20px;
  background-color: #fafafa;
}

/* Box Variants - Only Border */
.box.box-primary {
  border-top: 4px solid var(--primary-color);
}
.box.box-primary-left {
  border-left: 4px solid var(--primary-color);
}

.box.box-success {
  border-top: 4px solid var(--success-color);
}

.box.box-info {
  border-top: 4px solid var(--info-color);
}

.box.box-warning {
  border-top: 4px solid var(--warning-color);
}

.box.box-danger {
  border-top: 4px solid var(--danger-color);
}

/* Box Solid - Fully Colored Boxes */
.box.box-solid.box-primary > .box-header {
  background-color: var(--primary-color);
  background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-light) 100%);
  color: #fff;
  border: none;
}

.box.box-solid.box-primary {
  border: 1px solid var(--primary-color);
}

.box.box-solid.box-success > .box-header {
  background-color: var(--success-color);
  background: linear-gradient(135deg, var(--success-color) 0%, #4ed99f 100%);
  color: #fff;
  border: none;
}

.box.box-solid.box-success {
  border: 1px solid var(--success-color);
}

.box.box-solid.box-info > .box-header {
  background-color: var(--info-color);
  background: linear-gradient(135deg, var(--info-color) 0%, #a0e2f3 100%);
  color: #fff;
  border: none;
}

.box.box-solid.box-info {
  border: 1px solid var(--info-color);
}

.box.box-solid.box-warning > .box-header {
  background-color: var(--warning-color);
  background: linear-gradient(135deg, var(--warning-color) 0%, #efd09d 100%);
  color: #fff;
  border: none;
}

.box.box-solid.box-warning {
  border: 1px solid var(--warning-color);
}

.box.box-solid.box-danger > .box-header {
  background-color: var(--danger-color);
  background: linear-gradient(135deg, var(--danger-color) 0%, #e48e82 100%);
  color: #fff;
  border: none;
}

.box.box-solid.box-danger {
  border: 1px solid var(--danger-color);
}

/* ========================================
   BUTTONS - Modern Design
   ======================================== */
.btn {
  border-radius: var(--border-radius-md);
  font-weight: 500;
  transition: all 0.3s ease;
  font-size: 1.4rem;
  padding: 8px 16px;
  border: none;
  box-shadow: var(--shadow-sm);
}

.btn:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.btn:active {
  transform: translateY(0);
  box-shadow: var(--shadow-sm);
}

.btn-group-vertical > .btn:last-child:not(:first-child) {
  border-radius: var(--border-radius-md);
}

/* Button Primary - Purple */
.btn-primary {
  background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-light) 100%);
  border-color: var(--primary-dark);
  color: #ffffff;
}

.btn-primary:hover,
.btn-primary:active,
.btn-primary.hover,
.btn-primary:focus {
  background: linear-gradient(135deg, var(--primary-dark) 0%, var(--primary-color) 100%);
  border-color: var(--primary-darker);
  color: #ffffff;
}

/* Button Success */
.btn-success {
  background: linear-gradient(135deg, var(--success-color) 0%, #4ed99f 100%);
  border-color: var(--success-dark);
  color: #ffffff;
}

.btn-success:hover,
.btn-success:active,
.btn-success.hover,
.btn-success:focus {
  background: linear-gradient(135deg, var(--success-dark) 0%, var(--success-color) 100%);
  border-color: #268d5e;
  color: #ffffff;
}

/* Button Info */
.btn-info {
  background: linear-gradient(135deg, var(--info-color) 0%, #a0e2f3 100%);
  border-color: var(--info-dark);
  color: #ffffff;
}

.btn-info:hover,
.btn-info:active,
.btn-info.hover,
.btn-info:focus {
  background: linear-gradient(135deg, var(--info-dark) 0%, var(--info-color) 100%);
  border-color: #4aa5c0;
  color: #ffffff;
}

/* Button Warning */
.btn-warning {
  background: linear-gradient(135deg, var(--warning-color) 0%, #efd09d 100%);
  border-color: var(--warning-dark);
  color: #ffffff;
}

.btn-warning:hover,
.btn-warning:active,
.btn-warning.hover,
.btn-warning:focus {
  background: linear-gradient(135deg, var(--warning-dark) 0%, var(--warning-color) 100%);
  border-color: #c08e47;
  color: #ffffff;
}

/* Button Danger */
.btn-danger {
  background: linear-gradient(135deg, var(--danger-color) 0%, #e48e82 100%);
  border-color: var(--danger-dark);
  color: #ffffff;
}

.btn-danger:hover,
.btn-danger:active,
.btn-danger.hover,
.btn-danger:focus {
  background: linear-gradient(135deg, var(--danger-dark) 0%, var(--danger-color) 100%);
  border-color: #b54a3e;
  color: #ffffff;
}

/* ========================================
   BACKGROUND COLORS - Modern Palette
   ======================================== */

/* Primary Colors */
.bg-purple {
  background-color: var(--primary-color) !important;
  color: #fff;
}

.bg-light-blue,
.label-primary,
.modal-primary .modal-body {
  background-color: var(--primary-color) !important;
  color: #fff;
}

.bg-purple-active {
  background-color: var(--primary-dark) !important;
  color: #fff;
}

.bg-light-blue-active,
.modal-primary .modal-header,
.modal-primary .modal-footer {
  background-color: var(--primary-dark) !important;
  color: #fff;
}

/* Status Colors */
.bg-green,
.callout.callout-success,
.alert-success,
.label-success,
.modal-success .modal-body {
  background-color: var(--success-color) !important;
  color: #fff;
}

.bg-green-active,
.modal-success .modal-header,
.modal-success .modal-footer {
  background-color: var(--success-dark) !important;
  color: #fff;
}

.bg-red,
.callout.callout-danger,
.alert-danger,
.alert-error,
.label-danger,
.modal-danger .modal-body {
  background-color: var(--danger-color) !important;
  color: #fff;
}

.bg-red-active,
.modal-danger .modal-header,
.modal-danger .modal-footer {
  background-color: var(--danger-dark) !important;
  color: #fff;
}

.bg-yellow,
.callout.callout-warning,
.alert-warning,
.label-warning,
.modal-warning .modal-body {
  background-color: var(--warning-color) !important;
  color: #fff;
}

.bg-yellow-active,
.modal-warning .modal-header,
.modal-warning .modal-footer {
  background-color: var(--warning-dark) !important;
  color: #fff;
}

.bg-aqua,
.callout.callout-info,
.alert-info,
.label-info,
.modal-info .modal-body {
  background-color: var(--info-color) !important;
  color: #fff;
}

.bg-aqua-active,
.modal-info .modal-header,
.modal-info .modal-footer {
  background-color: var(--info-dark) !important;
  color: #fff;
}

/* Additional Colors */
.bg-blue {
  background-color: var(--blue-color) !important;
  color: #fff;
}

.bg-blue-active {
  background-color: #3f96c6 !important;
  color: #fff;
}

.bg-navy {
  background-color: #001f3f !important;
  color: #fff;
}

.bg-navy-active {
  background-color: #001a35 !important;
  color: #fff;
}

.bg-teal {
  background-color: var(--teal-color) !important;
  color: #fff;
}

.bg-teal-active {
  background-color: #30bbbb !important;
  color: #fff;
}

.bg-olive {
  background-color: #3d9970 !important;
  color: #fff;
}

.bg-olive-active {
  background-color: #368763 !important;
  color: #fff;
}

.bg-lime {
  background-color: #01ff70 !important;
  color: #111;
}

.bg-lime-active {
  background-color: #00e765 !important;
  color: #111;
}

.bg-orange {
  background-color: var(--orange-color) !important;
  color: #fff;
}

.bg-orange-active {
  background-color: #ff7701 !important;
  color: #fff;
}

.bg-fuchsia {
  background-color: var(--fuchsia-color) !important;
  color: #fff;
}

.bg-fuchsia-active {
  background-color: #c72da1 !important;
  color: #fff;
}

.bg-maroon {
  background-color: var(--maroon-color) !important;
  color: #fff;
}

.bg-maroon-active {
  background-color: #c52a61 !important;
  color: #fff;
}

.bg-gray-active {
  color: #000;
  background-color: #b5bbc8 !important;
}

.bg-black-active {
  background-color: #000000 !important;
  color: #fff;
}

/* Background Gradients */
.bg-purple-gradient {
  background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-light) 100%) !important;
  color: #fff;
}

.bg-light-blue-gradient {
  background: linear-gradient(135deg, var(--primary-color) 0%, var(--primary-lighter) 100%) !important;
  color: #fff;
}

.bg-green-gradient {
  background: linear-gradient(135deg, var(--success-color) 0%, #4ed99f 100%) !important;
  color: #fff;
}

.bg-red-gradient {
  background: linear-gradient(135deg, var(--danger-color) 0%, #e48e82 100%) !important;
  color: #fff;
}

.bg-yellow-gradient {
  background: linear-gradient(135deg, var(--warning-color) 0%, #efd09d 100%) !important;
  color: #fff;
}

.bg-aqua-gradient {
  background: linear-gradient(135deg, var(--info-color) 0%, #a0e2f3 100%) !important;
  color: #fff;
}

.bg-blue-gradient {
  background: linear-gradient(135deg, var(--blue-color) 0%, #7fcbf7 100%) !important;
  color: #fff;
}

.bg-teal-gradient {
  background: linear-gradient(135deg, var(--teal-color) 0%, #80f5f5 100%) !important;
  color: #fff;
}

.bg-black-gradient {
  background: linear-gradient(135deg, #111111 0%, #2b2b2b 100%) !important;
  color: #fff;
}

.bg-maroon-gradient {
  background: linear-gradient(135deg, var(--maroon-color) 0%, #ee6a9a 100%) !important;
  color: #fff;
}

/* ========================================
   TEXT COLORS
   ======================================== */
.text-red {
  color: var(--danger-color) !important;
}

.text-yellow {
  color: var(--warning-color) !important;
}

.text-aqua {
  color: var(--info-color) !important;
}

.text-blue {
  color: var(--blue-color) !important;
}

.text-black {
  color: #111111 !important;
}

.text-light-blue {
  color: var(--primary-color) !important;
}

.text-green {
  color: var(--success-color) !important;
}

.text-gray {
  color: #d2d6de !important;
}

.text-navy {
  color: #001f3f !important;
}

.text-teal {
  color: #39cccc !important;
}

.text-olive {
  color: #3d9970 !important;
}

.text-lime {
  color: #01ff70 !important;
}

.text-orange {
  color: var(--orange-color) !important;
}

.text-fuchsia {
  color: var(--fuchsia-color) !important;
}

.text-purple {
  color: var(--primary-light) !important;
}

.text-maroon {
  color: var(--maroon-color) !important;
}

.text-muted {
  color: var(--text-light) !important;
}

/* ========================================
   ALERTS & CALLOUTS
   ======================================== */

/* Alerts */
.alert {
  border-radius: var(--border-radius-md);
  border-width: 1px;
  border-style: solid;
  padding: 15px 20px;
  margin-bottom: 20px;
  box-shadow: var(--shadow-sm);
}

.alert-primary {
  background-color: rgba(120, 19, 215, 0.1);
  border-color: var(--primary-color);
  color: var(--primary-darker);
}

.alert-primary .alert-link {
  color: var(--primary-darker);
  font-weight: 600;
}

.alert-success {
  background-color: rgba(59, 204, 139, 0.1);
  border-color: var(--success-color);
  color: var(--success-dark);
}

.alert-success .alert-link {
  color: var(--success-dark);
  font-weight: 600;
}

.alert-danger,
.alert-error {
  background-color: rgba(221, 116, 102, 0.1);
  border-color: var(--danger-color);
  color: var(--danger-dark);
}

.alert-danger .alert-link,
.alert-error .alert-link {
  color: var(--danger-dark);
  font-weight: 600;
}

.alert-warning {
  background-color: rgba(232, 193, 131, 0.1);
  border-color: var(--warning-color);
  color: var(--warning-dark);
}

.alert-warning .alert-link {
  color: var(--warning-dark);
  font-weight: 600;
}

.alert-info {
  background-color: rgba(137, 214, 233, 0.1);
  border-color: var(--info-color);
  color: var(--info-dark);
}

.alert-info .alert-link {
  color: var(--info-dark);
  font-weight: 600;
}

/* Callouts */
.callout {
  border-radius: var(--border-radius-md);
  border-left: 5px solid #eee;
  margin-bottom: 20px;
  padding: 15px 20px;
  box-shadow: var(--shadow-sm);
}

.callout.callout-primary {
  background-color: rgba(120, 19, 215, 0.05);
  border-color: var(--primary-color);
}

.callout.callout-primary h4 {
  color: var(--primary-color);
}

.callout.callout-danger {
  background-color: rgba(221, 116, 102, 0.05);
  border-color: var(--danger-dark);
}

.callout.callout-danger h4 {
  color: var(--danger-color);
}

.callout.callout-warning {
  background-color: rgba(232, 193, 131, 0.05);
  border-color: var(--warning-dark);
}

.callout.callout-warning h4 {
  color: var(--warning-color);
}

.callout.callout-info {
  background-color: rgba(137, 214, 233, 0.05);
  border-color: var(--info-dark);
}

.callout.callout-info h4 {
  color: var(--info-color);
}

.callout.callout-success {
  background-color: rgba(59, 204, 139, 0.05);
  border-color: var(--success-dark);
}

.callout.callout-success h4 {
  color: var(--success-color);
}

/* Alert Solid Variants - Full Background */
.alert.alert-solid-primary,
.alert-primary.alert-dismissible {
  background-color: var(--primary-color);
  border-color: var(--primary-dark);
  color: #fff;
}

.alert.alert-solid-success {
  background-color: var(--success-color);
  border-color: var(--success-dark);
  color: #fff;
}

.alert.alert-solid-danger,
.alert.alert-solid-error {
  background-color: var(--danger-color);
  border-color: var(--danger-dark);
  color: #fff;
}

.alert.alert-solid-warning {
  background-color: var(--warning-color);
  border-color: var(--warning-dark);
  color: #fff;
}

.alert.alert-solid-info {
  background-color: var(--info-color);
  border-color: var(--info-dark);
  color: #fff;
}

/* ========================================
   TODO LIST & CHAT
   ======================================== */

/* Todo List */
.todo-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.todo-list > li {
  border-radius: var(--border-radius-md);
  background: #fff;
  margin-bottom: 10px;
  padding: 12px 15px;
  border-left: 3px solid #ddd;
  box-shadow: var(--shadow-sm);
  transition: all 0.3s ease;
}

.todo-list > li:hover {
  box-shadow: var(--shadow-md);
}

.todo-list .danger {
  border-left-color: var(--danger-color);
}

.todo-list .warning {
  border-left-color: var(--warning-color);
}

.todo-list .info {
  border-left-color: var(--info-color);
}

.todo-list .success {
  border-left-color: var(--success-color);
}

.todo-list .primary {
  border-left-color: var(--primary-color);
}

.todo-list > li .tools {
  color: var(--danger-color);
  display: none;
}

.todo-list > li:hover .tools {
  display: inline-block;
}

/* Chat */
.chat .item > .online {
  border: 2px solid var(--success-color);
  border-radius: 50%;
}

.chat .item > .offline {
  border: 2px solid var(--danger-color);
  border-radius: 50%;
}

/* ========================================
   NAVIGATION - Pills & Tabs
   ======================================== */

/* Nav Pills */
.nav-pills > li.active > a,
.nav-pills > li.active > a:hover,
.nav-pills > li.active > a:focus {
  background-color: var(--primary-color);
  border-top-color: var(--primary-color);
  color: #fff;
}

.nav-stacked > li.active > a,
.nav-stacked > li.active > a:hover {
  background-color: var(--primary-color);
  border-left-color: var(--primary-color);
  color: #fff;
}

/* Nav Tabs Custom */
.nav-tabs-custom {
  margin-bottom: 20px;
  background: #fff;
  box-shadow: var(--shadow-md);
  border-radius: var(--border-radius-lg);
  overflow: hidden;
}

.nav-tabs-custom > .nav-tabs {
  border-bottom: 2px solid #f4f4f4;
}

.nav-tabs-custom > .nav-tabs > li {
  border-top: 3px solid transparent;
}

.nav-tabs-custom > .nav-tabs > li.active {
  border-top-color: var(--primary-color);
}

.nav-tabs-custom > .nav-tabs > li.active > a {
  color: var(--primary-color);
  font-weight: 600;
}

.nav-tabs-custom > .tab-content {
  padding: 20px;
}

/* ========================================
   FORMS & INPUTS
   ======================================== */
.form-control {
  border-radius: var(--border-radius-sm);
  border: 1px solid var(--border-light);
  font-size: 1.2rem;
  transition: all 0.3s ease;
  box-shadow: none;
}

.form-control:focus {
  border-color: var(--primary-color);
  box-shadow: 0 0 0 0.2rem rgba(120, 19, 215, 0.25);
  outline: none;
}

.input-group-addon {
  border-radius: var(--border-radius-md);
  background-color: #f7f7f7;
  border: 1px solid var(--border-light);
}

/* ========================================
   LABELS & BADGES
   ======================================== */
.label {
  border-radius: var(--border-radius-sm);
  font-size: 1.1rem;
  font-weight: 600;
  padding: 0.3em 0.6em;
}

.badge {
  border-radius: var(--border-radius-lg);
  font-size: 1.1rem;
  font-weight: 600;
  padding: 4px 8px;
}

/* ========================================
   TABLES
   ======================================== */
.table {
  font-size: 1.4rem;
}

.table > thead > tr > th {
  border-bottom: 2px solid var(--border-light);
  font-weight: 600;
  text-transform: uppercase;
  font-size: 1.2rem;
  letter-spacing: 0.5px;
  color: var(--text-medium);
}

.table-bordered {
  border: 1px solid var(--border-light);
  border-radius: var(--border-radius-md);
  overflow: hidden;
}

.table-striped > tbody > tr:nth-of-type(odd) {
  background-color: rgba(120, 19, 215, 0.02);
}

.table-hover > tbody > tr:hover {
  background-color: rgba(120, 19, 215, 0.05);
}

/* ========================================
   MODALS
   ======================================== */
.modal-content {
  border-radius: var(--border-radius-lg);
  border: none;
  box-shadow: var(--shadow-xl);
}

.modal-header {
  border-bottom: 1px solid var(--border-light);
  border-top-left-radius: var(--border-radius-lg);
  border-top-right-radius: var(--border-radius-lg);
  padding: 20px 25px;
}

.modal-body {
  padding: 25px;
}

.modal-footer {
  border-top: 1px solid var(--border-light);
  border-bottom-left-radius: var(--border-radius-lg);
  border-bottom-right-radius: var(--border-radius-lg);
  padding: 15px 25px;
}

/* ========================================
   PAGINATION
   ======================================== */
.pagination > li > a,
.pagination > li > span {
  border-radius: var(--border-radius-md);
  margin: 0 3px;
  border: 1px solid var(--border-light);
  color: var(--primary-color);
  transition: all 0.3s ease;
}

.pagination > li > a:hover {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
  color: #fff;
}

.pagination > .active > a,
.pagination > .active > span {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
}

/* ========================================
   PROGRESS BARS
   ======================================== */
.progress {
  height: 20px;
  border-radius: var(--border-radius-lg);
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
  background-color: #f5f5f5;
  overflow: hidden;
}

.progress-bar {
  border-radius: var(--border-radius-lg);
  font-size: 1.2rem;
  line-height: 20px;
  transition: width 0.6s ease;
  box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.15);
}

.progress-bar-primary {
  background-color: var(--primary-color);
}

.progress-bar-success {
  background-color: var(--success-color);
}

.progress-bar-info {
  background-color: var(--info-color);
}

.progress-bar-warning {
  background-color: var(--warning-color);
}

.progress-bar-danger {
  background-color: var(--danger-color);
}

/* ========================================
   BOOTSTRAP OVERRIDES - FORCE PURPLE PRIMARY
   ======================================== */

/* Links - Override Bootstrap default blue */
a {
  color: var(--primary-color);
  text-decoration: none;
  transition: all 0.3s ease;
}

a:hover,
a:active,
a:focus {
  outline: none;
  text-decoration: none;
  color: var(--primary-dark);
}

/* Bootstrap Panel Primary Override */
.panel-primary {
  border-color: var(--primary-color);
}

.panel-primary > .panel-heading {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
  color: #fff;
}

/* Bootstrap List Group Primary */
.list-group-item.active,
.list-group-item.active:hover,
.list-group-item.active:focus {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
  color: #fff;
}

/* Bootstrap Wells */
.well-primary {
  background-color: rgba(120, 19, 215, 0.1);
  border-color: var(--primary-color);
}

/* Bootstrap Text Colors */
.text-primary {
  color: var(--primary-color) !important;
}

a.text-primary:hover,
a.text-primary:focus {
  color: var(--primary-dark) !important;
}

/* Bootstrap Background Colors */
.bg-primary {
  background-color: var(--primary-color) !important;
  color: #fff;
}

a.bg-primary:hover,
a.bg-primary:focus {
  background-color: var(--primary-dark) !important;
}

/* Bootstrap Contextual Colors Override */
.has-success .help-block,
.has-success .control-label,
.has-success .radio,
.has-success .checkbox,
.has-success .radio-inline,
.has-success .checkbox-inline {
  color: var(--success-color);
}

.has-success .form-control {
  border-color: var(--success-color);
}

.has-success .form-control:focus {
  border-color: var(--success-dark);
  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px rgba(59, 204, 139, 0.6);
}

.has-warning .help-block,
.has-warning .control-label,
.has-warning .radio,
.has-warning .checkbox,
.has-warning .radio-inline,
.has-warning .checkbox-inline {
  color: var(--warning-color);
}

.has-warning .form-control {
  border-color: var(--warning-color);
}

.has-warning .form-control:focus {
  border-color: var(--warning-dark);
  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px rgba(232, 193, 131, 0.6);
}

.has-error .help-block,
.has-error .control-label,
.has-error .radio,
.has-error .checkbox,
.has-error .radio-inline,
.has-error .checkbox-inline {
  color: var(--danger-color);
}

.has-error .form-control {
  border-color: var(--danger-color);
}

.has-error .form-control:focus {
  border-color: var(--danger-dark);
  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 6px rgba(221, 116, 102, 0.6);
}

/* ========================================
   UTILITY CLASSES
   ======================================== */

/* Spacing */
.no-padding {
  padding: 0 !important;
}

.no-margin {
  margin: 0 !important;
}

.no-pad-top {
  padding-top: 0 !important;
}

/* Display */
.hide {
  display: none !important;
}

.show {
  display: block !important;
}

/* Position */
.position-static {
  position: static !important;
}

/* Border Radius */
.flat {
  border-radius: 0 !important;
}

.rounded {
  border-radius: var(--border-radius-md) !important;
}

.rounded-lg {
  border-radius: var(--border-radius-lg) !important;
}

/* Opacity */
.full-opacity-hover {
  opacity: 0.65;
  filter: alpha(opacity=65);
  transition: opacity 0.3s ease;
}

.full-opacity-hover:hover {
  opacity: 1;
  filter: alpha(opacity=100);
}

/* Lists */
.list-header {
  font-size: 1.5rem;
  padding: 10px 4px;
  font-weight: bold;
  color: var(--text-medium);
}

.list-seperator {
  height: 1px;
  background: #f4f4f4;
  margin: 15px 0 9px 0;
}

.list-link > a {
  padding: 4px;
  color: #777;
  transition: color 0.3s ease;
}

.list-link > a:hover {
  color: #222;
}

/* User Block */
.user-block:before,
.user-block:after {
  content: " ";
  display: table;
}

.user-block:after {
  clear: both;
}

.user-block img {
  width: 40px;
  height: 40px;
  float: left;
  border-radius: 50%;
  box-shadow: var(--shadow-sm);
}

.user-block .username,
.user-block .description,
.user-block .comment {
  display: block;
  margin-left: 50px;
}

.user-block .username {
  font-size: 1.6rem;
  font-weight: 600;
}

.user-block .description {
  color: var(--text-light);
  font-size: 1.3rem;
}

/* Images */
.img-sm,
.img-md,
.img-lg {
  float: left;
  border-radius: 50%;
  box-shadow: var(--shadow-sm);
}

.img-sm {
  width: 30px !important;
  height: 30px !important;
}

.img-md {
  width: 60px !important;
  height: 60px !important;
}

.img-lg {
  width: 100px !important;
  height: 100px !important;
}

.img-bordered {
  border: 3px solid var(--border-light);
  padding: 3px;
  border-radius: 50%;
}

.img-bordered-sm {
  border: 2px solid var(--border-light);
  padding: 2px;
  border-radius: 50%;
}

/* Attachment Block */
.attachment-block {
  border: 1px solid #f4f4f4;
  padding: 10px;
  margin-bottom: 10px;
  background: #f7f7f7;
  border-radius: var(--border-radius-md);
}

.attachment-block .attachment-img {
  max-width: 100px;
  max-height: 100px;
  height: auto;
  float: left;
  border-radius: var(--border-radius-sm);
}

.attachment-block .attachment-pushed {
  margin-left: 110px;
}

.attachment-block .attachment-heading {
  margin: 0;
  font-weight: 600;
}

.attachment-block .attachment-text {
  color: var(--text-medium);
}

/* Chart */
.chart {
  position: relative;
  overflow: hidden;
  width: 100%;
}

.chart svg,
.chart canvas {
  width: 100% !important;
}

/* Description Block */
.description-block {
  text-align: center;
}

.description-block .description-icon {
  font-size: 1.6rem;
}

.description-block .description-header {
  font-size: 1.6rem;
  font-weight: 600;
  margin-bottom: 5px;
}

.description-block .description-text {
  font-size: 1.3rem;
  color: var(--text-light);
}

/* Sortable */
.connectedSortable {
  min-height: 100px;
}

.sort-highlight {
  background: #f4f4f4;
  border: 1px dashed #ddd;
  margin-bottom: 10px;
  border-radius: var(--border-radius-md);
}

/* jQuery UI */
.ui-helper-hidden-accessible {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

/* Tooltip */
.jqstooltip {
  padding: 5px !important;
  width: auto !important;
  height: auto !important;
  border-radius: var(--border-radius-sm) !important;
}

/* ========================================
   PRINT STYLES
   ======================================== */
@media print {
  .no-print,
  .main-sidebar,
  .left-side,
  .main-header,
  .content-header {
    display: none !important;
  }
  
  .content-wrapper,
  .right-side,
  .main-footer {
    margin-left: 0 !important;
    min-height: 0 !important;
    -webkit-transform: translate(0, 0) !important;
    -ms-transform: translate(0, 0) !important;
    -o-transform: translate(0, 0) !important;
    transform: translate(0, 0) !important;
  }
  
  .fixed .content-wrapper,
  .fixed .right-side {
    padding-top: 0 !important;
  }
  
  .invoice {
    width: 100%;
    border: 0;
    margin: 0;
    padding: 0;
  }
  
  .invoice-col {
    float: left;
    width: 33.3333333%;
  }
  
  .table-responsive {
    overflow: auto;
  }
  
  .table-responsive > .table tr th,
  .table-responsive > .table tr td {
    white-space: normal !important;
  }
}

/* ========================================
   ANIMATIONS & TRANSITIONS
   ======================================== */
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes slideInUp {
  from {
    transform: translateY(20px);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

.fade-in {
  animation: fadeIn 0.3s ease-in;
}

.slide-in-up {
  animation: slideInUp 0.4s ease-out;
}

/* Smooth Scrolling */
html {
  scroll-behavior: smooth;
}

/* ========================================
   RESPONSIVE ADJUSTMENTS
   ======================================== */

/* Extra Small Devices */
@media (max-width: 480px) {
  .small-box h3 {
    font-size: 2.4rem;
  }
  
  .small-box .icon {
    font-size: 50px;
  }
  
  .info-box {
    flex-direction: column;
    text-align: center;
  }
  
  .info-box-icon {
    width: 100%;
    border-radius: var(--border-radius-lg) var(--border-radius-lg) 0 0;
    padding: 20px;
  }
  
  .box-header {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* Small Devices */
@media (max-width: 767px) {
  .content {
    padding: 15px 10px;
  }
  
  .box {
    margin-bottom: 15px;
  }
  
  .box-header,
  .box-body,
  .box-footer {
    padding: 12px 15px;
  }
}

/* Medium Devices */
@media (min-width: 768px) and (max-width: 991px) {
  .content {
    padding: 20px 15px;
  }
}

/* Large Devices */
@media (min-width: 992px) {
  .box-body {
    padding: 15px;
  }
}


/*
    BOX COMPONENT - Modern Design
    ======================================== */


.select2-container--default .select2-selection--single {
  border-radius: var(--border-radius-sm);
  border: 1px solid var(--border-light);
  height: 38px;
  font-size: 1.2rem;
  transition: all 0.3s ease;
}

/* ========================================
   GLOBAL MODERN COMPACT OVERRIDES (2026)
   ======================================== */

:root {
  --app-purple-900: #2b114a;
  --app-purple-800: #3a1763;
  --app-purple-700: #5a2496;
  --app-purple-600: #7a31c0;
  --app-purple-500: #9340d6;
  --app-purple-400: #af67e7;
  --app-surface: #f7f4ff;
  --app-surface-2: #ffffff;
  --app-border: #ded1f3;
  --app-text: #2e2a37;
}

html,
body {
  font-size: 10px;
}

body {
  font-family: "Roboto Flex", "Segoe UI", Arial, sans-serif;
  font-weight: 380;
  color: var(--app-text);
  line-height: 1.35;
  background: #f6f7f9;
}

.content-wrapper {
  background-color: transparent;
  position: relative;
}

.content-wrapper:before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 1;
  background: linear-gradient(180deg, rgba(255,255,255,.92) 0%, rgba(246,247,249,.96) 100%);
}

.content {
  position: relative;
  z-index: 1;
  padding: 10px 12px;
}

@keyframes appPurpleFlow {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}

.skin-purple .main-header .navbar,
.skin-purple .main-header .logo {
  background: linear-gradient(90deg, var(--app-purple-700) 0%, var(--app-purple-500) 100%);
}

.skin-purple .main-sidebar,
.skin-purple .left-side {
  background: linear-gradient(180deg, var(--app-purple-800) 0%, var(--app-purple-900) 100%);
}

.skin-purple .sidebar-menu > li > a {
  border-left-width: 2px;
  padding: 9px 10px;
  font-size: 1.2rem;
}

.skin-purple .sidebar-menu > li.active > a,
.skin-purple .sidebar-menu > li:hover > a {
  background: rgba(255,255,255,.10);
}

.box {
  border-radius: 10px;
  border: 1px solid var(--app-border);
  box-shadow: 0 4px 12px rgba(43,17,74,.08);
  margin-bottom: 10px;
  background: var(--app-surface-2);
}

.box-header {
  padding: 8px 10px;
}

.box-title {
  font-size: 1.4rem;
  font-weight: 620;
}

.box-body,
.box-footer {
  padding: 8px 10px;
}

.nav-tabs-custom > .nav-tabs > li > a {
  font-size: 1.2rem;
  padding: 7px 10px;
}

.table {
  margin-bottom: 8px;
  font-size: 1.15rem;
}

.table > thead > tr > th {
  padding: 6px 6px;
  white-space: nowrap;
  font-weight: 650;
  line-height: 1.2;
}

.table > tbody > tr > td {
  padding: 5px 6px;
  line-height: 1.25;
  vertical-align: middle;
}

.dataTables_wrapper .dataTables_filter input {
  height: 30px;
  font-size: 1.2rem;
}

.dataTables_wrapper .dataTables_length select {
  height: 30px;
  padding: 2px 4px;
  font-size: 1.2rem;
}

.form-control {
  height: 32px;
  padding: 5px 8px;
  font-size: 1.2rem;
  border-radius: 7px;
  border-color: var(--app-border);
}

textarea.form-control {
  height: auto;
  min-height: 68px;
}

.input-group-addon,
.input-group-btn .btn {
  padding: 6px 8px;
  font-size: 1.2rem;
}

.btn {
  border-radius: 7px;
  font-size: 1.15rem;
  padding: 5px 10px;
  line-height: 1.25;
}

.btn.btn-xs {
  padding: 3px 7px;
  font-size: 1.05rem;
}

.btn.btn-sm {
  padding: 4px 8px;
  font-size: 1.1rem;
}

.label,
.badge {
  font-size: 1rem;
  font-weight: 600;
}

.main-footer {
  font-size: 1.1rem;
  padding: 8px 12px;
}

@media (max-width: 991px) {
  .content {
    padding: 8px;
  }

  .box-header,
  .box-body,
  .box-footer {
    padding: 7px 8px;
  }
}

/* ========================================
   SIDEBAR FLYOUT & VISIBILITY FIXES
   ======================================== */
@media (min-width: 768px) {
  .sidebar-mini.sidebar-collapse .sidebar-menu > li:hover > a > span:not(.pull-right),
  .sidebar-mini.sidebar-collapse .sidebar-menu > li:hover > a > .pull-right-container,
  .sidebar-mini.sidebar-collapse .sidebar-menu > li:hover > .treeview-menu {
    background: #3a1763 !important;
    color: #fff !important;
    border: 1px solid rgba(255,255,255,.16);
    box-shadow: 0 8px 22px rgba(20, 8, 36, .32);
    opacity: 1 !important;
  }

  .sidebar-mini.sidebar-collapse .sidebar-menu > li:hover > .treeview-menu {
    border-radius: 0 8px 8px 0;
    padding: 6px;
  }

  .sidebar-mini:not(.sidebar-collapse) .sidebar-menu > li.treeview {
    position: relative;
  }

  .sidebar-mini:not(.sidebar-collapse) .sidebar-menu > li.treeview > .treeview-menu {
    display: none !important;
    position: absolute;
    left: 100%;
    top: 0;
    min-width: 260px;
    margin: 0 0 0 2px;
    padding: 6px;
    z-index: 1060;
    background: #3a1763;
    border: 1px solid rgba(255,255,255,.16);
    border-radius: 0 8px 8px 8px;
    box-shadow: 0 10px 26px rgba(20, 8, 36, .34);
  }

  .sidebar-mini:not(.sidebar-collapse) .sidebar-menu > li.treeview:hover > .treeview-menu {
    display: block !important;
  }

  .sidebar-mini:not(.sidebar-collapse) .sidebar-menu > li.treeview > .treeview-menu > li > a {
    padding: 7px 10px;
    border-radius: 6px;
    white-space: nowrap;
  }

  .sidebar-mini:not(.sidebar-collapse) .sidebar-menu > li.treeview > .treeview-menu > li > a:hover,
  .sidebar-mini:not(.sidebar-collapse) .sidebar-menu > li.treeview > .treeview-menu > li.active > a {
    background: rgba(255,255,255,.12);
  }
}