/* widgets/main/crop_modal/crop_modal.css — v1.1.3.981 */

.kp-crop-modal[hidden] { display: none !important; }
.kp-crop-modal {
  position: fixed; inset: 0;
  z-index: 10000;
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
}
.kp-crop-modal__backdrop {
  position: absolute; inset: 0;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(4px);
}
.kp-crop-modal__sheet {
  position: relative;
  background: var(--kp-surface, var(--n-surface, #1a1a22));
  color: var(--kp-text, var(--n-text, #f0f0f5));
  border-radius: 12px;
  border: 1px solid var(--kp-border, rgba(255, 255, 255, 0.1));
  width: min(720px, 100%);
  max-height: 90vh;
  display: flex; flex-direction: column;
  overflow: hidden;
  box-shadow: 0 20px 60px -10px rgba(0, 0, 0, 0.5);
}
.kp-crop-modal__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px;
  border-bottom: 1px solid var(--kp-border, rgba(255, 255, 255, 0.08));
}
.kp-crop-modal__title { margin: 0; font-size: 1.05rem; font-weight: 600; }
.kp-crop-modal__close {
  background: none; border: none; color: inherit;
  font-size: 1.5rem; line-height: 1; cursor: pointer;
  padding: 4px 10px; border-radius: 6px;
}
.kp-crop-modal__close:hover { background: rgba(255, 255, 255, 0.06); }

.kp-crop-modal__toolbar {
  padding: 8px 16px;
  border-bottom: 1px solid var(--kp-border, rgba(255, 255, 255, 0.08));
  display: flex; flex-wrap: wrap; gap: 12px; align-items: center;
}
.kp-crop-modal__label {
  display: flex; align-items: center; gap: 8px;
  font-size: 0.88rem; color: var(--kp-text-mute, var(--n-text-mute, #888));
}
.kp-crop-modal__aspect {
  background: var(--kp-bg, var(--n-bg, #0e0e15));
  color: inherit; border: 1px solid var(--kp-border, rgba(255, 255, 255, 0.12));
  border-radius: 6px; padding: 4px 8px; font-size: 0.88rem;
}

.kp-crop-modal__stage {
  position: relative;
  flex: 1; min-height: 300px;
  background: #000;
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  touch-action: none;  /* prevent scroll while dragging */
}
.kp-crop-modal__img {
  max-width: 100%; max-height: 100%;
  display: block;
  user-select: none; pointer-events: none;
}
.kp-crop-modal__frame {
  position: absolute;
  border: 2px solid #fff;
  box-shadow: 0 0 0 9999px rgba(0, 0, 0, 0.55);
  cursor: move;
  /* Grid lines (rule of thirds) */
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.3) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.3) 1px, transparent 1px);
  background-size: 33.33% 33.33%;
  background-position: -1px -1px;
}
.kp-crop-modal__handle {
  position: absolute; width: 16px; height: 16px;
  background: #fff; border: 2px solid #1a1a22;
  border-radius: 50%;
}
.kp-crop-modal__handle--tl { top: -10px; left:  -10px; cursor: nwse-resize; }
.kp-crop-modal__handle--tr { top: -10px; right: -10px; cursor: nesw-resize; }
.kp-crop-modal__handle--bl { bottom: -10px; left:  -10px; cursor: nesw-resize; }
.kp-crop-modal__handle--br { bottom: -10px; right: -10px; cursor: nwse-resize; }

.kp-crop-modal__foot {
  display: flex; gap: 12px; justify-content: flex-end;
  padding: 12px 16px;
  border-top: 1px solid var(--kp-border, rgba(255, 255, 255, 0.08));
}
.kp-crop-modal__btn {
  border: 1px solid var(--kp-border, rgba(255, 255, 255, 0.12));
  background: transparent; color: inherit;
  padding: 8px 18px; border-radius: 8px;
  font-size: 0.92rem; font-weight: 500; cursor: pointer;
}
.kp-crop-modal__btn--primary {
  background: var(--kp-accent, var(--n-accent, #ef6443));
  border-color: transparent; color: #fff;
}
.kp-crop-modal__btn--primary:hover { filter: brightness(1.1); }
.kp-crop-modal__btn--ghost:hover  { background: rgba(255, 255, 255, 0.05); }
.kp-crop-modal__btn:disabled { opacity: 0.5; cursor: wait; }

/* Mobile */
@media (max-width: 600px) {
  .kp-crop-modal { padding: 0; }
  .kp-crop-modal__sheet {
    /* v982: dvh для коректної висоти на mobile (100vh може включати browser UI).
       safe-area-inset-bottom — щоб footer не залазив під home indicator/swipe bar. */
    width: 100%; height: 100dvh; max-height: 100dvh;
    border-radius: 0; border: none;
    padding-bottom: env(safe-area-inset-bottom);
  }
  .kp-crop-modal__stage { min-height: 0; }
  .kp-crop-modal__foot {
    /* sticky footer — гарантовано видимий на mobile, поверх stage */
    position: sticky; bottom: 0;
    background: var(--kp-surface, var(--n-surface, #1a1a22));
    z-index: 2;
  }
}
