/* =============================================================================
   FEEDBACK-WIDGET.CSS — Floating Feedback Button & Form Panel
   Hello Elementor Child Theme

   Structure:
     div#hec-feedback-widget [data-state="closed|open"]
       button#hec-feedback-trigger           (floating tab)
         svg.hec-feedback-widget__trigger-icon
         span.hec-feedback-widget__trigger-label
       div.hec-feedback-widget__tooltip      (hover callout)
         span.hec-feedback-widget__tooltip-text
         span.hec-feedback-widget__tooltip-arrow
       div.hec-feedback-widget__backdrop     (click to close)
       div#hec-feedback-panel                (slide-in form)
         div.hec-feedback-widget__panel-header
           h2 + p
           button.hec-feedback-widget__close
         form.hec-feedback-widget__form
           ...fields...
           div.hec-feedback-widget__form-error
           button.hec-feedback-widget__submit
         div.hec-feedback-widget__success

   States:
     data-state="closed" → trigger visible, panel hidden
     data-state="open"   → trigger hidden, panel slides in, backdrop visible

   Design intent:
     The feedback widget lives on the right edge of the viewport.
     It must be discoverable but never obstructive.
     The trigger is a vertical pill/tab with rotated text.
     On hover, a tooltip pops to the left with a warm invitation.
     On click, a premium slide-in panel appears from the right.
     The form is compact, warm, and frictionless.
   ============================================================================= */


/* =============================================================================
   1. WIDGET ROOT
   ============================================================================= */

.hec-feedback-widget {
  position:  fixed;
  top:       0;
  right:     0;
  bottom:    0;
  z-index:   var(--hec-z-feedback);

  /*
   * The widget root spans the full right edge.
   * It has no visual output itself — children handle rendering.
   * Pointer events are disabled on the root so it doesn't block
   * clicks on the page content behind it.
   */
  pointer-events: none;
  display:        flex;
  align-items:    center;
  justify-content: flex-end;
}

/* Re-enable pointer events on interactive children */
.hec-feedback-widget__trigger,
.hec-feedback-widget__tooltip,
.hec-feedback-widget__backdrop,
.hec-feedback-widget__panel {
  pointer-events: auto;
}


/* =============================================================================
   2. TRIGGER BUTTON — floating tab
   ============================================================================= */

.hec-feedback-widget__trigger {
  position:       fixed;
  right:          0;
  top:            50%;
  transform:      translateY(-50%);
  z-index:        var(--hec-z-feedback);

  display:        flex;
  align-items:    center;
  gap:            var(--hec-space-2);

  /*
   * Rotated 90deg so text reads vertically top-to-bottom.
   * The transform origin is set so the button stays anchored
   * to the right edge of the viewport.
   */
  writing-mode:   vertical-rl;

  padding:        var(--hec-space-4) var(--hec-space-3);
  border-radius:  var(--hec-radius-lg) 0 0 var(--hec-radius-lg);

  background:     var(--hec-color-feedback-bg);
  color:          var(--hec-color-feedback-text);

  font-family:    var(--hec-font-ui);
  font-size:      var(--hec-text-xs);
  font-weight:    var(--hec-weight-bold);
  letter-spacing: var(--hec-tracking-widest);
  text-transform: uppercase;

  border:         none;
  border-left:    1px solid rgba(255, 255, 255, 0.15);

  box-shadow:     var(--hec-shadow-amber);
  cursor:         pointer;

  transition:
    background  var(--hec-transition-fast),
    transform   var(--hec-transition-spring),
    box-shadow  var(--hec-transition-fast),
    opacity     var(--hec-transition-normal);
}

.hec-feedback-widget__trigger:hover {
  background: var(--hec-brand-amber-light);
  transform:  translateY(-50%) translateX(-4px);
  box-shadow: var(--hec-shadow-amber-lg);
}

.hec-feedback-widget__trigger:active {
  transform:  translateY(-50%) translateX(-2px);
  box-shadow: var(--hec-shadow-amber);
}

/* Icon inside trigger */
.hec-feedback-widget__trigger-icon {
  flex-shrink: 0;
  fill:        currentColor;
  transition:  transform var(--hec-transition-spring);
}

.hec-feedback-widget__trigger:hover .hec-feedback-widget__trigger-icon {
  transform: scale(1.15);
}

/* Label text */
.hec-feedback-widget__trigger-label {
  font-size:      var(--hec-text-xs);
  letter-spacing: var(--hec-tracking-widest);
}

/* Hide trigger when panel is open */
[data-state="open"] .hec-feedback-widget__trigger {
  opacity:        0;
  pointer-events: none;
  transform:      translateY(-50%) translateX(20px);
}


/* =============================================================================
   3. TOOLTIP / CALLOUT BUBBLE
   ============================================================================= */

.hec-feedback-widget__tooltip {
  position:       fixed;
  right:          56px;
  top:            50%;
  transform:      translateY(-50%) translateX(8px);
  z-index:        var(--hec-z-feedback);

  max-width:      220px;
  padding:        var(--hec-space-3) var(--hec-space-4);
  border-radius:  var(--hec-radius-lg);

  background:     var(--hec-brand-brown-deep);
  color:          var(--hec-white);

  font-family:    var(--hec-font-body);
  font-size:      var(--hec-text-sm);
  font-weight:    var(--hec-weight-medium);
  line-height:    var(--hec-leading-snug);

  box-shadow:     var(--hec-shadow-xl);
  pointer-events: none;
  opacity:        0;

  transition:
    opacity   var(--hec-transition-fast),
    transform var(--hec-transition-spring);
}

[data-theme="dark"] .hec-feedback-widget__tooltip {
  background: var(--hec-neutral-900);
  border:     1px solid rgba(212, 183, 170, 0.10);
}

/* Arrow pointing right toward the trigger */
.hec-feedback-widget__tooltip-arrow {
  position:       absolute;
  right:          -8px;
  top:            50%;
  transform:      translateY(-50%);
  width:          0;
  height:         0;
  border:         8px solid transparent;
  border-left-color: var(--hec-brand-brown-deep);
}

[data-theme="dark"] .hec-feedback-widget__tooltip-arrow {
  border-left-color: var(--hec-neutral-900);
}

/* Show tooltip on trigger hover */
.hec-feedback-widget__trigger:hover ~ .hec-feedback-widget__tooltip {
  opacity:   1;
  transform: translateY(-50%) translateX(0);
}

/* Hide tooltip when panel is open */
[data-state="open"] .hec-feedback-widget__tooltip {
  opacity:        0;
  pointer-events: none;
}


/* =============================================================================
   4. BACKDROP
   ============================================================================= */

.hec-feedback-widget__backdrop {
  position:   fixed;
  inset:      0;
  z-index:    var(--hec-z-overlay);

  background: rgba(39, 26, 14, 0.40);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);

  opacity:    0;
  pointer-events: none;

  transition:
    opacity var(--hec-transition-normal);
}

[data-theme="dark"] .hec-feedback-widget__backdrop {
  background: rgba(10, 6, 2, 0.60);
}

[data-state="open"] .hec-feedback-widget__backdrop {
  opacity:        1;
  pointer-events: auto;
}


/* =============================================================================
   5. FORM PANEL
   ============================================================================= */

.hec-feedback-widget__panel {
  position:       fixed;
  top:            0;
  right:          0;
  bottom:         0;
  z-index:        var(--hec-z-modal);

  width:          clamp(320px, 90vw, 420px);
  max-width:      100vw;

  display:        flex;
  flex-direction: column;

  background:     var(--hec-color-feedback-panel);
  border-left:    1px solid var(--hec-color-feedback-border);
  box-shadow:     var(--hec-shadow-2xl);

  /*
   * Slide in from right.
   * transform: translateX(100%) hides the panel off-screen right.
   * When data-state="open", it slides to translateX(0).
   */
  transform:      translateX(100%);
  visibility:     hidden;

  transition:
    transform   var(--hec-duration-slow) var(--hec-ease-spring),
    visibility  0ms linear var(--hec-duration-slow),
    background  var(--hec-transition-slow),
    border-color var(--hec-transition-slow);

  overflow-y:     auto;
  overscroll-behavior: contain;
}

/*
 * When hidden attribute is set by PHP, ensure the panel stays hidden
 * until JS removes the hidden attribute (only when opening).
 * The hidden attribute is managed by feedback-widget.js.
 */
.hec-feedback-widget__panel[hidden] {
  display: none;
}

[data-state="open"] .hec-feedback-widget__panel {
  transform:   translateX(0);
  visibility:  visible;
  transition:
    transform   var(--hec-duration-slow) var(--hec-ease-spring),
    visibility  0ms linear 0ms,
    background  var(--hec-transition-slow),
    border-color var(--hec-transition-slow);
}


/* =============================================================================
   6. PANEL HEADER
   ============================================================================= */

.hec-feedback-widget__panel-header {
  display:     flex;
  align-items: flex-start;
  justify-content: space-between;
  gap:         var(--hec-space-4);
  padding:     var(--hec-space-6) var(--hec-space-6) var(--hec-space-4);
  border-bottom: 1px solid var(--hec-color-border);
  flex-shrink: 0;

  transition:
    border-color var(--hec-transition-slow);
}

.hec-feedback-widget__panel-title-group {
  flex: 1;
}

.hec-feedback-widget__panel-title {
  font-family:    var(--hec-font-heading);
  font-size:      var(--hec-text-lg);
  font-weight:    var(--hec-weight-bold);
  color:          var(--hec-color-text-primary);
  line-height:    var(--hec-leading-tight);
  margin-bottom:  var(--hec-space-1);

  transition:
    color var(--hec-transition-slow);
}

.hec-feedback-widget__panel-desc {
  font-family: var(--hec-font-meta);
  font-size:   var(--hec-text-xs);
  color:       var(--hec-color-text-tertiary);
  line-height: var(--hec-leading-normal);

  transition:
    color var(--hec-transition-slow);
}


/* =============================================================================
   7. CLOSE BUTTON
   ============================================================================= */

.hec-feedback-widget__close {
  display:     flex;
  align-items: center;
  justify-content: center;

  width:        36px;
  height:       36px;
  flex-shrink:  0;
  border-radius: var(--hec-radius-md);

  color:       var(--hec-color-text-secondary);
  cursor:      pointer;

  transition:
    background var(--hec-transition-fast),
    color      var(--hec-transition-fast),
    transform  var(--hec-transition-spring);
}

.hec-feedback-widget__close:hover {
  background: var(--hec-color-hover-bg);
  color:      var(--hec-color-accent);
  transform:  rotate(90deg);
}

.hec-feedback-widget__close svg {
  flex-shrink: 0;
  fill:        currentColor;
}


/* =============================================================================
   8. FORM
   ============================================================================= */

.hec-feedback-widget__form {
  display:        flex;
  flex-direction: column;
  gap:            var(--hec-space-5);
  padding:        var(--hec-space-6);
  flex:           1;
}


/* =============================================================================
   9. FIELD GROUPS
   ============================================================================= */

.hec-feedback-widget__field-group {
  display:        flex;
  flex-direction: column;
  gap:            var(--hec-space-2);
}

.hec-feedback-widget__label {
  font-family:    var(--hec-font-ui);
  font-size:      var(--hec-text-sm);
  font-weight:    var(--hec-weight-semibold);
  color:          var(--hec-color-text-primary);

  display:        flex;
  align-items:    center;
  gap:            var(--hec-space-2);

  transition:
    color var(--hec-transition-slow);
}

.hec-feedback-widget__optional {
  font-size:    var(--hec-text-xs);
  font-weight:  var(--hec-weight-regular);
  color:        var(--hec-color-text-tertiary);
}

.hec-feedback-widget__required {
  color:       var(--hec-color-error);
  font-weight: var(--hec-weight-bold);
}


/* =============================================================================
   10. INPUT FIELDS
   ============================================================================= */

.hec-feedback-widget__input,
.hec-feedback-widget__textarea {
  width:         100%;
  padding:       var(--hec-space-3) var(--hec-space-4);

  font-family:   var(--hec-font-body);
  font-size:     var(--hec-text-sm);
  color:         var(--hec-color-text-primary);
  line-height:   var(--hec-leading-normal);

  background:    var(--hec-color-feedback-input);
  border:        2px solid var(--hec-color-feedback-input-border);
  border-radius: var(--hec-radius-md);

  transition:
    border-color  var(--hec-transition-fast),
    box-shadow    var(--hec-transition-fast),
    background    var(--hec-transition-slow),
    color         var(--hec-transition-slow);
}

.hec-feedback-widget__input:focus,
.hec-feedback-widget__textarea:focus {
  outline:      none;
  border-color: var(--hec-color-feedback-input-focus);
  box-shadow:   0 0 0 3px rgba(209, 106, 11, 0.15);
}

.hec-feedback-widget__input::placeholder,
.hec-feedback-widget__textarea::placeholder {
  color:       var(--hec-color-text-disabled);
  font-style:  italic;
}

/* Textarea specific */
.hec-feedback-widget__textarea {
  resize:   vertical;
  min-height: 100px;
}


/* =============================================================================
   11. CHARACTER COUNTER
   ============================================================================= */

.hec-feedback-widget__char-count {
  display:      flex;
  align-items:  center;
  gap:          var(--hec-space-1);

  font-family:  var(--hec-font-meta);
  font-size:    var(--hec-text-xs);
  color:        var(--hec-color-text-disabled);
  text-align:   right;
  align-self:   flex-end;

  transition:
    color var(--hec-transition-fast);
}

/*
 * Counter turns amber when nearing limit (1800+).
 * Counter turns red when at limit (2000).
 * These classes are toggled by feedback-widget.js.
 */
.hec-feedback-widget__char-count.hec-char--warn {
  color: var(--hec-brand-amber);
}

.hec-feedback-widget__char-count.hec-char--limit {
  color: var(--hec-color-error);
  font-weight: var(--hec-weight-semibold);
}


/* =============================================================================
   12. FIELD ERROR
   ============================================================================= */

.hec-feedback-widget__field-error {
  font-family: var(--hec-font-meta);
  font-size:   var(--hec-text-xs);
  font-weight: var(--hec-weight-medium);
  color:       var(--hec-color-error);
  line-height: var(--hec-leading-snug);

  display:     flex;
  align-items: center;
  gap:         var(--hec-space-1);

  animation: hec-fade-up var(--hec-duration-fast) var(--hec-ease-out) forwards;
}

.hec-feedback-widget__field-error[hidden] {
  display: none;
}

/* Error icon */
.hec-feedback-widget__field-error::before {
  content:       '!';
  display:       inline-flex;
  align-items:   center;
  justify-content: center;
  width:         16px;
  height:        16px;
  border-radius: var(--hec-radius-full);
  background:    var(--hec-color-error);
  color:         var(--hec-white);
  font-size:     10px;
  font-weight:   var(--hec-weight-bold);
  flex-shrink:   0;
  line-height:   1;
}

/* Error state on input */
.hec-feedback-widget__field-group.hec-field--error .hec-feedback-widget__input,
.hec-feedback-widget__field-group.hec-field--error .hec-feedback-widget__textarea {
  border-color: var(--hec-color-error);
  box-shadow:   0 0 0 3px rgba(114, 36, 16, 0.10);
}


/* =============================================================================
   13. FORM-LEVEL ERROR
   ============================================================================= */

.hec-feedback-widget__form-error {
  font-family:    var(--hec-font-meta);
  font-size:      var(--hec-text-sm);
  font-weight:    var(--hec-weight-medium);
  color:          var(--hec-color-error);
  padding:        var(--hec-space-3) var(--hec-space-4);
  background:     var(--hec-color-error-bg);
  border:         1px solid var(--hec-color-error);
  border-radius:  var(--hec-radius-md);
  line-height:    var(--hec-leading-snug);

  animation:      hec-fade-up var(--hec-duration-fast) var(--hec-ease-out) forwards;
}

.hec-feedback-widget__form-error[hidden] {
  display: none;
}


/* =============================================================================
   14. SUBMIT BUTTON
   ============================================================================= */

.hec-feedback-widget__submit {
  display:        flex;
  align-items:    center;
  justify-content: center;
  gap:            var(--hec-space-2);

  width:          100%;
  padding:        var(--hec-space-3) var(--hec-space-6);
  margin-top:     var(--hec-space-2);
  border-radius:  var(--hec-radius-md);

  background:     var(--hec-brand-amber);
  color:          var(--hec-white);

  font-family:    var(--hec-font-ui);
  font-size:      var(--hec-text-sm);
  font-weight:    var(--hec-weight-semibold);
  letter-spacing: var(--hec-tracking-wide);

  cursor:         pointer;

  transition:
    background  var(--hec-transition-fast),
    transform   var(--hec-transition-spring),
    box-shadow  var(--hec-transition-fast);
}

.hec-feedback-widget__submit:hover {
  background:  var(--hec-brand-amber-light);
  transform:   translateY(-2px);
  box-shadow:  var(--hec-shadow-amber);
}

.hec-feedback-widget__submit:active {
  transform:  translateY(0);
  box-shadow: none;
}

/* Icon inside submit button */
.hec-feedback-widget__submit-icon {
  flex-shrink: 0;
  fill:        currentColor;
}

/* Disabled state during AJAX request */
.hec-feedback-widget__submit:disabled {
  opacity:        0.70;
  cursor:         not-allowed;
  transform:      none;
  box-shadow:     none;
  pointer-events: none;
}

/* Loading spinner inside button */
.hec-feedback-widget__submit .hec-spinner {
  width:  14px;
  height: 14px;
}


/* =============================================================================
   15. SUCCESS STATE
   ============================================================================= */

.hec-feedback-widget__success {
  display:        flex;
  flex-direction: column;
  align-items:    center;
  justify-content: center;
  text-align:     center;
  gap:            var(--hec-space-4);
  padding:        var(--hec-space-10) var(--hec-space-6);
  flex:           1;

  animation: hec-scale-spring var(--hec-duration-slow) var(--hec-ease-spring) forwards;
}

.hec-feedback-widget__success[hidden] {
  display: none;
}

.hec-feedback-widget__success-icon {
  color:          var(--hec-color-success);
  animation:      hec-scale-spring var(--hec-duration-slow) var(--hec-ease-spring) 0.1s both;
}

.hec-feedback-widget__success-icon svg {
  fill: currentColor;
}

.hec-feedback-widget__success-title {
  font-family:    var(--hec-font-heading);
  font-size:      var(--hec-text-xl);
  font-weight:    var(--hec-weight-bold);
  color:          var(--hec-color-text-primary);

  transition:
    color var(--hec-transition-slow);
}

.hec-feedback-widget__success-message {
  font-family: var(--hec-font-body);
  font-size:   var(--hec-text-sm);
  color:       var(--hec-color-text-secondary);
  line-height: var(--hec-leading-relaxed);
  max-width:   280px;

  transition:
    color var(--hec-transition-slow);
}

/* Close button in success state */
.hec-feedback-widget__success-close {
  display:       inline-flex;
  align-items:   center;
  padding:       var(--hec-space-2) var(--hec-space-6);
  border-radius: var(--hec-radius-full);

  background:    transparent;
  color:         var(--hec-color-accent);
  border:        1px solid var(--hec-color-accent);

  font-family:   var(--hec-font-ui);
  font-size:     var(--hec-text-sm);
  font-weight:   var(--hec-weight-medium);
  cursor:        pointer;

  transition:
    background  var(--hec-transition-fast),
    color       var(--hec-transition-fast),
    transform   var(--hec-transition-fast);
}

.hec-feedback-widget__success-close:hover {
  background: var(--hec-color-accent);
  color:      var(--hec-white);
  transform:  translateY(-1px);
}


/* =============================================================================
   16. MOBILE ADJUSTMENTS
   ============================================================================= */

@media (max-width: 768px) {

  /* Full-width panel on mobile */
  .hec-feedback-widget__panel {
    width: 100vw;
  }

  /* Trigger button moves lower and becomes smaller */
  .hec-feedback-widget__trigger {
    top:       auto;
    bottom:    80px;
    transform: none;
    padding:   var(--hec-space-3) var(--hec-space-2);
    font-size: 10px;
  }

  .hec-feedback-widget__trigger:hover {
    transform: translateX(-3px);
  }

  [data-state="open"] .hec-feedback-widget__trigger {
    transform: translateX(20px);
  }

  /* Hide label text on mobile — icon only */
  .hec-feedback-widget__trigger-label {
    display: none;
  }

  /* Tooltip adjustments for mobile */
  .hec-feedback-widget__tooltip {
    right:      48px;
    max-width:  180px;
    font-size:  var(--hec-text-xs);
  }

  .hec-feedback-widget__form {
    padding: var(--hec-space-5);
  }
}

@media (max-width: 480px) {
  .hec-feedback-widget__trigger {
    bottom: 70px;
  }

  .hec-feedback-widget__panel-header {
    padding: var(--hec-space-5) var(--hec-space-5) var(--hec-space-3);
  }

  .hec-feedback-widget__form {
    padding: var(--hec-space-4);
    gap:     var(--hec-space-4);
  }
}

/*
 * On mobile the social share bar sits at the bottom.
 * The feedback trigger button must sit above it.
 * We push it higher using bottom positioning already defined.
 * The 80px bottom value accounts for the share bar height + padding.
 */


/* =============================================================================
   17. REDUCED MOTION
   ============================================================================= */

@media (prefers-reduced-motion: reduce) {
  .hec-feedback-widget__panel {
    transition:
      transform  0.01ms linear,
      visibility 0ms linear;
  }

  [data-state="open"] .hec-feedback-widget__panel {
    transition:
      transform  0.01ms linear,
      visibility 0ms linear 0ms;
  }

  .hec-feedback-widget__trigger:hover {
    transform: translateY(-50%);
  }

  .hec-feedback-widget__close:hover {
    transform: none;
  }

  .hec-feedback-widget__submit:hover {
    transform: none;
  }

  .hec-feedback-widget__success {
    animation: none;
  }

  .hec-feedback-widget__success-icon {
    animation: none;
  }

  .hec-feedback-widget__field-error {
    animation: none;
  }

  .hec-feedback-widget__form-error {
    animation: none;
  }
}