/**
 * @file
 * Styles for QuickQueue Event Group Registration
 */

/* Guest fields container */
#guest-fields-wrapper {
  margin-top: 20px;
  /* Remove background and border for cleaner look */
}

/* Fill-method chooser ("Registration for Additional Participants"):
   bold the group title (rendered as a fieldset legend) but keep the two
   radio option labels plain weight. */
.qq-fill-method > legend,
.qq-fill-method .fieldset-legend {
  font-weight: 700;
}
.qq-fill-method .option {
  font-weight: 400;
}

/* Guest fieldsets */
.guest-fieldset {
  margin-bottom: 20px;
  padding: 15px;
  background-color: #fff;
  border: 1px solid #ccc;
  border-radius: 4px;
  box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

/* Guest container styling - boxed layout */
.guest-container {
  margin: 20px 0;
  clear: both;
}

/* Boxed guest registration styling */
.guest-registration-box {
  border: 2px solid #ddd !important;
  border-radius: 8px !important;
  padding: 15px !important;
  margin: 15px 0 !important;
  background-color: #f9f9f9 !important;
  box-shadow: 0 2px 4px rgba(0,0,0,0.1);
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.guest-registration-box:hover {
  border-color: #0073aa;
  box-shadow: 0 4px 8px rgba(0,0,0,0.15);
}

.participant-title {
  font-size: 16px;
  font-weight: bold;
  color: #333;
  margin: 0 0 15px 0;
  padding-bottom: 5px;
  border-bottom: 1px solid #ccc;
  text-decoration: none;
}

.guest-registration-box .participant-title {
  margin-top: 0;
  color: #333;
  border-bottom: 1px solid #ccc;
  padding-bottom: 5px;
}

.guest-container .form-item {
  margin-bottom: 15px;
}

.guest-container input[type="text"],
.guest-container input[type="email"],
.guest-container input[type="tel"],
.guest-container input[type="number"],
.guest-container select,
.guest-container textarea {
  width: 100%;
  max-width: none; /* Allow full width like main form fields */
  padding: 8px 12px;
  border: 1px solid #ccc;
  border-radius: 4px;
  box-sizing: border-box;
}

/* Ensure guest fields match main form field widths.
   Exclude checkbox/radio so they keep the theme's 18px sizing. Without the
   exclusion the width:100% below stretched every checkbox, which is why an
   old global `.form-checkbox { width: unset !important }` hack used to live
   here — but that leaked to ALL checkboxes site-wide. Scoping it this way
   keeps the override local to the guest container and lets us drop the hack. */
.guest-container .form-item input:not([type="checkbox"]):not([type="radio"]),
.guest-container .form-item select,
.guest-container .form-item textarea {
  max-width: none;
  width: 100%;
}

/* Prevent field cutting and overflow issues */
.guest-container,
.guest-container .form-item {
  overflow: visible;
  clear: both;
}

/* Make sure container doesn't restrict field width */
.guest-fields-container {
  width: 100%;
  overflow: visible;
}

/* Hide container when no guests to prevent empty box */
#guest-fields-wrapper:empty {
  display: none;
}

.guest-fieldset legend {
  font-weight: bold;
  font-size: 16px;
  color: #333;
  padding: 0 10px;
  background-color: #fff;
  border: 1px solid #ccc;
  border-radius: 4px;
  margin-bottom: 15px;
}

.guest-fieldset.collapsible legend {
  cursor: pointer;
  position: relative;
}

.guest-fieldset.collapsible legend:before {
  content: "▼";
  position: absolute;
  left: -15px;
  top: 0;
  font-size: 12px;
  color: #666;
}

.guest-fieldset.collapsed legend:before {
  content: "▶";
}

.guest-fieldset.collapsed .fieldset-wrapper {
  display: none;
}

/* Guest field inputs */
.guest-fieldset .form-item {
  margin-bottom: 15px;
}

.guest-fieldset .form-item label {
  font-weight: 600;
  color: #555;
}

.guest-fieldset input[type="text"],
.guest-fieldset input[type="email"],
.guest-fieldset input[type="tel"],
.guest-fieldset select,
.guest-fieldset textarea {
  width: 100%;
  max-width: 400px;
  padding: 8px 12px;
  border: 1px solid #ccc;
  border-radius: 4px;
  box-sizing: border-box;
}

.guest-fieldset input:focus,
.guest-fieldset select:focus,
.guest-fieldset textarea:focus {
  border-color: #0073aa;
  box-shadow: 0 0 5px rgba(0, 115, 170, 0.3);
  outline: none;
}

/* Error styling */
.guest-fieldset input.error,
.guest-fieldset select.error,
.guest-fieldset textarea.error {
  border-color: #d32f2f;
  background-color: #fef2f2;
}

.field-error {
  margin-top: 5px;
  padding: 5px 10px;
  background-color: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: 4px;
  color: #b91c1c;
  font-size: 13px;
}

/* Copy buttons */
.copy-from-previous,
.copy-from-main {
  margin: 10px 5px 15px 0;
  padding: 6px 12px;
  font-size: 12px;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  text-transform: uppercase;
  font-weight: 600;
  transition: all 0.3s ease;
}

.copy-from-main {
  background-color: #0073aa;
  color: white;
}

.copy-from-main:hover {
  background-color: #005a87;
}

.copy-from-previous {
  background-color: #6c757d;
  color: white;
}

.copy-from-previous:hover {
  background-color: #5a6268;
}

/* Number of guests field styling */
.form-item-field-delegate-no-of-guest-und-0-value {
  position: relative;
}

.form-item-field-delegate-no-of-guest-und-0-value input {
  max-width: 100px;
}

/* Notification messages */
.messages.temporary {
  position: relative;
  margin-bottom: 15px;
  padding: 12px 15px;
  border-radius: 4px;
  border-left: 4px solid;
  font-weight: 500;
}

.messages.status {
  background-color: #d4edda;
  border-color: #28a745;
  color: #155724;
}

.messages.warning {
  background-color: #fff3cd;
  border-color: #ffc107;
  color: #856404;
}

.messages.error {
  background-color: #f8d7da;
  border-color: #dc3545;
  color: #721c24;
}

/* Responsive design */
@media (max-width: 768px) {
  #guest-fields-wrapper {
    margin-top: 15px;
  }
  
  .guest-fieldset {
    padding: 10px;
    margin-bottom: 15px;
  }
  
  .guest-fieldset input[type="text"],
  .guest-fieldset input[type="email"],
  .guest-fieldset input[type="tel"],
  .guest-fieldset select,
  .guest-fieldset textarea,
  .guest-container input[type="text"],
  .guest-container input[type="email"],
  .guest-container input[type="tel"],
  .guest-container input[type="number"],
  .guest-container select,
  .guest-container textarea {
    max-width: 100%;
    width: 100%;
  }
  
  .copy-from-previous,
  .copy-from-main {
    width: 100%;
    margin: 10px 0 15px 0;
    box-sizing: border-box;
  }
}

/* Admin configuration form styling */
.quickqueue-group-registration-admin {
  max-width: 800px;
}

.quickqueue-group-registration-admin fieldset {
  margin-bottom: 20px;
  padding: 15px;
  border: 1px solid #ccc;
  border-radius: 4px;
}

.quickqueue-group-registration-admin .form-checkboxes {
  max-height: 300px;
  overflow-y: auto;
  border: 1px solid #ddd;
  padding: 10px;
  background-color: #fafafa;
}

.quickqueue-group-registration-admin .form-checkboxes .form-item {
  margin-bottom: 8px;
}

/* Loading states */
.guest-fields-loading {
  opacity: 0.6;
  pointer-events: none;
  position: relative;
}

.guest-fields-loading:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 20px;
  height: 20px;
  margin: -10px 0 0 -10px;
  border: 2px solid #ccc;
  border-radius: 50%;
  border-top-color: #0073aa;
  animation: spin 1s ease-in-out infinite;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* Form layout improvements */
.guest-fieldset .form-item {
  display: inline-block;
  width: 48%;
  margin-right: 2%;
  vertical-align: top;
}

.guest-fieldset .form-item:nth-child(even) {
  margin-right: 0;
}

.guest-fieldset .form-item.form-type-textarea,
.guest-fieldset .form-item.full-width {
  width: 100%;
  margin-right: 0;
}

@media (max-width: 768px) {
  .guest-fieldset .form-item {
    width: 100%;
    margin-right: 0;
    display: block;
  }
}

/* Highlight active guest */
.guest-fieldset.active {
  border-color: #0073aa;
  box-shadow: 0 0 10px rgba(0, 115, 170, 0.3);
}

/* Required field indicators */
.guest-fieldset .form-required {
  color: #d32f2f;
  font-weight: bold;
}

/* Field descriptions */
.guest-fieldset .description {
  font-size: 12px;
  color: #666;
  font-style: italic;
  margin-top: 5px;
} 