.kjp-pricing-app {
  --kjp-black: #050505;
  --kjp-panel: #101010;
  --kjp-panel-2: #171717;
  --kjp-panel-3: #202020;
  --kjp-text: #f5f2ec;
  --kjp-muted: rgba(245, 242, 236, 0.72);
  --kjp-faint: rgba(245, 242, 236, 0.52);
  --kjp-line: rgba(255, 255, 255, 0.14);
  --kjp-soft-line: rgba(255, 255, 255, 0.08);
  --kjp-gold: #b7a46a;
  --kjp-red: #b10f18;
  --kjp-green: #99d9a6;
  --kjp-error: #ffb3b3;
  color: var(--kjp-text);
  background: radial-gradient(circle at top right, rgba(177, 15, 24, 0.16), transparent 34%), var(--kjp-black);
  margin: clamp(38px, 6vw, 90px) auto;
  max-width: 1240px;
  padding: clamp(26px, 5vw, 70px) clamp(16px, 4vw, 34px);
}

.kjp-pricing-app * { box-sizing: border-box; }
.kjp-pricing-app [hidden] { display: none !important; }

.kjp-pricing-app__honeypot {
  left: -9999px !important;
  opacity: 0 !important;
  position: absolute !important;
  top: auto !important;
}

.kjp-pricing-app__shell {
  margin-inline: auto;
  max-width: 1120px;
}

.kjp-pricing-app__header {
  max-width: 890px;
  margin: 0 0 clamp(24px, 4vw, 42px);
}

.kjp-pricing-app__eyebrow,
.kjp-pricing-app__mini {
  color: var(--kjp-gold);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  margin: 0 0 10px;
  text-transform: uppercase;
}

.kjp-pricing-app__title {
  color: var(--kjp-text);
  font-size: clamp(2.1rem, 5vw, 4.8rem);
  font-weight: 800;
  letter-spacing: -0.055em;
  line-height: 0.95;
  margin: 0 0 18px;
  max-width: 920px;
}

.kjp-pricing-app__intro {
  color: var(--kjp-muted);
  font-size: clamp(1rem, 1.4vw, 1.16rem);
  line-height: 1.7;
  max-width: 850px;
}

.kjp-pricing-app__intro p { margin: 0 0 12px; }

.kjp-pricing-app__app-frame {
  background: linear-gradient(180deg, rgba(255,255,255,0.07), rgba(255,255,255,0.035));
  border: 1px solid var(--kjp-line);
  border-radius: 30px;
  box-shadow: 0 32px 90px rgba(0,0,0,0.42);
  overflow: hidden;
}

.kjp-pricing-app__topbar {
  background: rgba(0,0,0,0.36);
  border-bottom: 1px solid var(--kjp-soft-line);
  padding: 16px clamp(16px, 3vw, 28px);
}

.kjp-pricing-app__progress {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  list-style: none;
  margin: 0;
  padding: 0;
}

.kjp-pricing-app__progress button {
  align-items: center;
  background: rgba(255,255,255,0.045);
  border: 1px solid var(--kjp-soft-line);
  border-radius: 999px;
  color: var(--kjp-faint);
  cursor: pointer;
  display: flex;
  font-size: 0.82rem;
  font-weight: 800;
  gap: 8px;
  justify-content: flex-start;
  min-height: 42px;
  padding: 7px 12px 7px 8px;
  text-transform: uppercase;
  transition: border-color 160ms ease, color 160ms ease, background 160ms ease, transform 160ms ease;
  width: 100%;
}

.kjp-pricing-app__progress span {
  align-items: center;
  background: rgba(255,255,255,0.08);
  border-radius: 999px;
  color: var(--kjp-muted);
  display: inline-flex;
  height: 28px;
  justify-content: center;
  width: 28px;
}

.kjp-pricing-app__progress li.is-active button,
.kjp-pricing-app__progress li.is-complete button {
  border-color: rgba(183,164,106,0.5);
  color: var(--kjp-text);
}

.kjp-pricing-app__progress li.is-active button {
  background: rgba(183,164,106,0.15);
  transform: translateY(-1px);
}

.kjp-pricing-app__progress li.is-active span,
.kjp-pricing-app__progress li.is-complete span {
  background: var(--kjp-gold);
  color: #090909;
}

.kjp-pricing-app__form { margin: 0; }

.kjp-pricing-app__screens {
  min-height: 560px;
  position: relative;
}

.kjp-pricing-app__screen {
  display: none;
  padding: clamp(26px, 4vw, 46px);
}

.kjp-pricing-app__screen.is-active { display: block; }

.kjp-pricing-app__question {
  margin: 0 0 26px;
  max-width: 760px;
}

.kjp-pricing-app__question h3 {
  color: var(--kjp-text);
  font-size: clamp(1.7rem, 3vw, 3rem);
  letter-spacing: -0.04em;
  line-height: 1;
  margin: 0 0 12px;
}

.kjp-pricing-app__question p:not(.kjp-pricing-app__mini) {
  color: var(--kjp-muted);
  font-size: 1rem;
  line-height: 1.65;
  margin: 0;
}

.kjp-pricing-app__client-types,
.kjp-pricing-app__services {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.kjp-pricing-app__client-type,
.kjp-pricing-app__service {
  background: rgba(255,255,255,0.055);
  border: 1px solid var(--kjp-soft-line);
  border-radius: 22px;
  color: var(--kjp-text);
  cursor: pointer;
  min-height: 130px;
  padding: 20px;
  position: relative;
  text-align: left;
  transition: border-color 160ms ease, background 160ms ease, transform 160ms ease;
}

.kjp-pricing-app__client-type:hover,
.kjp-pricing-app__service:hover,
.kjp-pricing-app__client-type.is-selected,
.kjp-pricing-app__service.is-selected {
  background: rgba(183,164,106,0.12);
  border-color: rgba(183,164,106,0.58);
  transform: translateY(-2px);
}

.kjp-pricing-app__client-type::after,
.kjp-pricing-app__service::after {
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 999px;
  color: transparent;
  content: "";
  height: 20px;
  position: absolute;
  right: 18px;
  top: 18px;
  width: 20px;
}

.kjp-pricing-app__client-type.is-selected::after,
.kjp-pricing-app__service.is-selected::after {
  background: var(--kjp-gold);
  border-color: var(--kjp-gold);
  box-shadow: inset 0 0 0 5px #161616;
}

.kjp-pricing-app__client-type strong,
.kjp-pricing-app__service strong {
  color: var(--kjp-text);
  display: block;
  font-size: 1.2rem;
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin: 0 34px 10px 0;
}

.kjp-pricing-app__client-type span,
.kjp-pricing-app__service p {
  color: var(--kjp-muted);
  display: block;
  font-size: 0.96rem;
  line-height: 1.55;
  margin: 0;
}

.kjp-pricing-app__service {
  cursor: default;
  display: flex;
  flex-direction: column;
  min-height: 220px;
}

.kjp-pricing-app__service-top {
  cursor: pointer;
  display: block;
  margin: 0 0 12px;
}

.kjp-pricing-app__service-top input {
  opacity: 0;
  pointer-events: none;
  position: absolute;
}

.kjp-pricing-app__service-category {
  color: var(--kjp-gold);
  display: block;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  margin-bottom: 5px;
  text-transform: uppercase;
}

.kjp-pricing-app__service-bottom {
  align-items: flex-start;
  display: flex;
  flex-direction: column;
  gap: 7px;
  margin-top: auto;
  padding-top: 16px;
}

.kjp-pricing-app__service-price {
  color: var(--kjp-text);
  font-size: 1.1rem;
  font-weight: 850;
}

.kjp-pricing-app__badge,
.kjp-pricing-app__fine {
  border: 1px solid var(--kjp-soft-line);
  border-radius: 999px;
  color: var(--kjp-muted);
  display: inline-flex;
  font-size: 0.76rem;
  padding: 5px 9px;
}

.kjp-pricing-app__badge {
  border-color: rgba(183,164,106,0.42);
  color: var(--kjp-gold);
}

.kjp-pricing-app__qty {
  align-items: center;
  border-top: 1px solid var(--kjp-soft-line);
  display: flex;
  justify-content: space-between;
  margin-top: 16px;
  padding-top: 14px;
}

.kjp-pricing-app__qty span {
  color: var(--kjp-muted);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.kjp-pricing-app__qty input {
  max-width: 92px;
  text-align: center;
}

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

.kjp-pricing-app__field-card,
.kjp-pricing-app__contact-card label {
  background: rgba(255,255,255,0.055);
  border: 1px solid var(--kjp-soft-line);
  border-radius: 20px;
  display: block;
  padding: 16px;
}

.kjp-pricing-app__field-card > span,
.kjp-pricing-app__contact-card label > span,
.kjp-pricing-app__fields label > span {
  color: var(--kjp-gold);
  display: block;
  font-size: 0.75rem;
  font-weight: 850;
  letter-spacing: 0.12em;
  margin: 0 0 9px;
  text-transform: uppercase;
}

.kjp-pricing-app input,
.kjp-pricing-app select,
.kjp-pricing-app textarea {
  background: rgba(0,0,0,0.32);
  border: 1px solid rgba(255,255,255,0.16);
  border-radius: 14px;
  color: var(--kjp-text);
  font: inherit;
  min-height: 48px;
  padding: 11px 13px;
  width: 100%;
}

.kjp-pricing-app textarea {
  min-height: 140px;
  resize: vertical;
}

.kjp-pricing-app input:focus,
.kjp-pricing-app select:focus,
.kjp-pricing-app textarea:focus {
  border-color: rgba(183,164,106,0.72);
  box-shadow: 0 0 0 3px rgba(183,164,106,0.16);
  outline: none;
}

.kjp-pricing-app__wide { grid-column: 1 / -1; }

.kjp-pricing-app__review-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: 0.9fr 1.1fr;
}

.kjp-pricing-app__summary-card,
.kjp-pricing-app__contact-card {
  background: rgba(0,0,0,0.26);
  border: 1px solid var(--kjp-line);
  border-radius: 24px;
  padding: clamp(18px, 3vw, 28px);
}

.kjp-pricing-app__summary-total {
  color: var(--kjp-text);
  font-size: clamp(2rem, 5vw, 4.2rem);
  font-weight: 900;
  letter-spacing: -0.06em;
  line-height: 0.96;
  margin: 0 0 12px;
}

.kjp-pricing-app__summary-note,
.kjp-pricing-app__empty {
  color: var(--kjp-muted);
  font-size: 0.95rem;
  line-height: 1.55;
  margin: 0 0 16px;
}

.kjp-pricing-app__summary-lines {
  border-top: 1px solid var(--kjp-soft-line);
  margin-top: 18px;
  padding-top: 10px;
}

.kjp-pricing-app__line {
  border-bottom: 1px solid var(--kjp-soft-line);
  display: grid;
  gap: 2px 10px;
  grid-template-columns: 1fr auto;
  padding: 10px 0;
}

.kjp-pricing-app__line span {
  color: var(--kjp-text);
  font-weight: 750;
}

.kjp-pricing-app__line small {
  color: var(--kjp-faint);
  grid-column: 1;
  line-height: 1.35;
}

.kjp-pricing-app__line strong {
  color: var(--kjp-gold);
  grid-column: 2;
  grid-row: 1 / span 2;
  white-space: nowrap;
}

.kjp-pricing-app__line.needs-review strong { color: var(--kjp-error); }

.kjp-pricing-app__quote-only {
  background: rgba(177,15,24,0.16);
  border: 1px solid rgba(177,15,24,0.36);
  border-radius: 18px;
  margin-top: 18px;
  padding: 14px;
}

.kjp-pricing-app__quote-only strong {
  color: var(--kjp-text);
  display: block;
  margin-bottom: 5px;
}

.kjp-pricing-app__quote-only span {
  color: var(--kjp-muted);
  display: block;
  font-size: 0.9rem;
  line-height: 1.5;
}

.kjp-pricing-app__nav {
  align-items: center;
  border-top: 1px solid var(--kjp-soft-line);
  display: flex;
  gap: 12px;
  justify-content: space-between;
  margin-top: clamp(22px, 4vw, 36px);
  padding-top: 18px;
}

.kjp-pricing-app__nav-status {
  color: var(--kjp-error);
  font-size: 0.92rem;
  line-height: 1.4;
  min-height: 1.4em;
}

.kjp-pricing-app__next,
.kjp-pricing-app__back,
.kjp-pricing-app__submit,
.kjp-pricing-app__estimate-dock button {
  align-items: center;
  border: 0;
  border-radius: 999px;
  cursor: pointer;
  display: inline-flex;
  font-weight: 900;
  justify-content: center;
  min-height: 48px;
  padding: 13px 22px;
  text-decoration: none;
  transition: opacity 160ms ease, transform 160ms ease;
}

.kjp-pricing-app__next,
.kjp-pricing-app__submit {
  background: var(--kjp-red);
  color: #fff;
}

.kjp-pricing-app__back,
.kjp-pricing-app__estimate-dock button {
  background: rgba(255,255,255,0.08);
  border: 1px solid var(--kjp-soft-line);
  color: var(--kjp-text);
}

.kjp-pricing-app__next:hover,
.kjp-pricing-app__back:hover,
.kjp-pricing-app__submit:hover,
.kjp-pricing-app__estimate-dock button:hover {
  transform: translateY(-1px);
}

.kjp-pricing-app__submit {
  font-size: 1rem;
  margin-top: 18px;
  width: 100%;
}

.kjp-pricing-app__submit:disabled { opacity: 0.6; cursor: wait; }

.kjp-pricing-app__status {
  color: var(--kjp-muted);
  font-size: 0.95rem;
  line-height: 1.5;
  margin-top: 14px;
  min-height: 1.4em;
}

.kjp-pricing-app__status.is-error { color: var(--kjp-error); }
.kjp-pricing-app__status.is-success { color: var(--kjp-green); }

.kjp-pricing-app__disclaimer {
  border-top: 1px solid var(--kjp-soft-line);
  color: var(--kjp-faint);
  font-size: 0.82rem;
  line-height: 1.55;
  margin: 18px 0 0;
  padding-top: 14px;
}

.kjp-pricing-app__estimate-dock {
  align-items: center;
  background: rgba(0,0,0,0.72);
  border-top: 1px solid var(--kjp-soft-line);
  display: grid;
  gap: 12px;
  grid-template-columns: auto 1fr auto;
  padding: 15px clamp(16px, 3vw, 28px);
  position: sticky;
  bottom: 0;
  z-index: 4;
}

.kjp-pricing-app__estimate-dock span {
  color: var(--kjp-faint);
  display: block;
  font-size: 0.72rem;
  font-weight: 850;
  letter-spacing: 0.12em;
  margin-bottom: 2px;
  text-transform: uppercase;
}

.kjp-pricing-app__estimate-dock strong {
  color: var(--kjp-text);
  font-size: 1.45rem;
  letter-spacing: -0.03em;
}

.kjp-pricing-app__estimate-dock p {
  color: var(--kjp-muted);
  font-size: 0.9rem;
  line-height: 1.35;
  margin: 0;
}

@media (max-width: 860px) {
  .kjp-pricing-app { padding-inline: 12px; }
  .kjp-pricing-app__app-frame { border-radius: 22px; }
  .kjp-pricing-app__progress { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .kjp-pricing-app__screen { padding: 24px 16px; }
  .kjp-pricing-app__client-types,
  .kjp-pricing-app__services,
  .kjp-pricing-app__fields,
  .kjp-pricing-app__review-grid { grid-template-columns: 1fr; }
  .kjp-pricing-app__estimate-dock { grid-template-columns: 1fr; position: relative; }
  .kjp-pricing-app__nav { align-items: stretch; flex-direction: column; }
  .kjp-pricing-app__nav-status { order: -1; }
  .kjp-pricing-app__next,
  .kjp-pricing-app__back { width: 100%; }
}

@media (max-width: 520px) {
  .kjp-pricing-app__progress button { font-size: 0.74rem; }
  .kjp-pricing-app__client-type,
  .kjp-pricing-app__service { padding: 17px; }
}
