/**
 * Course Registration Form - Combined & Optimized Styles
 */

/* =========================================
   Base Styles
   ========================================= */
.course-registration-container {
  padding: 40px 0;
}

.course-registration-container * {
  box-sizing: border-box;
}

/* Typography */
.course-registration-container h2,
.course-registration-container h3,
.course-registration-container h4 {
  margin-top: 0;
  font-weight: 600;
}

.course-registration-container h2 {
  text-transform: uppercase;
}

.course-registration-container h3 {
  margin-bottom: 20px;
  font-size: 18px;
  text-transform: unset;
  font-family: "proxima-nova", sans-serif;
}

.course-registration-container h4 {
  font-size: 20px;
  margin-bottom: 15px;
}

.course-registration-container a {
  text-decoration: none;
}

.course-registration-container a:before {
  text-decoration: none;
}

/* Form Elements */
.course-registration-container label {
  display: flex;
  align-items: center;
  margin-bottom: 5px;
  font-weight: 300;
  font-size: 16px;
}

.course-registration-container input[type="text"],
.course-registration-container input[type="email"],
.course-registration-container input[type="tel"],
.course-registration-container input[type="number"],
.course-registration-container select,
.course-registration-container textarea {
  width: 100%;
  padding: 12px 16px;
  border: 1px solid #333;
  border-radius: 0;
  transition: border-color 0.3s ease;
  font-size: 16px;
  background: white;
  height: 45px;
}

.course-registration-container input[type="text"]:focus,
.course-registration-container input[type="email"]:focus,
.course-registration-container input[type="tel"]:focus,
.course-registration-container input[type="number"]:focus,
.course-registration-container select:focus,
.course-registration-container textarea:focus {
  outline: none;
  border-color: #3cb371;
  box-shadow: 0 0 0 3px rgba(60, 179, 113, 0.2);
}

/* Placeholder text color */
.course-registration-container input[type="text"]::placeholder,
.course-registration-container input[type="email"]::placeholder,
.course-registration-container input[type="tel"]::placeholder,
.course-registration-container input[type="number"]::placeholder,
.course-registration-container textarea::placeholder {
  color: #afafaf;
}

/* Webkit browsers (Chrome, Safari, Edge) */
.course-registration-container input[type="text"]::-webkit-input-placeholder,
.course-registration-container input[type="email"]::-webkit-input-placeholder,
.course-registration-container input[type="tel"]::-webkit-input-placeholder,
.course-registration-container input[type="number"]::-webkit-input-placeholder,
.course-registration-container textarea::-webkit-input-placeholder {
  color: #afafaf;
}

/* Firefox */
.course-registration-container input[type="text"]::-moz-placeholder,
.course-registration-container input[type="email"]::-moz-placeholder,
.course-registration-container input[type="tel"]::-moz-placeholder,
.course-registration-container input[type="number"]::-moz-placeholder,
.course-registration-container textarea::-moz-placeholder {
  color: #afafaf;
  opacity: 1;
}

/* IE/Edge */
.course-registration-container input[type="text"]:-ms-input-placeholder,
.course-registration-container input[type="email"]:-ms-input-placeholder,
.course-registration-container input[type="tel"]:-ms-input-placeholder,
.course-registration-container input[type="number"]:-ms-input-placeholder,
.course-registration-container textarea:-ms-input-placeholder {
  color: #afafaf;
}

#participant_count:focus {
  box-shadow: none;
}

/* Override browser autofill styling */
.course-registration-container input:-webkit-autofill,
.course-registration-container input:-webkit-autofill:hover,
.course-registration-container input:-webkit-autofill:focus,
.course-registration-container input:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0 30px white inset !important;
  box-shadow: 0 0 0 30px white inset !important;
  -webkit-text-fill-color: #333 !important;
  background-color: white !important;
  background-image: none !important;
}

.course-registration-container input:-internal-autofill-selected {
  appearance: none !important;
  background-image: none !important;
  background-color: white !important;
  color: #333 !important;
}

.course-registration-container select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="6"><path d="M0 0l6 6 6-6z" fill="%23333"/></svg>');
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 30px;
  background-color: white;
  cursor: pointer;
}

.course-registration-container textarea {
  min-height: 80px;
  resize: vertical;
  cursor: text;
  border-radius: 0;
}

.course-registration-container button {
  cursor: pointer;
  transition: all 0.3s ease;
  font-weight: 600;
}

.course-registration-container button:focus {
  outline: none;
}


/* =========================================
     Iti Phone Input
     ========================================= */
.course-registration-container .iti {
  width: 100%;
  display: block;
  position: relative;
}

/* Customize the dropdown trigger button */
.course-registration-container .iti__flag-container {
  height: 45px;
  border-right: 1px solid #ccc;
}

/* Style the flag dropdown to match your form style */
.course-registration-container .iti__selected-flag {
  padding: 0 12px;
  background-color: #f7f7f7 !important;
  border-radius: 0;
  transition: background-color 0.3s;
}

.course-registration-container .iti__selected-flag:hover {
  background-color: #e9e9e9 !important;
}

/* Make the country dropdown match your form styling */
.course-registration-container .iti__country-list {
  border-radius: 6px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.15);
  border: 1px solid #ddd;
  margin-top: 4px;
}

/* Style the country items */
.course-registration-container .iti__country {
  padding: 10px 12px;
  display: flex;
  align-items: center;
}

.course-registration-container .iti__country.iti__active {
  background-color: rgba(42, 109, 108, 0.1);
}

.course-registration-container .iti__country.iti__highlight {
  background-color: rgba(42, 109, 108, 0.05);
}

/* Input field adjustments */
.course-registration-container input[type="tel"].iti__input {
  padding-left: 90px !important;
  /* Make space for the country code */
}

/* Style validation states */
.course-registration-container .iti input.error {
  border-color: #d9534f;
}

/* Improve mobile responsiveness */
@media (max-width: 576px) {
  .course-registration-container .iti__country-list {
    width: 260px;
    left: 0;
  }

  .course-registration-container input[type="tel"].iti__input {
    font-size: 14px;
    /* Slightly smaller on mobile */
  }
}

/* Adjust for cases where there might be error messages */
.course-registration-container .form-group .error-message+.iti,
.course-registration-container .iti+.error-message {
  margin-top: 5px;
}

/* Fix for z-index issues with the dropdown */
.course-registration-container .iti__country-list {
  z-index: 99;
  max-height: 200px;
}

/* Style for when a valid number is entered */
.course-registration-container .iti__input.valid-number {
  border-color: #28a745 !important;
  background-color: rgba(40, 167, 69, 0.05);
}

/* Remove the original phone prefix styles since we're replacing it */
.course-registration-container .phone-prefix {
  display: none;
}

/* For participant phone fields too */


.course-registration-container .participant-section .iti {
  width: 100%;
}

/* =========================================
     Layout & Structure
     ========================================= */
.course-registration-container .course-registration-content {
  display: flex;
  flex-wrap: nowrap;
  gap: 30px;
  align-items: flex-start;
}

.course-registration-container .course-registration-main {
  flex: 1;
  min-width: 0;
  background-color: #fff;
  order: 1;
}

.course-registration-container .course-registration-sidebar {
  position: sticky;
  top: 210px;
  align-self: flex-start;
  /* max-height: calc(100vh - 220px); */
  order: 2;
  flex-shrink: 0;
  width: 400px;
  max-width: 400px;
}

.course-registration-container .group-container {
  padding: 20px;
}

/* Form Groups & Rows */
.course-registration-container .form-group:not(:last-child) {
  margin-bottom: 20px;
}

.course-registration-container .form-group {
  position: relative;
  min-height: 45px;
}

.course-registration-container .form-row {
  display: flex;
  gap: 20px;
}

.course-registration-container .form-row::before,
.course-registration-container .form-row::after {
  content: unset !important;
}

.course-registration-container .form-row .form-group {
  flex: 1;
}

/* Form validation messages */
.course-registration-container .error-message {
  color: #d9534f;
  font-size: 12px;
  margin-top: 5px;
  text-align: left;
  display: block;
  min-height: 18px;
  line-height: 1.4;
}

.course-registration-container .success-message {
  color: #5cb85c;
  font-size: 14px;
  margin-top: 5px;
}

.course-registration-container .info-message {
  color: #0073aa;
  font-size: 14px;
  margin-top: 5px;
}

.course-registration-container input.error,
.course-registration-container select.error,
.course-registration-container textarea.error {
  border-color: #d9534f;
}

/* Form Hints & Tooltips */
.course-registration-container .form-hint {
  display: block;
  font-size: 12px;
  margin-top: 5px;
  color: #666;
  font-style: italic;
}

.course-registration-container .form-hint[id*='invoice-'] {
  color: #ff6b35;
  font-weight: 500;
}

.course-registration-container .info-tooltip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 0;
  background-color: #d0d0d0;
  font-style: italic;
  font-weight: bold;
  font-size: 14px;
  color: #666;
  cursor: help;
  position: relative;
  margin-left: 8px;
  vertical-align: middle;
}

.course-registration-container .info-tooltip::before {
  content: attr(data-tooltip);
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%) translateY(-100%);
  background-color: #333;
  color: white;
  padding: 8px 12px;
  border-radius: 4px;
  font-size: 14px;
  white-space: nowrap;
  opacity: 0;
  visibility: hidden;
  transition: all 0.2s ease;
  font-style: normal;
  font-weight: normal;
  pointer-events: none;
  z-index: 100;
}

.course-registration-container .info-tooltip::after {
  content: '';
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%) translateY(0);
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-top: 6px solid #333;
  opacity: 0;
  visibility: hidden;
  transition: all 0.2s ease;
}

.course-registration-container .info-tooltip:hover::before,
.course-registration-container .info-tooltip:hover::after {
  opacity: 1;
  visibility: visible;
}

/* =========================================
     Checkbox & Radio Groups
     ========================================= */
.course-registration-container .checkbox-group,
.course-registration-container .radio-group {
  display: flex;
  align-items: center;
  gap: 10px;
}

.course-registration-container .checkbox-group input[type="checkbox"],
.course-registration-container .radio-group input[type="radio"] {
  margin: 0;
  cursor: pointer;
  width: 20px;
  height: 20px;
  border-radius: 0;
  appearance: none;
  -webkit-appearance: none;
  border: 1px solid #333;
  background-color: white;
}

.course-registration-container .checkbox-group input[type="checkbox"]:checked {
  background-color: #11a540;
  border-color: #11a540;
  appearance: none;
  -webkit-appearance: none;
  position: relative;
}

.course-registration-container .checkbox-group input[type="checkbox"]:checked::after {
  content: "✓";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: white;
  font-size: 14px;
  font-weight: bold;
}

.course-registration-container .summary-terms-acceptance .checkbox-group input[type="checkbox"]:checked {
  background-color: #11a540;
  border-color: #11a540;
  appearance: none;
  -webkit-appearance: none;
  position: relative;
}

.course-registration-container .summary-terms-acceptance .checkbox-group input[type="checkbox"]:checked::after {
  content: "✓";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: white;
  font-size: 14px;
  font-weight: bold;
}

.course-registration-container .checkbox-group label,
.course-registration-container .radio-group label {
  margin: 0;
  cursor: pointer;
  display: flex;
  font-weight: bold;
}

.course-registration-container .checkbox-group label strong,
.course-registration-container .radio-group label strong {
  display: block;
  margin-bottom: 4px;
  font-weight: 600;
}

.course-registration-container .option-description {
  display: block;
  color: #3cb371;
  font-size: 14px;
  margin-bottom: 4px;
}

.course-registration-container .option-details,
.course-registration-container .option-note {
  display: block;
  font-size: 14px;
  font-weight: normal;
  color: #666;
}

.course-registration-container .conditional-field {
  margin-top: 10px;
}

/* Disabled option styling */
.course-registration-container .disabled-option {
  opacity: 0.6;
  pointer-events: none;
}

.course-registration-container .disabled-option label {
  color: #999;
  cursor: not-allowed;
}

.course-registration-container .disabled-option input[type="checkbox"] {
  cursor: not-allowed;
}

/* Participant Data Option Cards */
.course-registration-container .participant-data-options {
  margin: 20px 0;
}

.course-registration-container .data-option-cards {
  display: flex;
  gap: 15px;
  margin-bottom: 15px;
}

.course-registration-container .data-option-card {
  flex: 1;
  background-color: white;
  padding: 20px;
  cursor: pointer;
  transition: all 0.3s ease;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  min-height: 180px;
  box-shadow: 0 2px 8px rgba(60, 179, 113, 0.1);
}

.course-registration-container .data-option-card:hover {
  box-shadow: 0 2px 8px rgba(60, 179, 113, 0.1);
}

.course-registration-container .data-option-card.selected {
  background-color: #e6f5eb;
  border-color: #3cb371;
  box-shadow: 0 2px 8px rgba(60, 179, 113, 0.2);
}

.course-registration-container .data-option-card.disabled {
  opacity: 0.6;
  cursor: not-allowed;
  background-color: #f5f5f5;
  border-color: #ccc;
}

.course-registration-container .data-option-card.disabled:hover {
  border-color: #ccc;
  box-shadow: none;
}

.course-registration-container .option-icon img {
  width: 32px;
  height: 32px;
  opacity: 0.7;
}

.course-registration-container .data-option-card.selected .option-icon img {
  opacity: 1;
}

.course-registration-container .option-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.course-registration-container .option-content h4 {
  font-size: 16px;
  font-weight: 600;
  margin: 0 0 8px 0;
  color: #333;
}

.course-registration-container .option-content p {
  font-size: 14px;
  color: #666;
  line-height: 1.4;
  margin: 0;
}

.course-registration-container .option-indicator {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}


.course-registration-container .circle-icon {
  width: 20px;
  height: 20px;
  border: 2px solid #ccc;
  border-radius: 50%;
  background-color: white;
}

.course-registration-container .data-option-card.selected .circle-icon {
  border-color: #3cb371;
  background-color: #3cb371;
}

.course-registration-container .data-option-card.selected .circle-icon::after {
  content: '✓';
  color: white;
  font-size: 12px;
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

/* Payment Option Cards */
.course-registration-container .payment-option-cards {
  display: flex;
  gap: 15px;
}

.course-registration-container .payment-option-card {
  flex: 1;
  background-color: white;
  padding: 20px;
  cursor: pointer;
  transition: all 0.3s ease;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  min-height: 180px;
  box-shadow: 0 2px 8px rgba(60, 179, 113, 0.1);
}

.course-registration-container .payment-option-card:hover {
  box-shadow: 0 2px 8px rgba(60, 179, 113, 0.1);
}

.course-registration-container .payment-option-card.selected {
  background-color: #e6f5eb;
  border-color: #3cb371;
  box-shadow: 0 2px 8px rgba(60, 179, 113, 0.2);
}

.course-registration-container .payment-option-card .option-icon {
  margin-bottom: 15px;
}

.course-registration-container .payment-option-card .option-icon img {
  width: 32px;
  height: 32px;
  opacity: 0.7;
}

.course-registration-container .payment-option-card.selected .option-icon img {
  opacity: 1;
}

.course-registration-container .payment-option-card .option-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.course-registration-container .payment-option-card .option-content h4 {
  font-size: 16px;
  font-weight: 600;
  margin: 0 0 8px 0;
  color: #333;
}

.course-registration-container .payment-option-card .option-content p {
  font-size: 14px;
  color: #666;
  line-height: 1.4;
  margin: 0;
}

.course-registration-container .payment-option-card .option-indicator {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Payment option card circle icon styling */
.course-registration-container .payment-option-card .circle-icon {
  width: 20px;
  height: 20px;
  border: 2px solid #ccc;
  border-radius: 50%;
  background-color: white;
}

.course-registration-container .payment-option-card.selected .circle-icon {
  border-color: #3cb371;
  background-color: #3cb371;
}

.course-registration-container .payment-option-card.selected .circle-icon::after {
  content: '✓';
  color: white;
  font-size: 12px;
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

.course-registration-container #invoice-details {
  margin-top: 20px;
}

/* Phone Input */
.course-registration-container .phone-input-wrapper {
  position: relative;
}

.course-registration-container .phone-prefix {
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  color: #333;
  font-size: 16px;
}

.course-registration-container .phone-input-wrapper input[type="tel"] {
  padding-left: 50px;
}

/* =========================================
     Multi-step Form Navigation
     ========================================= */
.course-registration-container #course-registration-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* Registration Steps */
.course-registration-container .registration-step {
  display: none;
  opacity: 0;
  transition: opacity 0.3s ease;
}

/* .registration-step:not(.step-course, .step-participants-details) {
  padding: 30px;
} */

.course-registration-container .registration-step.step-participants-details {
  box-shadow: none;
}

.course-registration-container .registration-step.step-participants-count {
  padding: 0;
  box-shadow: none;
}

.course-registration-container .step-2-top-buttons {
  margin-bottom: 20px;
  margin-top: 0 !important;
  justify-content: flex-start;
}

.course-registration-container .step-2-top-buttons .prev-button {
  display: inline-flex;
  align-items: center;
  font-size: 18px;
  gap: 8px;
  font-weight: bold;
  color: #7C7C7C;
}

.course-registration-container .step-2-top-buttons .prev-button .prev-button-text {
  text-decoration: underline;
}

.course-registration-container .step-2-top-buttons .prev-button .icon-left-open-big {
  display: inline-block;
}

.course-registration-container .step-3-top-buttons {
  margin-bottom: 20px;
  margin-top: 0 !important;
  justify-content: flex-start;
}

.course-registration-container .step-3-top-buttons .prev-button {
  display: inline-flex;
  align-items: center;
  font-size: 18px;
  gap: 8px;
  font-weight: bold;
  color: #7C7C7C;
}

.course-registration-container .step-3-top-buttons .prev-button .prev-button-text {
  text-decoration: underline;
}

.course-registration-container .step-3-top-buttons .prev-button .icon-left-open-big {
  display: inline-block;
}

.course-registration-container .registration-step.active {
  display: block;
  opacity: 1;
  animation: fadeIn 0.4s ease;
}

.course-registration-container .step-course {
  background-color: transparent;
  box-shadow: none;
  padding: 0;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

/* Waitlist Form */
.course-registration-container .waitlist-form {
  margin-top: 20px;
}

.course-registration-container .waitlist-form .waitlist-title {
  font-size: 18px;
  color: rgb(255, 0, 0);
  font-weight: 600;
  margin: 0 0 5px 0;
}

.course-registration-container .waitlist-description {
  margin: 0 0 20px 0;
}

.course-registration-container .waitlist-email-input {
  width: 100%;
  padding: 12px 15px;
  border: 1px solid #000000;
  border-radius: 0;
  font-size: 16px;
  margin-top: 8px;
}

.course-registration-container .waitlist-submit-button {
  margin: 0;
}

.course-registration-container .waitlist-message {
  margin-top: 15px;
  padding: 12px;
  border-radius: 4px;
  font-size: 14px;
}

.course-registration-container .waitlist-message.success-message {
  background-color: #d4edda;
  color: #155724;
  border: 1px solid #c3e6cb;
}

.course-registration-container .waitlist-message.error-message {
  background-color: #f8d7da;
  color: #721c24;
  border: 1px solid #f5c6cb;
}

/* Navigation Buttons */
.course-registration-container .form-buttons {
  display: flex;
  justify-content: space-between;
  margin-top: 15px;
  gap: 15px;
}

.course-registration-container .primary-button,
.course-registration-container .secondary-button {
  padding: 14px 24px;
  font-weight: 600;
  font-size: 16px;
  cursor: pointer;
  border: none;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  transition: all 0.2s ease;
  border: none !important;
}

.course-registration-container .primary-button {
  background-color: #2a6d6c;
  color: white;
  flex-grow: 1;
  max-width: 300px;
}

.course-registration-container .primary-button:hover {
  background-color: #225958;
}

.course-registration-container .primary-button:disabled {
  background-color: #E7F3E9;
  color: black;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  cursor: not-allowed;
}

.course-registration-container .secondary-button {
  background-color: #f0f0f0;
  color: #333;
}

.course-registration-container .secondary-button:hover {
  background-color: #e0e0e0;
}


/* Step Header Styles */
.course-registration-container .step-header {
  margin-bottom: 20px;
}

.course-registration-container .step-header h1 {
  font-size: 32px;
  font-weight: 700;
  margin: 0 0 10px 0;
  line-height: 1.2;
}

.course-registration-container .step-header .step-header-title {
  font-size: 16px;
  font-weight: bold;
  color: #666;
  margin: 0 0 5px 0;
  text-transform: uppercase;
}

.course-registration-container .step-header h3 {
  font-size: 24px;
  font-weight: 700;
  margin: 0;
  color: #333;
}

.course-registration-container .step-header p.location-date {
  font-size: 18px;
  color: #333;
  margin: 10px 0 0 0;
}

/* =========================================
     Step Indicator in Sidebar
     ========================================= */
.course-registration-container .step-progress {
  display: flex;
  justify-content: space-between;
  position: relative;
  padding: 0;
  margin-bottom: 0;
  width: 100%;
}

.course-registration-container .step-progress::before {
  content: '';
  position: absolute;
  top: 20px;
  left: 0;
  right: 0;
  height: 2px;
  background-color: #e0e0e0;
  z-index: 1;
}

.course-registration-container .progress-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  z-index: 2;
  width: 25%;
  text-align: center;
}

.course-registration-container .progress-number {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: #e0e0e0;
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  margin-bottom: 8px;
  transition: all 0.3s ease;
}

.course-registration-container .progress-item.active .progress-number {
  background-color: #2a6d6c;
}

.course-registration-container .progress-item.completed .progress-number {
  background-color: #2a6d6c;
}

.course-registration-container .progress-item span {
  font-size: 14px;
  color: #666;
  font-weight: 500;
}

.course-registration-container .progress-item.active span {
  color: #2a6d6c;
  font-weight: 600;
}

.course-registration-container .checkmark {
  width: 20px;
  height: 20px;
  fill: white;
}

/* Make completed and active step indicators look clickable */
.course-registration-container .progress-item.completed,
.course-registration-container .progress-item.active {
  cursor: pointer;
  transition: transform 0.2s ease;
}

.course-registration-container .progress-item.completed:hover,
.course-registration-container .progress-item.active:hover {
  transform: translateY(-2px);
}

/* Add subtle glow effect on hover */
.course-registration-container .progress-item.completed:hover .progress-number,
.course-registration-container .progress-item.active:hover .progress-number {
  box-shadow: 0 0 10px rgba(42, 109, 108, 0.4);
}

/* Add slight scale effect to the number/checkmark */
.course-registration-container .progress-item.completed:hover .progress-number,
.course-registration-container .progress-item.active:hover .progress-number {
  transform: scale(1.05);
}

/* Add a subtle hint for users to know these are clickable */
.course-registration-container .progress-item.completed:after,
.course-registration-container .progress-item.active:after {
  content: '';
  position: absolute;
  bottom: -15px;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 2px;
  background-color: #2a6d6c;
  transition: width 0.2s ease;
}

.course-registration-container .progress-item.completed:hover:after,
.course-registration-container .progress-item.active:hover:after {
  width: 30px;
}

/* =========================================
     Summary Section in Sidebar
     ========================================= */
.course-registration-container .course-summary {
  background-color: #f7f7f7;
  padding: 20px;
  margin-top: 20px;
  position: relative;
}

.course-registration-container .course-summary h2 {
  font-size: 24px;
  text-transform: uppercase;
  font-weight: 700;
  margin-top: 0;
  margin-bottom: 10px;
  color: #333;
}

.course-registration-container .course-summary-title {
  font-size: 16px;
  font-weight: 700;
  margin: 10px 0;
  line-height: 1.3;
}

.course-registration-container .course-summary-details {
  display: flex;
  font-size: 16px;
  color: #222;
}

.course-registration-container .course-summary-details svg {
  fill: #11a540;
  margin-left: -3px;
}

.course-registration-container .course-summary-details #summary-date {
  margin-left: 3px;
}

/* Ensure participant count is always visible */
.course-registration-container #summary-participants-count {
  visibility: visible !important;
}

/* Price summary styling */
.course-registration-container .price-summary {
  border-top: 1px solid #d0d0d0;
}

.course-registration-container .price-row {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
}

/* Price elements styling */
.course-registration-container #summary-base-price,
.course-registration-container #summary-vat,
.course-registration-container #summary-total,
.course-registration-container #summary-discount {
  display: inline-block !important;
  font-weight: 600;
  color: #333;
  visibility: visible !important;
  min-width: 80px;
  text-align: right;
}

.course-registration-container .discount-row {
  color: #3cb371;
}

.course-registration-container .price-row {
  border-bottom: 1px solid #d0d0d0;
}

.course-registration-container .vat-row {
  padding-top: 5px;
  border-bottom: 1px solid #d0d0d0;
}

.course-registration-container .total-row {
  padding-top: 5px;
  font-weight: 700;
  font-size: 18px;
}

/* Discount Code Section in Summary */
.course-registration-container .discount-code-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  padding: 10px 0;
}

.course-registration-container .discount-code-label {
  text-decoration: underline;
  color: #333;
  font-size: 16px;
}

.course-registration-container .discount-code-toggle {
  display: flex;
  align-items: center;
  transition: transform 0.3s ease;
}

.course-registration-container .discount-code-toggle::before {
  content: "\6e";
  font-family: "kunskapsgruppen";
}

.course-registration-container .summary-discount-code.active .discount-code-toggle {
  transform: rotate(180deg);
}

.course-registration-container .discount-code-content {
  margin-top: 15px;
}

.course-registration-container .discount-code-input-group {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 10px;
}

.course-registration-container .discount-code-input-group input {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid #333;
  border-radius: 0;
  font-size: 14px;
}

.course-registration-container .discount-code-message {
  margin-top: 10px;
  font-size: 14px;
}

.course-registration-container .discount-code-message .error-message {
  color: #d9534f;
  text-align: right;
}

.course-registration-container .discount-code-message .success-message {
  color: #5cb85c;
  text-align: right;
}

/* Terms Acceptance & BOKA Button in Summary */
.course-registration-container .summary-terms-acceptance {
  padding-top: 20px;
  transition: opacity 0.3s ease;
  position: relative;
  min-height: 60px;
}

.course-registration-container .summary-terms-acceptance .error-message {
  color: #d9534f;
  font-size: 12px;
  margin-top: 8px;
  padding: 8px 12px;
  background-color: #f8d7da;
  border-left: 3px solid #d9534f;
  display: block;
}

.course-registration-container .summary-terms-acceptance .checkbox-group {
  margin-bottom: 20px;
}

.course-registration-container .summary-terms-acceptance .checkbox-group input[type="checkbox"] {
  transform: scale(1.1);
}

.course-registration-container .summary-terms-acceptance .checkbox-group label {
  font-size: 15px;
  color: #333;
  font-weight: 700;
}

.course-registration-container .summary-terms-acceptance .checkbox-group label .terms-link {
  margin-left: 5px;
}

.course-registration-container #summary-submit-button {
  width: 100%;
  padding: 16px 24px;
  font-size: 18px;
  font-weight: 700;
  background-color: #2a6d6c;
  color: white;
  border: none;
  border-radius: 0;
  cursor: pointer;
  transition: all 0.2s ease;
  text-align: center;
  max-width: none;
  margin-top: 15px;
}

.course-registration-container #summary-submit-button:hover {
  background-color: #225958;
  transform: translateY(-2px);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

.course-registration-container #summary-submit-button:disabled {
  background-color: #aaa;
  transform: none;
  box-shadow: none;
  cursor: not-allowed;
}

.course-registration-container #summary-submit-button:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(42, 109, 108, 0.4);
}

.course-registration-container .summary-terms-acceptance .terms-link {
  color: #2a6d6c;
  text-decoration: underline;
  font-weight: 600;
}

.course-registration-container .summary-terms-acceptance .terms-link:hover {
  color: #225958;
}

/* Step 2 Continue Button in Summary */
.course-registration-container .summary-step-2-button {
  margin-top: 20px;
}

.course-registration-container .summary-step-2-button .next-button {
  width: 100%;
  padding: 16px 24px;
  font-size: 18px;
  font-weight: 700;
  background-color: #2a6d6c;
  color: white;
  border: none;
  border-radius: 0;
  cursor: pointer;
  transition: all 0.2s ease;
  text-align: center;
  max-width: none;
}

.course-registration-container .summary-step-2-button .next-button:hover {
  background-color: #225958;
  transform: translateY(-2px);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

.course-registration-container .summary-step-2-button .next-button:disabled {
  background-color: #aaa;
  transform: none;
  box-shadow: none;
  cursor: not-allowed;
}

/* =========================================
     Step 1: Course Selection
     ========================================= */
.course-registration-container .step1-container {
  display: flex;
  gap: 40px;
}

.course-registration-container .course-selection-section {
  flex: 1;
  background-color: #f7f7f7;
  padding: 20px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.course-registration-container .contact-info-section {
  max-width: 400px;
  background-color: #f7f7f7;
  padding: 20px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.course-registration-container .contact-person {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 15px;
  margin-top: 20px;
}

.course-registration-container .avatar-circle {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background-color: #e0e0e0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.course-registration-container .contact-person-details {
  font-size: 16px;
}

.course-registration-container .contact-name {
  font-weight: 600;
  margin-bottom: 5px;
}

.course-registration-container .contact-title,
.course-registration-container .contact-email,
.course-registration-container .contact-phone {
  margin: 5px 0;
  color: #555;
  word-break: break-all;
}


.course-registration-container .course-title {
  font-weight: 600;
}

.course-registration-container .course-location-date span {
  display: inline-block;
}

.course-registration-container .course-price {
  display: none;
  font-size: 18px;
  margin-top: 20px;
}

/* =========================================
     Step 2: Participants Count
     ========================================= */
.course-registration-container .registration-step.step-participants-count h2 {
  font-size: 24px;
}

.course-registration-container .registration-step.step-participants-count h3 {
  font-size: 18px;
}

.course-registration-container .participants-info {
  color: #666;
}

.course-registration-container .step-2-content-wrapper {
  background-color: #f7f7f7;
  padding: 20px;
  margin-bottom: 20px;
}

.course-registration-container .participant-data-options {
  margin-top: 20px;
}

.course-registration-container .participant-data-options h3 {
  font-size: 18px;
  margin-bottom: 15px;
  color: #333;
}

.course-registration-container .participants-input {
  display: flex;
  align-items: center;
}

.course-registration-container .participants-input input {

  max-width: 100px;
  font-size: 18px;
  text-align: center;
  border: none !important;
  border-bottom: 1px solid #7C7C7C !important;
  border-right: none;
  background-color: #f7f7f7 !important;
  cursor: default;
  user-select: none;
  height: 45px;
  padding: 0 8px;
}

.course-registration-container .participants-input input:focus {
  background-color: white;
  cursor: text;
  user-select: text;
}

.course-registration-container .participant-btn {
  background-color: #f7f7f7 !important;
  width: 45px;
  height: 45px;
  border: none !important;
  border-bottom: 1px solid #7C7C7C !important;
  color: #333;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  min-width: 45px;
  flex-shrink: 0;
  border-radius: 0;
  padding: 0;
}

.course-registration-container .participant-btn svg {
  width: 16px;
  height: 16px;
  display: block;
}

.course-registration-container .participant-btn.minus-btn {
  border-left: none;
}

.course-registration-container .participant-btn.plus-btn {
  border-left: none;
}

.course-registration-container .participant-btn:hover {
  background-color: #e0e0e0 !important;
}

.course-registration-container .participant-btn:active {
  transform: scale(0.95);
}

.course-registration-container .participant-btn:disabled {
  cursor: not-allowed;
  color: #999;
}

.course-registration-container .participant-btn:disabled:hover {
  background-color: #f0f0f0;
  border-color: #ccc;
}

.course-registration-container .discount-input {
  display: flex;
  gap: 10px;
}

.course-registration-container .activate-button {
  width: fit-content;
  padding: 12px 34px;
  cursor: pointer;
  text-transform: uppercase;
  align-self: end;
  border: none !important;
}

.course-registration-container .activate-button.activated {
  background-color: #46b450;
  color: white;
  border-color: #46b450;
  cursor: default;
}

.course-registration-container .activate-button.remove-button {
  background-color: #E1E1E1;
  color: #000;
}

.course-registration-container .remove-discount {
  min-width: 100px;
  background-color: #dc3232;
  color: white;
  border: 1px solid #dc3232;
  padding: 10px 16px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}

.course-registration-container .remove-discount:hover {
  background-color: #a00;
  border-color: #a00;
}

/* =========================================
     Step 3: Contact & Payment 
     ========================================= */
.course-registration-container .company-information {
  padding: 20px;
  background-color: #EDF1FE;
}

.course-registration-container .company-information h2 {
  font-family: 'proxima-nova-extra-condensed';
  text-transform: uppercase;
  margin: 0;
  padding-bottom: 20px;
  font-size: 24px;
}

.course-registration-container .company-information .address-header {
  font-family: 'proxima-nova-extra-condensed';
  text-transform: uppercase;
  margin: 20px 0 15px 0;
  font-size: 18px;
  color: #333;
}

.course-registration-container .info-tooltip {
  background-color: #f7f7f7;
}


.course-registration-container .company-information .form-row .form-group {
  margin-bottom: 0;
}

/* Payment Options */
.course-registration-container .payment-options {
  display: flex;
  flex-direction: column;
  padding: 20px;
}

.course-registration-container .payment-options h3 {
  font-size: 20px;
  margin: 0 0 20px 0;
  padding: 0;
  font-family: "proxima-nova-extra-condensed", sans-serif;
}

.course-registration-container .payment-buttons {
  display: flex;
  gap: 15px;
}

.course-registration-container .payment-option {
  flex: 1;
  padding: 15px;
  border: 1px solid #ddd;
  border-radius: 0;
  text-align: center;
  font-weight: 600;
  background-color: white;
  cursor: pointer;
  transition: all 0.2s ease;
  color: #333;
}

.course-registration-container .payment-option.active {
  border-color: #2a6d6c;
  background-color: #e6f7ef;
  color: #2a6d6c;
}

.course-registration-container .payment-option:hover {
  border-color: #76c7a6;
}

input#organization_number.validated {
  border-color: #46b450;
  background-color: #f7fff7;
}

/* Invoice Delivery Options */
.course-registration-container .invoice-delivery-options {
  padding: 20px;
}

.course-registration-container .invoice-delivery-options h3 {
  font-family: "proxima-nova-extra-condensed", sans-serif;
  font-size: 20px;
  text-transform: uppercase;
}

.course-registration-container .invoice-delivery-options .radio-group .conditional-field {
  width: 100%;
  order: 3;
}

.course-registration-container .invoice-delivery-options .radio-group {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  flex-wrap: wrap;
  margin-bottom: 15px;
  transition: all 0.3s ease;
  padding: 15px;
  gap: 10px;
}

.course-registration-container .invoice-delivery-options .radio-group input[type="radio"] {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  margin-top: 2px;
  order: 1;
}

.course-registration-container .invoice-delivery-options .radio-group input[type="radio"]:checked {
  background-color: #11a540;
  border-color: #11a540;
  position: relative;
}

.course-registration-container .invoice-delivery-options .radio-group input[type="radio"]:checked::after {
  content: "✓";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: white;
  font-size: 14px;
  font-weight: bold;
}

.course-registration-container .invoice-delivery-options .radio-group>label {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  cursor: pointer;
  flex: 1;
  margin-left: 0;
  order: 2;
}

.course-registration-container .invoice-delivery-options .radio-group>label>div:first-child {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
}

.course-registration-container .invoice-delivery-options .radio-group>label>div:first-child strong {
  font-weight: 600;
  color: #000;
}

.course-registration-container .invoice-delivery-options .radio-group .option-description {
  color: #666;
  font-weight: normal;
  font-size: 14px;
}

.course-registration-container .invoice-delivery-options .radio-group .option-details {
  color: #000;
  font-size: 14px;
  display: block;
  margin-top: 4px;
}

.course-registration-container .invoice-delivery-options .radio-group .conditional-field label {
  display: block;
  margin-bottom: 8px;
  font-weight: bold;
  color: #000;
}

.course-registration-container .invoice-delivery-options .radio-group .conditional-field input[type="email"] {
  width: 100%;
  background-color: white;
  border: 1px solid #333;
  border-radius: 0;
  padding: 10px;
}

.course-registration-container .invoice-delivery-options .radio-group .conditional-field input[type="email"]:focus {
  border-color: #333;
  outline: none;
}

.course-registration-container .invoice-delivery-options .radio-group:has(input:checked) {
  border-color: #333;
  background-color: #e6f5eb;
}

.course-registration-container .invoice-delivery-options .radio-group:has(input:checked) input[type="radio"] {
  margin-right: 10px;
}

/* Checkout Container */
.course-registration-container #checkout-container {
  margin-top: 0;
}

/* Loading overlay for discount validation */
.course-registration-container .discount-loading-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(255, 255, 255, 0.9);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}

.course-registration-container .discount-loading-overlay .loading-spinner {
  width: 40px;
  height: 40px;
  border: 4px solid #f3f3f3;
  border-top: 4px solid #11a540;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

.course-registration-container .button-loader {
  display: inline-block;
  width: 16px;
  height: 16px;
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-top: 2px solid #ffffff;
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
  margin-right: 8px;
  vertical-align: middle;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(360deg);
  }
}

.course-registration-container .loading-indicator {
  display: inline-block;
  margin-top: 5px;
  padding: 5px 10px;
  background-color: #f0f0f0;
  border-left: 3px solid #0073aa;
  font-size: 14px;
  color: #444;
}

.course-registration-container .org-number-message.error-message {
  margin-top: 5px;
  padding: 5px 10px;
  background-color: #ffebe8;
  border-left: 3px solid #dc3232;
  color: #8a1f11;
  font-size: 14px;
}

.course-registration-container .org-number-message.success-message {
  margin-top: 5px;
  padding: 5px 10px;
  background-color: #ecf7ed;
  border-left: 3px solid #46b450;
  color: #1d7d31;
  font-size: 14px;
}

/* Swedbank Pay Checkout */
.course-registration-container #swedbank-pay-checkout {
  display: block !important;
  min-height: 400px;
  width: 100%;
  position: relative;
  z-index: 100;
}

/* Payment loading and error messages */
.course-registration-container .payment-loading {
  padding: 20px;
  text-align: center;
  font-weight: 500;
  color: #555;
}

.course-registration-container .payment-error {
  padding: 20px;
  text-align: center;
  color: #d9534f;
  background-color: #f2dede;
  border-radius: 6px;
  margin-top: 15px;
}

.course-registration-container .payment-error a.try-again {
  display: inline-block;
  margin-top: 10px;
  color: #2a6d6c;
  font-weight: 600;
  text-decoration: underline;
}

/* =========================================
     Step 4: Participants
     ========================================= */
.course-registration-container .participant-section {
  background-color: white;
  padding: 25px;
  border-radius: 6px;
  margin-bottom: 20px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.course-registration-container .participant-section h3 {
  font-size: 18px;
  margin-top: 0;
  margin-bottom: 20px;
}

.course-registration-container .participant-section .participant-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.course-registration-container .participant-section h4,
.course-registration-container .contact-person-section h4 {
  margin-top: 0;
}

.course-registration-container .contact-person-section #contact_phone {
  padding-left: 104px !important;
}

/* Add Participant Button */
.course-registration-container .add-participant-button {
  display: flex;
  justify-content: center;
  margin: 20px 0;
}

.course-registration-container .add-participant-button button {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  background-color: transparent;
  color: #2a6d6c;
  border: 2px dashed #76c7a6;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
}

.course-registration-container .add-participant-button button:hover {
  background-color: #f0f9f5;
}

.course-registration-container .add-participant-button button svg {
  fill: #2a6d6c;
}

.course-registration-container .remove-participant-container {
  text-align: right;
  margin-top: 10px;
}

.course-registration-container .remove-participant {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: none;
  border: none;
  color: #777;
  font-size: 14px;
  cursor: pointer;
  padding: 5px 10px;
}

.course-registration-container .remove-participant:hover {
  color: #d9534f;
}

.course-registration-container .remove-participant svg {
  fill: currentColor;
}

/* =========================================
     Responsive Adjustments
     ========================================= */
@media (max-width: 992px) {

  .course-registration-container .course-registration-content {
    flex-direction: column;
  }

  .course-registration-container .course-registration-sidebar {
    position: unset;
    width: 100%;
    max-width: 100%;
    order: 2;
  }

  /* Fixed step progress bar at top on mobile */
  .course-registration-container .step-progress {
    position: fixed;
    top: 131px;
    left: 0;
    right: 0;
    z-index: 1000;
    background: white;
    padding: 20px 0;
  }

  .course-registration-container .step-progress:before {
    top: 40px;
  }

  .course-registration-container .course-registration-main {
    min-width: unset;
    order: 1;
    width: 100%;
  }

  .course-registration-container .step1-container {
    flex-direction: column-reverse;
    gap: 20px;
  }

  .course-registration-container .contact-info-section {
    width: 100%;
    max-width: unset;
  }

  .course-registration-container .form-row {
    flex-direction: column;
    gap: 0;
    margin-bottom: 20px;
  }

  .course-registration-container .payment-buttons {
    flex-direction: column;
  }

  .course-registration-container .primary-button,
  .course-registration-container .secondary-button {
    max-width: 100%;
  }

  .course-registration-container .summary-terms-acceptance {
    margin-top: 20px;
    padding-top: 15px;
  }

  .course-registration-container #summary-submit-button {
    padding: 14px 20px;
    font-size: 16px;
  }

  .course-registration-container .course-summary {
    margin-top: 0;
  }
}

@media (max-width: 890px) {
  .course-registration-container .step-progress {
    top: 125px;
  }
}

/* Mobile optimizations */
@media (max-width: 768px) {
  .course-registration-container .participant-btn {
    width: 50px;
    height: 50px;
  }

  .course-registration-container .participant-btn svg {
    width: 18px;
    height: 18px;
  }

  .course-registration-container .participants-input input {
    max-width: 120px;
    font-size: 20px;
    height: 50px;
  }

  .course-registration-container .data-option-cards {
    flex-direction: column;
    gap: 10px;
  }

  .course-registration-container .data-option-card {
    min-height: 140px;
    padding: 15px;
  }

  .course-registration-container .option-icon img {
    width: 28px;
    height: 28px;
  }

  .course-registration-container .payment-option-cards {
    flex-direction: column;
    gap: 10px;
  }

  .course-registration-container .payment-option-card {
    min-height: 140px;
    padding: 15px;
  }

  .course-registration-container .payment-option-card .option-icon img {
    width: 28px;
    height: 28px;
  }
}

@media (max-width: 576px) {
  .course-registration-container .progress-steps .step .step-name {
    font-size: 12px;
  }

  .course-registration-container .form-row {
    flex-direction: column;
    gap: 0;
  }

  .course-registration-container .payment-options {
    flex-direction: column;
  }

  .course-registration-container .step-progress {
    overflow-x: auto;
    padding-bottom: 10px;
  }

  .course-registration-container .progress-item {
    min-width: 70px;
  }

  .course-registration-container .form-buttons {
    flex-direction: column;
  }
}

@media (max-width: 480px) {
  .course-registration-container .step-progress {
    top: 122px;
  }
}