.pgv-widget,
.pgv-inlineCta {
  --pgv-ink: #243126;
  --pgv-copy: #5d6b60;
  --pgv-green: #8eb63f;
  --pgv-green-deep: #304a2c;
  --pgv-line: rgba(36, 49, 38, 0.12);
  --pgv-paper: #f7f3ea;
  --pgv-white: #ffffff;
  color: var(--pgv-ink);
  font-family: "Helvetica Neue", Arial, sans-serif;
}

.pgv-inlineCta {
  width: min(100%, 920px);
  margin: 48px auto 0;
  padding: 24px;
  border-radius: 24px;
  border: 1px solid rgba(36, 49, 38, 0.1);
  background:
    linear-gradient(180deg, rgba(244, 247, 239, 0.96), rgba(255, 255, 255, 0.98)),
    #ffffff;
  display: grid;
  gap: 18px;
}

.pgv-inlineCta__copy {
  display: grid;
  gap: 10px;
  max-width: 58ch;
  margin: 0 auto;
  justify-items: center;
  text-align: center;
}

.pgv-inlineCta__eyebrow {
  margin: 0;
  color: var(--pgv-green);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.pgv-inlineCta__copy h2 {
  margin: 0;
  color: var(--pgv-ink);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.35rem, 2.15vw, 1.95rem);
  line-height: 1.16;
}

.pgv-inlineCta__copy p {
  margin: 0;
  color: var(--pgv-copy);
  line-height: 1.6;
}

.pgv-inlineCta .pgv-compact {
  width: min(100%, 680px);
  margin: 0 auto;
}

.pgv-compact {
  width: min(100%, 760px);
  margin: 0 auto;
  display: grid;
  gap: 14px;
}

.pgv-progress {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.pgv-inlineCta .pgv-progress {
  gap: 8px;
}

.pgv-progress__item {
  display: grid;
  gap: 7px;
  justify-items: center;
  padding: 10px 6px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid var(--pgv-line);
}

.pgv-inlineCta .pgv-progress__item {
  padding: 8px 6px;
}

.pgv-progress__item.is-current {
  background: rgba(142, 182, 63, 0.16);
  border-color: rgba(142, 182, 63, 0.32);
}

.pgv-progress__item.is-done {
  background: rgba(48, 74, 44, 0.08);
}

.pgv-progress__dot {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #e6ebde;
  color: var(--pgv-green-deep);
  font-size: 0.85rem;
  font-weight: 700;
}

.pgv-inlineCta .pgv-progress__dot {
  width: 24px;
  height: 24px;
  font-size: 0.78rem;
}

.pgv-progress__item.is-current .pgv-progress__dot,
.pgv-progress__item.is-done .pgv-progress__dot {
  background: var(--pgv-green);
  color: var(--pgv-white);
}

.pgv-progress__label {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--pgv-copy);
}

.pgv-inlineCta .pgv-progress__label {
  font-size: 0.8rem;
}

.pgv-card {
  padding: 22px;
  border-radius: 28px;
  border: 1px solid var(--pgv-line);
  background:
    radial-gradient(circle at top left, rgba(142, 182, 63, 0.12), transparent 32%),
    linear-gradient(135deg, #f7f3ea 0%, #ffffff 56%, #eef4e7 100%);
  box-shadow: 0 24px 58px rgba(26, 34, 27, 0.12);
  display: grid;
  gap: 16px;
}

.pgv-inlineCta .pgv-card {
  padding: 18px;
  border-radius: 22px;
  gap: 14px;
  box-shadow: 0 14px 34px rgba(26, 34, 27, 0.08);
}

.pgv-stepView {
  display: grid;
  gap: 16px;
}

.pgv-stepView--intro {
  min-height: 360px;
  align-content: center;
  justify-items: center;
  text-align: center;
}

.pgv-inlineCta .pgv-stepView--intro {
  min-height: 0;
  gap: 14px;
}

.pgv-stepView__head {
  display: grid;
  gap: 6px;
  justify-items: center;
  text-align: center;
}

.pgv-stepView__head h3,
.pgv-stepView--intro h2 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-weight: 600;
  line-height: 1.06;
  color: var(--pgv-ink);
}

.pgv-stepView--intro h2 {
  font-size: clamp(1.65rem, 3vw, 2.55rem);
  max-width: 18ch;
}

.pgv-inlineCta .pgv-stepView--intro h2 {
  font-size: clamp(1.45rem, 2.5vw, 2rem);
  max-width: 16ch;
}

.pgv-stepView__head h3 {
  font-size: clamp(1.2rem, 2vw, 1.65rem);
  max-width: 24ch;
}

.pgv-intro,
.pgv-stepView__head p,
.pgv-teaser p,
.pgv-helpBox,
.pgv-promptPreview span,
.pgv-checkbox span,
.pgv-microcopy,
.pgv-resultMini p {
  margin: 0;
  color: var(--pgv-copy);
  line-height: 1.55;
}

.pgv-stepView__head p,
.pgv-intro {
  max-width: 60ch;
}

.pgv-eyebrow {
  margin: 0;
  color: var(--pgv-green);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.pgv-teaser,
.pgv-uploadCard,
.pgv-promptPreview,
.pgv-helpBox,
.pgv-resultMini,
.pgv-resultMini__copy {
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid var(--pgv-line);
  background: rgba(255, 255, 255, 0.82);
}

.pgv-teaser {
  max-width: 60ch;
  text-align: center;
}

.pgv-uploadCard {
  display: grid;
  gap: 14px;
}

.pgv-uploadCard .pgv-fileInput {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.pgv-fileStatus {
  margin: 0;
  color: var(--pgv-green-deep);
  font-size: 0.92rem;
  font-weight: 600;
}

.pgv-uploadActions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.pgv-button {
  border: 0;
  border-radius: 16px;
  padding: 14px 18px;
  background: var(--pgv-green);
  color: var(--pgv-white);
  font: inherit;
  font-weight: 700;
  cursor: pointer;
}

.pgv-button:disabled {
  opacity: 0.72;
  cursor: progress;
}

.pgv-button--ghost {
  background: transparent;
  color: var(--pgv-green-deep);
  border: 1px solid rgba(48, 74, 44, 0.2);
}

.pgv-placeholder,
.pgv-preview {
  border-radius: 18px;
  overflow: hidden;
  border: 1px dashed rgba(48, 74, 44, 0.2);
  background: rgba(48, 74, 44, 0.04);
}

.pgv-placeholder {
  min-height: 220px;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 24px;
  color: var(--pgv-copy);
}

.pgv-inlineCta .pgv-placeholder {
  min-height: 170px;
  padding: 18px;
}

.pgv-preview {
  min-height: 240px;
  display: grid;
  place-items: center;
  padding: 12px;
}

.pgv-preview img,
.pgv-resultMini__visual img,
.pgv-resultCard__media img {
  display: block;
  width: 100%;
  height: auto;
  max-height: 420px;
  object-fit: contain;
  aspect-ratio: auto;
}

.pgv-grid {
  display: grid;
  gap: 12px;
}

.pgv-grid--two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.pgv-field {
  display: grid;
  gap: 8px;
}

.pgv-field span {
  color: var(--pgv-copy);
  font-size: 0.94rem;
  font-weight: 700;
}

.pgv-field input,
.pgv-field textarea,
.pgv-field select {
  width: 100%;
  border-radius: 14px;
  border: 1px solid rgba(36, 49, 38, 0.16);
  padding: 13px 14px;
  font: inherit;
  color: var(--pgv-ink);
  background: #fffdf9;
}

.pgv-field textarea {
  resize: vertical;
  min-height: 110px;
}

.pgv-helpBox {
  padding: 12px 14px;
  background: rgba(142, 182, 63, 0.1);
}

.pgv-chipRow {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.pgv-chip {
  border: 1px solid rgba(48, 74, 44, 0.18);
  background: #ffffff;
  color: var(--pgv-ink);
  border-radius: 999px;
  padding: 9px 13px;
  cursor: pointer;
  font: inherit;
  font-size: 0.95rem;
  font-weight: 700;
}

.pgv-chip.is-active {
  background: var(--pgv-green);
  color: var(--pgv-white);
  border-color: var(--pgv-green);
}

.pgv-checkbox {
  display: flex;
  align-items: start;
  gap: 11px;
  color: var(--pgv-copy);
}

.pgv-checkbox input {
  margin-top: 0.2rem;
}

.pgv-checkbox a {
  color: var(--pgv-green-deep);
}

.pgv-honeypot {
  position: absolute;
  left: -9999px;
  opacity: 0;
  pointer-events: none;
}

.pgv-promptPreview span {
  display: block;
  margin-bottom: 8px;
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.pgv-promptPreview strong {
  color: var(--pgv-ink);
  line-height: 1.5;
}

.pgv-alert {
  padding: 14px 16px;
  border-radius: 16px;
  font-weight: 600;
}

.pgv-alert--error {
  background: #fde8e8;
  color: #9d2f2f;
}

.pgv-alert--success {
  background: #edf7de;
  color: #335824;
}

.pgv-actions {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
}

.pgv-actions > span {
  min-width: 1px;
}

.pgv-resultMini {
  display: grid;
  gap: 14px;
}

.pgv-resultMini h3 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.5rem, 2.8vw, 2.1rem);
}

.pgv-resultMini__meta {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.pgv-resultCompare {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.pgv-resultCard {
  display: grid;
  gap: 10px;
}

.pgv-resultCard__label {
  color: var(--pgv-green-deep);
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.pgv-resultCard__media,
.pgv-resultCard__placeholder {
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(48, 74, 44, 0.16);
  background: rgba(255, 255, 255, 0.9);
}

.pgv-resultCard__media {
  min-height: 260px;
  display: grid;
  place-items: center;
  padding: 12px;
}

.pgv-resultCard__mediaButton {
  width: 100%;
  appearance: none;
  cursor: zoom-in;
  position: relative;
  text-align: left;
}

.pgv-resultCard__mediaButton:hover .pgv-resultCard__zoomHint,
.pgv-resultCard__mediaButton:focus-visible .pgv-resultCard__zoomHint {
  opacity: 1;
  transform: translateY(0);
}

.pgv-resultCard__mediaButton:focus-visible {
  outline: 2px solid rgba(142, 182, 63, 0.6);
  outline-offset: 3px;
}

.pgv-resultCard__zoomHint {
  position: absolute;
  right: 14px;
  bottom: 14px;
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(36, 49, 38, 0.82);
  color: #ffffff;
  font-size: 0.82rem;
  font-weight: 700;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.pgv-resultCard__placeholder {
  min-height: 220px;
  padding: 24px;
  display: grid;
  place-items: center;
  text-align: center;
  color: var(--pgv-copy);
  line-height: 1.55;
}

.pgv-badge {
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(142, 182, 63, 0.16);
  color: var(--pgv-green-deep);
  font-size: 0.88rem;
  font-weight: 700;
}

.pgv-resultMini__visual {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 14px;
  align-items: start;
}

.pgv-resultMini__actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.pgv-lightbox {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: grid;
  place-items: center;
  padding: 28px;
  background: rgba(22, 29, 24, 0.84);
  backdrop-filter: blur(6px);
}

.pgv-lightbox__panel {
  width: min(100%, 1200px);
  max-height: calc(100vh - 56px);
  display: grid;
  gap: 12px;
  justify-items: center;
  position: relative;
}

.pgv-lightbox__meta {
  color: rgba(255, 255, 255, 0.88);
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.pgv-lightbox__image {
  width: auto;
  max-width: 100%;
  max-height: calc(100vh - 140px);
  border-radius: 18px;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.35);
  background: rgba(255, 255, 255, 0.06);
}

.pgv-lightbox__close {
  position: absolute;
  top: -8px;
  right: -8px;
  width: 44px;
  height: 44px;
  border: 0;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.16);
  color: #ffffff;
  font-size: 2rem;
  line-height: 1;
  cursor: pointer;
}

@media (max-width: 720px) {
  .pgv-progress,
  .pgv-grid--two,
  .pgv-resultMini__visual,
  .pgv-resultCompare {
    grid-template-columns: 1fr;
  }

  .pgv-inlineCta {
    width: 100%;
    margin-top: 38px;
    padding: 18px;
    border-radius: 22px;
  }

  .pgv-card {
    padding: 18px;
    border-radius: 22px;
  }

  .pgv-actions {
    flex-direction: column;
  }

  .pgv-resultMini__actions {
    flex-direction: column;
  }

  .pgv-actions .pgv-button {
    width: 100%;
  }

  .pgv-resultMini__actions .pgv-button {
    width: 100%;
  }

  .pgv-lightbox {
    padding: 16px;
  }

  .pgv-lightbox__image {
    max-height: calc(100vh - 110px);
  }

  .pgv-resultCard__zoomHint {
    opacity: 1;
    transform: translateY(0);
    font-size: 0.75rem;
  }
}
