/* Ongoing Editable Panels Styles */

/* Players Editable Panel */
.players-editable-panel {
  background: transparent;
  box-shadow: none;
}

.players-editable-panel .editable-panel-header {
  background: transparent;
  border: none;
  padding: 0;
  margin-bottom: 16px;
}

.players-editable-panel .editable-panel-content {
  padding: 0;
}

/* Integration with existing panel system */
.panel-content .editable-panel {
  margin: -20px; /* Compensate for panel padding */
}

.panel-content .editable-panel-content {
  padding: 20px;
}

/* Edit mode visual feedback */
.panel-content .editable-panel.editing {
  box-shadow: none;
  background: rgba(var(--primary-rgb), 0.02);
  border-radius: 8px;
}

.panel-content .editable-panel.editing .editable-panel-content {
  background: transparent;
}

/* Button styling to match existing design */
.editable-panel-edit,
.editable-panel-save,
.editable-panel-cancel {
  width: 32px;
  height: 32px;
  border-radius: 6px;
  background: var(--bg-secondary);
  border: 1px solid var(--border-color);
}

.editable-panel-edit:hover {
  background: var(--primary-color);
  color: white;
  border-color: var(--primary-color);
}

.editable-panel-save:hover {
  background: var(--success-color);
  color: white;
  border-color: var(--success-color);
}

.editable-panel-cancel:hover {
  background: var(--danger-color);
  color: white;
  border-color: var(--danger-color);
}

/* Mobile adjustments */
@media (max-width: 768px) {
  .panel-content .editable-panel {
    margin: -16px;
  }
  
  .panel-content .editable-panel-content {
    padding: 16px;
  }
  
  .players-editable-panel .editable-panel-header {
    margin-bottom: 12px;
  }
}

/* Animation for edit mode transition */
.editable-panel {
  transition: background-color 0.3s ease, box-shadow 0.3s ease;
}

.editable-panel-controls {
  animation: fadeIn 0.3s ease;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateX(10px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

/* Panel action buttons for inline editing */
.panel-action-edit,
.panel-action-save {
  transition: all 0.2s ease;
}

.panel-action-edit:hover {
  color: var(--primary-color);
}

.panel-action-save {
  color: var(--success-color, #28a745);
  animation: pulse 1.5s ease infinite;
}

.panel-action-save:hover {
  color: var(--success-hover, #218838);
}

@keyframes pulse {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.7;
  }
}

/* Panel content in edit mode */
.panel-content[data-editing="true"] {
  background: rgba(var(--primary-rgb), 0.02);
  border-radius: 8px;
  padding: 24px;
  margin: -4px;
}

/* Panel action buttons for add/edit items */
.panel-action-buttons {
  padding: 16px;
  background: rgba(var(--primary-rgb), 0.05);
  border-radius: 8px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.panel-action-buttons .btn {
  font-size: 14px;
  font-weight: 500;
  padding: 8px 16px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  transition: all 0.2s ease;
}

.panel-action-buttons .btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

/* Judges panel specific */
.panel-judges-container .panel-judge-card {
  transition: all 0.3s ease;
}

.panel-judges-container .panel-judge-card:hover {
  background: rgba(var(--primary-rgb), 0.02);
}

/* Boulder cards in edit mode */
.adddata-boulders-data-box.editing-mode {
  position: relative;
  border: 2px solid transparent;
  transition: all 0.3s ease;
  cursor: default !important;
}

.adddata-boulders-data-box.editing-mode:hover {
  border-color: var(--primary-color);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

/* Show edit controls on hover in edit mode */
.adddata-boulders-data-box.editing-mode .adddata-boulder-icons-container {
  min-width: 140px;
}

/* Edit/Delete buttons on boulder cards */
.adddata-boulder-icons-container .btn-sm {
  padding: 6px 10px;
  font-size: 13px;
  border-radius: 0; /* Square shape */
  transition: all 0.2s ease;
  min-width: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* Boulder edit mode buttons - using dark theme without borders */
.adddata-boulder-icons-container .btn-outline-secondary {
  border: none;
  background: transparent;
  color: #6c757d;
  padding: 6px 10px;
  margin: 0 2px;
  border-radius: 0;
  transition: all 0.2s ease;
  min-width: 36px;
}

.adddata-boulder-icons-container .btn-outline-secondary:hover {
  background: rgba(108, 117, 125, 0.1);
  color: #495057;
  transform: none;
}

/* Specific button colors */
.adddata-boulder-icons-container .btn-outline-secondary.text-success {
  color: #28a745;
}

.adddata-boulder-icons-container .btn-outline-secondary.text-success:hover {
  background: rgba(40, 167, 69, 0.1);
  color: #1e7e34;
}

.adddata-boulder-icons-container .btn-outline-secondary.text-warning {
  color: #ffc107;
}

.adddata-boulder-icons-container .btn-outline-secondary.text-warning:hover {
  background: rgba(255, 193, 7, 0.1);
  color: #d39e00;
}

.adddata-boulder-icons-container .btn-outline-secondary.text-danger {
  color: #dc3545;
}

.adddata-boulder-icons-container .btn-outline-secondary.text-danger:hover {
  background: rgba(220, 53, 69, 0.1);
  color: #bd2130;
}

.adddata-boulder-icons-container .btn-outline-danger {
  border: none;
  background: transparent;
  color: #dc3545;
}

.adddata-boulder-icons-container .btn-outline-danger:hover {
  background: rgba(220, 53, 69, 0.1);
  color: #bd2130;
  transform: none;
}

/* Row hover effect in edit mode */
.adddata-boulders-data-box-row.editing-mode {
  cursor: pointer !important;
}

.adddata-boulders-data-box-row.editing-mode:hover {
  background: rgba(var(--primary-rgb), 0.05);
}

/* Mobile boulder card in edit mode */
.boulder-box-mobile.editing-mode {
  cursor: pointer !important;
}

.boulder-box-mobile.editing-mode:hover {
  background: rgba(var(--primary-rgb), 0.05);
  transform: none; /* Disable transform on mobile */
}

/* Mobile specific adjustments */
@media (max-width: 768px) {
  .panel-action-buttons {
    padding: 12px;
  }
  
  .panel-action-buttons .btn {
    font-size: 13px;
    padding: 6px 12px;
  }
  
  .boulder-box-mobile .btn-sm {
    padding: 3px 6px;
    font-size: 11px;
  }
}

/* ===========================
   UNIFIED MAP CONTAINER STYLES
   Used by all components with SectorMap
   =========================== */

/* Universal map wrapper - used by ALL components */
.sector-map-wrapper,
.sector-map-container {
  position: relative;
  width: 100%;
  margin-bottom: 20px;
  border-radius: 10px;
  overflow: visible; /* Per popups */

  /* Mobile First - Default */
  height: 25vh;
  min-height: 180px;
  max-height: 250px;
}

/* Tablet (768px-1199px) */
@media (min-width: 768px) and (max-width: 1199px) {
  .sector-map-wrapper,
  .sector-map-container {
    height: 330px; /* Fixed height per compatibilità con StageManager */
    min-height: 330px;
    max-height: 330px;
  }
}

/* Desktop (≥1200px) */
@media (min-width: 1200px) {
  .sector-map-wrapper,
  .sector-map-container {
    height: 330px; /* Uniformato per tutti i desktop */
    min-height: 330px;
    max-height: 400px; /* Permette espansione su schermi grandi */
  }
}

/* Mobile override per schermi molto piccoli */
@media (max-width: 480px) {
  .sector-map-wrapper,
  .sector-map-container {
    min-height: 25vh;
    max-height: 30vh;
  }
}

.sector-map-controls {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 10;
}

/* Add Boulder button - full width below map */
.addBoulderBtnPanel {
  color: #f3f3f3;
  font-size: 19px;
  font-family: "DINBold";
  background-color: #f5484d;
  border: 0;
  padding: 10px 15px;
  border-radius: 5px;
  width: 100%;
  margin-top: 15px;
  transition: background-color 0.3s ease;
}

.addBoulderBtnPanel:hover {
  background-color: #e03e43;
  color: #f3f3f3;
}

/* Ensure button is positioned below map and filters */
.add-boulder-button-container {
  margin-top: 15px;
  width: 100%;
}

/* Add Boulder slot button styling to match boulder rows */
.add-boulder-slot-btn {
  width: 100%;
  height: 64px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px dashed rgba(255, 255, 255, 0.2);
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  color: rgba(255, 255, 255, 0.6);
  font-size: 16px;
  font-weight: 500;
  transition: all 0.3s ease;
  margin-bottom: 10px;
  cursor: pointer;
  padding: 0;
}

.add-boulder-slot-btn:hover {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(255, 255, 255, 0.3);
  color: rgba(255, 255, 255, 0.8);
}

.add-boulder-slot-btn:hover svg {
  transform: scale(1.1);
}

.add-boulder-slot-btn svg {
  transition: transform 0.3s ease;
}

/* Filter tabs overlay styles */
.filter-tabs-overlay {
  position: absolute;
  bottom: 10px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(23, 25, 28, 0.8);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 25px;
  padding: 4px;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  z-index: 5;
  max-width: 90%;
}

.filter-tabs-overlay .MuiTab-root {
  border-radius: 20px !important;
  min-height: 36px !important;
  padding: 6px 16px !important;
  margin: 0 2px !important;
  background: transparent !important;
  color: rgba(255, 255, 255, 0.7) !important;
  transition: all 0.3s ease !important;
}

.filter-tabs-overlay .MuiTab-root.Mui-selected {
  background: rgba(245, 72, 77, 1) !important;
  color: #fff !important;
}

.filter-tabs-overlay .MuiTabs-indicator {
  display: none !important;
}