/* UI Components - Cards, Modals, Lightboxes, etc. */
/* Timezone combobox */
.tz-combobox-wrapper {
  position: relative;
}

.tz-combobox-input {
  width: 100%;
  padding-right: 34px;
  box-sizing: border-box;
}

.tz-combobox-toggle {
  position: absolute;
  right: 6px;
  transform: translateY(-175%);
  width: 24px;
  height: 24px;
  border: none;
  background: transparent;
  cursor: pointer;
  color: var(--color-text-primary);
}
.tz-combobox-toggle:hover {
  background: var(--color-bg-secondary);
}

.tz-combobox-list {
  position: absolute;
  left: 0;
  right: 0;
  max-height: 240px;
  overflow-y: auto;
  background: #fff;
  border: 1px solid #ccc;
  border-top: none;
  z-index: 1000;
  display: none;
  font-size: 13px;
}

.tz-combobox-list.show {
  display: block;
}

.tz-combobox-option {
  padding: 8px 10px;
  cursor: pointer;
}

.tz-combobox-option:hover,
.tz-combobox-option.active {
  background: #eaeaea;
}

/* Ensure timezone combobox respects grid sizing inside date-time-inputs */
.date-time-inputs .tz-combobox-wrapper {
  width: 100%;
  min-width: 0; /* allow shrink inside CSS grid */
}

.date-time-inputs .tz-combobox-input {
  width: 100%;
  padding-right: 34px; /* ensure space for toggle */
  box-sizing: border-box;
}

/* General: inputs/selects in date-time-inputs should not overflow */
.date-time-inputs input,
.date-time-inputs select {
  box-sizing: border-box;
  width: 100%;
}


/* Utility Classes */
.hidden {
  display: none !important;
}

.error-text {
  color: var(--color-error);
}

.loading-message {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-lg);
  background-color: var(--color-bg-secondary);
  border: 1px solid var(--color-border-light);
  border-radius: var(--border-radius-base);
  margin: var(--spacing-lg) 0;
  color: var(--color-text-secondary);
}

.loading-message .loader {
  margin: 0;
}

/* Decoration Positioning */
.decoration-container {
  transform: translate(0px, 0px) scale(1);
}

.decoration-sized-container {
  display:block; /* dynamic sizing applied inline */
}

.decoration-image {
  display:block; /* transform/width applied inline */
}

/* Warning/Info Boxes */
.warning-box {
  background-color: #fff3cd;
  border: 1px solid #ffeeba;
  border-radius: var(--border-radius-base);
  padding: var(--spacing-sm) var(--spacing-lg);
  margin-bottom: var(--spacing-lg);
}

.warning-box strong {
  color: #856404;
}

.warning-box ul {
  margin: var(--spacing-xs) 0 0 var(--spacing-xl);
  padding: 0;
}

/* Info Icons and Tooltips */
.info-icon {
  margin-left: var(--spacing-sm);
  cursor: pointer;
  display: inline-block;
  position: relative;
  margin-bottom: -5px;
}

.info-icon img {
  width: 16px;
  height: 16px;
  vertical-align: middle;
}

.help-text {
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
  margin-bottom: var(--spacing-sm);
  background-color: var(--color-bg-secondary);
  padding: var(--spacing-sm);
  border-radius: var(--border-radius-base);
  line-height: 1.4;
}

.help-text a {
  color: var(--color-primary);
  text-decoration: underline;
}

#analysis-modal .analysis-chart{
  width: 100%;
}
#analysis-modal .analysis-chart canvas{
  width: 100% !important;
  max-width: 500px !important;
  max-height: 350px !important;
  height: auto !important;
  margin: 0 auto;
}

/* Modal Components for JavaScript-generated modals */
.js-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 10000;
  display: flex;
  justify-content: center;
  align-items: center;
}

.js-modal-content {
  background-color: var(--color-bg-primary);
  padding: var(--spacing-xl);
  border-radius: var(--border-radius-lg);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
  max-width: 600px;
  width: 90%;
  font-family: var(--font-family-base);
}

.js-modal-content.small {
  max-width: 500px;
}

.js-modal-content.centered {
  text-align: center;
}

.js-modal-header {
  margin: 0 0 var(--spacing-lg) 0;
  color: var(--color-text-primary);
  text-align: center;
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-lg);
}

.js-modal-message {
  margin-bottom: var(--spacing-lg);
  color: var(--color-text-primary);
  line-height: 1.4;
  text-align: left;
}

.js-modal-message h1,
.js-modal-message h2,
.js-modal-message h3,
.js-modal-message h4,
.js-modal-message h5,
.js-modal-message h6 {
  margin: 0 0 var(--spacing-sm) 0;
  color: var(--color-text-primary);
  font-weight: var(--font-weight-bold);
  text-align: center;
}

.js-modal-message h2 {
  font-size: var(--font-size-lg);
}

.js-modal-message h3,
.js-modal-message h4,
.js-modal-message h5,
.js-modal-message h6 {
  font-size: var(--font-size-base);
}

.js-modal-message p {
  margin: 0 0 var(--spacing-sm) 0;
  line-height: 1.5;
  text-align: left;
}

.js-modal-input {
  width: 100%;
  padding: var(--spacing-sm);
  margin-bottom: var(--spacing-lg);
  border: var(--input-border);
  border-radius: var(--border-radius-base);
  font-size: var(--font-size-base);
  box-sizing: border-box;
  transition: var(--transition-base);
}

.js-modal-input:focus {
  border: var(--input-border-focus);
  outline: none;
  box-shadow: var(--shadow-focus);
}

.js-modal-buttons {
  display: flex;
  gap: var(--spacing-sm);
  justify-content: center;
}

.js-modal-button {
  padding: var(--spacing-sm) var(--spacing-lg);
  border: none;
  border-radius: var(--border-radius-base);
  cursor: pointer;
  font-size: var(--font-size-base);
  transition: var(--transition-hover);
}

.js-modal-button.primary {
  background-color: var(--color-primary);
  color: var(--color-text-light);
}

.js-modal-button.primary:hover {
  background-color: var(--color-primary-hover);
}

.js-modal-button.secondary {
  background-color: var(--color-text-muted);
  color: var(--color-text-light);
}

.js-modal-button.secondary:hover {
  background-color: var(--color-text-secondary);
}

.js-modal-form-group {
  margin-bottom: var(--spacing-lg);
}

.js-modal-form-group label {
  display: block;
  margin-bottom: var(--spacing-sm);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
  font-size: var(--font-size-base);
}

/* Success Messages */
.success-message {
  position: fixed;
  top: var(--spacing-lg);
  right: var(--spacing-lg);
  background-color: var(--color-success);
  color: var(--color-text-light);
  padding: var(--spacing-sm) var(--spacing-xl);
  border: 1px solid var(--color-success-border, #c3e6cb);
  border-radius: var(--border-radius-base);
  z-index: 1000;
  font-family: var(--font-family-base);
  box-shadow: var(--shadow-md);
  font-size: var(--font-size-base);
  max-width: 300px;
}

#vote-content-wrapper #sync-previews-toggle{
  width: initial;
}

/* Loading and Processing States */
.processing {
  pointer-events: none;
  opacity: 0.6;
  transition: opacity 0.3s ease;
}

.success-highlight {
  background-color: var(--color-success-bg);
  transition: background-color 0.3s ease;
}

.warning-highlight {
  background-color: var(--color-warning-bg);
  transition: background-color 0.3s ease;
}

/* Tile Selection States */
.tile-selected {
  border-color: var(--color-primary) !important;
  background-color: var(--color-bg-secondary) !important;
}

.tile-unselected {
  border-color: var(--color-border) !important;
  background-color: var(--color-bg-primary) !important;
}

/* Modal Body Overflow Control */
.modal-open {
  overflow: hidden !important;
}

/* Designs Grid Styling */
.designs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--spacing-lg);
  margin: var(--spacing-xl) 0;
  max-height: 400px;
  overflow-y: auto;
  padding: var(--spacing-sm);
  border: 1px solid var(--color-border-light);
  border-radius: var(--border-radius-base);
  background-color: var(--color-bg-secondary);
}

/* Visibility Toggle States */
.show-inline-block {
  display: inline-block !important;
}

.show-block {
  display: block !important;
}

/* Image Cards */
.image-card {
  position: relative;
  display: block;
  width: 100%;
  border: 2px solid var(--color-text-muted);
  border-radius: var(--border-radius-md);
  box-shadow: var(--shadow-sm);
  transition: var(--transition-slow);
  text-align: center;
  cursor: pointer;
  display: inline-block;
  margin-bottom: var(--spacing-3xl);
  background-color: var(--color-bg-primary);
}

.decorations .image-card {
  max-width: 300px;
  min-width: 300px;
  vertical-align: top;
}
/* removed stray closing brace */

.image-card:hover {
  box-shadow: var(--shadow-xl);
}

.results .image-card:hover,
.management .image-card:hover {
  box-shadow: var(--shadow-sm);
  transform: none;
}

.image-card img {
  width: 100%;
  height: auto;
  margin-bottom: var(--spacing-sm);
  margin-top: var(--spacing-sm);
  max-width: 100%;
}

.image-card.selected {
  border-color: var(--color-accent-indigo);
  box-shadow: var(--shadow-focus);
}

.image-card.selected::after {
  content: "Selected";
  position: absolute;
  top: 8px;
  right: 45px;
  background: #28a745;
  color: #fff;
  font-size: .7rem;
  font-weight: 600;
  padding: 5px 10px;
  border-radius: 3px;
}
#create-vote-form .image-card.selected::after {
  display: none;
}

.image-card.selected .selected-indicator {
  color: var(--color-accent-blue);
}

.image-card.winner {
  border: 3px solid;
  position: relative;
  border-image: linear-gradient(to bottom right, #FFB03A, #FF4236, #BB36FF, #8129D5, #1B8FD7, #19D5CB, #80C662, #FFDC58) 1;
  border-image-slice: 1;
  position: relative;
  /* border-image: var(--gradient-winner) 1; */
  border-image-slice: 1;
  border-radius: var(--border-radius-lg);
  position: relative;
  background: var(--color-bg-primary);
  background-clip: padding-box;
  box-shadow: var(--shadow-lg);
}



.image-card.disabled .decoration-box {
  opacity: 0.3;
}

.image-card.disabled::after {
  content: 'Disabled';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: var(--font-size-lg);
  color: var(--color-primary);
  background: var(--color-bg-overlay);
  padding: var(--spacing-sm);
  border-radius: var(--border-radius-md);
}

/* Selection Indicators */
.selected-indicator {
  position: absolute;
  bottom: var(--spacing-sm);
  right: var(--spacing-sm);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-secondary);
  display: block;
  zoom:1.5;
}

#vote-results .selected-indicator {
  display: none;
}

.selected-indicator.unselected {
  color: var(--color-text-primary);
}

/* Design Cards Grid Layout */
.designs-grid-container {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--grid-gap);
  margin: 0;
  padding: 0;
  background-color: var(--color-bg-primary);
  border: none;
  border-radius: 0;
}

/* Designs Section Styling */
.designs-section {
  background-color: var(--color-bg-primary);
  border: 1px solid var(--color-border-light);
  border-radius: var(--border-radius-lg);
  margin: var(--spacing-3xl) 0;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

/* Section Header */
.section-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: var(--spacing-xl) var(--spacing-xl) var(--spacing-lg) var(--spacing-xl);
  background: linear-gradient(135deg, var(--color-bg-secondary) 0%, var(--color-bg-primary) 100%);
  border-bottom: 1px solid var(--color-border-light);
  gap: var(--spacing-lg);
}

.section-title-area {
  flex: 1;
}

.section-title {
  margin: 0 0 var(--spacing-xs) 0;
  color: var(--color-text-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  margin-bottom: 10px;
}

.section-subtitle {
  margin: 0;
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
  line-height: 1.4;
}

/* Section Actions */
.section-actions {
  display: flex;
  gap: var(--spacing-sm);
  flex-shrink: 0;
}

.section-action-btn {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding: var(--spacing-sm) var(--spacing-lg);
  border: none;
  border-radius: var(--border-radius-md);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: var(--transition-fast);
  min-width: 110px;
  justify-content: center;
}

.section-action-btn.primary {
  background-color: var(--color-primary);
  color: white;
}

.section-action-btn.primary:hover {
  background-color: var(--color-primary-dark);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.section-action-btn.secondary {
  background: transparent;
  color: var(--color-text-primary);
  border: 2px solid var(--color-primary);
}

.section-action-btn.secondary:hover {
  background: var(--color-primary);
  color: white;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.section-action-btn.secondary.active {
  background-color: var(--color-accent-orange);
  color: white;
  border-color: var(--color-accent-orange);
}

.section-action-btn i {
  font-size: var(--font-size-xs);
}


/* Updated Designs Grid Container */
.designs-grid-container {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--grid-gap);
  margin: 0;
  padding: var(--spacing-xl);
  background-color: var(--color-bg-primary);
  border: none;
  border-radius: 0;
}



/* Section Header */
.section-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: var(--spacing-xl) var(--spacing-xl);
  background: linear-gradient(135deg, var(--color-bg-secondary) 0%, var(--color-bg-primary) 100%);
  border-bottom: 1px solid var(--color-border-light);
  gap: var(--spacing-lg);
}


.section-subtitle {
  margin: 0;
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
  line-height: 1.4;
}

/* Section Actions */
.section-actions {
  display: flex;
  gap: var(--spacing-sm);
  flex-shrink: 0;
}

.section-action-btn {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding: var(--spacing-sm) var(--spacing-lg);
  border: none;
  border-radius: var(--border-radius-md);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: var(--transition-fast);
  min-width: 110px;
  justify-content: center;
}

.section-action-btn.primary {
  background-color: var(--color-primary);
  color: white;
}

.section-action-btn.primary:hover {
  background-color: var(--color-primary-dark);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.section-action-btn.secondary {
  background: transparent;
  color: var(--color-text-primary);
  border: 2px solid var(--color-primary);
}

.section-action-btn.secondary:hover {
  background: var(--color-primary);
  color: white;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.section-action-btn.secondary.active {
  background-color: var(--color-accent-orange);
  color: white;
  border-color: var(--color-accent-orange);
}

.section-action-btn i {
  font-size: var(--font-size-xs);
}


/* Updated Reorder Mode Controls */
.reorder-mode-controls {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
}

.reorder-mode-info {
  background-color: var(--color-bg-info);
  border-bottom: 1px solid var(--color-border-light);
  padding: var(--spacing-lg) var(--spacing-xl);
  margin: 0;
}

.reorder-mode-info .info-content {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  color: var(--color-text-info);
  font-size: var(--font-size-sm);
}

.reorder-mode-info i {
  color: var(--color-primary);
  font-size: var(--font-size-base);
}

.reorder-mode-actions {
  background-color: var(--color-bg-secondary);
  border-bottom: 1px solid var(--color-border-light);
  padding: var(--spacing-lg) var(--spacing-xl);
  display: flex;
  gap: var(--spacing-sm);
  justify-content: flex-end;
}

.reorder-action-btn {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding: var(--spacing-sm) var(--spacing-lg);
  border: none;
  border-radius: var(--border-radius-md);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: var(--transition-fast);
}

.reorder-action-btn.save {
  background-color: var(--color-accent-green);
  color: white;
}

.reorder-action-btn.save:hover:not(:disabled) {
  background-color: var(--color-accent-green-dark);
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}

.reorder-action-btn.save:disabled {
  background-color: var(--color-text-muted);
  cursor: not-allowed;
  opacity: 0.6;
}

.reorder-action-btn.cancel {
  background-color: var(--color-text-muted);
  color: white;
}

.reorder-action-btn.cancel:hover {
  background-color: var(--color-text-dark);
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}

/* Reorder Mode Active State */
.designs-grid-container.reorder-mode {
  background-color: #f8f9fa;
  border: 2px dashed var(--color-primary);
}

.designs-grid-container.reorder-mode .design-card {
  cursor: grab;
  transition: all 0.3s ease;
  position: relative;
}

.designs-grid-container.reorder-mode .design-card:hover {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.designs-grid-container.reorder-mode .design-card.dragging {
  cursor: grabbing;
  opacity: 0.8;
  transform: rotate(3deg) scale(1.02);
  z-index: 1000;
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.4);
  border: 2px solid var(--color-primary);
  background-color: var(--color-bg-primary);
}

.designs-grid-container.reorder-mode .design-card.drag-over {
  border: 2px solid var(--color-primary);
  background-color: var(--color-primary-light);
  transform: translateY(-4px);
}

/* Drop placeholder to show where card will be inserted */
.drop-placeholder {
  background: linear-gradient(45deg, var(--color-primary) 25%, transparent 25%), 
              linear-gradient(-45deg, var(--color-primary) 25%, transparent 25%), 
              linear-gradient(45deg, transparent 75%, var(--color-primary) 75%), 
              linear-gradient(-45deg, transparent 75%, var(--color-primary) 75%);
  background-size: 8px 8px;
  background-position: 0 0, 0 4px, 4px -4px, -4px 0px;
  border: 2px dashed var(--color-primary);
  border-radius: var(--border-radius-lg);
  opacity: 0.7;
  min-height: 400px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--font-weight-bold);
  color: var(--color-primary);
  font-size: var(--font-size-sm);
  animation: placeholderPulse 1.5s ease-in-out infinite;
  margin: 0;
  padding: var(--spacing-lg);
  box-sizing: border-box;
  /* Ensure it takes up the same space as a design card in the grid */
  grid-column: span 1;
  position: relative;
}

.drop-placeholder::before {
  content: "Drop here";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: rgba(255, 255, 255, 0.9);
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--border-radius-base);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-primary);
}

@keyframes placeholderPulse {
  0%, 100% { opacity: 0.3; }
  50% { opacity: 0.6; }
}

/* Smooth transitions for card movements during drag */
.designs-grid-container.reorder-mode .design-card:not(.dragging) {
  transition: transform 0.2s ease, opacity 0.2s ease;
}

/* Visual feedback for insertion points */
.designs-grid-container.reorder-mode .design-card.insert-before {
  padding-left: calc(var(--spacing-lg) - 4px);
}

.designs-grid-container.reorder-mode .design-card.insert-after {
  border-right: 4px solid var(--color-accent-green);
  padding-right: calc(var(--spacing-lg) - 4px);
}

/* Disable interactions during reorder mode */
.designs-grid-container.reorder-mode .design-settings-btn,
.designs-grid-container.reorder-mode .design-settings-menu {
  pointer-events: none;
  opacity: 0.5;
}

/* Save reorder button */
.save-reorder-btn {
  background-color: var(--color-accent-green);
  color: white;
  border: none;
  padding: var(--spacing-sm) var(--spacing-lg);
  border-radius: var(--border-radius-md);
  cursor: pointer;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  transition: var(--transition-fast);
  margin-left: var(--spacing-md);
}

.save-reorder-btn:hover {
  background-color: var(--color-accent-green-dark);
}

.save-reorder-btn:disabled {
  background-color: var(--color-text-muted);
  cursor: not-allowed;
}

.cancel-reorder-btn {
  background-color: var(--color-text-muted);
  color: white;
  border: none;
  padding: var(--spacing-sm) var(--spacing-lg);
  border-radius: var(--border-radius-md);
  cursor: pointer;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  transition: var(--transition-fast);
  margin-left: var(--spacing-sm);
}

.cancel-reorder-btn:hover {
  background-color: var(--color-text-dark);
}

.design-card {
  background: var(--color-bg-primary);
  border: 2px solid var(--color-border);
  border-radius: var(--border-radius-lg);
  padding: var(--spacing-lg);
  transition: var(--transition-slow);
  position: relative;
  display: flex;
  flex-direction: column;
}

.design-card:hover {
  border-color: var(--color-text-muted);
  box-shadow: var(--shadow-lg);
}

.design-card.winner {
  border: 3px solid var(--color-accent-indigo);
  border-radius: var(--border-radius-lg);
  position: relative;
  background: var(--color-bg-primary);
  background-clip: padding-box;
  box-shadow: var(--shadow-lg);
  /* border-image: var(--gradient-winner) 1; */ 
}



.design-card.leading {
  border: 3px solid;
  position: relative;
  border-image: linear-gradient(to bottom right, #FFB03A, #FF4236, #BB36FF, #8129D5, #1B8FD7, #19D5CB, #80C662, #FFDC58) 1;
  border-image-slice: 1;
  border-radius: var(--border-radius-lg);
  position: relative;
  background: var(--color-bg-primary);
  background-clip: padding-box;
  box-shadow: var(--shadow-lg);
  /* border-image: var(--gradient-winner) 1; */
}



/* Card Header Layout */
.card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  width: 100%;
  min-height:40px;
}

.lightbox .card-header-left{
  zoom: 1.25;
}

.card-header-left {
  position: relative !important; /* reset absolute so header row flexes */
  top: auto !important;
  left: auto !important;
  width: auto !important;
}
#images-container .card-header-left{
  margin-left: 10px;
  margin-top: 10px;
}
#images-container .card-header .magnifier-icon{
  margin-right: 10px;
  margin-top: 10px;
}

.card-header-left div{
  background: var(--color-primary);
  color: var(--color-text-light);
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--border-radius-base);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-normal);
  background: var(--color-primary);
  color: var(--color-text-light);
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--border-radius-base);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  margin-right: var(--spacing-xxs);
  display: inline-block;

}

.card-header .magnifier-icon{
  position: static !important; /* use flex space */
  margin-left: auto; /* push to right */
  margin-right: 10px;

}

#status-tag-container{
  padding: 0;
  background: none;
}


/* Status Tag Styling */
.status-tag {
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
  padding: var(--spacing-xxs) var(--spacing-sm);
  border-radius: var(--border-radius-base);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  margin-right: var(--spacing-xs);
  border: 2px solid var(--color-primary);
  background-color: #fff;
  color: #000;
}

.status-tag.winner {
  background: var(--color-accent-indigo);
  color: var(--color-text-light);
  box-shadow: 0 2px 4px rgba(40, 167, 69, 0.2);
}

.status-tag.leading {
  background: var(--color-accent-indigo);
  color: var(--color-text-light);
  box-shadow: 0 2px 4px rgba(253, 126, 20, 0.2);
}

/* Design Image */
.design-image {
  width: 100%;
  height: 250px;
  overflow: hidden;
  border-radius: var(--border-radius-base);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--spacing-sm);
  margin-top: var(--spacing-lg);
}

.design-image img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

.no-image {
  color: var(--color-text-secondary);
  font-style: italic;
  text-align: center;
}



/* Product Name Layout */
.product-name {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--spacing-xs);
  margin-bottom: var(--spacing-sm);
}

/* Design Settings Button - Repositioned to Top Right */
.design-settings-btn {
  position: absolute;
  top: 8px;
  right: 8px;
  background: var(--color-text-light);
  color: var(--color-primary);
  border: 2px solid #000000;
  border-radius: 50%;
  width: 26px;
  height: 26px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: var(--font-size-sm);
  transition: var(--transition-hover);
  box-shadow: var(--shadow-sm);
  z-index: 10;
  flex-shrink: 0;
  padding: 0;
}

.design-settings-btn:hover {
  background: var(--color-bg-secondary);
  transform: scale(1.1);
  box-shadow: var(--shadow-md);
}

.design-settings-btn i {
  font-size: 12px;
  line-height: 1;
}

/* Design Settings Menu - Positioned relative to new button location */
.design-settings-menu {
  position: absolute;
  top: 40px;
  right: 8px;
  background: var(--color-bg-primary);
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-md);
  box-shadow: var(--shadow-lg);
  z-index: 20;
  min-width: 180px;
  display: none;
  overflow: hidden;
  opacity: 0;
  transform: translateY(-10px) scale(0.95);
  transition: all var(--transition-fast);
}

.design-settings-menu.show {
  display: block;
  opacity: 1;
  transform: translateY(0) scale(1);
  animation: menuSlideIn var(--transition-fast) ease-out;
  z-index: 2000; /* Ensure menu is above lightbox triggers/cards */
}

/* Smooth menu opening animation */
@keyframes menuSlideIn {
  from {
    opacity: 0;
    transform: translateY(-10px) scale(0.95);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* Menu item separator enhancement */
.design-settings-menu .settings-menu-item:not(:last-child)::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: var(--spacing-lg);
  right: var(--spacing-lg);
  height: 1px;
  background: linear-gradient(90deg, 
    transparent 0%, 
    var(--color-border-light) 20%, 
    var(--color-border-light) 80%, 
    transparent 100%);
}

.settings-menu-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm) var(--spacing-lg);
  color: var(--color-text-primary);
  text-decoration: none;
  border: none;
  background: none;
  width: 100%;
  text-align: left;
  cursor: pointer;
  transition: all var(--transition-fast);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-normal);
  position: relative;
  overflow: hidden;
}

.settings-menu-item:last-child {
  border-bottom: none;
}

/* Base hover state for all menu items */
.settings-menu-item:hover {
  background-color: var(--color-bg-secondary);
  color: var(--color-primary);
  transform: translateX(2px);
}

/* Specific hover effects for different action types */
.settings-menu-item:hover::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 3px;
  background-color: var(--color-primary);
  transform: scaleY(1);
  transition: transform var(--transition-fast);
}

/* View Design action (link) - Blue accent */
.settings-menu-item[href]:hover {
  background-color: rgba(0, 123, 255, 0.05);
  color: var(--color-accent-blue);
}

.settings-menu-item[href]:hover::before {
  background-color: var(--color-accent-blue);
}

.settings-menu-item[href]:hover i {
  color: var(--color-accent-blue);
  transform: scale(1.1);
}

/* Update Data action - Green accent */
.settings-menu-item[onclick*="updateDesignData"]:hover {
  background-color: rgba(40, 167, 69, 0.05);
  color: var(--color-accent-green);
}

.settings-menu-item[onclick*="updateDesignData"]:hover::before {
  background-color: var(--color-accent-green);
}

.settings-menu-item[onclick*="updateDesignData"]:hover i {
  color: var(--color-accent-green);
  transform: scale(1.1);
}

/* Replace Design action - Orange accent */
.settings-menu-item[onclick*="replaceDesign"]:hover {
  background-color: rgba(253, 126, 20, 0.05);
  color: var(--color-accent-orange);
}

.settings-menu-item[onclick*="replaceDesign"]:hover::before {
  background-color: var(--color-accent-orange);
}

.settings-menu-item[onclick*="replaceDesign"]:hover i {
  color: var(--color-accent-orange);
  transform: scale(1.1);
}

/* Toggle voting action - Red accent for disable, Green for enable */
.settings-menu-item.toggle-voting:hover {
  background-color: rgba(220, 53, 69, 0.05);
  color: var(--color-accent-red);
}

.settings-menu-item.toggle-voting:hover::before {
  background-color: var(--color-accent-red);
}

.settings-menu-item.toggle-voting:hover i {
  color: var(--color-accent-red);
  transform: scale(1.1);
}

/* When toggling to enable (when disabled) */
.design-card.disabled .settings-menu-item.toggle-voting:hover {
  background-color: rgba(40, 167, 69, 0.05);
  color: var(--color-accent-green);
}

.design-card.disabled .settings-menu-item.toggle-voting:hover::before {
  background-color: var(--color-accent-green);
}

.design-card.disabled .settings-menu-item.toggle-voting:hover i {
  color: var(--color-accent-green);
}

/* Icon styling */
.settings-menu-item i {
  font-size: var(--font-size-xs);
  width: 16px;
  text-align: center;
  color: var(--color-text-secondary);
  transition: all var(--transition-fast);
  flex-shrink: 0;
}

.settings-menu-item:hover i {
  color: var(--color-primary);
  transform: scale(1.1);
}

/* Active/pressed state */
.settings-menu-item:active {
  transform: translateX(1px);
  background-color: var(--color-border-light);
}

/* Focus state for accessibility */
.settings-menu-item:focus {
  outline: 2px solid var(--color-primary);
  outline-offset: -2px;
  background-color: var(--color-bg-secondary);
}

/* Text styling */
.settings-menu-item span,
.settings-menu-item .toggle-text {
  transition: color var(--transition-fast);
  font-weight: var(--font-weight-medium);
}

/* Loading state for menu items */
.settings-menu-item.loading {
  pointer-events: none;
  opacity: 0.6;
  position: relative;
}

.settings-menu-item.loading::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  background: linear-gradient(90deg, 
    transparent 0%, 
    rgba(0, 0, 0, 0.03) 50%, 
    transparent 100%);
  animation: shimmer 1.5s ease-in-out infinite;
}

.settings-menu-item.loading i {
  animation: spin 1s linear infinite;
}

@keyframes shimmer {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}

/* Disabled state for unavailable actions */
.settings-menu-item:disabled,
.settings-menu-item.disabled {
  opacity: 0.4;
  pointer-events: none;
  cursor: not-allowed;
}

.settings-menu-item:disabled i,
.settings-menu-item.disabled i {
  opacity: 0.5;
}

/* Design Card Disabled State */
.design-card.disabled {
  position: relative;
}


/* By default, hide disabled cards. A parent class will toggle them back on. */
.designs-section:not(.show-hidden-designs) .design-card.disabled {
  display: none;
}

.design-card.disabled::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(128, 128, 128, 0.6);
  z-index: 1;
  border-radius: var(--border-radius-lg);
  pointer-events: none;
}


/* Modal Components */
.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--modal-backdrop);
  display: none !important;
  z-index: var(--z-modal);
  justify-content: center;
  align-items: center;
}

.modal-overlay.show {
  display: flex !important;
}

.modal-content {
  background-color: var(--color-bg-primary);
  border-radius: var(--modal-border-radius);
  width: 90%;
  max-width: 1280px;
  max-height: 90%;
  overflow-y: auto;
  box-shadow: var(--shadow-xl);
  animation: modalFadeIn var(--transition-slow) ease-out;
  display: flex;
  flex-direction: column;
  padding: 20px;
  min-height: calc(80%);
}

.modal-header{
  position: sticky;
  top:0;
  background:#fff;
  z-index:15;
}


.modal-header h3 {
  margin: 0;
  color: var(--color-text-primary);
  min-width: 200px;

}

.modal-close {
  background: none;
  border: none;
  font-size: var(--font-size-lg);
  cursor: pointer;
  color: var(--color-text-secondary);
  padding: 0;
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  position: absolute;
  top: var(--spacing-xl);
  right: var(--spacing-3xl);
  color: var(--color-primary);
  font-size: 35px;
  font-weight: var(--font-weight-bold);
  cursor: pointer;
  transition: var(--transition-hover);
  z-index: 20;
}

.modal-close:hover {
  color: var(--color-text-primary);
  background-color: var(--color-bg-secondary);
  border-radius: var(--border-radius-base);
}
#feedback-modal .modal-header{
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  padding-right: 80px;
  padding-left: 20px;
  margin-top: 10px;
}
#feedback-modal .modal-header{
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-md);
}
#feedback-modal .modal-header > :first-child{
    flex: 1 1 auto;
}
#feedback-modal .modal-right-header-buttons{
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: var(--spacing-md);
    flex-direction: row;
}

#feedback-modal .modal-header h2{

  padding-right: 20px;
  min-width: 200px;

}


#feedback-modal .modal-close{
 top:5px; 
 padding-right: 0px;
}

@media screen and (max-width: 768px) {
  #feedback-modal .modal-close{
    top:5px; 
    right: 0px
   }
   #feedback-modal .modal-header{
    padding-right: 20px;
   }
   
}

#feedback-modal .primary-btn{
  padding: 7px 10px;
}

.modal-body {
  padding: var(--spacing-xl);
  flex: 1;
}

.modal-footer {
  padding: var(--spacing-xl);
  border-top: 2px solid var(--color-border-light);
  display: flex;
  justify-content: flex-end;
  gap: var(--spacing-sm);
}

@keyframes modalFadeIn {
  from {
    opacity: 0;
    transform: scale(0.95);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

/* Lightbox */
.lightbox {
  display: none;
  position: fixed;
  z-index: var(--z-modal);
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: var(--color-bg-primary);
  overflow-y: auto; /* allow internal scrolling when content exceeds viewport */
  -webkit-overflow-scrolling: touch;
}
.lightbox-rank-info{
  font-size: 14px;
  color: var(--color-text-secondary);
  margin-bottom: 20px;
  text-align: left;
}
.lightbox-content {
  position: relative;
  width: 100%;
  margin: auto;
  overflow: hidden; /* contain zoomed image */
}
#create-vote .lightbox-content{
  max-width: 800px;
}
.lightbox-image {
  width: auto;
  height: auto;
  max-height: 800px;
  padding-top: 50px;
  margin-bottom: 20px;
  max-width: 100%;
}
#create-vote .lightbox-image{
  padding-top: 0;
  max-width: 800px;
  max-height: 800px;
  object-fit: contain;
}

.lightbox-close {
  position: absolute;
  top: var(--spacing-xl);
  right: var(--spacing-3xl);
  color: var(--color-primary);
  font-size: 35px;
  font-weight: var(--font-weight-bold);
  cursor: pointer;
  transition: var(--transition-hover);
  z-index: 20;
  padding-left: 20px;
  padding-right: 20px;
}

.lightbox-prev,
.lightbox-next {
  position: absolute;
  top: 45%;
  zoom:1.5;
  width: auto;
  padding: 28px;
  color: var(--color-primary);
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-lg);
  cursor: pointer;
  user-select: none;
  transition: var(--transition-hover);
  stroke: #e6f7ff;
  text-shadow:-1px 0 #fff, 1px 0 #fff, 0 1px #fff, 0 -1px #fff;
}


.lightbox-prev{
  transform: translateX(-20%);
}
.lightbox-next{
  transform: translateX(20%);
}



.lightbox-prev:hover,
.lightbox-next:hover,
.lightbox-close:hover {
  color: var(--color-text-primary);
}

.lightbox-prev {
  left: 0;
}

.lightbox-next {
  right: 0;
}

.lightbox-content a {
  text-decoration: none;
}

/* Magnifier Icon */
.magnifier-icon {
  position: absolute;
  top: var(--spacing-sm);
  right: var(--spacing-sm);
  cursor: pointer;
  width: 25px;
  height: 25px;
  background-image: url('https://media.reformclothing.com/media/logos/magnify.svg');
  background-size: contain;
  background-repeat: no-repeat;
  transition: transform var(--transition-slow);
}

.magnifier-icon:hover {
  transform: scale(1.3);
}

/* Information Boxes */
.info {
  border: 2px solid transparent;
  margin-top: var(--spacing-xl);
  padding: var(--spacing-sm);
  border: 1px solid var(--color-border);
  background-color: var(--color-bg-secondary);
  color: var(--color-text-primary);
  font-size: var(--font-size-sm);
  max-width: 600px;
  word-break: break-word;
  border-radius: var(--border-radius-base);
}

.info-box {
  margin-top: var(--spacing-xl);
  padding: var(--spacing-sm);
  border: 1px solid var(--color-border);
  background-color: var(--color-bg-secondary);
  color: var(--color-text-primary);
  display: none;
  transition: border-color var(--transition-base);
  border: 2px solid transparent;
  margin-bottom: var(--spacing-xl);
  border-radius: var(--border-radius-base);
}

.info-box.success {
  border-color: var(--color-success);
  background-color: var(--color-success-bg);
  color: var(--color-success-text);
}

.info-box.error {
  border-color: var(--color-error);
  background-color: var(--color-error-bg);
  color: var(--color-error-text);
}

/* Tooltip */
.tooltip {
  display: none;
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border);
  padding: var(--spacing-sm) var(--spacing-xl);
  border-radius: var(--border-radius-base);
  box-shadow: var(--shadow-sm);
  margin-top: var(--spacing-sm);
  font-size: var(--font-size-sm);
  max-width: 600px;
  font-weight: var(--font-weight-normal);
  margin-bottom: var(--spacing-sm);
}

.info-icon {
  display: inline-block;
  margin-left: 5px;
  cursor: help;
}

/* Percentage Display */
.percentage {
  font-size: var(--font-size-xs);
}

/* Loading Spinner */
.loader {
  border: 5px solid var(--color-border-light);
  border-top: 5px solid var(--color-accent-blue);
  border-radius: var(--border-radius-round);
  width: 25px;
  height: 25px;
  animation: spin 1s linear infinite;
  display: block;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* Flash Animation */
@keyframes flashZoom {
  0% { transform: scale(1); }
  50% { transform: scale(1.05); }
  100% { transform: scale(1); }
}

.flashZoom {
  animation-name: flashZoom;
  animation-duration: var(--transition-base);
}

/* Recycled Indicator */
.design-card .recycled-indicator img {
  width: 15px;
  height: 15px;
  margin-left: 0px;
}
.recycled-indicator img {
  width: 20px;
  height: 20px;
  margin-top: 0;
  margin-bottom: -4px;
  margin-left: 5px;
  max-width: 20px;
  max-height: 20px;
  min-width: 20px;
  min-height: 20px;
}

/* Beta Test Banner */
#beta-test {
  background: var(--color-bg-secondary);
  padding: 5px var(--spacing-xl) var(--spacing-xl) var(--spacing-xl);
  border-radius: var(--border-radius-base);
  border: 3px solid;
  border-image: var(--gradient-winner) 1;
  border-image-slice: 1;
  margin-bottom: var(--spacing-3xl);
}

/* CTA Container */
.cta-container {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
  gap: var(--spacing-3xl);
  margin: var(--spacing-xl) 0;
}

/* CTA Box Base Styling */
.cta-box {
  background: var(--color-bg-primary);
  border: 1px solid var(--color-border-light);
  border-radius: var(--border-radius-lg);
  padding: var(--spacing-xl);
  box-shadow: var(--shadow-sm);
  transition: var(--transition-fast);
  position: relative;
}

.cta-box:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--color-border);
}

/* Section Type Styling */
.cta-box.primary-section {
  background: linear-gradient(135deg, var(--color-bg-primary) 0%, rgba(24, 144, 255, 0.02) 100%);
}

.cta-box.secondary-section {
  background: linear-gradient(135deg, var(--color-bg-primary) 0%, rgba(82, 196, 26, 0.02) 100%);
}

.cta-box.management-section {
  background: linear-gradient(135deg, var(--color-bg-primary) 0%, rgba(250, 173, 20, 0.02) 100%);
}

/* CTA Headers */
.cta-box h2 {
  color: var(--color-text-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  margin: 0 0 var(--spacing-sm) 0;
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.cta-box h2 i {
  opacity: 0.8;
}
.cta-box h3 {
  font-size: var(--font-size-lg);
  opacity: 0.9;
  margin-bottom: 0;
}
.cta-box h4 {
  font-size: var(--font-size-md);
  font-weight: bold;
  opacity: 0.8;
  margin-bottom: 0;
}


.cta-box p {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  margin: 0 0 var(--spacing-lg) 0;
  line-height: 1.5;
}

/* Action Groups */
.action-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  margin-top: var(--spacing-md);
}

.action-group.two-column {
  flex-direction: row;
  gap: var(--spacing-md);
}

.action-group.two-column .inline-form {
  flex: 1;
  width: 50%;
}

.action-group.two-column .secondary-btn,
.action-group.two-column .primary-btn {
  width: 100%;
  justify-content: center;
}

.inline-form {
  display: inline-block;
}

/* Button Styling */
.primary-btn {
  background: var(--color-primary);
  color: white;
  border: none;
  padding: var(--spacing-md) var(--spacing-lg);
  border-radius: var(--border-radius-md);
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-base);
  cursor: pointer;
  transition: var(--transition-fast);
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
  text-decoration: none;
}

.primary-btn:hover {
  background: var(--color-primary-hover);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}
a:hover {
  text-decoration: none;
}

/* Official Secondary Button Style */
.secondary-btn {
  background: transparent;
  color: var(--color-text-primary);
  border: 2px solid var(--color-primary);
  padding: var(--spacing-md) var(--spacing-lg);
  border-radius: var(--border-radius-md);
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-base);
  cursor: pointer;
  transition: var(--transition-fast);
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
  text-decoration: none;
}

.secondary-btn:hover {
  background:var(--color-primary-hover);
  color:var(--color-secondary);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  text-decoration: none;
}

.secondary-btn:active {
  transform: translateY(0);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.management-btn {
  background: var(--color-bg-secondary);
  color: var(--color-text-primary);
  border: 1px solid var(--color-border);
  padding: var(--spacing-sm) var(--spacing-md);
  border-radius: var(--border-radius-md);
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-sm);
  cursor: pointer;
  transition: var(--transition-fast);
  display: inline-flex;
  align-items: left;
  gap: var(--spacing-xs);
  text-decoration: none;
}

.management-btn:hover {
  background: var(--color-accent-orange);
  color: white;
  border-color: var(--color-accent-orange);
}
.management-btn.small {
  padding: var(--spacing-sm) var(--spacing-md);
  font-size: var(--font-size-sm);
}

.design-card .management-btn.small {
  padding: var(--spacing-xs) var(--spacing-sm);
  font-size: var(--font-size-sm);
}

.management-btn.secondary {
  background: transparent;
  color: var(--color-text-primary);
  border: 2px solid var(--color-primary);
}

#sync-previews-toggle.management-btn.secondary {

  height:38px;
  align-items: center;
}
#vote-designs-container #sync-previews-toggle.management-btn.secondary {
  margin-top: 0px;
}

.management-btn.secondary:hover {
  background: var(--color-primary);
  color: white;
}

.management-btn.danger {
  background: var(--color-error);
  border-color: var(--color-error);
}

.management-btn.danger:hover {
  background: var(--color-error-dark);
  color: white;
}

/* Share Section */
.share-section {
  width: 100%;
  box-sizing: border-box;
  overflow: hidden;
}

.share-section form, .share-section button{
  width: 100%;
}


.warning-note {
  background: var(--color-warning-bg);
  color: var(--color-warning-text);
  padding: var(--spacing-sm) var(--spacing-md);
  border-radius: var(--border-radius-md);
  margin-bottom: var(--spacing-md);
  font-size: var(--font-size-sm);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  border: 1px solid var(--color-warning);
}

.url-copy-section {
  margin-top: var(--spacing-md);
  display: flex;
  align-items: stretch;
  flex-wrap: wrap;
  width: 100%;
  box-sizing: border-box;
}

.url-copy-section input {
  flex: 2;
  min-width: 200px;
  max-width: calc(100% - 240px); /* Ensure space for buttons */
  padding: 0 3px 0 var(--spacing-md);
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-base) 0 0 var(--border-radius-base);
  background-color: var(--color-bg-secondary);
  font-size: var(--font-size-sm);
  box-sizing: border-box;

}

.url-copy-section .copy-btn,
.url-copy-section .inline-form {
  flex: 1;
  min-width: 120px;
  box-sizing: border-box;
  margin-top: 0;
}

.url-copy-section .inline-form {
  display: flex;
}

.url-copy-section .inline-form button {
  width: 100%;
  white-space: nowrap;
}

.copy-btn {
  background: var(--color-accent-indigo);
  color: white;
  border: none;
  padding: var(--spacing-md) var(--spacing-lg);
  border-radius: 0 var(--border-radius-base) var(--border-radius-base) 0;

  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-base);
  cursor: pointer;
  transition: var(--transition-fast);
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
  text-decoration: none;
  box-sizing: border-box;
}

.copy-btn:hover {
  background: var(--color-accent-indigo-hover);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(129, 41, 213, 0.25);
}

/* Duplicate Detection */
.duplicate-detection {
  background: var(--color-error-bg);
  border: 1px solid var(--color-error);
  border-radius: var(--border-radius-md);
  padding: var(--spacing-md);
  margin-top: var(--spacing-lg);
}

.duplicate-detection h4 {
  color: var(--color-error);
  margin: 0 0 var(--spacing-sm) 0;
  font-size: var(--font-size-base);
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.duplicate-list {
  margin: var(--spacing-sm) 0;
  padding-left: var(--spacing-lg);
  color: var(--color-error-text);
}

.integrity-note {
  margin: var(--spacing-sm) 0 0 0;
  font-size: var(--font-size-sm);
  color: var(--color-error-text);
  font-style: italic;
}

.csv-note {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  margin-top: var(--spacing-md);
  padding-top: var(--spacing-md);
  font-style: italic;
}

/* Management Controls */


.management-controls {
  display: flex;
  flex-direction: column;
  padding-top: var(--spacing-md);
}

.management-controls #countdown {
  display: flex;
  flex-direction: row;
  justify-content: center;
  margin: 0;
  width: 100%;
  max-width: 100%;
  
}

.management-controls #countdown div {
  background-color: var(--color-bg-secondary);
  color: var(--color-text-primary);
  text-align: center;
  padding: var(--spacing-sm) var(--spacing-md);
  border-radius: var(--border-radius-base);
  min-width: 40px;
  font-size: var(--font-size-md);
  font-weight: bold;
  border: 1px solid var(--color-border-light);
  flex: 1;
  max-width: 60px;
  margin: 0px 5px;
}

.management-controls #countdown div::after {
  content: attr(id);
  display: block;
  font-size: 0.75em;
  color: var(--color-text-muted);
  margin-top: var(--spacing-xs);
  text-transform: capitalize;
}

.control-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-md);
}

.control-description {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  margin-left: var(--spacing-sm);
}

/* Date Management */
.date-info {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-sm);
  font-size: var(--font-size-base);
}

.date-label {
  font-weight: var(--font-weight-medium);
  color: var(--color-text-primary);
  font-size: var(--font-size-base);
}

.info-container p{
  font-size: var(--font-size-sm);
}
.info-container p.productName{
  font-size: var(--font-size-md);
  margin-bottom: 5px;
}
.info-container p.productRename{

  margin-bottom: 5px;
}

.date-actions {
  display: flex;
  gap: var(--spacing-sm);
  flex-wrap: wrap;
}

/* Date Popup Styling */
.editCloseDatePopup {
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-md);
  padding: var(--spacing-md);
  margin-top: var(--spacing-md);
}

.editCloseDatePopup h4 {
  margin: 0 0 var(--spacing-md) 0;
  color: var(--color-text-primary);
  font-size: var(--font-size-base);
}

.date-time-inputs {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--spacing-sm) var(--spacing-md);
  align-items: center;
  margin-bottom: var(--spacing-md);
}

.date-time-inputs label {
  font-weight: var(--font-weight-medium);
  font-size: var(--font-size-sm);
  color: var(--color-text-primary);
}

.date-time-inputs input,
.date-time-inputs select {
  padding: var(--spacing-sm) var(--spacing-sm);
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-md);
  font-size: var(--font-size-sm);
  background: var(--color-bg-primary);
}

.popup-actions {
  display: flex;
  gap: var(--spacing-sm);
  align-items: center;
}

.popup-actions .confirmEditCloseDate {
  background: var(--color-primary);
  color: white;
  border: none;
  padding: var(--spacing-md) var(--spacing-md);
  border-radius: var(--border-radius-md);
  font-size: var(--font-size-sm);
  cursor: pointer;
  transition: var(--transition-fast);
}

.popup-actions .confirmEditCloseDate:hover {
  background: var(--color-primary-dark);
}

.popup-actions .cancelEditCloseDate {

  text-decoration: none;
  font-size: var(--font-size-sm);
  cursor: pointer;
  padding: var(--spacing-sm) var(--spacing-sm);
  margin-top: var(--spacing-sm);
}

.popup-actions .cancelEditCloseDate:hover {
  color: var(--color-text-primary);
  text-decoration: underline;
}


@media screen and (max-width: 1200px) {
  .url-copy-section .copy-btn{
    height: 40px;
  }

  .designs-grid-container {
    grid-template-columns: repeat(3, minmax(240px, 1fr));
    
  }
  
  /* CTA Container Responsive */
  .cta-container {
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));

  }
  
  .action-group {
    gap: var(--spacing-md);
  }
  
  /* Section Header Responsive */
  .section-header {
    align-items: stretch;
    gap: var(--spacing-md);
  }

  .section-actions {
    justify-content: center;
  }

  
  .section-action-btn {
    flex: 1;
    max-width: 150px;
  }
  
  /* Reorder Actions Responsive */
  .reorder-mode-actions {
    flex-direction: column;
    align-items: stretch;
  }
  
  .reorder-action-btn {
    width: 100%;
    justify-content: center;
  }
  
  /* Reorder Mode Info Responsive */
  .reorder-mode-info,
  .reorder-mode-actions {
    padding: var(--spacing-md) var(--spacing-lg);
  }
  
  .reorder-mode-info .info-content {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-xs);
    text-align: left;
  }
  

  /* CTA Container Mobile */
  .cta-container {
    grid-template-columns: 1fr;

  }
  
  .cta-box {
    padding: var(--spacing-lg);
  }
  

  
  .url-copy-section input {
    max-width: 100%;
    min-width: auto;
    flex: 1;
  }
  
  .url-copy-section .copy-btn,
  .url-copy-section .inline-form {
    flex: 1;
    min-width: auto;
    max-width: 100%;
    width: 100%;
  }
  
  .url-copy-section input {
    margin-bottom: var(--spacing-xs);
    font-size: var(--font-size-xs);
  }

  .date-actions {
    justify-content: center;
  }
  
  .management-controls {
    gap: var(--spacing-md);
  }
  
  /* Image Card Responsive */
  .image-card {
    min-height: 280px;
    height: auto;
  }
  
  /* Modal Responsive */
  .modal-content {
    margin: var(--spacing-md);
    width: calc(100% - 2 * var(--spacing-md));
  }
  
  .modal-header,
  .modal-body,
  .modal-footer {
    padding: var(--spacing-md);
  }
}

@media screen and (max-width: 900px) {
  .designs-grid-container {
    grid-template-columns: repeat(2, minmax(220px, 1fr));
  }
  
  /* Section Header Responsive */
  .section-header {
    flex-direction: column;
    align-items: stretch;
    gap: var(--spacing-md);
  }
  
  .section-subtitle {
    font-size: var(--font-size-sm);
  }
  
  .section-actions {
    flex-direction: column;
    align-self: center;
    gap: var(--spacing-xs);
    width: 100%;
  }
  
  .section-action-btn {
    max-width: none;
    width: 100%;

  }

  #sort-options label{
    max-width: none;
    width: 100%;
    padding-left: 20px;


  }
  #sort-options select{
    max-width: none;
    margin-left: 20px;
    margin-right: 20px;

  }
  #vote-content-wrapper #sync-previews-toggle{
    width: 100%;
  }
  

  
  .url-copy-section input {
    max-width: 100%;
    min-width: auto;
    flex: 1;
  }
  
  
  .url-copy-section .copy-btn,
  .url-copy-section .inline-form {
    flex: 1;
    min-width: auto;
    max-width: 100%;
    width: 100%;
  }
  
  .image-card {
    max-width: 100%;
    margin: var(--spacing-sm) 0 var(--spacing-xl) 0;
    box-sizing: border-box;
  }
  
  .modal-content {
    width: 100%;
    margin: 0;
    height: 100%;
    max-height: 100%;
    border-radius: 0;
  }
  
  .modal-header,
  .modal-body,
  .modal-footer {
    padding: var(--spacing-lg);
  }
}

@media screen and (max-width: 735px) {
  .designs-grid-container {
    grid-template-columns: 1fr;
  }
}

@media screen and (max-width: 600px) {
  #vote-designs-container .results-header-row{
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    gap: 10px;
  }
  #vote-designs-container .results-header-row div{
    width: 100%;
  }
  #vote-designs-container .results-header-row #sync-previews-toggle{
    min-width: 200px;
  }
  .designs-grid-container {
    grid-template-columns: 1fr;
    gap: var(--grid-gap-sm);
    padding: var(--spacing-lg);
  }
  
  .design-card {
    min-height: auto;
  }
  
  .design-image {
    max-height:420px;
  }
  
  /* Card Header Mobile Adjustments */
  .card-header {
    gap: var(--spacing-xs);
  }
  
  .card-header-left {
    gap: var(--spacing-xs);
  }

  
  .status-tag {
    padding: 2px var(--spacing-xs);
  }
  
  /* Settings Menu Mobile Adjustments */
  .design-settings-menu {
    right: 4px;
    min-width: 160px;
    max-width: calc(100vw - 40px);
  }
  
  .settings-menu-item {
    padding: var(--spacing-md) var(--spacing-lg);
    font-size: var(--font-size-base);
  }
  
  .settings-menu-item i {
    width: 18px;
    font-size: var(--font-size-sm);
  }
  
  /* Section Responsive */
  .section-header {
    padding: var(--spacing-lg) var(--spacing-lg);
  }
  
  /* Management countdown responsive - very small screens */
  .management-controls #countdown {
    gap: var(--spacing-xs);
    margin: var(--spacing-sm) auto;
    justify-content: center;
    max-width: 280px;
  }
  
  .management-controls #countdown div {
    padding: var(--spacing-xs);
    font-size: var(--font-size-sm);
  }
  
  .management-controls #countdown div::after {
    font-family: Arial, Helvetica, sans-serif;
    font-size: 0.8em;
    margin-top: 2px;
  }
}

@media screen and (max-width: 480px) {
  /* Extra small screens - even more compact countdown */
  #countdown {
    gap: var(--spacing-xs);
    flex-wrap: wrap;
  }
  
  #countdown div {
    min-width: 45px;
    padding: var(--spacing-xs);
    font-size: var(--font-size-md);
  }
  
  #countdown div::after {
    font-size: 0.35em;
  }
  .cta-container{
    gap: var(--spacing-3xl);
  }
}

/* CTA Container Responsive */
@media screen and (min-width: 769px) {
  .cta-container {
    display: grid;
    grid-template-columns: repeat(auto-fit);

  }
}

/* Decoration Specific Styles */
.decoration-box {
  position: relative;
  width: 100%;
  height: fit-content;
  overflow: hidden;
  user-select: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: center;
  align-items: flex-start;
}

.decoration {
  display: flex;
  flex-wrap: wrap;
  width: fit-content;
  height: fit-content;
  margin: 0;
  padding: 0;
  transform-origin: 0% 0%;
}

/* Decoration Section Styling */
#decorations-section {
  background-color: var(--color-bg-primary);
  border: 1px solid var(--color-border-light);
  border-radius: var(--border-radius-lg);
  margin: var(--spacing-xl) 0;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.decoration-group {
  margin-bottom: var(--spacing-xl);
}

.decoration-group:last-child {
  margin-bottom: 0;
}

.decoration-group-title {
  margin: 0 0 var(--spacing-lg) 0;
  padding: 0 var(--spacing-xl);
  color: var(--color-text-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  padding-bottom: var(--spacing-sm);
}
.decoration-group-note{
  padding: 0 var(--spacing-xl);
}
/* Old decoration card styles removed - using unified component below */

.decoration-toggle-container {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  margin-top: var(--spacing-lg);
}

.decoration-toggle-container .switch-label {
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-sm);
}

/* Decoration Grid Layout */
.designs-grid-container.decorations {
  padding: var(--spacing-lg) var(--spacing-xl);
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--spacing-xl);
}

/* Warning Note in Decorations Section */
.warning-note {
  background-color: var(--color-bg-secondary);
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-base);
  padding: var(--spacing-lg);
  margin: var(--spacing-lg) var(--spacing-xl);
  color: var(--color-text-secondary);
}

.warning-note p {
  margin: 0;
  font-size: var(--font-size-sm);
}

/* Old responsive decoration styles removed - using unified responsive behavior below */

/* Decoration Specific Styles */
.decoration-box {
  position: relative;
  width: 100%;
  height: fit-content;
  overflow: hidden;
  user-select: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: center;
  align-items: flex-start;
}

.decoration {
  display: flex;
  flex-wrap: wrap;
  width: fit-content;
  height: fit-content;
  margin: 0;
  padding: 0;
  transform-origin: 0% 0%;
}

/* Decoration Section Styling */
#decorations-section {
  background-color: var(--color-bg-primary);
  border: 1px solid var(--color-border-light);
  border-radius: var(--border-radius-lg);
  margin: var(--spacing-xl) 0;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}


.decoration-group:last-child {
  margin-bottom: 0;
}

.decoration-group-title {
  margin: 0 0 var(--spacing-lg) 0;
  color: var(--color-text-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  border-top: 1px solid var(--color-border-light);
  padding-top: 20px ;
}


.decoration-card .design-info {
  padding: var(--spacing-lg);
  text-align: left;
}



.decoration-card .application-type {
  margin-bottom: var(--spacing-sm);
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
}

.decoration-card .design-id {
  margin-bottom: var(--spacing-lg);
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
}

.decoration-card .design-id a {
  color: var(--color-primary);
  text-decoration: underline;
}

.decoration-toggle-container {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  margin-top: var(--spacing-lg);
}

.decoration-toggle-container .switch-label {
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-sm);
}

/* Decoration Grid Layout */
.designs-grid-container.decorations {
  padding: var(--spacing-lg) var(--spacing-xl);
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--spacing-xl);
}

/* Warning Note in Decorations Section */
.warning-note {
  background-color: var(--color-bg-secondary);
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-base);
  padding: var(--spacing-lg);
  margin: var(--spacing-lg) var(--spacing-xl);
  color: var(--color-text-secondary);
}

.warning-note p {
  margin: 0;
  font-size: var(--font-size-sm);
}

/* Responsive adjustments for decorations */
@media screen and (max-width: 1200px) {
  .designs-grid-container.decorations {
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  }
  
  
  /* Scale decorations proportionally for 320px containers */
  .decoration-card .decoration {
    transform: scale(0.941) !important; /* 320/340 = 0.941 */
    transform-origin: center center;
  }
}

@media screen and (max-width: 900px) {
  .designs-grid-container.decorations {
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    padding: var(--spacing-lg);
  }
  
   /* Scale decorations proportionally for 280px containers */
  .decoration-card .decoration {
    transform: scale(0.824) !important; /* 280/340 = 0.824 */
    transform-origin: center center;
  }

  
  .warning-note {
    margin: var(--spacing-lg);
  }
}

@media screen and (max-width: 600px) {
  .designs-grid-container.decorations {
    grid-template-columns: 1fr;
    padding: var(--spacing-md);
  }
  
  .decoration-card {
    max-width: 100%;
    min-width: auto;
  }
  
  /* For mobile, scale based on actual container width */
  .decoration-card .decoration {
    transform: scale(calc(100vw / 320px * 0.8)) !important; /* Approximate scale for mobile */
    transform-origin: center center;
  }
}

/* Decoration Specific Styles */
.decoration-box {
  position: relative;
  width: 100%;
  height: fit-content;
  overflow: hidden;
  user-select: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: center;
  align-items: flex-start;
}

.decoration {
  display: flex;
  flex-wrap: wrap;
  width: fit-content;
  height: fit-content;
  margin: 0;
  text-shadow: 
    1px 1px 2px rgba(255, 255, 255, 0.8),
    -1px -1px 2px rgba(255, 255, 255, 0.8),
    1px -1px 2px rgba(255, 255, 255, 0.8),
    -1px 1px 2px rgba(255, 255, 255, 0.8);
  line-height: var(--line-height-heading);
  max-width: 90%;
}

/* Disabled state for decoration cards */
.decoration-card.disabled {
  position: relative;
}

.decoration-card.disabled::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(255, 255, 255, 0.7);
  z-index: 1;
  pointer-events: none;
  border-radius: var(--border-radius-md);
}

.decoration-card.disabled::after {
  content: 'DISABLED';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: var(--color-text-muted);
  color: white;
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--border-radius-sm);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  z-index: 2;
  pointer-events: none;
}

/* Decoration Settings Menu Styles */
.decoration-settings-btn {
  position: absolute;
  top: 8px;
  right: 8px;
  background: var(--color-text-light);
  color: var(--color-primary);
  border: 2px solid #000000;
  border-radius: 50%;
  width: 26px;
  height: 26px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: var(--font-size-sm);
  transition: var(--transition-hover);
  box-shadow: var(--shadow-sm);
  z-index: 10;
  flex-shrink: 0;
  padding: 0;
}

.decoration-settings-btn:hover {
  background: var(--color-bg-secondary);
  transform: scale(1.1);
  box-shadow: var(--shadow-md);
}

.decoration-settings-btn i {
  font-size: 12px;
  line-height: 1;
}

.decoration-settings-menu {
  position: absolute;
  top: 40px;
  right: var(--spacing-sm);
  background: white;
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-md);
  box-shadow: var(--shadow-lg);
  z-index: 2000;
  min-width: 180px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: all 0.2s ease;
}

.decoration-settings-menu.show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  animation: menuSlideIn 0.2s ease forwards;
  z-index: 2000; /* Ensure menu is above lightbox triggers/cards */
}

.decoration-settings-menu .settings-menu-item {
  display: flex;
  align-items: center;
  padding: var(--spacing-sm) var(--spacing-md);
  color: var(--color-text-primary);
  text-decoration: none;
  font-size: var(--font-size-sm);
  border: none;
  background: none;
  width: 100%;
  cursor: pointer;
  transition: all 0.2s ease;
  position: relative;
}

.decoration-settings-menu .settings-menu-item:not(:last-child)::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: var(--spacing-md);
  right: var(--spacing-md);
  height: 1px;
  background: var(--color-border-light);
}

.decoration-settings-menu .settings-menu-item:last-child {
  border-bottom: none;
}

.decoration-settings-menu .settings-menu-item:hover {
  background: var(--color-bg-secondary);
  color: var(--color-primary);
}

.decoration-settings-menu .settings-menu-item:hover::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--color-primary);
}

.decoration-settings-menu .settings-menu-item i {
  margin-right: var(--spacing-sm);
  width: 14px;
  font-size: 12px;
  color: var(--color-text-muted);
}

.decoration-settings-menu .settings-menu-item:hover i {
  color: var(--color-primary);
}

/* Decoration card disabled state settings button styling */
.decoration-card.disabled .decoration-settings-menu .settings-menu-item.toggle-decoration-voting:hover {
  background: var(--color-success-light);
  color: var(--color-success);
}

.decoration-card.disabled .decoration-settings-menu .settings-menu-item.toggle-decoration-voting:hover::before {
  background: var(--color-success);
}

.decoration-card.disabled .decoration-settings-menu .settings-menu-item.toggle-decoration-voting:hover i {
  color: var(--color-success);
}

/* Responsive scaling for decorations on voting and results pages */
/* Responsive scaling handled by unified decoration card component below */

/* ==========================================================================
   UNIFIED DECORATION CARD COMPONENT
   ========================================================================== */

/* Decoration card base styling - consistent across all pages */
.decoration-card {
  background: var(--color-bg);
  border: 2px solid var(--color-border);
  border-radius: var(--border-radius-lg);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  transition: all 0.3s ease;
  position: relative;
  min-height: 400px;
}

.decoration-card:hover {
  box-shadow: var(--shadow-card-hover);
  border-color: var(--color-primary-light);
}

/* Selected state for decoration cards */
.decoration-card.selected {
  border: 1px solid var(--color-success);
}

/* Leading/Winner states for decoration cards */
.decoration-card.leading {
  border: 3px solid;
  position: relative;
  border-image: linear-gradient(to bottom right, #FFB03A, #FF4236, #BB36FF, #8129D5, #1B8FD7, #19D5CB, #80C662, #FFDC58) 1;
  border-image-slice: 1;
  border-radius: var(--border-radius-lg);
  position: relative;
  background: var(--color-bg-primary);
  background-clip: padding-box;
  box-shadow: var(--shadow-lg);
  border-image: var(--gradient-winner) 1;
}

.decoration-card.winner {
  border: 3px solid;
  position: relative;
  border-image: linear-gradient(to bottom right, #FFB03A, #FF4236, #BB36FF, #8129D5, #1B8FD7, #19D5CB, #80C662, #FFDC58) 1;
  border-image-slice: 1;
  border-radius: var(--border-radius-lg);
  position: relative;
  background: var(--color-bg-primary);
  background-clip: padding-box;
  box-shadow: var(--shadow-lg);
  border-image: var(--gradient-winner) 1;
}

/* Decoration card image container */
.decoration-card .decoration-box {
  position: relative;
  width: 100%;
  overflow: hidden;
  cursor: pointer;
  background: #f8f9fa;
}

.decoration-card .decoration-box:hover .decoration-magnifier-icon {
  opacity: 0.7;
}

.decoration-card .decoration-box:hover .decoration img {
  opacity: 0.8;
}

/* Decoration magnifier icon - matches design card style */
.decoration-card .decoration-magnifier-icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.25);
  width: 100px;
  height: 100px;
  background-image: url('https://media.reformclothing.com/media/logos/magnify.svg');
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  opacity: 0;
  transition: opacity 0.3s ease;
  z-index: 10;
  pointer-events: none;
}

/* Decoration vote button for voting page */
.decoration-vote-btn {
  background: #28a745;
  height: 40px;
  color: white;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  font-size: 12px;
  font-weight: 600;
  transition: all 0.3s ease;
  width: 100%;
  display: flex
;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 0;
}

.decoration-vote-btn:hover {
  background: #13772a;
}

.decoration-vote-btn.selected {
  background: #13772a;
}

.decoration-vote-btn.selected:hover {
  background: #13772a;
}

.decoration-vote-checkbox {
  width: 16px;
  height: 16px;
  border: 2px solid currentColor;
  border-radius: 3px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: bold;
}

.decoration-vote-checkbox.checked::before {
  content: "✓";
}

/* Decoration card header */
.decoration-card .card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: var(--spacing-sm) var(--spacing-sm) 0;
  background: var(--color-bg);
}

.decoration-card .card-header-left {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--spacing-xs);
  flex-wrap: wrap;
}

/* Decoration info section */
.decoration-card .decoration-info {
  padding: var(--spacing-sm);
}

.decoration-card .decoration-info .application-type {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: var(--spacing-xs);
}

.decoration-card .decoration-info .product-name {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  margin: 0 0 var(--spacing-xs) 0;
  color: var(--color-text);
}

.decoration-card .decoration-info .design-id {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  margin: var(--spacing-xs) 0;
}

.decoration-card .decoration-info .design-id a {
  color: var(--color-primary);
  text-decoration: none;
}

.decoration-card .decoration-info .design-id a:hover {
  text-decoration: underline;
}

/* Decoration lightbox styling */
.decoration-lightbox {
  display: none;
  position: fixed;
  z-index: var(--z-modal);
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: var(--color-bg-primary);
  overflow-y: auto; /* allow internal scrolling when content exceeds viewport */
  -webkit-overflow-scrolling: touch;

}

.decoration-lightbox.show {
  display: flex;
}

.decoration-lightbox-content {
  position: relative;
  max-width: 1280px;
  width: 100%;

  background: white;
  border-radius: var(--border-radius-lg);
  overflow: hidden;
}

.decoration-lightbox-close {
  position: absolute;
  top: var(--spacing-lg);
  right: var(--spacing-3xl);
  color: var(--color-primary);
  font-size: 35px;
  font-weight: var(--font-weight-bold);
  cursor: pointer;
  transition: var(--transition-hover);
  z-index: 20;
  background-color: none;
  font-family: var(--font-family-primary);
  line-height: var(--line-height-base);
  background-color: transparent;
}

.decoration-lightbox-close:hover {
  background: transparent
}

.decoration-lightbox-image {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

/* Mobile pinch-to-zoom support */
@media (max-width: 768px) {

  
  .decoration-lightbox-image {
    touch-action: pinch-zoom;
  }
}

/* Decoration group styling for voting page */
.decoration-group-header {
  padding: var(--spacing-lg) var(--spacing-lg) var(--spacing-md);
  border-bottom: 1px solid var(--color-border-light);
  margin-bottom: var(--spacing-lg);
}

.decoration-group-title {
  margin: 0 0 var(--spacing-xs) 0;
  color: var(--color-text-primary);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
}

.decoration-group-subtitle {
  margin: 0;
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-normal);
}
.decorationSet{
  margin-bottom: var(--spacing-xl);
  padding-bottom: var(--spacing-xl);
  border-bottom: 1px solid var(--color-border-light);
}

.decorationSet.decoration-group {
  background-color: var(--color-bg-primary);
  border: none;
  margin-bottom: var(--spacing-xl);
  overflow: hidden;
}
#vote-results .decorationSet.decoration-group{
  border: none;
  border-bottom: 1px solid var(--color-border-light);
  border-radius: 0;
  box-shadow: none;
  margin-bottom: 0;
}
#vote-results .decoration-group-header{
  border: none;
  padding-top: 0;
  padding-bottom: 0;

}
#vote-results .decoration-group-title{
  padding-left: 0;
  border: none;
}
#vote-results .vote-percentage{
    display: none;
}


.decorationSet.decoration-group:last-child {
  margin-bottom: 0;
}

.decorationSet .decorations-grid-container {
  padding: 0 var(--spacing-lg) var(--spacing-lg);
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: var(--spacing-lg);
}

/* Responsive styling for decoration groups */
@media (max-width: 1200px) {
  .decorationSet .decorations-grid-container {
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  }
}

@media (max-width: 900px) {
  .decorationSet .decorations-grid-container {
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  }
}

/* Decoration card responsive behavior */
@media (max-width: 768px) {
  .decoration-card .decoration-vote-btn {
    bottom: 5px;
    right: 5px;
    padding: 6px 10px;
    font-size: 11px;
  }
  
  .decoration-card .decoration-magnifier-icon {
    width: 35px;
    height: 35px;
  }
  
  .decoration-group-header {
    padding: var(--spacing-md);
  }
  
  .decorationSet .decorations-grid-container {
    padding: 0 var(--spacing-md) var(--spacing-md);
    grid-template-columns: 1fr;
  }
}

/* Vote Statistics Summary Styling */
.vote-stats-summary {
  margin: 20px 0;
  padding: 15px;
  background: #f8f9fa;
  border-radius: 6px;
  border-left: 4px solid #007bff;
}

.vote-stats-summary h4 {
  margin: 0 0 15px 0;
  color: #495057;
  font-size: 16px;
  font-weight: 600;
}

.vote-stats-summary .stats-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.vote-stats-summary .stats-list li {
  display: flex;
  flex-wrap: wrap; /* allow sentence to wrap nicely on narrow screens */
  column-gap: 4px; /* consistent spacing between inline elements */
  row-gap: 4px;
  align-items: center;
  margin-bottom: 10px;
  padding: 8px 0;
  font-size: 14px;
}

.vote-stats-summary .stats-list li:last-child {
  margin-bottom: 0;
}

.vote-stats-summary .stats-list li i {
  margin-right: 10px;
  margin-top: 2px;
  flex-shrink: 0;
}

.vote-stats-summary .feedback-link,
.vote-stats-summary .integrity-link {
  color: #007bff;
  text-decoration: none;
}

.vote-stats-summary .feedback-link:hover,
.vote-stats-summary .integrity-link:hover {
  text-decoration: underline;
}

.bookmark-btn{
  font-size: 12px;
}

/* Close date control styling from vote-created.ejs */
.date-actions {
    margin-top: 0px !important; /* Reduce gap above buttons */
}

.date-actions.action-group.two-column {
    display: flex;
    gap: 10px;
    width: 100%;
}

.date-actions .management-btn {
    flex: 1; /* Make buttons share available space equally */
    min-width: 0; /* Allow buttons to shrink if needed */
}

/* When only one button is visible (vote closed), it takes full width */
.date-actions .management-btn:only-child {
    flex: none;
    width: 100%;
    justify-content: flex-start; /* left-align icon & text */
    text-align: left;
}

/* Product price styling consistency from vote-created.ejs */
.product-price {
    font-weight: var(--font-weight-bold);
    margin-top: 0;
    margin-bottom: var(--spacing-xs);
    font-size: var(--font-size-sm);
}

.product-price span {
    font-weight: var(--font-weight-normal);
}

/* General Feedback Table Styling from vote-created.ejs */
.general-feedback-section {
    margin: 30px 0;
    padding: 20px;
    background: #f8f9fa;
    border-radius: 8px;
}

.feedback-table-container {
    overflow-x: auto;
    margin-top: var(--spacing-lg);
}

.feedback-table, .feedback-table-alt {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    border: 1px solid var(--color-border-light);
    border-radius: 6px;
    overflow: hidden;
    font-size: 0.9rem;
}

.feedback-table th, .feedback-table-alt th {
    text-align: left;
    background: #f4f4f4;
    color: #000;
    font-weight: 600;
    padding: 10px 12px;
    border-bottom: 1px solid var(--color-border-light);
}

.feedback-table td, .feedback-table-alt td {
    padding: 10px 12px;
    border-bottom: 1px solid var(--color-border-light);
    vertical-align: top;
}

.feedback-table tr:last-child td, .feedback-table-alt tr:last-child td {
    border-bottom: none;
}

.feedback-table tr, .feedback-table-alt tr{
    background: #ffffff;
}


.feedback-table tr:hover, .feedback-table-alt tr:hover {
    background: #eef6ff;
}

.feedback-table .feedback-text, .feedback-table-alt .feedback-text {
    max-width: 600px;
    white-space: pre-wrap;
    word-break: break-word;
}

.feedback-list #feedback-user {
  font-style: italic;
}

@media (max-width: 600px) {
    .feedback-table, .feedback-table-alt {
        font-size: 0.8rem;
    }
    .feedback-table .feedback-text, .feedback-table-alt .feedback-text {
        max-width: 100%;
    }
}

@media (max-width: 768px) {
    .feedback-table th,
    .feedback-table td {
        padding: 8px 10px;
        font-size: 14px;
    }
    
    .feedback-table .feedback-text {
        max-width: 200px;
    }
    .lightbox-right{
      margin-left: 30px;
      margin-right: 30px;
      padding-top: 0px;
      margin-top: 0px;
    }
} 

/* Magnifying glass hover effects for design cards from vote-created.ejs */
.design-card .design-image {
    position: relative;
    /* Stop flash on click by preventing parent hover fade from interfering */
    transition: none;
    overflow: hidden;
    cursor: pointer;
}

/* In-card image nav arrows overlayed on design-image */
.design-card .design-image .lightbox-prev,
.design-card .design-image .lightbox-next{
  position:absolute;
  top:45%;
  transform: translateY(-50%);
  padding:15px; /* tap target >= 15px */
  color: var(--color-primary);
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-lg);
  cursor:pointer;
  user-select:none;
  text-decoration:none;
  outline: none;
  border: none;
  box-shadow: none;
  -webkit-tap-highlight-color: transparent;
  line-height: 1;
  z-index: 5;
}
.design-card .design-image .lightbox-prev{ left:0px; }
.design-card .design-image .lightbox-next{ right:0px; }
.design-card .design-image .lightbox-prev:hover,
.design-card .design-image .lightbox-next:hover{   color: var(--color-bg-overlay); }

/* suppress focus/active outlines on arrow buttons */
.design-card .design-image .lightbox-prev:focus,
.design-card .design-image .lightbox-next:focus,
.design-card .design-image .lightbox-prev:active,
.design-card .design-image .lightbox-next:active{
  outline:none;
  box-shadow:none;
}

/* Prevent hover-dim flash on management page while using in-card arrows */
.management .design-card .design-image:hover img{ opacity: 1 !important; }
.management .design-card .design-image:hover .magnifier-icon{ opacity: 0.5 !important; }

.design-card .design-image img {
    transition: none;
    height: auto;
    display: block;
}

.design-card .magnifier-icon {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(0.25);
    width: 100px;
    height: 100px;
    background-image: url('https://media.reformclothing.com/media/logos/magnify.svg');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    opacity: 0;
    transition: opacity 0.3s ease;
    z-index: 10;
    pointer-events: none;
}

.design-card .design-image:hover .magnifier-icon {
    opacity: 0.5;
    pointer-events: auto;
}

.design-card .design-image:hover img {
    opacity: 0.5;
}

/* Ensure the magnifier icon is properly positioned relative to the image container */
.design-card .design-image {
    overflow: hidden;
}

.info-box-important {
    background-color: #e6f7ff;
    border: 1px solid #91d5ff;
    border-left: 5px solid #1890ff;
    border-radius: 4px;
    padding: 15px;
    margin: 20px 0;
    font-size: 1.1em;
    line-height: 1.6;
    color: #333;
}

/* Utility class added via JS to freeze page scroll when lightbox is open */
body.modal-open-lightbox {
  overflow: hidden;
}

.lightbox-content {
  position: relative;
  max-width: 1280px;
  width: 100%;
  margin: auto;
  overflow: hidden; /* contain zoomed image */
}

.lightbox-image-wrapper {
  position: relative;
  overflow: hidden; /* contain zoomed image */
  min-height: 200px;
}

.lightbox-grid{
  display:flex;
  flex-direction: row;
  gap:20px;
  padding-top: 20px;
}

.lightbox-left{flex:1;min-width:0;}
.lightbox-right{flex:1;display:flex;flex-direction:column;gap:16px;align-items:flex-start;}

.lightbox-right .product-name{margin-top:0;font-size:1.2rem;font-weight:600;}
.lightbox-right .product-price{font-size:1rem;color:var(--color-text-secondary);}
.full-width{width:100%;}

@media (max-width: 768px){
  .lightbox-grid{flex-direction:column;}

  .lightbox-right{
    margin-left: 30px;
    margin-right: 30px;
    padding-top: 0px;
    margin-top: 0px;
  }

}

.lightbox-right{
  margin-left: 30px;
  margin-right: 30px;
  padding-top: 20px;
  padding-bottom: 20px;
}

/* ===== Lightbox Desktop Enhancements ===== */
@media (min-width: 1024px){
  .lightbox-grid{gap:20px;}
}
@media (min-width: 768px){
  .lightbox-right{
    margin-left: 30px;
    margin-right: 30px;
    padding-top:70px;
    margin-top: 0px;
  }
  
}

.lightbox-left{flex:1 1 50%;}
.lightbox-right{flex:1 1 50%;display:flex;flex-direction:column;gap:16px;align-items:flex-start;}


.lightbox-right .product-name{font-size:1.4rem;font-weight:600;margin:0;line-height:1.3;}
.lightbox-right .product-price{font-size:1.1rem;color:var(--color-text-primary);margin-bottom:8px;}

.lightbox-action-buttons{
  display:flex;
  gap:10px;
  justify-content:center;
  width:100%;
  flex-direction:column;   /* keep your current layout */
  gap:12px;
}
.lightbox-action-buttons button{display:block;width:100%;}


.submit-now-btn{
  background:#000;
  color:#fff;
  border:none;
  padding:12px 20px;
  font-size:1rem;
  cursor:pointer;
  border-radius:var(--border-radius-base);
  transition:var(--transition-fast);
}
.submit-now-btn:hover{background:#111;color:#fff;}

/* ===== Decoration Lightbox (gallery) ===== */
.decoration-lightbox.show{display:flex;}
.decoration-lightbox-content{position:relative;background:#fff;border-radius:8px;width:100%;height:100%;overflow:auto;margin: auto;}
.decoration-lightbox-close{position:absolute;top:10px;right:14px;background:transparent;border:none;font-size:28px;cursor:pointer;}
.decoration-lightbox-grid{display:flex;gap:20px;padding:20px;align-items:flex-start; margin-top: auto; vertical-align: middle;}
.dlb-left{flex:1 1 55%;min-width:0;}
.dlb-right{flex:1 1 45%;display:flex;flex-direction:column;gap:14px;}
.decoration-lightbox-image-wrapper{position:relative;overflow:hidden;min-height:260px;display:flex;align-items:center;justify-content:center;}
.decoration-lightbox-image{max-width:100%;max-height:70vh;display:block;}
.img-stage{position:relative;}
.dec-overlay{position:absolute;border:2px solid #ff6600;box-shadow:0 0 4px rgba(255,102,0,.7);pointer-events:none;}
.dlb-header{display:flex;justify-content:space-between;align-items:center;gap:12px;}
.dlb-location{font-weight:600;}
.dlb-position{font-size:.9rem;color:#555;}
.dlb-meta{display:flex;flex-direction:column;gap:6px;}
.dlb-actions{display:flex;flex-direction:column;gap:10px; width:100%;}
.dlb-separator{height:1px;background:#e5e5e5;margin:6px 0;}
.dlb-guidance{font-size:.95rem;line-height:1.3;}
.dlb-guidance.warning{color:#7a4800;background:#fff8e1;border:1px solid #ffe8b0;padding:8px 10px;border-radius:6px; font-size: 12px;}
.dlb-guidance.info{color:#0f5132;background:#d1e7dd;border:1px solid #badbcc;padding:8px 10px;border-radius:6px;}
.dlb-row.nav-row{display:flex;align-items:center;gap:10px;justify-content:space-between;}
.dlb-row button{width:100%;}
.dlb-nav{padding:10px 12px;border:1px solid #ccc;border-radius:6px;background:#f5f5f5;cursor:pointer;}
.dlb-counter{font-size:.9rem;color:#555;}
.dlb-vote-btn{padding:12px 16px;}
.full-width{width:100%;}
.dlb-header #positionCounter{
  font-size:0.8rem;
  color: var(--color-text-light);
}
#dlbViewAllDecorations.primary-btn{
  font-weight: bold;
  text-align: center;
  display: block;
}

@media(max-width: 900px){
  .decoration-lightbox-content{max-width:100%;max-height:100vh;height:100%;border-radius:0;}
  .decoration-lightbox-grid{flex-direction:column;}
  .dlb-left, .dlb-right{flex:1 1 auto;}
}

/* ===== Voting Method Cards (Create Vote Page) ===== */
.voting-method-cards{display:flex;gap:1rem;flex-wrap:no-wrap;margin-bottom:1rem;}
.vote-method-card{position:relative;border:1px solid #ccc;border-radius:6px;padding:1rem;flex:1 1 220px;cursor:pointer;text-align:center;transition:border-color .2s,box-shadow .2s,background .2s;color:var(--color-text-primary);}
.vote-method-card:hover{border-color:#000;box-shadow:0 0 0 2px rgba(0,0,0,.2);background:#d3d3d3;}
.vote-method-card:hover img{filter:invert(0);} /* invert icon for dark bg */

.vote-method-card.selected{border-color:#000;box-shadow:0 0 0 2px rgba(0,0,0,.6);background:#000;color:#fff;}
.vote-method-card.selected img{filter:invert(1);} /* invert icon for dark bg */
/* Selected tag */
.vote-method-card.selected::after{content:"Selected";position:absolute;top:8px;right:8px;background:#fff;color:#000;font-size:.7rem;font-weight:600;padding:2px 6px;border-radius:3px;}
.vote-method-card img{display:block;margin:0 auto .5rem;}
.vote-method-card h3{margin:0 0 .5rem;font-size:1rem;}
.vote-method-card p{font-size:.9rem;min-height:48px;}
.vote-method-card a{font-size:.9rem;}
@media(max-width:600px){.vote-method-card{flex:1 1 100%;padding-top: 40px;}}

/* ===== Designs Container Info (Create Vote Page) ===== */
.designs-info{
  padding: var(--spacing-sm) var(--spacing-lg);
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border-light);
  border-radius: var(--border-radius-md);
  margin: var(--spacing-sm) 0;
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
}

/* Modifiers */
.designs-info.error{background: var(--color-error-bg);border-color: var(--color-error);color: var(--color-error-text);}
.designs-info.success{background: var(--color-success-bg);border-color: var(--color-success);color: var(--color-success-text);} 

/* Make the embedded loader smaller to fit the new bar */
.designs-info .loader{width:18px;height:18px;border-width:3px;}

/* Hide loading indicator by default until explicitly shown */
.designs-info #loading-message{display:none;}

/* ===== Create Vote – Designs Grid Layout ===== */
.designs-grid-container h4{grid-column:1 / -1;margin:0rem 0 0.5rem 0;font-size:1.1rem;}
#create-vote .designs-grid-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;}
#create-vote .designs-grid-container:not(:has(div)){display:flex;flex-wrap:wrap;gap:1rem;}
@media(min-width:1200px){#create-vote .designs-grid-container{grid-template-columns:repeat(4,1fr);}}
@media(max-width:900px){#create-vote .designs-grid-container{grid-template-columns:repeat(3,1fr);}}
@media(max-width:600px){#create-vote .designs-grid-container{grid-template-columns:repeat(2,1fr);}}

/* Hidden by default; shown via .show class when needed */
.designs-info{display:none;}
.designs-info.show{
  padding: var(--spacing-sm) var(--spacing-lg);
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border-light);
  border-radius: var(--border-radius-md);
  margin: var(--spacing-sm) 0;
  display:flex;
  align-items:center;
  gap:var(--spacing-sm);
  font-size:var(--font-size-sm);
  color:var(--color-text-secondary);
}

/* Icon styling for font-awesome within vote-method-cards */
.vote-method-card i{
  font-size:2.2rem;
  margin-bottom:0.5rem;
}

/* === Create Vote action enhancements === */
.create-vote-btn{bottom:24px;right:24px;padding:0.85rem 2.2rem;font-size:1.1rem;font-weight:600;z-index:2000;display:inline-flex;align-items:center;gap:8px;transition:transform .2s ease,box-shadow .2s ease;}
.create-vote-btn[aria-disabled="true"],.create-vote-btn:disabled{opacity:.6;cursor:not-allowed;}
.create-vote-btn.pulse{animation:pulseGlow 1.5s infinite;}
@keyframes pulseGlow{0%{box-shadow:0 0 0 rgba(0,0,0,0);}50%{box-shadow:0 0 12px rgba(0,0,0,0.25);}100%{box-shadow:0 0 0 rgba(0,0,0,0);}}
@media(max-width:768px){
  .create-vote-btn{left:0;right:0;width:100%;bottom:0;}
}

.btn-spinner{border:3px solid #fff;border-top:3px solid transparent;border-radius:50%;width:16px;height:16px;display:inline-block;vertical-align:middle;animation:spin .8s linear infinite;margin-right:6px;}
@keyframes spin{to{transform:rotate(360deg);}}

.vote-summary{background:#f9f9f9;border:1px solid #ddd;border-radius:6px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.9rem;line-height:1.4;}

.terms-wrapper{background:#fafafa;border:1px solid #e2e2e2;border-radius:6px;padding:.75rem 1rem;margin-bottom:1rem;}
.terms-wrapper.error{border-color:var(--color-error);box-shadow:0 0 0 2px var(--color-error-bg);}

.vote-method-info{margin-top:1rem;font-size:.9rem;line-height:1.5;}
.vote-method-info a{color:var(--color-primary);text-decoration:underline;}

.hero-banner{background: #000; padding: 20px;}
.hero-banner .hero-content{max-width:960px;margin:0 auto;text-align:center; color: #fff; }
.hero-banner .hero-logo{width:160px;height:auto; margin-top: 15px;}
.primary-btn.hero-btn{
  background-color: var(--color-accent-blue);
  font-weight: bold;
}
.primary-btn.hero-btn:hover{
  background-color: var(--color-bg-primary);
  color: var(--color-accent-blue);
  font-weight: bold;
  outline: 1px solid var(--color-accent-blue);
}
.secondary-btn.hero-btn{
  background-color: var(--color-bg-primary);
  color: var(--color-text-dark);
  outline: 1px solid var(--color-text-dark);
  font-weight: bold;
}
.secondary-btn.hero-btn:hover{
  background-color: var(--color-text-primary);
  color: var(--color-text-light);
  font-weight: bold;
}

/* Layout Utilities */
#designs-container #designs-dynamic .designs-style-group {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 280px)); /* wrap into as many 180–220px tiles as fit */
  gap: 12px;
  justify-content: start; /* left-align remaining space */
}
#designs-container .designs-style-group .design-tile {
  width: 100%;
}

#designs-container-info {
  background: linear-gradient(90deg, #f0f4ff 0%, #e6f0fa 100%);
  border: 1px solid #b3c6e6;
  border-radius: 8px;
  padding: 1.1rem 1.5rem;
  margin: 1.2rem 0 1.5rem 0;
  /* Hidden by default; revealed via the .show class added dynamically in JS */
  display: none;
  align-items: center;
  justify-content: center;
  width: 100%;
  font-size: 1rem;
  color: #234;
  box-shadow: 0 2px 8px rgba(60,100,180,0.06);
  min-height: 48px;
  box-sizing: border-box;
}

/* When JS adds the .show class, reveal the info bar */
#designs-container-info.show {
  display: flex;
}

#loading-message {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  gap: 0.7rem;
  font-size: 1.08rem;
  color: #2a3a5a;
  font-weight: 500;
  letter-spacing: 0.01em;
  background: none;
  border: none;
  box-shadow: none;
  min-height: 32px;
  box-sizing: border-box;
}

#loading-message .loader {
  width: 22px;
  height: 22px;
  min-width: 22px;
  min-height: 22px;
  border: 3px solid #b3c6e6;
  border-top: 3px solid #3a6ed8;
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
  background: none;
  display: inline-block;
}



@keyframes spin {
  to { transform: rotate(360deg); }
}

.submission-confirmation{
  font-size: 12px;
}

.terms-wrapper label{
  font-weight: normal;
  max-width: 720px;
  padding-left: 40px;
}

/* Hide designs grid until designs are loaded */
#designs-container{display:none;}
#designs-container.show{display:flex; flex-wrap: wrap;}
#designs-container.show  #designs-dynamic{
  display:flex;
  flex-direction: column;
  width: 100%;
}

#addDesignContainer{
  display: flex;
  gap: 10px;
  flex-flow: wrap;
}
#addDesignContainer .design-card, #addDesignContainer .image-card{
  width: 300px;
}

/* Hide missing designs helper until designs have loaded */
.missing-info{display:none;}
.missing-info.show{display:block;}

/* Disabled vote method card */
.vote-method-card.disabled{
  pointer-events:none;
  opacity:0.45;
  filter:grayscale(100%);
}

/* Responsive video wrapper for demo modal */
.video-wrapper{position:relative;margin-top: 20px;}
.video-wrapper .creation-extra{margin:16px 0px 20px 0; padding:14px 16px; border:2px solid #0a58ca; background:#e7f1ff; color:#0a1f44; border-radius:8px;}
.video-iframe-container{position:relative;width:100%;padding-top:56.25%;height:0;}
.video-wrapper iframe{position:absolute;top:0;left:0;width:100%;height:100%;margin:0;border:0;}

/* Video modal sizing */
.video-modal{max-width:95vw;width:95vw;height:auto;padding:24px;background:#fff;position:relative;box-sizing:border-box;}
@media(min-width:768px){.video-modal{max-width:1024px;}}
@media(min-width:1200px){.video-modal{max-width:1280px;}}
.video-modal .modal-close{position:absolute;top:18px;right:24px;color:#333;font-size:1.8rem;background:none;border:none;cursor:pointer;z-index:5;line-height:1;}

/* Stats grid in Results & Analytics */
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:16px;}
/* Stats grid in Results & Analytics */
.general-feedback-section .stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:16px;}
.general-feedback-section .stats-grid .stat-item{background-color: #ffffff;}
.general-feedback-section .stats-grid .stat-item .stat-value{font-size:0.9rem;font-weight:600;}


@media(max-width:600px){
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .page-header-section{
    flex-flow: column !important;
  }


}
.stat-item{background:#f9f9f9;border:1px solid #ddd;border-radius:6px;padding:1rem;display:flex;flex-direction:column;gap:0.4rem;align-items:center;text-align:center;}
.stat-item i{font-size:1.2rem;color:var(--color-text-primary);}
/* Trophy icon should be black */
.stat-item .fa-trophy{color:#000;}
.stat-value{font-size:0.75rem;font-weight:600;}
.stat-sublink{font-size:.75rem;text-decoration:underline;color:var(--color-primary);} 
.stat-sublink:hover{opacity:.8;}
.placeholder{background:transparent;border:none;}

.vote-type-label{
  font-size: var(--font-size-md);
  margin-bottom: var(--spacing-sm);
}

.application-type{
  border: 1px solid var(--color-border-light);
  color: var(--color-text-light);
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--border-radius-base);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  margin-right: var(--spacing-xxs);
  display: inline-block;
}

#sort-options{
  display: flex;
  align-items: center;
  gap: 10px;
  border: 2px solid var(--color-primary);
  border-radius: var(--border-radius-md);
  padding: 0px;
  max-height: 36px;

}
#designs-section #sort-options{
  margin-top: 8px;
}
#designs-section #sort-options{
  width: 100%;
}
#designs-section #sync-previews-toggle{
  width: 100%;
}



#vote-designs-container #sort-options{
  height: 34px;
}


#sort-options label{
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  margin-top: 2px;
  max-width: 50px;
}
#sort-options select{
  font-size: var(--font-size-sm);
  border: none;
  margin-top: -1px;
  margin-right: 5px;

}

.results-header-row{
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 10px 0;
  padding: 15px 0;
  border-bottom: 2px solid #e9ecef;
  font-size: var(--font-size-sm);
}
#voteActionLink{
  font-size: var(--font-size-sm);
  padding: 5px 10px;
  border-radius: var(--border-radius-md);
  background: var(--color-primary);
  color: var(--color-text-light);
  text-decoration: none;
  font-weight: var(--font-weight-bold);
  height: 28px;
  min-width: 130px;
}

.tile-buttons{
  display:flex;
  justify-content:center;
  gap:4px;
}

.tile-buttons button{
  background:transparent!important;
  color:#000!important;
  border:none;
  zoom:1.5;
  margin-top: 0;
}

.tile-buttons button:hover{
  background:transparent!important;
  color:#333!important;
}

/* ========================= */
/* Full-page loading overlay */
/* ========================= */
.page-loading-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  text-align: center;
  padding: 20px;
  box-sizing: border-box;
}

.page-loading-overlay h1,
.page-loading-overlay h2,
.page-loading-overlay p {
  color: #ffffff;
  margin: 0.3rem 0;
}

.page-loading-overlay .overlay-logo {
  width: 180px;
  height: auto;
  margin-bottom: 1rem;
}

.page-loading-overlay .overlay-content{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
}

.page-loading-overlay .loader {
  border: 5px solid rgba(255, 255, 255, 0.3);
  border-top: 5px solid #ffffff;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  animation: spin 1s linear infinite;
  margin-top: 1.5rem;
}

.page-header-section{
  display:flex;
  flex-flow: row;
  justify-content:space-between;
  align-items:center;
  margin-bottom:1rem;
}

/* Favourite indicator */
.design-tile{
  position:relative;
}
.favourite-indicator{
  position:absolute;
  top:6px;
  left:10px;
  font-size:1.2rem;
  color:#000;
  z-index:5;
}
.favourite-indicator i{color:#000;}

.general-feedback-section h2{
  margin: 0;
  margin-bottom: 10px;
}

.card-header-left{
  /* existing overrides */
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-start;
  align-items:center;
  gap: var(--spacing-xxs);
}

.section-actions .section-action-btn, .section-actions #sort-options,  .section-actions #sync-previews-toggle{
  height: 40px;
  align-items: center;
}


.section-actions #add-design-btn{
  padding: 13px;
}
#toggle-hidden-btn{
  min-width: 175px;
}

#sort-options{
  gap: 0;
}
#sort-options label{
  max-width: none;
  width: 100%;
  padding-left: 10px;
  min-width: 47px ;


}
#sort-options select#sort{
  text-align: right;
  padding-right: 10px;
  max-width: 105px;
}

#lbProductPrice{
  font-weight: normal;
}

.hero-ctas{
  display: flex;
  gap: 10px;
}
#lbEditDesignBtn{
  padding: 5px 10px;
  border-radius: var(--border-radius-base);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  margin-right: var(--spacing-xxs);
  margin-top: 0;
}

#replaceDesignContainer{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: stretch;
}

#replaceDesignContainer .design-card,
#replaceDesignContainer .image-card{
  box-sizing: border-box;
  flex: 1 1 220px;
  max-width: 250px;
}

#replaceDesignContainer .image-card img,
#replaceDesignContainer .design-card img{
  display: block;
  max-width: 100%;
  height: auto;
}

.mgmt-banner{
  width:100%;
  box-sizing:border-box;
  margin:10px 0 16px 0;
  padding:14px 16px;
  color:#0a1f44;
  border: 3px solid;
  position: relative;
  border-image: linear-gradient(to bottom right, #FFB03A, #FF4236, #BB36FF, #8129D5, #1B8FD7, #19D5CB, #80C662, #FFDC58) 1;
  border-image-slice: 1;
  border-radius: var(--border-radius-lg);
  position: relative;
  background: var(--color-bg-primary);
  background-clip: padding-box;
  box-shadow: var(--shadow-lg);
}

.all-feedback .card-header-left {
  display: flex;
  margin:0 0 15px 0px;
  gap:5px;
  align-items: center;
  flex-wrap: wrap;
}

.all-feedback .option-text {
  font-size: var(--font-size-sm);
}

.all-feedback .votes-count {
  font-size: var(--font-size-sm);
}

#feedback-modal .feedback-tip {
  margin-bottom: 15px;
  font-size: 14px;
}

#feedback-modal .feedback-tip i {
  margin-right: 5px;
}
#feedback-modal .design-thumb .renamed-name, #feedback-modal .design-thumb .design-id{
  font-size: 13px;
}
#feedback-modal .edit-design-link a{
  font-size: 13px;
}

.modal-header button{
  margin-top: 0 !important;
}