// =============================================================================
// Comments Press Zone - Forms, Dashboard & Widgets
// =============================================================================
// Form elements, dashboard header, stat widgets, activity and health panels.
// Converted from main.css lines 895-1150.
// =============================================================================


// =============================================================================
// FORM GROUPS
// =============================================================================

.presszone-comments-form-group {
  margin-bottom: 20px;

  label {
    display: block;
    margin-bottom: 6px;
    font-weight: 500;
    color: $presszone-comments-text;

    @include dark-mode-class {
      color: $presszone-comments-text-dark;
    }
  }

  .presszone-comments-label--settings {
    font-size: 13px;
    font-weight: 600;
    color: $presszone-comments-text;
    display: flex !important;
    align-items: center;
    gap: 6px;
    margin-bottom: 2px !important;
    white-space: nowrap;

    @include dark-mode-class {
      color: $presszone-comments-text-dark;
    }
  }

  &--checkbox {
    label {
      display: flex;
      align-items: center;
      gap: 8px;
      cursor: pointer;
    }
  }

  &--half {
    margin-bottom: 8px;
  }

  &--third {
    margin-bottom: 8px;
  }
}

// Standalone settings label (outside form-group)
.presszone-comments-label--settings {
  font-size: 13px;
  font-weight: 600;
  color: $presszone-comments-text;
  display: flex !important;
  align-items: center;
  gap: 6px;
  margin-bottom: 2px !important;
  white-space: nowrap;

  @include dark-mode-class {
    color: $presszone-comments-text-dark;
  }
}

// =============================================================================
// FORM ROWS (Grid Layouts)
// =============================================================================

.presszone-comments-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;

  &--thirds {
    grid-template-columns: 1fr 1fr 1fr;
  }
}

// =============================================================================
// FORM HELP TEXT
// =============================================================================

.presszone-comments-form-help {
  margin-top: 4px;
  font-size: 12px;
  color: $presszone-comments-text-muted;

  @include dark-mode-class {
    color: $presszone-comments-text-muted-dark;
  }

  &--row {
    margin-top: -8px;
    margin-bottom: 20px;
  }
}

// =============================================================================
// TOOLTIP TRIGGER BUTTON
// =============================================================================

.presszone-comments-tooltip-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  padding: 0;
  margin: 0;
  margin-inline-start: 4px;
  font-size: 11px;
  color: $presszone-comments-text-muted;
  background: none;
  border: none;
  cursor: help;
  opacity: 0.6;
  transition: opacity $presszone-comments-duration-fast,
              color $presszone-comments-duration-fast;
  
  @include dark-mode-class {
    color: $presszone-comments-text-muted-dark;
  }
  
  &:hover {
    opacity: 1;
    color: $presszone-comments-primary;
    
    @include dark-mode-class {
      color: $presszone-comments-primary-dark;
    }
  }
  
  &:focus {
    outline: 2px solid $presszone-comments-primary;
    outline-offset: 2px;
    opacity: 1;
    
    @include dark-mode-class {
      outline-color: $presszone-comments-primary-dark;
    }
  }
}

// =============================================================================
// FLOATING TOOLTIP (Positioned absolutely)
// =============================================================================

.presszone-comments-floating-tooltip {
  position: absolute;
  z-index: 10000;
  display: none;
  max-width: 280px;
  padding: 10px 14px;
  background: $presszone-comments-surface;
  color: $presszone-comments-text;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.5;
  border-radius: $presszone-comments-radius;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15), 
              0 0 0 1px $presszone-comments-border;
  pointer-events: none;
  animation: tooltipFadeIn 0.15s $presszone-comments-ease-smooth;
  
  @include dark-mode-class {
    background: $presszone-comments-surface-dark;
    color: $presszone-comments-text-dark;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4), 
                0 0 0 1px $presszone-comments-border-dark;
  }
  
  // Arrow pointing to trigger (default: below tooltip)
  &::before {
    content: '';
    position: absolute;
    bottom: -6px;
    left: 50%;
    transform: translateX(-50%);
    border: 6px solid transparent;
    border-top-color: $presszone-comments-surface;
    
    @include dark-mode-class {
      border-top-color: $presszone-comments-surface-dark;
    }
  }
  
  // When tooltip is below trigger
  &.presszone-comments-floating-tooltip--below {
    &::before {
      top: -6px;
      bottom: auto;
      border-top-color: transparent;
      border-bottom-color: $presszone-comments-surface;
      
      @include dark-mode-class {
        border-bottom-color: $presszone-comments-surface-dark;
      }
    }
  }
}

@keyframes tooltipFadeIn {
  from {
    opacity: 0;
    transform: translateY(-4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

// =============================================================================
// COLOR INPUT
// =============================================================================

.presszone-comments-color-input {
  display: flex;
  gap: 8px;
  align-items: center;

  input[type="color"] {
    width: 40px;
    height: 40px;
    padding: 0;
    border: none;
    border-radius: $presszone-comments-radius;
    cursor: pointer;
  }
}

// =============================================================================
// RADIO GROUP
// =============================================================================

.presszone-comments-radio-group {
  display: flex;
  flex-direction: column;
  gap: 8px;

  label {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
  }
}

// =============================================================================
// DASHBOARD
// =============================================================================

.presszone-comments-dashboard {
  &__header {
    margin-bottom: 24px;

    h1 {
      font-size: 28px;
      margin: 0 0 4px 0;
    }
  }

  &__subtitle {
    color: $presszone-comments-text-muted;
    margin: 0;

    @include dark-mode-class {
      color: $presszone-comments-text-muted-dark;
    }
  }
}

// =============================================================================
// WIDGETS GRID
// =============================================================================

.presszone-comments-widgets {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 16px;
  margin-bottom: 24px;
}

// =============================================================================
// WIDGET CARD
// =============================================================================

.presszone-comments-widget {
  background: $presszone-comments-surface;
  border-radius: $presszone-comments-radius-lg;
  padding: 24px;
  display: flex;
  align-items: center;
  gap: 12px;
  border-inline-start: 4px solid $presszone-comments-primary;
  transition: transform $presszone-comments-duration-normal $presszone-comments-ease-smooth,
              box-shadow $presszone-comments-duration-normal $presszone-comments-ease-smooth;

  @include dark-mode-class {
    background: $presszone-comments-surface-dark;
  }

  &:hover {
    transform: translateY(-2px);
    box-shadow: $presszone-comments-shadow-hover;

    @include dark-mode-class {
      box-shadow: $presszone-comments-shadow-hover-dark;
    }
  }

  // Color variants
  &--primary {
    border-inline-start-color: $presszone-comments-primary;

    @include dark-mode-class {
      border-inline-start-color: $presszone-comments-primary-dark;
    }
  }

  &--success {
    border-inline-start-color: $presszone-comments-success;

    @include dark-mode-class {
      border-inline-start-color: $presszone-comments-success-dark;
    }
  }

  &--warning {
    border-inline-start-color: $presszone-comments-warning;

    @include dark-mode-class {
      border-inline-start-color: $presszone-comments-warning-dark;
    }
  }

  &--error {
    border-inline-start-color: $presszone-comments-error;

    @include dark-mode-class {
      border-inline-start-color: $presszone-comments-error-dark;
    }
  }

  &__icon {
    font-size: 24px;
  }

  &__value {
    display: flex;
    align-items: baseline;
    gap: 8px;
    font-size: 20px;
    font-weight: 700;
    color: $presszone-comments-text;
    line-height: 1.2;

    @include dark-mode-class {
      color: $presszone-comments-text-dark;
    }
  }

  &__growth {
    font-size: 12px;
    font-weight: 500;
    color: $presszone-comments-success;
    opacity: 0.8;

    @include dark-mode-class {
      color: $presszone-comments-success-dark;
    }
  }

  &__label {
    font-size: 12px;
    color: $presszone-comments-text-muted;

    @include dark-mode-class {
      color: $presszone-comments-text-muted-dark;
    }
  }

  &__content {
    flex: 1;
    min-width: 0;
  }

  &__meta {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 4px;
    font-size: 12px;
  }

  &__trend {
    font-weight: 600;

    &--up {
      color: $presszone-comments-success;

      @include dark-mode-class {
        color: $presszone-comments-success-dark;
      }
    }

    &--down {
      color: $presszone-comments-error;

      @include dark-mode-class {
        color: $presszone-comments-error-dark;
      }
    }

    &--neutral {
      color: $presszone-comments-text-muted;

      @include dark-mode-class {
        color: $presszone-comments-text-muted-dark;
      }
    }
  }

  &__comparison {
    color: $presszone-comments-text-muted;
    opacity: 0.8;

    @include dark-mode-class {
      color: $presszone-comments-text-muted-dark;
    }
  }
}

// =============================================================================
// ACTIVITY & HEALTH PANELS
// =============================================================================

.presszone-comments-activity,
.presszone-comments-health {
  background: $presszone-comments-surface;
  border-radius: $presszone-comments-radius-lg;
  padding: 24px;
  margin-bottom: 20px;
  transition: transform $presszone-comments-duration-normal $presszone-comments-ease-smooth,
              box-shadow $presszone-comments-duration-normal $presszone-comments-ease-smooth;

  @include dark-mode-class {
    background: $presszone-comments-surface-dark;
  }

  &:hover {
    transform: translateY(-2px);
    box-shadow: $presszone-comments-shadow-hover;

    @include dark-mode-class {
      box-shadow: $presszone-comments-shadow-hover-dark;
    }
  }

  h2 {
    margin: 0 0 16px 0;
    font-size: 16px;
  }
}

// Activity Panel
.presszone-comments-activity {
  &__grid {
    display: flex;
    gap: 32px;
  }

  &__item {
    display: flex;
    flex-direction: column;
  }

  &__value {
    font-size: 24px;
    font-weight: 600;
    color: $presszone-comments-primary;

    @include dark-mode-class {
      color: $presszone-comments-primary-dark;
    }
  }

  &__label {
    font-size: 13px;
    color: $presszone-comments-text-muted;

    @include dark-mode-class {
      color: $presszone-comments-text-muted-dark;
    }
  }
}

// Health Panel
.presszone-comments-health {
  &__checks {
    display: flex;
    flex-direction: column;
    gap: 8px;
  }

  &__item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;

    &--ok {
      color: $presszone-comments-success;

      @include dark-mode-class {
        color: $presszone-comments-success-dark;
      }
    }
  }
}

// =============================================================================
// NODE TREE HEADER
// =============================================================================

.presszone-comments-node-tree {
  &__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 24px;

    h1 {
      margin: 0 0 4px 0;
    }
  }
}
