/**
 * HSMS Theme - Pink/Magenta Palette with Responsive Design
 * Primary: #eb21d4 | Light: #fec2d4
 */

:root {
  --hsms-primary: #eb21d4;
  --hsms-primary-dark: #c91bb5;
  --hsms-primary-light: #f259e3;
  --hsms-light: #fec2d4;
  --hsms-light-soft: #ffe8ee;
  --hsms-light-bg: #fff5f8;
}

/* Global Responsive Styles */
* { box-sizing: border-box; }

html, body {
  height: 100%;
  width: 100%;
  margin: 0;
  padding: 0;
}

/* Bootstrap overrides */
body { 
  background-color: var(--hsms-light-bg) !important;
  font-size: clamp(14px, 2vw, 16px);
}

.bg-light { background-color: var(--hsms-light-bg) !important; }

.btn-primary,
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
  background-color: var(--hsms-primary) !important;
  border-color: var(--hsms-primary) !important;
}
.btn-primary:hover { filter: brightness(1.1); }
.btn-outline-primary {
  color: var(--hsms-primary) !important;
  border-color: var(--hsms-primary) !important;
}
.btn-outline-primary:hover {
  background-color: var(--hsms-light) !important;
  color: var(--hsms-primary-dark) !important;
  border-color: var(--hsms-primary) !important;
}

.bg-primary { background-color: var(--hsms-primary) !important; }
.text-primary { color: var(--hsms-primary) !important; }
.border-left-primary { border-left-color: var(--hsms-primary) !important; }

.bg-success { background-color: var(--hsms-primary-light) !important; }
.btn-success { background-color: var(--hsms-primary) !important; border-color: var(--hsms-primary) !important; }
.btn-success:hover { filter: brightness(1.1); background-color: var(--hsms-primary) !important; }
.btn-outline-success {
  color: var(--hsms-primary) !important;
  border-color: var(--hsms-primary) !important;
}
.btn-outline-success:hover {
  background-color: var(--hsms-light) !important;
  color: var(--hsms-primary-dark) !important;
  border-color: var(--hsms-primary) !important;
}
.text-success { color: var(--hsms-primary) !important; }

.bg-info { background-color: var(--hsms-light) !important; color: #333 !important; }
.btn-info { background-color: var(--hsms-primary-light) !important; border-color: var(--hsms-primary) !important; color: #fff !important; }
.btn-info:hover { background-color: var(--hsms-primary) !important; border-color: var(--hsms-primary) !important; color: #fff !important; }

.bg-warning { background-color: var(--hsms-light) !important; color: #333 !important; }
.btn-warning { background-color: var(--hsms-primary-light) !important; border-color: var(--hsms-primary) !important; color: #fff !important; }

.bg-dark { background-color: var(--hsms-primary-dark) !important; }
.navbar-dark { background-color: var(--hsms-primary) !important; }
.table-dark { background-color: var(--hsms-primary-dark) !important; }

.card-header.bg-primary,
.card-header.bg-dark { background-color: var(--hsms-primary) !important; border-color: var(--hsms-primary) !important; }
.card-header.bg-secondary { background-color: var(--hsms-primary-light) !important; color: #fff !important; }
.card-header.bg-info { background-color: var(--hsms-light) !important; color: #333 !important; }

.list-group-item.active { background-color: var(--hsms-primary) !important; border-color: var(--hsms-primary) !important; }
.badge.bg-success { background-color: var(--hsms-primary) !important; }
.badge.bg-primary { background-color: var(--hsms-primary) !important; }
.badge.bg-info { background-color: var(--hsms-primary-light) !important; }

/* Sidebar */
#sidebar { 
  background: linear-gradient(180deg, var(--hsms-primary-dark) 0%, var(--hsms-primary) 100%) !important;
  border-right: 1px solid rgba(0,0,0,0.1);
}
#sidebar .nav-link { 
  color: white !important;
  padding: 10px 12px;
  border-radius: 6px;
  font-size: clamp(13px, 2vw, 15px);
}
.nav-link:hover, .nav-link.active { 
  background: rgba(255,255,255,0.2) !important; 
  color: white !important;
  transform: translateX(4px);
}
.nav-link.text-danger:hover { background: rgba(255,255,255,0.15) !important; }

/* Cards - Responsive */
.card {
  transition: transform 0.2s, box-shadow 0.2s;
  margin-bottom: 1rem;
}
.card:hover {
  transform: translateY(-2px);
  box-shadow: 0 0.5rem 1rem rgba(235, 33, 212, 0.15) !important;
}

/* Tables - Responsive */
.table {
  font-size: clamp(12px, 1.5vw, 14px);
  margin-bottom: 0;
}
.table thead th {
  background-color: var(--hsms-primary);
  color: white;
  border: none;
  font-weight: 600;
  padding: 12px 8px;
}
.table tbody td {
  padding: 10px 8px;
  vertical-align: middle;
}

@media (max-width: 575px) {
  .table { font-size: 12px; }
  .table thead { font-size: 11px; }
  .table tbody td { padding: 8px 4px; }
}

/* Login */
body.login-page { 
  background: linear-gradient(135deg, var(--hsms-light) 0%, var(--hsms-light-soft) 50%, #fff 100%) !important; 
}
.login-card .card { 
  border-color: var(--hsms-light); 
  box-shadow: 0 0.5rem 1rem rgba(235,33,212,0.15) !important;
  max-width: 100%;
}
.login-card .btn-primary { 
  background-color: var(--hsms-primary) !important; 
  border-color: var(--hsms-primary) !important; 
}

/* Links - use primary for text links */
#content a.btn-link,
.card-body a:not(.btn) { 
  color: var(--hsms-primary);
  text-decoration: none;
}
#content a.btn-link:hover,
.card-body a:not(.btn):hover { 
  color: var(--hsms-primary-dark);
  text-decoration: underline;
}

/* Form focus ring */
.form-control:focus, .form-select:focus {
  border-color: var(--hsms-primary);
  box-shadow: 0 0 0 0.2rem rgba(235, 33, 212, 0.25);
}

/* Mobile Responsive Adjustments */
@media (max-width: 991px) {
  .container, .container-fluid {
    padding-left: 8px;
    padding-right: 8px;
  }
  
  .row {
    margin-left: -4px;
    margin-right: -4px;
  }
  
  .col, [class*="col-"] {
    padding-left: 4px;
    padding-right: 4px;
  }
}

@media (max-width: 575px) {
  .navbar-brand {
    font-size: 1rem !important;
  }
  
  h1 { font-size: clamp(1.25rem, 5vw, 2rem); }
  h2 { font-size: clamp(1.1rem, 4.5vw, 1.75rem); }
  h3 { font-size: clamp(1rem, 4vw, 1.5rem); }
  h4 { font-size: clamp(0.95rem, 3.5vw, 1.25rem); }
  h5 { font-size: clamp(0.9rem, 3vw, 1.1rem); }
  h6 { font-size: clamp(0.85rem, 2.5vw, 1rem); }
  
  .card {
    margin-bottom: 0.75rem;
  }
  
  .btn {
    padding: 8px 12px;
    font-size: clamp(12px, 2.5vw, 14px);
  }
  
  .form-control, .form-select {
    padding: 8px 12px;
    font-size: 16px; /* Prevents zoom on iOS */
  }
}

/* Visibility Helpers */
@media (max-width: 991px) {
  .hide-on-tablet { display: none !important; }
}

@media (max-width: 575px) {
  .hide-on-mobile { display: none !important; }
}
