/**
 * subito-student-portal.css (Safe Namespaced WP Theme Shield Version)
 * All variables and styles are carefully prioritized to prevent WordPress theme overrides.
 */

:root {
  --subito-primary: #021B31 !important;
  --subito-secondary: #FFFDD0 !important;
  --subito-btn: #2D6AA1 !important;
  --subito-btn-hover: #245882 !important;
  --subito-white: #ffffff !important;
  --subito-gray-text: #5b6b78 !important;
  --subito-border: #e4e9ee !important;
  --subito-radius-lg: 24px !important;
  --subito-radius-md: 16px !important;
  --subito-radius-sm: 12px !important;
  --subito-shadow: 0 24px 60px -20px rgba(2, 27, 49, 0.25),
                   0 8px 24px -8px rgba(2, 27, 49, 0.12) !important;
}

/* Local scoped fallback properties inside portal and isolation containers */
.subito-portal-container,
.subito-portal-isolation-shell {
  --subito-primary: #021B31 !important;
  --subito-secondary: #FFFDD0 !important;
  --subito-btn: #2D6AA1 !important;
  --subito-btn-hover: #245882 !important;
  --subito-white: #ffffff !important;
  --subito-gray-text: #5b6b78 !important;
  --subito-border: #e4e9ee !important;
  --subito-radius-lg: 24px !important;
  --subito-radius-md: 16px !important;
  --subito-radius-sm: 12px !important;
  --subito-shadow: 0 24px 60px -20px rgba(2, 27, 49, 0.25),
                   0 8px 24px -8px rgba(2, 27, 49, 0.12) !important;

  /* Prefix-less compatibility variables to prevent any third-party or builder overrides */
  --primary: #021B31 !important;
  --secondary: #FFFDD0 !important;
  --btn: #2D6AA1 !important;
  --btn-hover: #245882 !important;
  --white: #ffffff !important;
  --gray-text: #5b6b78 !important;
  --border: #e4e9ee !important;
  --radius-lg: 24px !important;
  --radius-md: 16px !important;
  --radius-sm: 12px !important;
  --shadow: 0 24px 60px -20px rgba(2, 27, 49, 0.25),
            0 8px 24px -8px rgba(2, 27, 49, 0.12) !important;
}

/* ===== CONTAINER RESET ===== */
.subito-portal-container {
  font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
  min-height: 100vh !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 60px 20px !important;
  color: var(--subito-primary) !important;
  box-sizing: border-box !important;
  background: #021B31 !important; /* beautiful classic deep dark blue used in design */
  line-height: 1.5 !important;
}

.subito-portal-container *:not(.simpay-form-wrap):not(.simpay-form-wrap *):not(.simpay-form):not(.simpay-form *) {
  box-sizing: border-box !important;
  margin: 0;
  padding: 0;
}

/* ===== BACKGROUND ===== */

/* ===== CARD ===== */
.subito-portal-container .subito-auth-card {
  width: 100% !important;
  max-width: 500px !important; /* increased from 440px slightly to give side-by-side inputs more room */
  background: #ffffff !important;
  border: 1px solid rgba(255, 255, 255, 0.95) !important;
  border-radius: var(--subito-radius-lg) !important;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.5) !important;
  padding: 20px 20px !important;
  animation: subitoFloatIn 0.7s cubic-bezier(0.16, 1, 0.3, 1) !important;
  text-align: left !important;
  margin: 0 auto !important;
}

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

/* ===== HEADER ===== */
.subito-portal-container .subito-auth-header {
  text-align: center !important;
  margin-bottom: 20px !important;
}

.subito-portal-container .subito-brand-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  background-color: var(--subito-secondary) !important;
  color: var(--subito-primary) !important;
  font-family: 'Poppins', 'Inter', sans-serif !important;
  font-weight: 600 !important;
  font-size: 11px !important;
  letter-spacing: 0.5px !important;
  padding: 6px 14px !important;
  border-radius: 100px !important;
  margin-bottom: 12px !important;
  border: none !important;
  line-height: 1.2 !important;
  box-shadow: 0 2px 8px rgba(2, 27, 49, 0.05) !important;
}

.subito-portal-container .subito-auth-card h1,
.subito-portal-container .subito-auth-header h1 {
  font-family: 'Poppins', 'Inter', sans-serif !important;
  font-weight: 600 !important;
  font-size: 24px !important;
  color: var(--subito-primary) !important;
  letter-spacing: -0.5px !important;
  line-height: 1.2 !important;
  margin-bottom: 8px !important;
}

.subito-portal-container .subito-auth-card p,
.subito-portal-container .subito-auth-header p {
  margin-top: 8px !important;
  font-size: 13px !important;
  color: var(--subito-gray-text) !important;
  max-width: 440px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  line-height: 1.5 !important;
}

/* ===== TABS ===== */
.subito-portal-container .subito-tabs-wrapper {
  margin: 0 auto 20px !important;
  max-width: 360px !important;
}

.subito-portal-container .subito-tabs {
  position: relative !important;
  display: grid !important;
  grid-template-columns: 1fr 1fr !important; /* symmetric equal-sized columns */
  grid-auto-flow: column !important;
  background-color: var(--subito-secondary) !important;
  border-radius: 100px !important;
  padding: 6px !important;
  border: none !important;
}

.subito-portal-container .subito-tab-indicator {
  position: absolute !important;
  top: 6px !important;
  left: 6px !important;
  width: calc(50% - 6px) !important;
  height: calc(100% - 12px) !important;
  background-color: var(--subito-btn) !important;
  border-radius: 100px !important;
  transition: transform 0.4s cubic-bezier(0.65, 0, 0.35, 1) !important;
  box-shadow: 0 6px 16px -4px rgba(9,56,91,0.5) !important;
  z-index: 1 !important;
}

.subito-portal-container .subito-tab-indicator.right {
  transform: translateX(100%) !important;
}

.subito-portal-container .subito-tab-btn {
  position: relative !important;
  z-index: 2 !important;
  background: none !important;
  background-color: transparent !important;
  border: none !important;
  cursor: pointer !important;
  padding: 12px 16px !important;
  font-family: 'Poppins', 'Inter', sans-serif !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  color: var(--subito-primary) !important;
  transition: color 0.3s !important;
  text-align: center !important;
  box-shadow: none !important;
  border-radius: 100px !important;
  outline: none !important;
  margin: 0 !important;
  height: auto !important;
  width: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  user-select: none !important;
}

.subito-portal-container .subito-tab-btn.subito-active,
.subito-portal-container .subito-tab-btn.subito-active:hover,
.subito-portal-container .subito-tab-btn.subito-active:focus,
.subito-portal-container .subito-tab-btn.subito-active:active {
  color: var(--subito-white) !important;
  background: none !important;
  background-color: transparent !important;
  box-shadow: none !important;
  border: none !important;
  outline: none !important;
  margin: 0 !important;
  border-radius: 100px !important;
}

.subito-portal-container .subito-tab-btn:not(.subito-active) {
  color: var(--subito-primary) !important;
}

/* ===== PANELS ===== */
.subito-portal-container .subito-panel {
  display: none;
  animation: subitoFadeUp 0.5s ease;
}
.subito-portal-container .subito-panel.subito-active {
  display: block !important;
}

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

/* ===== FLOATING FIELDS ===== */
.subito-portal-container .subito-field {
  position: relative !important;
  margin-bottom: 11px !important;
  text-align: left !important;
}

.subito-portal-container .subito-field input,
.subito-portal-container .subito-field textarea {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 12.5px !important;
  color: var(--subito-primary) !important;
  background-color: rgba(255,255,255,0.7) !important;
  border: 1.5px solid var(--subito-border) !important;
  border-radius: var(--subito-radius-sm) !important;
  outline: none !important;
  transition: all 0.25s ease !important;
  box-shadow: none !important;
}

.subito-portal-container .subito-field input {
  height: 42px !important;
  padding: 16px 12px 2px !important;
}

.subito-portal-container .subito-field textarea {
  min-height: 60px !important;
  padding: 16px 12px 2px !important;
  resize: vertical !important;
}

.subito-portal-container .subito-field input:focus,
.subito-portal-container .subito-field textarea:focus {
  border-color: var(--subito-btn) !important;
  box-shadow: 0 0 0 4px rgba(9,56,91,0.12) !important;
  background-color: #ffffff !important;
}

.subito-portal-container .subito-field label {
  position: absolute !important;
  left: 12px !important;
  top: 12px !important;
  font-size: 12.5px !important;
  color: var(--subito-gray-text) !important;
  pointer-events: none !important;
  transition: all 0.18s ease !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  line-height: 1 !important;
}

/* When input is focused, placeholder is not shown, or subito-has-value class is present */
.subito-portal-container .subito-field input:focus + label,
.subito-portal-container .subito-field input:not(:placeholder-shown) + label,
.subito-portal-container .subito-field input.subito-has-value + label,
.subito-portal-container .subito-field textarea:focus + label,
.subito-portal-container .subito-field textarea:not(:placeholder-shown) + label,
.subito-portal-container .subito-field textarea.subito-has-value + label {
  top: 3px !important;
  font-size: 9px !important;
  font-weight: 600 !important;
  color: var(--subito-btn) !important;
  letter-spacing: 0.3px !important;
}

/* Hide placeholders by default in floating fields to prevent overlap with floating labels, display on focus */
.subito-portal-container .subito-field input::placeholder,
.subito-portal-container .subito-field textarea::placeholder {
  opacity: 0 !important;
  transition: opacity 0.2s ease !important;
}
.subito-portal-container .subito-field input:focus::placeholder,
.subito-portal-container .subito-field textarea:focus::placeholder {
  opacity: 0.5 !important;
}

/* Validation styling */
.subito-portal-container .subito-field input.subito-invalid,
.subito-portal-container .subito-field textarea.subito-invalid {
  border-color: #e0495b !important;
  box-shadow: 0 0 0 4px rgba(224,73,91,0.1) !important;
}
.subito-portal-container .subito-field input.subito-valid,
.subito-portal-container .subito-field textarea.subito-valid {
  border-color: #29a36a !important;
}
.subito-portal-container .subito-err-msg {
  display: none !important;
  font-size: 12px !important;
  color: #e0495b !important;
  margin-top: 5px !important;
  padding-left: 4px !important;
  font-weight: 500 !important;
}
.subito-portal-container .subito-field.subito-show-error .subito-err-msg {
  display: block !important;
}

.subito-portal-container .subito-form-row {
  display: flex !important;
  flex-direction: row !important;
  gap: 8px !important;
  width: 100% !important;
  margin-bottom: 0 !important;
}
.subito-portal-container .subito-form-row .subito-field {
  flex: 1 1 50% !important;
  min-width: 0 !important;
  margin-bottom: 8px !important;
}
.subito-portal-container .subito-form-row .subito-field-full {
  flex: 1 1 100% !important;
  width: 100% !important;
}

/* ===== LOGIN EXTRAS ===== */
.subito-portal-container .subito-login-extras {
  display: flex !important;
  justify-content: flex-end !important;
  margin: -6px 0 22px !important;
}

.subito-portal-container .subito-link {
  color: var(--subito-btn) !important;
  font-size: 13.5px !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  transition: opacity 0.2s !important;
  border: none !important;
  background: none !important;
}
.subito-portal-container .subito-link:hover {
  opacity: 0.75 !important;
  text-decoration: underline !important;
}

/* ===== BUTTONS ===== */
.subito-portal-container .subito-btn-primary {
  width: 100% !important;
  padding: 16px 28px !important;
  background-color: var(--subito-btn) !important;
  background: var(--subito-btn) !important;
  color: var(--subito-white) !important;
  font-family: 'Poppins', 'Inter', sans-serif !important;
  font-weight: 600 !important;
  font-size: 14.5px !important;
  border: none !important;
  border-radius: 12px !important;
  cursor: pointer !important;
  transition: all 0.3s cubic-bezier(0.16,1,0.3,1) !important;
  box-shadow: 0 10px 24px -8px rgba(9,56,91,0.5) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  outline: none !important;
  height: auto !important;
  text-decoration: none !important;
}
.subito-portal-container .subito-btn-primary:hover {
  background-color: var(--subito-btn-hover) !important;
  background: var(--subito-btn-hover) !important;
  color: var(--subito-white) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 16px 30px -10px rgba(9,56,91,0.6) !important;
}
.subito-portal-container .subito-btn-primary:active {
  transform: translateY(0) !important;
}

.subito-portal-container .subito-btn-secondary {
  width: 100% !important;
  padding: 16px 28px !important;
  background-color: transparent !important;
  background: transparent !important;
  color: var(--subito-primary) !important;
  font-family: 'Poppins', 'Inter', sans-serif !important;
  font-weight: 600 !important;
  font-size: 14.5px !important;
  border: 1.5px solid var(--subito-border) !important;
  border-radius: 12px !important;
  cursor: pointer !important;
  transition: all 0.2s !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: none !important;
  outline: none !important;
}
.subito-portal-container .subito-btn-secondary:hover {
  background-color: rgba(2,27,49,0.03) !important;
  border-color: var(--subito-btn) !important;
  color: var(--subito-primary) !important;
}

.subito-portal-container .subito-footer-text {
  text-align: center !important;
  margin-top: 22px !important;
  font-size: 14px !important;
  color: var(--subito-gray-text) !important;
}

/* ===== REGISTER MULTI-STEP ===== */
.subito-portal-container .subito-registration-step {
  display: none !important;
}
.subito-portal-container .subito-registration-step.subito-active {
  display: block !important;
}

.subito-portal-container .subito-section-title {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 600 !important;
  font-size: 15px !important;
  color: var(--subito-primary) !important;
  margin-bottom: 10px !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  text-transform: none !important;
  border: none !important;
  padding: 0 !important;
}
.subito-portal-container .subito-section-title .subito-num {
  width: 24px !important;
  height: 24px !important;
  background-color: var(--subito-btn) !important;
  color: #ffffff !important;
  border-radius: 50% !important;
  font-size: 12px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-weight: 700 !important;
}

.subito-portal-container .subito-step-navigation {
  display: flex !important;
  justify-content: space-between !important;
  gap: 16px !important;
  margin-top: 12px !important;
}

/* ===== DISCIPLINE CARDS ===== */
.subito-portal-container .subito-discipline-grid {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
}
.subito-portal-container .subito-disc-card {
  border: 1.5px solid var(--subito-border) !important;
  border-radius: var(--subito-radius-md) !important;
  padding: 14px 18px !important;
  text-align: left !important;
  cursor: pointer !important;
  background-color: rgba(255,255,255,0.6) !important;
  transition: all 0.3s cubic-bezier(0.16,1,0.3,1) !important;
  user-select: none !important;
  box-shadow: none !important;
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
}
.subito-portal-container .subito-disc-card .subito-icon {
  font-size: 26px !important;
  display: block !important;
  margin-bottom: 0 !important;
  line-height: 1 !important;
}
.subito-portal-container .subito-disc-card .subito-name {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  color: var(--subito-primary) !important;
}
.subito-portal-container .subito-disc-card:hover {
  transform: translateX(4px) !important;
  border-color: #c3d2dd !important;
}
.subito-portal-container .subito-disc-card.subito-selected {
  border-color: var(--subito-btn) !important;
  box-shadow: 0 0 0 4px rgba(9,56,91,0.15) !important;
  transform: translateX(6px) !important;
  background-color: #ffffff !important;
}
.subito-portal-container .subito-disc-card.subito-invalid-card {
  border-color: #d93025 !important;
  background-color: rgba(217, 48, 37, 0.03) !important;
}

/* ===== PRICING ===== */
.subito-portal-container .subito-pricing-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 10px !important;
}
.subito-portal-container .subito-price-card {
  position: relative !important;
  border: 1.5px solid var(--subito-border) !important;
  border-radius: var(--subito-radius-md) !important;
  padding: 12px 14px !important;
  cursor: pointer !important;
  background-color: rgba(255,255,255,0.7) !important;
  transition: all 0.3s cubic-bezier(0.16,1,0.3,1) !important;
  text-align: left !important;
  box-shadow: none !important;
}
.subito-portal-container .subito-price-card:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 10px 20px -8px rgba(2,27,49,0.2) !important;
}
.subito-portal-container .subito-price-card.subito-highlight {
  border-color: var(--subito-btn) !important;
  background-color: #ffffff !important;
}
.subito-portal-container .subito-price-card.subito-selected {
  border-color: var(--subito-btn) !important;
  box-shadow: 0 0 0 3px rgba(9,56,91,0.12) !important;
}
.subito-portal-container .subito-badge {
  position: absolute !important;
  top: -9px !important;
  right: 12px !important;
  background-color: var(--subito-secondary) !important;
  color: var(--subito-primary) !important;
  font-family: 'Poppins', sans-serif !important;
  font-weight: 600 !important;
  font-size: 10px !important;
  padding: 3px 8px !important;
  border-radius: 100px !important;
  box-shadow: 0 4px 10px -4px rgba(2,27,49,0.2) !important;
  line-height: 1.1 !important;
  border: none !important;
}
.subito-portal-container .subito-price-card h3 {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  margin-bottom: 3px !important;
  color: var(--subito-primary) !important;
}
.subito-portal-container .subito-price-amount {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 700 !important;
  font-size: 22px !important;
  color: var(--subito-btn) !important;
  margin-bottom: 1px !important;
  line-height: 1.1 !important;
}
.subito-portal-container .subito-price-amount span {
  font-size: 12px !important;
  font-weight: 500 !important;
  color: var(--subito-gray-text) !important;
}
.subito-portal-container .subito-price-card ul {
  list-style: none !important;
  margin-top: 8px !important;
  padding: 0 !important;
}
.subito-portal-container .subito-price-card li {
  font-size: 11.5px !important;
  color: var(--subito-gray-text) !important;
  padding: 3px 0 3px 18px !important;
  position: relative !important;
  line-height: 1.3 !important;
  margin: 0 !important;
}
.subito-portal-container .subito-price-card li::before {
  content: "✓" !important;
  position: absolute !important;
  left: 0 !important;
  color: var(--subito-btn) !important;
  font-weight: 700 !important;
}

/* ===== TERMS CHECKBOX ===== */
.subito-portal-container .subito-terms {
  display: flex !important;
  align-items: flex-start !important;
  gap: 12px !important;
  margin-bottom: 26px !important;
  text-align: left !important;
}
.subito-portal-container .subito-checkbox {
  flex-shrink: 0 !important;
  width: 22px !important;
  height: 22px !important;
  border: 1.5px solid var(--subito-border) !important;
  border-radius: 7px !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: all 0.25s !important;
  background-color: #ffffff !important;
  margin-top: 1px !important;
  padding: 0 !important;
  box-shadow: none !important;
}
.subito-portal-container .subito-checkbox.subito-checked {
  background-color: var(--subito-btn) !important;
  background: var(--subito-btn) !important;
  border-color: var(--subito-btn) !important;
}
.subito-portal-container .subito-checkbox svg {
  width: 13px !important;
  height: 13px !important;
  stroke: #ffffff !important;
  stroke-width: 3 !important;
  fill: none !important;
  opacity: 0 !important;
  transform: scale(0.5) !important;
  transition: all 0.25s !important;
}
.subito-portal-container .subito-checkbox.subito-checked svg {
  opacity: 1 !important;
  transform: scale(1) !important;
}
.subito-portal-container .subito-terms p {
  font-size: 13.5px !important;
  color: var(--subito-gray-text) !important;
  line-height: 1.5 !important;
  margin: 0 !important;
}

/* ===== NOTIFICATIONS OR ALERTS ===== */
.subito-portal-container .subito-portal-alert {
  padding: 14px 18px !important;
  border-radius: var(--subito-radius-sm) !important;
  margin-bottom: 24px !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
  font-weight: 500 !important;
  text-align: left !important;
}
.subito-portal-container .subito-portal-alert-success {
  background-color: #e6f6ee !important;
  color: #167e43 !important;
  border: 1px solid rgba(41, 163, 106, 0.2) !important;
}
.subito-portal-container .subito-portal-alert-danger {
  background-color: #fdf3f4 !important;
  color: #e0495b !important;
  border: 1px solid rgba(224, 73, 91, 0.2) !important;
}

/* ===== SUCCESS SCREEN ===== */
.subito-portal-container .subito-success {
  display: none !important;
  text-align: center !important;
  padding: 30px 0 !important;
}
.subito-portal-container .subito-success.subito-show,
.subito-portal-container .subito-success.subito-active {
  display: block !important;
}
.subito-portal-container .subito-success-icon {
  width: 72px !important;
  height: 72px !important;
  background-color: #29a36a !important;
  background: #29a36a !important;
  border-radius: 50% !important;
  margin: 0 auto 20px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: 0 12px 28px -10px rgba(41,163,106,0.6) !important;
}
.subito-portal-container .subito-success-icon svg {
  width: 34px !important;
  height: 34px !important;
  stroke: #ffffff !important;
  stroke-width: 3 !important;
  fill: none !important;
}
.subito-portal-container .subito-success h2 {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 600 !important;
  font-size: 22px !important;
  margin-bottom: 8px !important;
  color: var(--subito-primary) !important;
}
.subito-portal-container .subito-success p {
  color: var(--subito-gray-text) !important;
  font-size: 15px !important;
}

/* ===== LOADER SPINNER ===== */
.subito-portal-container .subito-loader-spinner {
  display: none !important;
  width: 20px !important;
  height: 20px !important;
  border: 2.5px solid rgba(255, 255, 255, 0.3) !important;
  border-radius: 50% !important;
  border-top-color: #ffffff !important;
  animation: subitoSpin 0.8s ease-in-out infinite !important;
}
@keyframes subitoSpin {
  to { transform: rotate(360deg); }
}

/* ===== DASHBOARD SPECIFIC LAYOUT ===== */
.subito-portal-container .subito-dashboard-grid-layout {
  width: 100% !important;
  max-width: 1140px !important;
  margin: 0 auto !important;
  padding: 20px 0 !important;
  text-align: left !important;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 768px) {
  .subito-portal-container {
    padding: 16px 8px !important;
  }
  .subito-portal-container .subito-auth-card {
    padding: 16px 14px !important;
  }
  .subito-portal-container .subito-auth-card h1,
  .subito-portal-container .subito-auth-header h1 {
    font-size: 24px !important;
  }
  .subito-portal-container .subito-form-row {
    display: flex !important;
    flex-direction: row !important;
    gap: 8px !important;
  }
  .subito-portal-container .subito-pricing-grid {
    grid-template-columns: 1fr 1fr !important;
  }
  .subito-portal-container .subito-discipline-grid {
    grid-template-columns: 1fr !important;
  }
  .subito-portal-container .subito-disc-card {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    text-align: left !important;
    padding: 18px !important;
  }
  .subito-portal-container .subito-disc-card .subito-icon {
    margin: 0 !important;
    font-size: 26px !important;
  }
}

/* ===== PITCH.IO MODERN DASHBOARD SYSTEM ===== */
.subito-app-core-wrapper {
  display: flex !important;
  background-color: #FAF9F3 !important; /* very premium warm white/cream workspace background */
  border-radius: 24px !important;
  box-shadow: 0 30px 80px rgba(2, 27, 49, 0.08), 0 10px 30px rgba(2, 27, 49, 0.04) !important;
  overflow: hidden !important;
  min-height: 820px !important;
  width: 100% !important;
  max-width: 1140px !important;
  margin: 0 auto !important;
  border: 1.5px solid #eef1f4 !important;
}

/* SIDEBAR style */
.subito-dashboard-sidebar {
  width: 260px !important;
  background: #021B31 !important;
  border-right: 1.5px solid rgba(255, 255, 255, 0.08) !important;
  padding: 32px 24px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  flex-shrink: 0 !important;
  position: relative !important;
}

/* Sidebar Logo */
.subito-sidebar-logo-box {
  margin-bottom: 30px !important;
}
.subito-sidebar-logo-box img {
  max-height: 38px !important;
  width: auto !important;
  border-radius: 6px !important;
}

/* Sidebar Action Button */
.subito-sidebar-action-btn {
  background-color: #FFFDD0 !important;
  color: #021B31 !important;
  border: 1.5px solid #021B31 !important;
  padding: 12px 14px !important;
  border-radius: 12px !important;
  font-family: 'Poppins', sans-serif !important;
  font-weight: 600 !important;
  font-size: 13.5px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  cursor: pointer !important;
  transition: all 0.25s ease-in-out !important;
  margin-bottom: 28px !important;
  width: 100% !important;
  box-shadow: 0 4px 10px rgba(2, 27, 49, 0.05) !important;
}
.subito-sidebar-action-btn:hover {
  background-color: #021B31 !important;
  color: #FFFDD0 !important;
  transform: translateY(-1px) !important;
}

/* Sidebar Nav Links */
.subito-sidebar-nav {
  margin-bottom: auto !important;
}
.subito-sidebar-nav-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
}
.subito-sidebar-nav-item {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 12px 16px !important;
  border-radius: 12px !important;
  font-weight: 500 !important;
  font-size: 14px !important;
  color: rgba(255, 255, 255, 0.7) !important;
  text-decoration: none !important;
  cursor: pointer !important;
  transition: all 0.2s ease-in-out !important;
  border: none !important;
  background: none !important;
  width: 100% !important;
  text-align: left !important;
}
.subito-sidebar-nav-item svg {
  width: 18px !important;
  height: 18px !important;
  stroke: rgba(255, 255, 255, 0.7) !important;
  fill: none !important;
  stroke-width: 2 !important; /* corrected stroke width */
  transition: stroke 0.2s !important;
}
.subito-sidebar-nav-item:hover {
  color: #ffffff !important;
  background-color: rgba(255, 255, 255, 0.08) !important;
}
.subito-sidebar-nav-item:hover svg {
  stroke: #ffffff !important;
}
.subito-sidebar-nav-item.subito-active {
  color: #ffffff !important;
  background-color: #2D6AA1 !important; /* Steel blue */
  font-weight: 600 !important;
  border-left: none !important;
  border-radius: 12px !important;
}
.subito-sidebar-nav-item.subito-active svg {
  stroke: #ffffff !important;
}

/* Sidebar Support/Upgrade Card */
.subito-sidebar-help-card {
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1.5px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: 16px !important;
  padding: 18px !important;
  color: #ffffff !important;
  margin-top: 24px !important;
  box-shadow: none !important;
}
.subito-sidebar-help-card-title {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 600 !important;
  font-size: 13.5px !important;
  color: #FFFDD0 !important;
  margin-bottom: 6px !important;
}
.subito-sidebar-help-card-text {
  font-size: 11.5px !important;
  color: rgba(255, 255, 255, 0.8) !important;
  line-height: 1.4 !important;
  margin-bottom: 12px !important;
}
.subito-sidebar-help-card-btn {
  background: #ffffff !important;
  color: #021B31 !important;
  border: none !important;
  padding: 8px 12px !important;
  border-radius: 8px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  display: inline-block !important;
  text-decoration: none !important;
  text-align: center !important;
  width: 100% !important;
  cursor: pointer !important;
  transition: opacity 0.2s !important;
}
.subito-sidebar-help-card-btn:hover {
  opacity: 0.95 !important;
}

/* MAIN CONTENT AREA style */
.subito-dashboard-main-content {
  flex: 1 !important;
  padding: 40px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 28px !important;
  overflow-y: auto !important;
  height: auto !important;
  max-height: 900px !important;
}

/* Header Row */
.subito-main-header-row {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  border-bottom: 1.5px solid #eef1f4 !important;
  padding-bottom: 18px !important;
}
.subito-header-title {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 700 !important;
  font-size: 24px !important;
  color: #021B31 !important;
  margin: 0 !important;
}
.subito-header-date {
  font-size: 13px !important;
  color: #5b6b78 !important;
  margin-top: 3px !important;
}
.subito-header-right {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
}
.subito-header-user-badge {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  background-color: #ffffff !important;
  border: 1.5px solid #eef1f4 !important;
  padding: 6px 14px !important;
  border-radius: 12px !important;
}
.subito-header-user-badge-initials {
  width: 32px !important;
  height: 32px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  color: #021B31 !important;
  background-color: #FFFDD0 !important; /* gold init badge! */
}
.subito-header-user-badge-name {
  font-size: 13.5px !important;
  font-weight: 600 !important;
  color: #021B31 !important;
}

/* Welcome Banner */
.subito-welcome-banner {
  background: linear-gradient(180deg, #06284A 0%, #041E38 100%) !important;
  border-left: 5px solid #2D6AA1 !important;
  border-radius: 18px !important;
  padding: 30px !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  position: relative !important;
  overflow: hidden !important;
  box-shadow: 0 10px 35px rgba(2, 27, 49, 0.12) !important;
}
.subito-welcome-banner-left {
  flex: 1 !important;
  z-index: 2 !important;
}
.subito-welcome-message-title {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 700 !important;
  font-size: 26px !important;
  color: #ffffff !important;
  margin-bottom: 8px !important;
  letter-spacing: -0.5px !important;
}
.subito-welcome-message-subtitle {
  font-size: 14px !important;
  color: rgba(255, 255, 255, 0.8) !important;
  line-height: 1.5 !important;
  max-width: 500px !important;
}
.subito-welcome-banner-right {
  position: relative !important;
  width: 140px !important;
  height: 110px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Bento Stats Row */
.subito-bento-stats-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 12px !important;
}
.subito-bento-card {
  background-color: #ffffff !important;
  border: 1.5px solid #eef1f4 !important;
  border-radius: 12px !important;
  padding: 12px 14px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
  position: relative !important;
  overflow: hidden !important;
}
.subito-bento-card:hover {
  transform: translateY(-1px) !important;
  border-color: #cdd4dc !important;
}
.subito-bento-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
}
.subito-bento-circle-icon {
  width: 28px !important;
  height: 28px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 13px !important;
  line-height: 1 !important;
}
.subito-bento-card-val {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  color: #021B31 !important;
  line-height: 1.2 !important;
  margin-top: 2px !important;
}
.subito-bento-card-lbl {
  font-size: 9.5px !important;
  font-weight: 600 !important;
  color: #5b6b78 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.3px !important;
}
span.subito-bento-pill {
  font-size: 11.5px !important;
  white-space: normal !important;
  word-break: break-word !important;
}

/* Schedules Lists / Content cards */
.subito-content-card-box {
  background-color: #ffffff !important;
  border: 1.5px solid #eef1f4 !important;
  border-radius: 18px !important;
  padding: 28px !important;
  box-shadow: 0 4px 15px rgba(2, 27, 49, 0.01) !important;
}
.subito-content-card-title-row {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  border-bottom: 1.5px solid #eef1f4 !important;
  padding-bottom: 16px !important;
  margin-bottom: 20px !important;
}
.subito-content-card-title {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 700 !important;
  font-size: 17px !important;
  color: #021B31 !important;
  margin: 0 !important;
}

/* Custom list items like Pitch.io list */
.subito-schedule-list-item {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  background-color: #ffffff !important;
  border: 1.5px solid #eef1f4 !important;
  border-radius: 14px !important;
  padding: 16px 20px !important;
  margin-bottom: 12px !important;
  transition: all 0.25s cubic-bezier(0.16, 1, 0.3, 1) !important;
}
.subito-schedule-list-item:hover {
  border-color: #cbd5e0 !important;
  transform: translateX(4px) !important;
  background-color: #fbfbfc !important;
}
.subito-schedule-list-left {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
}
.subito-schedule-list-thumb {
  width: 44px !important;
  height: 44px !important;
  background-color: #FAF8EB !important;
  border-radius: 10px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 22px !important;
  flex-shrink: 0 !important;
  line-height: 1 !important;
}
.subito-schedule-list-details {
  display: flex !important;
  flex-direction: column !important;
  gap: 3px !important;
}
.subito-schedule-list-item-title {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 600 !important;
  font-size: 15px !important;
  color: #021B31 !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}
.subito-schedule-list-meta {
  font-size: 13px !important;
  color: #5b6b78 !important;
}
.subito-schedule-list-meta-instructor {
  font-size: 12px !important;
  color: #83929f !important;
}

/* Force "Join Classroom" and "Class Closed" list action buttons to stay small and compact */
.subito-schedule-list-right .subito-btn-primary,
.subito-schedule-list-right button.subito-btn-primary,
.subito-schedule-list-right a.subito-btn-primary,
.subito-schedule-list-right span.subito-btn-primary {
  padding: 6.5px 14px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  border-radius: 8px !important;
  box-shadow: none !important;
  width: auto !important;
  height: auto !important;
  line-height: 1.4 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* RESPONSIVE MOBILE STYLES FOR PITCH.IO */
@media (max-width: 1024px) {
  .subito-app-core-wrapper {
    flex-direction: column !important;
    min-height: auto !important;
    margin: 10px !important;
    border-radius: 16px !important;
  }
  .subito-dashboard-sidebar {
    width: 100% !important;
    border-right: none !important;
    border-bottom: 1.5px solid #eef1f4 !important;
    padding: 20px !important;
  }
  .subito-sidebar-nav-list {
    flex-direction: row !important;
    overflow-x: auto !important;
    gap: 10px !important;
    padding-bottom: 4px !important;
  }
  .subito-sidebar-nav-item {
    font-size: 13px !important;
    padding: 10px 14px !important;
    white-space: nowrap !important;
    width: auto !important;
  }
  .subito-sidebar-help-card,
  .subito-sidebar-logo-box,
  .subito-sidebar-action-btn {
    display: none !important;
  }
  .subito-dashboard-main-content {
    padding: 20px !important;
    height: auto !important;
    max-height: none !important;
  }
  .subito-bento-stats-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 640px) {
  .subito-bento-stats-grid {
    grid-template-columns: 1fr !important;
  }
  .subito-schedule-list-item {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 14px !important;
  }
  .subito-schedule-list-right {
    width: 100% !important;
  }
  .subito-schedule-list-right button,
  .subito-schedule-list-right a {
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
  }
}

/* Supplies Item Card Premium Hover Effect */
.supplies-item-card {
  transition: all 0.25s ease-in-out !important;
}
.supplies-item-card:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 10px 25px rgba(2, 27, 49, 0.08) !important;
  border-color: #021B31 !important;
}

/* Supplies Store Responsive Layouts */
.subito-dual-store-row {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 24px !important;
  align-items: start !important;
}
.subito-catalog-card-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 16px !important;
}

@media (min-width: 640px) {
  .subito-catalog-card-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (min-width: 1024px) {
  .subito-dual-store-row {
    grid-template-columns: 1.7fr 1.15fr !important;
  }
}

/* Custom Add to Cart and Check Out buttons styling */
.subito-portal-container .add-store-item-btn {
  padding: 10px 14px !important;
  font-size: 11px !important;
  border-radius: 8px !important;
  width: 100% !important;
  background-color: #021B31 !important;
  color: #ffffff !important;
  font-weight: 600 !important;
  box-shadow: none !important;
  border: none !important;
  cursor: pointer !important;
  transition: all 0.2s ease-in-out !important;
  text-align: center !important;
  display: block !important;
  outline: none !important;
}

.subito-portal-container .add-store-item-btn:hover {
  background-color: #09385B !important;
}

.subito-portal-container .add-store-item-btn.added-success {
  background-color: #29a36a !important;
  background: #29a36a !important;
  color: #ffffff !important;
}

.subito-portal-container #checkout-supplies-cart-btn {
  font-family: 'Poppins', sans-serif !important;
  background-color: #2D6AA1 !important;
  background: #2D6AA1 !important;
}

.subito-portal-container #checkout-supplies-cart-btn:hover {
  background-color: #245882 !important;
  background: #245882 !important;
}

/* Custom Log Out Button Highlight */
.subito-portal-container .subito-sidebar-nav-item-logout {
  background-color: #e0495b !important;
  background: #e0495b !important;
  color: #ffffff !important;
  font-weight: 600 !important;
  border-radius: 12px !important;
}
.subito-portal-container .subito-sidebar-nav-item-logout svg {
  stroke: #ffffff !important;
}
.subito-portal-container .subito-sidebar-nav-item-logout:hover {
  background-color: #c83b4c !important;
  background: #c83b4c !important;
  color: #ffffff !important;
}
.subito-portal-container .subito-sidebar-nav-item-logout:hover svg {
  stroke: #ffffff !important;
}

/* ===== ADDITIONAL FRONTEND CLASS EXTRACTS (To remove inline styles) ===== */
.subito-portal-container .subito-brand-logo {
  max-height: 50px !important;
  margin: 0 auto 16px !important;
  display: block !important;
  object-fit: contain !important;
}

.subito-portal-container .subito-field input[type="password"] {
  padding-right: 44px !important;
}

.subito-portal-container .subito-toggle-password {
  position: absolute !important;
  right: 12px !important;
  top: 14px !important;
  background: none !important;
  border: none !important;
  cursor: pointer !important;
  color: #5b6b78 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  outline: none !important;
  z-index: 10 !important;
}

.subito-portal-container .subito-login-extras {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  margin-bottom: 20px !important;
}

.subito-portal-container .subito-remember-me-label {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  font-size: 13.5px !important;
  color: #5b6b78 !important;
  cursor: pointer !important;
  font-weight: 500 !important;
  margin: 0 !important;
  user-select: none !important;
}

.subito-portal-container .subito-remember-me-label input[type="checkbox"] {
  width: 16px !important;
  height: 16px !important;
  accent-color: #2D6AA1 !important;
  cursor: pointer !important;
}

.subito-portal-container .subito-link-inline-size {
  font-size: 13.5px !important;
}

.subito-portal-container .next-step-btn-max {
  max-width: 240px !important;
}

.subito-portal-container .subito-step2-desc-size {
  font-size: 13px !important;
  color: #5b6b78 !important;
  margin-bottom: 16px !important;
}

.subito-portal-container .subito-discipline-grid-margin {
  margin-bottom: 20px !important;
}

.subito-portal-container .subito-disc-card-outline {
  outline: none !important;
}

.subito-portal-container .subito-field-hidden-step2 {
  opacity: 0 !important;
  height: 0 !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  position: absolute !important;
  pointer-events: none !important;
}

.subito-portal-container .subito-err-msg-step2 {
  margin-top: -10px !important;
  margin-bottom: 20px !important;
  font-weight: 500 !important;
  font-size: 13.5px !important;
  color: #d93025 !important;
}

.subito-portal-container .subito-step-navigation-margin-top-24 {
  margin-top: 24px !important;
}

.subito-portal-container .subito-step-navigation-margin-top-14 {
  margin-top: 14px !important;
}

.subito-portal-container .subito-terms-margins {
  margin-top: 14px !important;
  margin-bottom: 14px !important;
}

.subito-portal-container .subito-success-header-styles {
  text-align: center !important;
  margin-bottom: 26px !important;
}

.subito-portal-container .subito-success-header-styles .subito-success-icon {
  margin-bottom: 12px !important;
}

.subito-portal-container .subito-success-header-styles p {
  color: #5b6b78 !important;
  font-size: 14px !important;
  margin-top: 4px !important;
}

.subito-portal-container .subito-price-card-payment-piano {
  max-width: 540px !important;
  margin: 0 auto 30px !important;
  cursor: default !important;
}

.subito-portal-container .subito-price-card-payment-piano ul {
  border-bottom: 1px solid #e4e9ee !important;
  padding-bottom: 18px !important;
  margin-bottom: 18px !important;
}

.subito-portal-container .subito-simulated-payment-trigger-styles {
  margin-top: 20px !important;
  border-top: 1px dashed #e4e9ee !important;
  padding-top: 15px !important;
  text-align: center !important;
}

.subito-portal-container .subito-simulated-payment-trigger-styles p {
  font-size: 12px !important;
  color: #5b6b78 !important;
  margin-bottom: 10px !important;
}


