/* PersalOne Business — Interactive Demo Layer */

/* ─── TOAST NOTIFICATIONS ──────────────────────────────────────── */
.pb-toast-container {
  position: fixed;
  top: var(--sp-5);
  right: var(--sp-5);
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  pointer-events: none;
  max-width: 360px;
}

.pb-toast {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  background: var(--ps-white);
  border: 1px solid var(--ps-grey-100);
  border-radius: var(--r-lg);
  padding: var(--sp-4) var(--sp-5);
  box-shadow: var(--shadow-lg);
  pointer-events: all;
  animation: toast-in 0.3s cubic-bezier(0.34, 1.56, 0.64, 1) both;
  position: relative;
  overflow: hidden;
  min-width: 300px;
}

.pb-toast.leaving {
  animation: toast-out 0.25s ease forwards;
}

@keyframes toast-in {
  from { opacity: 0; transform: translateX(100%); }
  to   { opacity: 1; transform: translateX(0); }
}

@keyframes toast-out {
  from { opacity: 1; transform: translateX(0); max-height: 100px; margin-bottom: 0; }
  to   { opacity: 0; transform: translateX(80px); max-height: 0; margin-bottom: -12px; padding: 0; }
}

.pb-toast-bar {
  position: absolute;
  bottom: 0;
  left: 0;
  height: 3px;
  border-radius: 0 0 var(--r-lg) var(--r-lg);
  animation: toast-bar linear forwards;
}

@keyframes toast-bar {
  from { width: 100%; }
  to   { width: 0; }
}

.pb-toast-icon {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 1px;
}

.pb-toast-icon svg { width: 12px; height: 12px; }

.pb-toast.success .pb-toast-icon { background: var(--ps-success-bg); color: var(--ps-success); }
.pb-toast.success .pb-toast-bar  { background: var(--ps-success); }
.pb-toast.error   .pb-toast-icon { background: var(--ps-danger-bg); color: var(--ps-danger); }
.pb-toast.error   .pb-toast-bar  { background: var(--ps-danger); }
.pb-toast.warning .pb-toast-icon { background: var(--ps-warning-bg); color: var(--ps-warning); }
.pb-toast.warning .pb-toast-bar  { background: var(--ps-warning); }
.pb-toast.info    .pb-toast-icon { background: rgba(27,42,74,0.08); color: var(--ps-navy); }
.pb-toast.info    .pb-toast-bar  { background: var(--ps-navy); }

.pb-toast-content { flex: 1; }
.pb-toast-title { font-size: var(--text-sm); font-weight: var(--fw-semibold); color: var(--ps-navy); line-height: 1.3; }
.pb-toast-msg   { font-size: var(--text-xs); color: var(--ps-grey-300); margin-top: 2px; line-height: 1.4; }

.pb-toast-close {
  width: 20px;
  height: 20px;
  border: none;
  background: transparent;
  cursor: pointer;
  color: var(--ps-grey-300);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  flex-shrink: 0;
  transition: background var(--t-fast);
  padding: 0;
}

.pb-toast-close:hover { background: var(--ps-bg); color: var(--ps-grey-700); }
.pb-toast-close svg { width: 12px; height: 12px; }

/* ─── MODAL OVERLAY ────────────────────────────────────────────── */
.pb-overlay {
  position: fixed;
  inset: 0;
  background: rgba(27, 42, 74, 0.45);
  backdrop-filter: blur(4px);
  z-index: 8000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-6);
  animation: overlay-in 0.2s ease both;
}

.pb-overlay.leaving {
  animation: overlay-out 0.2s ease forwards;
}

@keyframes overlay-in  { from { opacity: 0; } to { opacity: 1; } }
@keyframes overlay-out { from { opacity: 1; } to { opacity: 0; } }

.pb-modal {
  background: var(--ps-white);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-lg);
  width: 100%;
  max-width: 520px;
  max-height: 90vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  animation: modal-in 0.3s cubic-bezier(0.34, 1.4, 0.64, 1) both;
}

.pb-modal.wide { max-width: 680px; }

.pb-overlay.leaving .pb-modal {
  animation: modal-out 0.2s ease forwards;
}

@keyframes modal-in  { from { opacity: 0; transform: scale(0.92) translateY(12px); } to { opacity: 1; transform: scale(1) translateY(0); } }
@keyframes modal-out { from { opacity: 1; transform: scale(1); } to { opacity: 0; transform: scale(0.95); } }

.pb-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-5) var(--sp-6);
  border-bottom: 1px solid var(--ps-grey-100);
  flex-shrink: 0;
}

.pb-modal-title { font-size: var(--text-xl); font-weight: var(--fw-bold); color: var(--ps-navy); letter-spacing: -0.01em; }
.pb-modal-subtitle { font-size: var(--text-sm); color: var(--ps-grey-300); margin-top: 2px; }

.pb-modal-close {
  width: 32px; height: 32px;
  border: none; background: transparent; cursor: pointer;
  color: var(--ps-grey-300);
  display: flex; align-items: center; justify-content: center;
  border-radius: var(--r-md);
  transition: background var(--t-fast), color var(--t-fast);
  flex-shrink: 0;
}

.pb-modal-close:hover { background: var(--ps-bg); color: var(--ps-grey-700); }
.pb-modal-close svg { width: 18px; height: 18px; }

.pb-modal-body {
  padding: var(--sp-6);
  overflow-y: auto;
  flex: 1;
}

.pb-modal-footer {
  padding: var(--sp-4) var(--sp-6);
  border-top: 1px solid var(--ps-grey-100);
  display: flex;
  justify-content: flex-end;
  gap: var(--sp-3);
  flex-shrink: 0;
  background: var(--ps-bg);
}

/* ─── WIZARD ───────────────────────────────────────────────────── */
.pb-wizard-steps {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin-bottom: var(--sp-6);
}

.pb-wizard-step-item {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}

.pb-wizard-step-circle {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 2px solid var(--ps-grey-100);
  background: var(--ps-white);
  color: var(--ps-grey-300);
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.25s;
  flex-shrink: 0;
}

.pb-wizard-step-label {
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  color: var(--ps-grey-300);
  white-space: nowrap;
  transition: color 0.25s;
}

.pb-wizard-step-item.active .pb-wizard-step-circle {
  border-color: var(--ps-green);
  background: var(--ps-green);
  color: white;
}

.pb-wizard-step-item.active .pb-wizard-step-label { color: var(--ps-navy); font-weight: var(--fw-semibold); }

.pb-wizard-step-item.done .pb-wizard-step-circle {
  border-color: var(--ps-success);
  background: var(--ps-success);
  color: white;
}

.pb-wizard-connector {
  flex: 1;
  height: 2px;
  background: var(--ps-grey-100);
  min-width: 32px;
  max-width: 60px;
  transition: background 0.25s;
}

.pb-wizard-connector.done { background: var(--ps-success); }

.pb-wizard-panel { display: none; }
.pb-wizard-panel.active { display: block; animation: fade-up 0.2s ease both; }

/* ─── FORM ELEMENTS IN MODAL ───────────────────────────────────── */
.pb-form-group {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  margin-bottom: var(--sp-5);
}

.pb-form-group:last-child { margin-bottom: 0; }

.pb-label {
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--ps-navy);
}

.pb-input,
.pb-select,
.pb-textarea {
  padding: 10px var(--sp-4);
  border: 1.5px solid var(--ps-grey-100);
  border-radius: var(--r-md);
  font-size: var(--text-sm);
  color: var(--ps-navy);
  background: var(--ps-bg);
  outline: none;
  width: 100%;
  font-family: inherit;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.pb-input:focus, .pb-select:focus, .pb-textarea:focus {
  border-color: var(--ps-green);
  box-shadow: 0 0 0 3px rgba(40,86,51,0.08);
  background: var(--ps-white);
}

.pb-textarea { resize: vertical; min-height: 80px; }

.pb-radio-group, .pb-check-group {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

.pb-radio-item, .pb-check-item {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  border: 1.5px solid var(--ps-grey-100);
  border-radius: var(--r-md);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
}

.pb-radio-item:hover, .pb-check-item:hover {
  border-color: var(--ps-green);
  background: var(--ps-green-05);
}

.pb-radio-item input, .pb-check-item input {
  accent-color: var(--ps-green);
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  cursor: pointer;
}

.pb-radio-item.selected, .pb-check-item.checked {
  border-color: var(--ps-green);
  background: var(--ps-green-05);
}

.pb-radio-content { flex: 1; }
.pb-radio-title { font-size: var(--text-sm); font-weight: var(--fw-semibold); color: var(--ps-navy); }
.pb-radio-desc  { font-size: var(--text-xs); color: var(--ps-grey-300); margin-top: 1px; }

.pb-summary-box {
  background: var(--ps-bg);
  border: 1px solid var(--ps-grey-100);
  border-radius: var(--r-md);
  padding: var(--sp-4);
}

.pb-summary-row {
  display: flex;
  justify-content: space-between;
  padding: var(--sp-2) 0;
  border-bottom: 1px solid var(--ps-grey-100);
  font-size: var(--text-sm);
}

.pb-summary-row:last-child { border-bottom: none; }
.pb-summary-key { color: var(--ps-grey-300); font-weight: var(--fw-medium); }
.pb-summary-val { color: var(--ps-navy); font-weight: var(--fw-semibold); }

/* ─── UPLOAD ZONE ──────────────────────────────────────────────── */
.pb-upload-zone {
  border: 2px dashed var(--ps-grey-100);
  border-radius: var(--r-lg);
  padding: var(--sp-8) var(--sp-6);
  text-align: center;
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s;
  background: var(--ps-bg);
}

.pb-upload-zone:hover, .pb-upload-zone.drag-over {
  border-color: var(--ps-green);
  background: var(--ps-green-05);
}

.pb-upload-zone svg { width: 40px; height: 40px; color: var(--ps-grey-300); margin: 0 auto var(--sp-3); }
.pb-upload-zone h4 { font-size: var(--text-base); font-weight: var(--fw-semibold); color: var(--ps-navy); margin-bottom: var(--sp-2); }
.pb-upload-zone p { font-size: var(--text-sm); color: var(--ps-grey-300); }
.pb-upload-zone .link { color: var(--ps-green); font-weight: var(--fw-semibold); cursor: pointer; }
.pb-upload-zone .link:hover { text-decoration: underline; }

.pb-file-selected {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  background: var(--ps-green-05);
  border: 1px solid var(--ps-green-12);
  border-radius: var(--r-md);
  margin-top: var(--sp-4);
}

.pb-file-selected svg { width: 20px; height: 20px; color: var(--ps-green); flex-shrink: 0; }
.pb-file-selected span { font-size: var(--text-sm); font-weight: var(--fw-medium); color: var(--ps-green); flex: 1; }

/* ─── FAKE PROGRESS ────────────────────────────────────────────── */
.pb-progress-track {
  height: 8px;
  background: var(--ps-grey-100);
  border-radius: var(--r-full);
  overflow: hidden;
  margin: var(--sp-4) 0;
}

.pb-progress-fill {
  height: 100%;
  background: var(--ps-green);
  border-radius: var(--r-full);
  width: 0%;
  transition: width 0.4s ease;
}

.pb-progress-label {
  font-size: var(--text-xs);
  color: var(--ps-grey-300);
  font-family: 'JetBrains Mono', monospace;
  text-align: right;
}

/* ─── AVATAR DROPDOWN ──────────────────────────────────────────── */
.pb-avatar-wrap { position: relative; }

.pb-user-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 220px;
  background: var(--ps-white);
  border: 1px solid var(--ps-grey-100);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-md);
  z-index: 500;
  overflow: hidden;
  animation: fade-up 0.15s ease both;
  display: none;
}

.pb-user-dropdown.open { display: block; }

.pb-user-dropdown-header {
  padding: var(--sp-4) var(--sp-4);
  border-bottom: 1px solid var(--ps-grey-100);
  background: var(--ps-bg);
}

.pb-user-dropdown-name { font-size: var(--text-sm); font-weight: var(--fw-bold); color: var(--ps-navy); }
.pb-user-dropdown-role { font-size: var(--text-xs); color: var(--ps-grey-300); margin-top: 1px; }

.pb-dropdown-item {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--text-sm);
  color: var(--ps-grey-700);
  cursor: pointer;
  transition: background var(--t-fast);
  text-decoration: none;
}

.pb-dropdown-item:hover { background: var(--ps-bg); color: var(--ps-navy); }
.pb-dropdown-item svg { width: 16px; height: 16px; color: var(--ps-grey-300); flex-shrink: 0; }
.pb-dropdown-item:hover svg { color: var(--ps-green); }

.pb-dropdown-divider { height: 1px; background: var(--ps-grey-100); margin: var(--sp-2) 0; }

.pb-dropdown-item.danger { color: var(--ps-danger); }
.pb-dropdown-item.danger:hover { background: var(--ps-danger-bg); }
.pb-dropdown-item.danger svg { color: var(--ps-danger); }

/* ─── COLOR PICKER ─────────────────────────────────────────────── */
.pb-color-row {
  display: flex;
  gap: var(--sp-3);
  margin-top: var(--sp-2);
}

.pb-color-dot {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  cursor: pointer;
  border: 2px solid transparent;
  transition: all 0.15s;
}

.pb-color-dot.selected { border-color: var(--ps-navy); transform: scale(1.15); }
.pb-color-dot:hover { transform: scale(1.1); }
