/**
 * Step 1A — PPDNCS / NSNI theme, fluid vw layout.
 */

.ppdncs-step1a-wrap {
	--ppdncs-navy: #1b1d3d;
	--ppdncs-navy-soft: #232640;
	--ppdncs-gold: #c5a059;
	--ppdncs-gold-bright: #d4af37;
	--ppdncs-text: #2a2d42;
	--ppdncs-muted: #5c6074;
	--ppdncs-border: rgba(27, 29, 61, 0.18);
	--ppdncs-bg-subtle: linear-gradient(180deg, #f6f7fb 0%, #ffffff 42%);
	box-sizing: border-box;
	font-family: "Montserrat", "Poppins", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
	color: var(--ppdncs-text);
	font-size: clamp(0.85rem, 1.05vw, 1.05rem);
	line-height: 1.65;
	width: 100%;
	margin-left: auto;
	margin-right: auto;
}

.ppdncs-step1a-wrap *,
.ppdncs-step1a-wrap *::before,
.ppdncs-step1a-wrap *::after {
	box-sizing: border-box;
}

.ppdncs-step1a-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(1.5rem, 4vw, 3.5rem);
	align-items: start;
}

@media (min-width: 56em) {
	.ppdncs-step1a-grid {
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
		gap: clamp(2rem, 5vw, 4.5rem);
	}
}

/* Left column */
.ppdncs-step1a-intro {
	padding-right: clamp(0rem, 2vw, 2rem);
}

.ppdncs-step1a-kicker {
	font-family: Georgia, "Times New Roman", serif;
	font-weight: 700;
	color: var(--ppdncs-navy);
	font-size: clamp(1.35rem, 2.4vw, 2rem);
	margin: 0 0 clamp(0.5rem, 1.2vw, 0.9rem);
	line-height: 1.2;
	position: relative;
	display: inline-block;
}

.ppdncs-step1a-kicker::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -0.35em;
	width: clamp(2.5rem, 6vw, 4rem);
	height: clamp(0.18rem, 0.35vw, 0.28rem);
	background: var(--ppdncs-gold-bright);
	border-radius: 999px;
}

.ppdncs-step1a-title {
	margin: clamp(1rem, 2vw, 1.5rem) 0 clamp(1rem, 2vw, 1.75rem);
	font-size: clamp(1.75rem, 3.6vw, 3rem);
	font-weight: 800;
	color: var(--ppdncs-navy-soft);
	letter-spacing: -0.02em;
	line-height: 1.15;
}

.ppdncs-step1a-intro p {
	margin: 0 0 clamp(1rem, 2vw, 1.35rem);
	color: var(--ppdncs-text);
	max-width: 40rem;
}

.ppdncs-step1a-intro strong {
	color: var(--ppdncs-navy);
	font-weight: 700;
}

.ppdncs-step1a-list-title {
	font-weight: 700;
	color: var(--ppdncs-navy);
	margin: clamp(1.25rem, 2.5vw, 2rem) 0 clamp(0.6rem, 1.2vw, 1rem);
	font-size: clamp(0.95rem, 1.15vw, 1.1rem);
}

.ppdncs-step1a-list {
	margin: 0;
	padding-left: clamp(1.1rem, 2.2vw, 1.5rem);
	color: var(--ppdncs-text);
}

.ppdncs-step1a-list li {
	margin-bottom: clamp(0.35rem, 0.9vw, 0.55rem);
	padding-left: 0.25em;
}

.ppdncs-step1a-list a {
	color: var(--ppdncs-navy);
	font-weight: 600;
	text-decoration: underline;
	text-underline-offset: 0.2em;
}

.ppdncs-step1a-list a:hover,
.ppdncs-step1a-list a:focus {
	color: var(--ppdncs-gold-bright);
}

/* Right: form card */
.ppdncs-step1a-form-card {
	background: #fff;
	border-radius: clamp(0.75rem, 1.6vw, 1.35rem);
	box-shadow: 0 clamp(0.35rem, 0.8vw, 0.75rem) clamp(1.5rem, 3vw, 2.25rem) rgba(27, 29, 61, 0.08);
	padding: clamp(1.5rem, 3.5vw, 2.75rem);
	border: 1px solid var(--ppdncs-border);
}

.ppdncs-step1a-form-heading {
	margin: 0 0 clamp(1.25rem, 2.8vw, 2rem);
	font-size: clamp(1.1rem, 1.85vw, 1.45rem);
	font-weight: 800;
	color: var(--ppdncs-navy);
}

.ppdncs-step1a-field {
	margin-bottom: clamp(1rem, 2.2vw, 1.5rem);
}

.ppdncs-step1a-field label {
	display: block;
	font-weight: 700;
	color: var(--ppdncs-navy);
	margin-bottom: clamp(0.35rem, 0.8vw, 0.5rem);
	font-size: clamp(0.8rem, 1vw, 0.95rem);
}

.ppdncs-step1a-field .description {
	display: block;
	font-weight: 500;
	color: var(--ppdncs-muted);
	font-size: clamp(0.72rem, 0.88vw, 0.85rem);
	margin-top: 0.25rem;
}

.ppdncs-step1a-field input[type="text"],
.ppdncs-step1a-field input[type="email"],
.ppdncs-step1a-field input[type="tel"],
.ppdncs-step1a-field input[type="url"],
.ppdncs-step1a-field select {
	width: 100%;
	padding: clamp(0.65rem, 1.1vw, 0.85rem) clamp(0.85rem, 1.4vw, 1.1rem);
	border: 1px solid var(--ppdncs-border);
	border-radius: clamp(0.55rem, 1vw, 1.1rem);
	background: #fff;
	color: var(--ppdncs-text);
	font-size: clamp(0.85rem, 1.05vw, 1rem);
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.ppdncs-step1a-field input:focus,
.ppdncs-step1a-field select:focus {
	outline: none;
	border-color: rgba(197, 160, 89, 0.75);
	box-shadow: 0 0 0 clamp(0.12rem, 0.22vw, 0.2rem) rgba(197, 160, 89, 0.25);
}

.ppdncs-step1a-row-2 {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(0.75rem, 2vw, 1.25rem);
}

@media (min-width: 36em) {
	.ppdncs-step1a-row-2 {
		grid-template-columns: 1fr 1fr;
	}
}

.ppdncs-step1a-row-3 {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(0.75rem, 2vw, 1.25rem);
}

@media (min-width: 42em) {
	.ppdncs-step1a-row-3 {
		grid-template-columns: 1fr 1fr 1fr;
	}
}

.ppdncs-step1a-actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	align-items: center;
	gap: clamp(0.75rem, 2vw, 1.25rem);
	margin-top: clamp(1.25rem, 2.8vw, 2rem);
}

.ppdncs-step1a-submit {
	appearance: none;
	border: none;
	cursor: pointer;
	background: var(--ppdncs-navy);
	color: #fff;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-size: clamp(0.78rem, 1vw, 0.92rem);
	padding: clamp(0.75rem, 1.4vw, 0.95rem) clamp(1.75rem, 3.5vw, 2.75rem);
	border-radius: 999px;
	box-shadow: 0 clamp(0.2rem, 0.45vw, 0.35rem) clamp(0.85rem, 1.6vw, 1.1rem) rgba(27, 29, 61, 0.22);
	transition: transform 0.12s ease, background 0.12s ease, box-shadow 0.12s ease;
}

.ppdncs-step1a-submit:hover,
.ppdncs-step1a-submit:focus {
	background: var(--ppdncs-navy-soft);
	box-shadow: 0 clamp(0.25rem, 0.55vw, 0.45rem) clamp(1rem, 2vw, 1.35rem) rgba(27, 29, 61, 0.28);
}

.ppdncs-step1a-submit:active {
	transform: translateY(1px);
}

.ppdncs-step1a-submit:disabled {
	opacity: 0.65;
	cursor: not-allowed;
}

/* Login area */
.ppdncs-step1a-login {
	margin-top: clamp(1.5rem, 3.2vw, 2.5rem);
	padding-top: clamp(1.25rem, 2.5vw, 2rem);
	border-top: 1px solid var(--ppdncs-border);
	text-align: center;
}

.ppdncs-step1a-login p {
	margin: 0;
	color: var(--ppdncs-muted);
	font-size: clamp(0.82rem, 1vw, 0.95rem);
}

.ppdncs-step1a-login a {
	display: inline-block;
	margin-top: clamp(0.5rem, 1.2vw, 0.85rem);
	font-weight: 700;
	color: var(--ppdncs-navy);
	text-decoration: none;
	padding: clamp(0.55rem, 1.1vw, 0.7rem) clamp(1.25rem, 2.5vw, 1.75rem);
	border-radius: 999px;
	border: 2px solid var(--ppdncs-gold);
	background: transparent;
	transition: background 0.15s ease, color 0.15s ease;
}

.ppdncs-step1a-login a:hover,
.ppdncs-step1a-login a:focus {
	background: var(--ppdncs-gold);
	color: #fff;
}

.ppdncs-step1a-login-lead {
	display: block;
	margin-bottom: clamp(0.35rem, 0.8vw, 0.5rem);
	color: #6b8fb8;
	font-size: clamp(0.82rem, 1vw, 0.95rem);
	font-weight: 600;
}

.ppdncs-step1a-login-btn {
	display: inline-block;
	margin-top: clamp(0.4rem, 1vw, 0.65rem);
	font-family: inherit;
	font-weight: 700;
	font-size: clamp(0.82rem, 1vw, 0.95rem);
	color: var(--ppdncs-navy);
	text-decoration: none;
	padding: clamp(0.55rem, 1.1vw, 0.7rem) clamp(1.25rem, 2.5vw, 1.75rem);
	border-radius: 999px;
	border: 2px solid var(--ppdncs-gold);
	background: transparent;
	cursor: pointer;
	transition: background 0.15s ease, color 0.15s ease;
}

.ppdncs-step1a-login-btn:hover,
.ppdncs-step1a-login-btn:focus {
	background: var(--ppdncs-gold);
	color: #fff;
	outline: none;
}

/* Inline login (replaces wizard while guest signs in) */
.ppdncs-app-inline-login {
    position: fixed;
    z-index: 9999999999;
    top: 0;
    width: 100%;
    height: 100%;
    left: 0;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all ease .3s;
    opacity: 1 !important;
    pointer-events: inherit !important;
    background: #ffffffbd;
    /* CSS Variables for modal styling */
    --ppdncs-navy: #1b1d3d;
    --ppdncs-navy-soft: #232640;
    --ppdncs-gold: #c5a059;
    --ppdncs-gold-bright: #d4af37;
    --ppdncs-text: #2a2d42;
    --ppdncs-muted: #5c6074;
    --ppdncs-border: rgba(27, 29, 61, 0.18);
}

.ppdncs-app-inline-login[hidden] {
    transition: all ease .3s;
    opacity: 0 !important;
    pointer-events: none !important;
}

.ppdncs-app-inline-login-card {
	width: min(26rem, 100% - 2rem);
	max-width: 26rem;
	min-width: 280px;
	margin: 0 auto;
	padding: clamp(1.1rem, 2.2vw, 1.65rem) clamp(1.25rem, 2.5vw, 1.75rem);
	background: #fff;
	border-radius: clamp(0.75rem, 1.6vw, 1.2rem);
	box-shadow: 0 clamp(0.35rem, 0.8vw, 0.75rem) clamp(1.5rem, 3vw, 2.25rem) rgba(27, 29, 61, 0.08);
	border: 1px solid rgba(27, 29, 61, 0.06);
}

.ppdncs-app-login-back {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	margin-bottom: clamp(0.65rem, 1.3vw, 0.95rem);
	padding: 0.35rem 0.65rem;
	font-family: inherit;
	font-size: clamp(0.78rem, 0.95vw, 0.9rem);
	font-weight: 600;
	color: var(--ppdncs-navy);
	background: rgba(197, 160, 89, 0.12);
	border: 1px solid rgba(197, 160, 89, 0.35);
	border-radius: 999px;
	cursor: pointer;
	transition: background 0.15s ease;
}

.ppdncs-app-login-back:hover,
.ppdncs-app-login-back:focus {
	background: rgba(197, 160, 89, 0.22);
	outline: none;
}

.ppdncs-app-login-heading {
	margin: 0 0 0.35rem;
	font-size: clamp(1.05rem, 1.8vw, 1.28rem);
	font-weight: 800;
	color: var(--ppdncs-navy);
}

.ppdncs-app-login-intro {
	margin: 0 0 clamp(1rem, 2vw, 1.35rem);
	font-size: clamp(0.82rem, 1vw, 0.95rem);
	color: var(--ppdncs-muted);
	line-height: 1.5;
}

.ppdncs-app-inline-login-card .ppdncs-step1a-field {
	margin-bottom: clamp(0.75rem, 1.5vw, 1rem);
}

.ppdncs-app-inline-login-card .ppdncs-step1a-field label {
	display: block;
	margin-bottom: 0.35rem;
	font-size: clamp(0.78rem, 0.95vw, 0.88rem);
	font-weight: 700;
	color: var(--ppdncs-navy);
}

.ppdncs-app-inline-login-card .ppdncs-step1a-field input[type='text'],
.ppdncs-app-inline-login-card .ppdncs-step1a-field input[type='password'] {
	width: 100%;
	padding: clamp(0.55rem, 1.1vw, 0.65rem) clamp(0.65rem, 1.2vw, 0.75rem);
	font-family: inherit;
	font-size: clamp(0.88rem, 1.05vw, 0.98rem);
	border: 1px solid rgba(27, 29, 61, 0.18);
	border-radius: clamp(0.35rem, 0.8vw, 0.6rem);
	box-sizing: border-box;
}

.ppdncs-app-inline-login-card .ppdncs-step1a-field input:focus {
	border-color: var(--ppdncs-gold);
	outline: none;
	box-shadow: 0 0 0 2px rgba(197, 160, 89, 0.25);
}

.ppdncs-app-login-remember {
	display: flex;
	align-items: center;
	gap: 0.45rem;
	margin-bottom: clamp(0.9rem, 1.6vw, 1.15rem);
	font-size: clamp(0.8rem, 1vw, 0.92rem);
	color: var(--ppdncs-muted);
	cursor: pointer;
}

.ppdncs-app-login-remember input {
	margin: 0;
}

.ppdncs-app-login-actions {
	margin-bottom: clamp(0.9rem, 1.6vw, 1.15rem);
	width: 100%;
	box-sizing: border-box;
}

.ppdncs-app-login-submit {
	width: 100%;
	padding: clamp(0.65rem, 1.2vw, 0.8rem);
	font-family: inherit;
	font-size: clamp(0.88rem, 1.05vw, 0.98rem);
	font-weight: 800;
	color: #fff;
	background: linear-gradient(180deg, var(--ppdncs-gold) 0%, #a88648 100%);
	border: none;
	border-radius: clamp(0.45rem, 0.9vw, 0.65rem);
	cursor: pointer;
	transition: opacity 0.15s ease, transform 0.12s ease;
	box-sizing: border-box;
}

.ppdncs-app-login-submit:hover:not(:disabled),
.ppdncs-app-login-submit:focus:not(:disabled) {
	opacity: 0.92;
	outline: none;
}

.ppdncs-app-login-submit:disabled {
	opacity: 0.65;
	cursor: not-allowed;
}

.ppdncs-app-login-lost {
	margin: clamp(0.75rem, 1.4vw, 1rem) 0 0;
	padding: 0;
	text-align: center;
	font-size: clamp(0.78rem, 0.95vw, 0.88rem);
}

.ppdncs-app-login-lost a {
	color: var(--ppdncs-navy);
	font-weight: 700;
	text-decoration: none;
	transition: color 0.15s ease;
}

.ppdncs-app-login-lost a:hover,
.ppdncs-app-login-lost a:focus {
	color: var(--ppdncs-gold);
	outline: none;
}

.ppdncs-app-login-meta {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.45rem;
	margin-top: clamp(0.9rem, 1.6vw, 1.15rem);
	font-size: clamp(0.78rem, 0.95vw, 0.88rem);
}

.ppdncs-app-login-meta a {
	color: var(--ppdncs-navy);
	font-weight: 700;
}

.ppdncs-app-login-error {
	margin: 0 0 clamp(0.75rem, 1.4vw, 1rem);
	padding: 0.65rem 0.85rem;
	border-radius: 0.45rem;
	background: rgba(180, 40, 40, 0.08);
	color: #8f1d1d;
	border: 1px solid rgba(180, 40, 40, 0.25);
	font-size: clamp(0.82rem, 1vw, 0.95rem);
	font-weight: 600;
	word-wrap: break-word;
	overflow-wrap: break-word;
}

.ppdncs-app-login-form {
	margin: 0;
	padding: 0;
	width: 100%;
	box-sizing: border-box;
}

/* Notices */
.ppdncs-step1a-notice {
	margin-bottom: clamp(1rem, 2.2vw, 1.5rem);
	padding: clamp(0.75rem, 1.5vw, 1rem) clamp(1rem, 2vw, 1.25rem);
	border-radius: clamp(0.5rem, 1vw, 0.85rem);
	font-weight: 600;
	font-size: clamp(0.82rem, 1vw, 0.95rem);
}

.ppdncs-step1a-notice--success {
	background: rgba(197, 160, 89, 0.18);
	color: var(--ppdncs-navy);
	border: 1px solid rgba(197, 160, 89, 0.45);
}

.ppdncs-step1a-notice--error {
	background: rgba(180, 40, 40, 0.08);
	color: #8f1d1d;
	border: 1px solid rgba(180, 40, 40, 0.25);
}

/* Honeypot — hidden */
.ppdncs-step1a-hp {
	position: absolute !important;
	left: -9999px !important;
	width: 1px !important;
	height: 1px !important;
	overflow: hidden !important;
}

/* —— Wizard: stacked phases + fade —— */
.ppdncs-app-phases {
	position: relative;
	display: grid;
	grid-template-columns: 1fr;
	width: 100%;
}

.ppdncs-app-phase {
	grid-row: 1;
	grid-column: 1;
	width: 100%;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.38s ease, visibility 0.38s ease;
	pointer-events: none;
}

.ppdncs-app-phase.is-active {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}

.ppdncs-app-phase.is-leaving {
	opacity: 0;
}

.ppdncs-app-phase--done .ppdncs-app-done-card {
	background: #fff;
	border-radius: clamp(0.75rem, 1.6vw, 1.35rem);
	box-shadow: 0 clamp(0.35rem, 0.8vw, 0.75rem) clamp(1.5rem, 3vw, 2.25rem) rgba(27, 29, 61, 0.08);
	padding: clamp(2rem, 5vw, 3.5rem);
	border: 1px solid var(--ppdncs-border);
	text-align: center;
	max-width: min(96vw, 40rem);
	margin-left: auto;
	margin-right: auto;
}

.ppdncs-app-phase--done .ppdncs-step1a-title {
	margin-top: 0;
}

.ppdncs-app-done-card p {
	margin: 0 0 clamp(0.85rem, 2vw, 1.25rem);
	line-height: 1.65;
}

.ppdncs-app-done-card p:last-child {
	margin-bottom: 0;
}

.ppdncs-app-done-note {
	font-size: clamp(0.78rem, 0.95vw, 0.88rem);
	color: var(--ppdncs-muted);
	font-weight: 600;
}

.ppdncs-app-phase--pause .ppdncs-app-pause-card {
	background: #fff;
	border-radius: clamp(0.75rem, 1.6vw, 1.35rem);
	box-shadow: 0 clamp(0.35rem, 0.8vw, 0.75rem) clamp(1.5rem, 3vw, 2.25rem) rgba(27, 29, 61, 0.08);
	padding: clamp(2rem, 5vw, 3.5rem);
	border: 1px solid var(--ppdncs-border);
	text-align: center;
	max-width: min(96vw, 40rem);
	margin-left: auto;
	margin-right: auto;
}

.ppdncs-app-phase--pause .ppdncs-step1a-title {
	margin-top: 0;
}

.ppdncs-app-pause-card p {
	margin: 0 0 clamp(0.85rem, 2vw, 1.25rem);
	line-height: 1.65;
}

.ppdncs-app-pause-card p:last-child {
	margin-bottom: 0;
}

.ppdncs-app-pause-note {
	font-size: clamp(0.78rem, 0.95vw, 0.88rem);
	color: var(--ppdncs-muted);
	font-weight: 600;
}

.ppdncs-app-phase--exam-pause .ppdncs-app-pause-card {
	background: #fff;
	border-radius: clamp(0.75rem, 1.6vw, 1.35rem);
	box-shadow: 0 clamp(0.35rem, 0.8vw, 0.75rem) clamp(1.5rem, 3vw, 2.25rem) rgba(27, 29, 61, 0.08);
	padding: clamp(2rem, 5vw, 3.5rem);
	border: 1px solid var(--ppdncs-border);
	text-align: center;
	max-width: min(96vw, 40rem);
	margin-left: auto;
	margin-right: auto;
}

.ppdncs-app-phase--exam-pause .ppdncs-step1a-title {
	margin-top: 0;
}

/* Step 3 — background check payment */
.ppdncs-step3-layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(1.5rem, 4vw, 2.5rem);
	align-items: stretch;
	max-width: min(96vw, 72rem);
	margin: 0 auto;
	padding-bottom: clamp(1.5rem, 4vw, 3rem);
}

@media (min-width: 56em) {
	.ppdncs-step3-layout {
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
		gap: 0;
		min-height: clamp(22rem, 50vh, 36rem);
	}
}

.ppdncs-step3-visual {
	position: relative;
	overflow: hidden;
	min-height: clamp(14rem, 38vw, 22rem);
	border-radius: clamp(0.75rem, 1.6vw, 1.25rem);
	background: linear-gradient(135deg, #e8ecf5 0%, #d4daf0 50%, #c5cde8 100%);
	background-size: cover;
	background-position: center;
}

.ppdncs-step3-visual__img {
	display: block;
	width: 100%;
	height: 100%;
	min-height: clamp(14rem, 38vw, 22rem);
	object-fit: cover;
	object-position: center center;
}

@media (min-width: 56em) {
	.ppdncs-step3-visual {
		min-height: 0;
		height: 100%;
		align-self: stretch;
	}

	.ppdncs-step3-visual__img {
		position: absolute;
		inset: 0;
		min-height: 100%;
		width: 100%;
		height: 100%;
	}
}

.ppdncs-step3-panel {
	background: #fff;
	padding: clamp(1.75rem, 4vw, 3rem) clamp(1.5rem, 4vw, 3.5rem);
	display: flex;
	flex-direction: column;
	justify-content: center;
}

@media (min-width: 56em) {
	.ppdncs-step3-panel {
		padding: clamp(2.5rem, 5vw, 4rem) clamp(2rem, 5vw, 4.5rem);
	}
}

.ppdncs-step3-title {
	margin-top: 0.35rem;
	margin-bottom: clamp(1rem, 2vw, 1.5rem);
	font-size: clamp(1.5rem, 3vw, 2.35rem);
}

.ppdncs-step3-copy p {
	margin: 0 0 clamp(0.85rem, 1.8vw, 1.15rem);
	line-height: 1.65;
	color: var(--ppdncs-text);
}

.ppdncs-step3-product-label {
	margin: clamp(1.25rem, 2.5vw, 1.75rem) 0 0.35rem;
	font-weight: 700;
	color: var(--ppdncs-navy-soft);
	font-size: clamp(0.95rem, 1.2vw, 1.05rem);
}

.ppdncs-step3-price {
	margin: 0;
	font-size: clamp(2.25rem, 5vw, 3.25rem);
	font-weight: 800;
	color: var(--ppdncs-navy);
	letter-spacing: -0.03em;
	line-height: 1.1;
}

.ppdncs-step3-price-note {
	margin: 0.35rem 0 clamp(1.25rem, 2.5vw, 1.75rem);
	font-size: clamp(0.8rem, 1vw, 0.92rem);
	color: var(--ppdncs-muted);
	font-weight: 600;
}

.ppdncs-step3-pay-btn {
	appearance: none;
	border: none;
	cursor: pointer;
	align-self: flex-start;
	padding: clamp(0.85rem, 1.8vw, 1.1rem) clamp(2.25rem, 5vw, 3.5rem);
	border-radius: 999px;
	font-family: inherit;
	font-weight: 800;
	font-size: clamp(0.85rem, 1.1vw, 1rem);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: #fff;
	background: linear-gradient(180deg, var(--ppdncs-gold-bright) 0%, var(--ppdncs-gold) 100%);
	box-shadow: 0 0.35rem 1rem rgba(197, 160, 89, 0.35);
	transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.ppdncs-step3-pay-btn:hover:not(:disabled) {
	transform: translateY(-1px);
	box-shadow: 0 0.5rem 1.25rem rgba(197, 160, 89, 0.45);
}

.ppdncs-step3-pay-btn:disabled {
	opacity: 0.65;
	cursor: not-allowed;
}

.ppdncs-app-textarea {
	width: 100%;
	min-height: clamp(8rem, 22vw, 14rem);
	padding: clamp(0.65rem, 1.1vw, 0.85rem) clamp(0.85rem, 1.4vw, 1.1rem);
	border: 1px solid var(--ppdncs-border);
	border-radius: clamp(0.55rem, 1vw, 1.1rem);
	background: #fff;
	color: var(--ppdncs-text);
	font-size: clamp(0.85rem, 1.05vw, 1rem);
	font-family: inherit;
	resize: vertical;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.ppdncs-app-textarea:focus {
	outline: none;
	border-color: rgba(197, 160, 89, 0.75);
	box-shadow: 0 0 0 clamp(0.12rem, 0.22vw, 0.2rem) rgba(197, 160, 89, 0.25);
}

/* Step 1B uploads: Squarespace-style dashed drop zone; native input visually hidden off-canvas */
.ppdncs-app-upload-shell {
	position: relative;
	width: 100%;
}

.ppdncs-app-file-native {
	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;
}

.ppdncs-app-upload-shell .ppdncs-app-file-zone {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: clamp(0.4rem, 1vw, 0.65rem);
	min-height: clamp(5.5rem, 15vw, 9.25rem);
	width: 100%;
	padding: clamp(1.2rem, 3vw, 2rem) clamp(1rem, 2.5vw, 1.75rem);
	margin: 0;
	border: 2px dashed rgba(27, 29, 61, 0.22);
	border-radius: clamp(0.45rem, 0.9vw, 0.65rem);
	background: #fafbfc;
	cursor: pointer;
	transition: border-color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

.ppdncs-app-upload-shell .ppdncs-app-file-zone:hover,
.ppdncs-app-upload-shell .ppdncs-app-file-zone:focus-within {
	border-color: rgba(197, 160, 89, 0.65);
	background: #fff;
	box-shadow: 0 0 0 clamp(0.12rem, 0.28vw, 0.22rem) rgba(197, 160, 89, 0.2);
}

.ppdncs-app-upload-shell .ppdncs-app-file-zone.has-files {
	border-color: rgba(27, 29, 61, 0.28);
	background: #fff;
}

.ppdncs-app-upload-shell .ppdncs-app-file-placeholder {
	font-size: clamp(1.65rem, 4vw, 2.4rem);
	font-weight: 300;
	color: rgba(27, 29, 61, 0.42);
	line-height: 1;
	user-select: none;
}

.ppdncs-app-upload-shell .ppdncs-app-file-label {
	font-weight: 600;
	color: var(--ppdncs-navy);
	font-size: clamp(0.8rem, 1.05vw, 0.95rem);
	text-align: center;
	word-break: break-word;
	max-width: 100%;
	padding: 0 clamp(0.5rem, 2vw, 1rem);
	user-select: none;
}

.ppdncs-app-file-status {
	margin: clamp(0.4rem, 1.05vw, 0.65rem) 0 0;
	padding: 0 clamp(0.25rem, 0.5vw, 0.35rem);
	font-size: clamp(0.78rem, 0.95vw, 0.88rem);
	color: var(--ppdncs-muted);
	font-weight: 500;
	line-height: 1.45;
	word-break: break-word;
}

.ppdncs-app-file-status[hidden] {
	display: none !important;
}

.ppdncs-app-actions-1b {
	margin-top: clamp(1.5rem, 3vw, 2.25rem);
	text-align: center;
}

.ppdncs-app-actions-1b .ppdncs-app-submit-1b {
	display: inline-flex;
	justify-content: center;
}

.ppdncs-app-terms {
	margin: clamp(1rem, 2.2vw, 1.5rem) 0 0;
	font-size: clamp(0.72rem, 0.9vw, 0.85rem);
	color: var(--ppdncs-muted);
	line-height: 1.5;
}

.ppdncs-app-terms a {
	color: var(--ppdncs-navy);
	font-weight: 600;
}

.ppdncs-app-wrap .ppdncs-app-notice[hidden] {
	display: none !important;
}

.ppdncs-app-wrap .ppdncs-app-notice:not([hidden]) {
	display: block;
}

/* —— Step 1B: same two-column grid as 1A (equal width) —— */
.ppdncs-app-1b-phase {
	background: transparent;
	padding: 0;
	margin: 0;
	border-radius: 0;
}

.ppdncs-app-1b-grid {
	align-items: start;
}

@media (min-width: 56em) {
	.ppdncs-step1a-grid.ppdncs-app-1b-grid {
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
		gap: clamp(2rem, 5.5vw, 4.75rem);
	}
}

.ppdncs-app-1b-sidebar .ppdncs-step1a-intro p,
.ppdncs-app-1b-sidebar .ppdncs-step1a-list {
	max-width: 38rem;
}

.ppdncs-app-1b-sidebar-lead {
	margin-top: clamp(0.5rem, 1.5vw, 1rem);
}

.ppdncs-app-1b-checklist li {
	line-height: 1.55;
}

.ppdncs-app-1b-card {
	padding: clamp(1.65rem, 3.8vw, 2.85rem);
	background: #fff;
	box-shadow: 0 clamp(0.22rem, 0.55vw, 0.4rem) clamp(1rem, 2.8vw, 2.25rem) rgba(27, 29, 61, 0.06);
	border: 1px solid rgba(27, 29, 61, 0.1);
}

.ppdncs-app-1b-sidebar .ppdncs-step1a-kicker {
	font-size: clamp(1.1rem, 2vw, 1.5rem);
}

.ppdncs-app-1b-sidebar .ppdncs-step1a-title {
	font-size: clamp(1.85rem, 3.8vw, 2.85rem);
	margin-top: clamp(0.65rem, 1.5vw, 1rem);
}

.ppdncs-app-field-block {
	margin-bottom: clamp(1.5rem, 3.2vw, 2.35rem);
	padding-bottom: 0;
}

.ppdncs-app-field-label {
	display: block;
	font-weight: 800;
	color: var(--ppdncs-navy);
	margin-bottom: clamp(0.5rem, 1.1vw, 0.75rem);
	font-size: clamp(0.88rem, 1.08vw, 1rem);
	letter-spacing: -0.01em;
}

.ppdncs-app-instructions,
.ppdncs-app-instructions p {
	margin: 0 0 clamp(0.65rem, 1.4vw, 0.95rem);
	color: var(--ppdncs-text);
	font-size: clamp(0.82rem, 1.02vw, 0.98rem);
	line-height: 1.65;
	max-width: 42rem;
}

.ppdncs-app-instructions--muted {
	color: var(--ppdncs-muted);
}

.ppdncs-app-instructions-stack p {
	margin-bottom: clamp(0.4rem, 1vw, 0.65rem);
}

.ppdncs-app-instructions-stack p:last-child {
	margin-bottom: 0;
}

.ppdncs-app-instructions a {
	color: var(--ppdncs-navy);
	font-weight: 600;
	text-decoration: underline;
	text-underline-offset: 0.18em;
}

.ppdncs-app-instructions-list {
	margin: 0 0 clamp(0.85rem, 1.8vw, 1.15rem);
	padding-left: clamp(1.15rem, 2.2vw, 1.45rem);
	color: var(--ppdncs-text);
	font-size: clamp(0.82rem, 1.02vw, 0.98rem);
	line-height: 1.65;
	max-width: 42rem;
}

.ppdncs-app-instructions-list li {
	margin-bottom: clamp(0.35rem, 0.85vw, 0.5rem);
}

.ppdncs-app-instructions-list li::marker {
	color: var(--ppdncs-gold-bright);
}

.ppdncs-app-field-hint {
	margin: clamp(0.45rem, 1vw, 0.65rem) 0 0;
	font-size: clamp(0.74rem, 0.92vw, 0.86rem);
	color: var(--ppdncs-muted);
	font-style: italic;
	line-height: 1.5;
}

.ppdncs-app-upload-inline-warning {
	margin: clamp(0.5rem, 1.2vw, 0.75rem) 0 0;
	padding: clamp(0.45rem, 1vw, 0.6rem) clamp(0.65rem, 1.2vw, 0.85rem);
	font-size: clamp(0.78rem, 0.95vw, 0.88rem);
	font-weight: 600;
	color: #7a2a2a;
	background: rgba(180, 60, 60, 0.09);
	border: 1px solid rgba(180, 60, 60, 0.2);
	border-radius: clamp(0.45rem, 0.85vw, 0.65rem);
}

.ppdncs-app-upload-inline-warning[hidden] {
	display: none !important;
}

.ppdncs-app-upload-shell .ppdncs-app-file-zone.is-dragover {
	border-color: var(--ppdncs-gold-bright);
	background: rgba(212, 175, 55, 0.07);
	box-shadow: inset 0 0 0 clamp(0.12rem, 0.25vw, 0.18rem) rgba(197, 160, 89, 0.35);
}

/* Thumbnails: horizontal strip under drop zone */
.ppdncs-app-upload-shell .ppdncs-app-file-preview {
	display: flex;
	flex-wrap: nowrap;
	align-items: stretch;
	gap: clamp(0.45rem, 1.2vw, 0.85rem);
	margin-top: clamp(0.55rem, 1.4vw, 0.85rem);
	padding-bottom: clamp(0.25rem, 0.6vw, 0.4rem);
	overflow-x: auto;
	overflow-y: hidden;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
}

.ppdncs-app-thumb {
	position: relative;
	display: flex;
	flex-direction: column;
	flex: 0 0 auto;
	width: clamp(5.25rem, 13vw, 7.25rem);
	border-radius: clamp(0.45rem, 0.85vw, 0.65rem);
	overflow: hidden;
	border: 1px solid var(--ppdncs-border);
	background: #fff;
	box-shadow: 0 clamp(0.1rem, 0.25vw, 0.18rem) clamp(0.4rem, 1vw, 0.65rem) rgba(27, 29, 61, 0.06);
}

.ppdncs-app-thumb-visual {
	width: 100%;
	aspect-ratio: 4 / 3;
	background: #f0f2f7;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}

.ppdncs-app-thumb-visual img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ppdncs-app-thumb-visual--doc {
	background: linear-gradient(145deg, #e8ebf2 0%, #f4f6fa 100%);
}

.ppdncs-app-thumb-ext {
	font-weight: 800;
	font-size: clamp(0.72rem, 1vw, 0.88rem);
	color: var(--ppdncs-navy);
	letter-spacing: 0.04em;
}

.ppdncs-app-thumb-meta {
	padding: clamp(0.4rem, 0.9vw, 0.55rem) clamp(0.45rem, 1vw, 0.6rem);
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
	min-width: 0;
}

.ppdncs-app-thumb-name {
	font-size: clamp(0.68rem, 0.82vw, 0.78rem);
	font-weight: 600;
	color: var(--ppdncs-navy);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.ppdncs-app-thumb-size {
	font-size: clamp(0.62rem, 0.76vw, 0.72rem);
	color: var(--ppdncs-muted);
}

.ppdncs-app-thumb-remove {
	position: absolute;
	top: clamp(0.25rem, 0.65vw, 0.4rem);
	right: clamp(0.25rem, 0.65vw, 0.4rem);
	width: clamp(1.5rem, 3.5vw, 1.85rem);
	height: clamp(1.5rem, 3.5vw, 1.85rem);
	border: none;
	border-radius: 50%;
	background: rgba(27, 29, 61, 0.82);
	color: #fff;
	font-size: clamp(1rem, 2.2vw, 1.25rem);
	line-height: 1;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	transition: background 0.12s ease, transform 0.12s ease;
	z-index: 4;
}

.ppdncs-app-thumb-remove:hover,
.ppdncs-app-thumb-remove:focus {
	background: #8f1d1d;
	outline: none;
}

/* Per-field upload progress (mirrors overall XHR progress) */
.ppdncs-app-field-upload-progress {
	margin-top: clamp(0.45rem, 1.1vw, 0.7rem);
}

.ppdncs-app-field-upload-progress[hidden] {
	display: none !important;
}

.ppdncs-app-field-upload-track {
	height: clamp(0.26rem, 0.5vw, 0.36rem);
	background: rgba(27, 29, 61, 0.09);
	border-radius: 999px;
	overflow: hidden;
}

.ppdncs-app-field-upload-fill {
	height: 100%;
	width: 0;
	border-radius: 999px;
	background: linear-gradient(90deg, var(--ppdncs-navy) 0%, var(--ppdncs-gold-bright) 100%);
	transition: width 0.12s ease-out;
}

.ppdncs-app-field-upload-fill.is-indeterminate {
	width: 100% !important;
	background: linear-gradient(
		90deg,
		var(--ppdncs-navy) 0%,
		var(--ppdncs-gold-bright) 45%,
		var(--ppdncs-navy) 90%
	);
	background-size: 200% 100%;
	animation: ppdncs-upload-stripes 0.85s linear infinite;
}

/* Overall submit progress */
.ppdncs-app-submit-progress {
	margin: clamp(1.25rem, 2.8vw, 1.85rem) 0;
	padding: clamp(0.85rem, 1.8vw, 1.15rem);
	background: rgba(27, 29, 61, 0.04);
	border-radius: clamp(0.55rem, 1vw, 0.85rem);
	border: 1px solid var(--ppdncs-border);
}

.ppdncs-app-submit-progress-track {
	height: clamp(0.45rem, 0.9vw, 0.55rem);
	background: rgba(27, 29, 61, 0.1);
	border-radius: 999px;
	overflow: hidden;
}

.ppdncs-app-submit-progress-fill {
	height: 100%;
	width: 0;
	background: linear-gradient(90deg, var(--ppdncs-gold) 0%, var(--ppdncs-gold-bright) 100%);
	border-radius: 999px;
	transition: width 0.18s ease;
}

.ppdncs-app-submit-progress-fill.is-indeterminate {
	width: 100% !important;
	background: linear-gradient(
		90deg,
		var(--ppdncs-gold) 0%,
		var(--ppdncs-gold-bright) 40%,
		var(--ppdncs-gold) 80%
	);
	background-size: 200% 100%;
	animation: ppdncs-upload-stripes 1s linear infinite;
}

@keyframes ppdncs-upload-stripes {
	0% {
		background-position: 0% 0;
	}
	100% {
		background-position: 200% 0;
	}
}

.ppdncs-app-submit-progress-text {
	margin: clamp(0.5rem, 1.2vw, 0.75rem) 0 0;
	text-align: center;
	font-weight: 700;
	font-size: clamp(0.78rem, 0.95vw, 0.9rem);
	color: var(--ppdncs-navy);
}

.ppdncs-app-submit-progress[hidden] {
	display: none !important;
}

/* Stronger error alert (top bar) */
.ppdncs-step1a-notice--error {
	background: rgba(220, 100, 100, 0.12);
	color: #6b1c1c;
	border: 1px solid rgba(200, 80, 80, 0.35);
}

/* —— Step 2: exam cards (2 + 1 layout) —— */
.ppdncs-app-phase-step2 {
	padding: clamp(0.5rem, 2vw, 1.5rem) 0;
}

.ppdncs-step2-inner {
	max-width: 52rem;
	margin: 0 auto;
	text-align: center;
}

.ppdncs-step2-title {
	margin-top: clamp(0.35rem, 1vw, 0.65rem);
}

.ppdncs-step2-lead {
	margin: clamp(0.75rem, 2vw, 1.25rem) auto clamp(1.25rem, 3vw, 2rem);
	max-width: 36rem;
	color: var(--ppdncs-text);
	font-size: clamp(0.85rem, 1.05vw, 0.98rem);
	line-height: 1.6;
}

.ppdncs-step2-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(1rem, 2.5vw, 1.75rem);
	margin: 0 auto;
	max-width: 44rem;
}

@media (min-width: 40em) {
	.ppdncs-step2-grid {
		grid-template-columns: 1fr 1fr;
		align-items: stretch;
	}

	.ppdncs-step2-card--span {
		grid-column: 1 / -1;
		justify-self: center;
		width: min(100%, 22rem);
	}
}

.ppdncs-step2-card {
	background: #f0f2f5;
	border-radius: clamp(0.55rem, 1vw, 0.85rem);
	padding: clamp(1.35rem, 3vw, 2rem) clamp(1rem, 2.5vw, 1.5rem);
	box-shadow: 0 clamp(0.12rem, 0.35vw, 0.25rem) clamp(0.65rem, 1.8vw, 1.1rem) rgba(27, 29, 61, 0.06);
	border: 1px solid rgba(27, 29, 61, 0.08);
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: clamp(0.65rem, 1.5vw, 1rem);
}

.ppdncs-step2-card-title {
	margin: 0;
	font-size: clamp(0.95rem, 1.15vw, 1.08rem);
	font-weight: 800;
	color: var(--ppdncs-navy);
	line-height: 1.35;
	max-width: 16rem;
}

.ppdncs-step2-card-price {
	margin: 0;
	font-size: clamp(1.15rem, 2.2vw, 1.45rem);
	font-weight: 700;
	color: var(--ppdncs-navy-soft);
}

.ppdncs-step2-purchase {
	appearance: none;
	border: none;
	background: #1a1a1a;
	color: #fff;
	font-weight: 800;
	font-size: clamp(0.72rem, 0.9vw, 0.82rem);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	padding: clamp(0.55rem, 1.2vw, 0.75rem) clamp(1.35rem, 3vw, 2rem);
	border-radius: 999px;
	cursor: pointer;
	transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}

.ppdncs-step2-purchase:hover,
.ppdncs-step2-purchase:focus-visible {
	background: #000;
	box-shadow: 0 clamp(0.15rem, 0.4vw, 0.28rem) clamp(0.65rem, 1.6vw, 1rem) rgba(0, 0, 0, 0.25);
	transform: translateY(-1px);
	outline: none;
}

.ppdncs-step2-purchase:disabled {
	opacity: 0.55;
	cursor: not-allowed;
	transform: none;
	box-shadow: none;
}

.ppdncs-step2-stripe-note {
	margin-top: clamp(1.25rem, 3vw, 2rem);
	max-width: 32rem;
	margin-left: auto;
	margin-right: auto;
	color: var(--ppdncs-muted);
	font-size: clamp(0.72rem, 0.88vw, 0.82rem);
}

/* Written certification exams (PPD + NSN share the same inner wrapper class) */
.ppdncs-app-phase--ppd-exam .ppdncs-ppd-exam-inner,
.ppdncs-app-phase--nsn-exam .ppdncs-ppd-exam-inner {
	max-width: 52rem;
	margin: 0 auto;
	padding-bottom: clamp(1.5rem, 4vw, 3rem);
}

/* Full-width header image (Google Forms–style banner) */
.ppdncs-ppd-exam-banner {
	width: 100%;
	margin: 0 0 clamp(1.15rem, 2.8vw, 1.85rem);
	border-radius: clamp(0.45rem, 1vw, 0.65rem);
	overflow: hidden;
	border: 1px solid var(--ppdncs-border);
	box-shadow: 0 clamp(0.1rem, 0.3vw, 0.2rem) clamp(0.5rem, 1.4vw, 0.85rem) rgba(27, 29, 61, 0.07);
	line-height: 0;
	aspect-ratio: 4 / 1;
	background: #f0f2f5;
}

.ppdncs-ppd-exam-banner__img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center 35%;
}

.ppdncs-ppd-exam-page-title {
	margin-top: clamp(0.35rem, 1vw, 0.65rem);
}

.ppdncs-ppd-exam-lead-note {
	color: var(--ppdncs-muted);
	font-size: clamp(0.85rem, 1.05vw, 0.98rem);
	margin: 0 0 clamp(1.25rem, 3vw, 2rem);
	max-width: 40rem;
}

.ppdncs-ppd-exam-card {
	text-align: left;
}

.ppdncs-ppd-exam-html {
	margin-bottom: clamp(1rem, 2.5vw, 1.5rem);
	color: var(--ppdncs-text);
}

.ppdncs-ppd-exam-html p {
	margin: 0 0 clamp(0.65rem, 1.5vw, 1rem);
}

.ppdncs-ppd-exam-prose {
	margin: 0 0 clamp(0.5rem, 1.2vw, 0.75rem);
	line-height: 1.65;
	color: var(--ppdncs-text);
}

.ppdncs-ppd-exam-list-spaced {
	margin-bottom: clamp(0.25rem, 0.8vw, 0.45rem);
}

.ppdncs-ppd-exam-required-note {
	font-size: clamp(0.78rem, 0.95vw, 0.88rem);
	color: var(--ppdncs-muted);
	margin: 0 0 clamp(1rem, 2.5vw, 1.35rem);
}

.ppdncs-ppd-exam-section {
	margin-bottom: clamp(1rem, 2.5vw, 1.5rem);
	padding-bottom: clamp(0.75rem, 2vw, 1.25rem);
	border-bottom: 1px solid var(--ppdncs-border);
}

.ppdncs-ppd-exam-section-title {
	margin: 0 0 clamp(0.5rem, 1.2vw, 0.75rem);
	font-size: clamp(1rem, 1.35vw, 1.15rem);
	font-weight: 800;
	color: var(--ppdncs-navy);
}

.ppdncs-ppd-exam-field {
	margin-bottom: clamp(1.15rem, 2.8vw, 1.75rem);
}

.ppdncs-ppd-exam-label {
	display: block;
	font-weight: 700;
	color: var(--ppdncs-navy-soft);
	font-size: clamp(0.82rem, 1vw, 0.95rem);
	margin-bottom: clamp(0.35rem, 1vw, 0.55rem);
	line-height: 1.45;
}

.ppdncs-ppd-exam-req {
	color: #b45309;
	font-weight: 800;
}

.ppdncs-ppd-exam-hint {
	margin: 0 0 clamp(0.45rem, 1.2vw, 0.65rem);
	font-size: clamp(0.78rem, 0.95vw, 0.88rem);
	color: var(--ppdncs-muted);
	line-height: 1.5;
}

.ppdncs-ppd-exam-input,
.ppdncs-ppd-exam-textarea {
	width: 100%;
	border: 1px solid var(--ppdncs-border);
	border-radius: clamp(0.35rem, 0.8vw, 0.5rem);
	padding: clamp(0.55rem, 1.2vw, 0.75rem) clamp(0.65rem, 1.4vw, 0.85rem);
	font-family: inherit;
	font-size: clamp(0.82rem, 1vw, 0.95rem);
	color: var(--ppdncs-text);
	background: #fff;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.ppdncs-ppd-exam-input:focus,
.ppdncs-ppd-exam-textarea:focus {
	outline: none;
	border-color: rgba(197, 160, 89, 0.85);
	box-shadow: 0 0 0 3px rgba(197, 160, 89, 0.2);
}

.ppdncs-ppd-exam-textarea {
	min-height: 6rem;
	resize: vertical;
	line-height: 1.55;
}

.ppdncs-ppd-exam-field--radio,
.ppdncs-ppd-exam-field--checkboxes {
	border: 1px solid var(--ppdncs-border);
	border-radius: clamp(0.45rem, 1vw, 0.65rem);
	padding: clamp(0.75rem, 2vw, 1.1rem) clamp(0.85rem, 2vw, 1.15rem);
	background: rgba(255, 255, 255, 0.65);
}

.ppdncs-ppd-exam-field--radio .ppdncs-ppd-exam-label,
.ppdncs-ppd-exam-field--checkboxes .ppdncs-ppd-exam-label {
	margin-bottom: clamp(0.5rem, 1.2vw, 0.75rem);
	padding: 0;
}

.ppdncs-ppd-exam-choice {
	display: flex;
	align-items: flex-start;
	gap: clamp(0.45rem, 1vw, 0.65rem);
	margin: 0 0 clamp(0.45rem, 1.1vw, 0.65rem);
	font-size: clamp(0.8rem, 0.98vw, 0.92rem);
	color: var(--ppdncs-text);
	line-height: 1.45;
	cursor: pointer;
}

.ppdncs-ppd-exam-choice:last-child {
	margin-bottom: 0;
}

.ppdncs-ppd-exam-choice input {
	margin-top: 0.2em;
	flex-shrink: 0;
	accent-color: var(--ppdncs-navy);
}

.ppdncs-ppd-exam-actions {
	margin-top: clamp(1.5rem, 3.5vw, 2.25rem);
	padding-top: clamp(1rem, 2.5vw, 1.5rem);
	border-top: 1px solid var(--ppdncs-border);
	text-align: center;
}

.ppdncs-ppd-exam-submit {
	min-width: min(100%, 14rem);
}

/* Step 4 — code of conduct + Step 5 cert fee column */
.ppdncs-step4-stack {
	max-width: 72rem;
	margin: 0 auto;
	padding: clamp(0.5rem, 2vw, 1rem) 0 clamp(1.5rem, 4vw, 2.5rem);
}

.ppdncs-step4-header {
	text-align: center;
	margin-bottom: clamp(1.25rem, 3vw, 2rem);
}

.ppdncs-step4-hero {
	margin: 0 auto clamp(1rem, 2.5vw, 1.5rem);
	max-width: 52rem;
	border-radius: clamp(0.5rem, 1.2vw, 0.85rem);
	overflow: hidden;
	box-shadow: 0 0.5rem 2rem rgba(27, 29, 61, 0.12);
}

.ppdncs-step4-hero__img {
	display: block;
	width: 100%;
	height: auto;
	vertical-align: middle;
}

.ppdncs-step4-title {
	margin-bottom: clamp(0.75rem, 2vw, 1.25rem);
}

.ppdncs-step4-intro {
	max-width: 48rem;
	margin: 0 auto;
	text-align: left;
}

.ppdncs-step4-intro p {
	margin: 0 0 clamp(0.65rem, 1.5vw, 0.9rem);
	font-size: clamp(0.88rem, 1.05vw, 1rem);
	line-height: 1.55;
	color: var(--ppdncs-text);
}

.ppdncs-step4-pdf-placeholder {
	font-style: italic;
	color: var(--ppdncs-muted);
}

.ppdncs-step4-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(1.5rem, 4vw, 2.5rem);
	align-items: start;
	margin-top: clamp(1rem, 3vw, 1.75rem);
}

@media (min-width: 900px) {
	.ppdncs-step4-grid {
		grid-template-columns: 1fr minmax(16rem, 22rem);
		gap: clamp(2rem, 4vw, 3rem);
	}
}

.ppdncs-step4-form-title {
	margin: 0 0 clamp(1rem, 2vw, 1.35rem);
	font-size: clamp(1.05rem, 1.35vw, 1.25rem);
	color: var(--ppdncs-navy);
}

.ppdncs-step4-file-field {
	position: relative;
}

.ppdncs-step4-file-label {
	display: block;
	font-weight: 600;
	margin-bottom: 0.5rem;
	color: var(--ppdncs-navy);
	font-size: clamp(0.82rem, 1vw, 0.95rem);
}

.ppdncs-step4-file-drop {
	display: block;
	cursor: pointer;
	margin: 0;
}

.ppdncs-step4-file-input {
	position: absolute;
	width: 1px;
	height: 1px;
	opacity: 0;
	overflow: hidden;
}

.ppdncs-step4-file-drop-inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.35rem;
	min-height: clamp(5.5rem, 14vw, 8.5rem);
	padding: clamp(1rem, 2.5vw, 1.5rem);
	border: 2px dashed rgba(27, 29, 61, 0.22);
	border-radius: clamp(0.45rem, 0.9vw, 0.65rem);
	background: #fafbfc;
	transition: border-color 0.2s ease, background 0.2s ease;
}

.ppdncs-step4-file-drop:hover .ppdncs-step4-file-drop-inner,
.ppdncs-step4-file-drop:focus-within .ppdncs-step4-file-drop-inner {
	border-color: rgba(197, 160, 89, 0.65);
	background: #fff;
}

.ppdncs-step4-file-plus {
	font-size: clamp(1.75rem, 4vw, 2.25rem);
	font-weight: 300;
	color: rgba(27, 29, 61, 0.45);
	line-height: 1;
}

.ppdncs-step4-file-hint {
	font-weight: 600;
	font-size: clamp(0.82rem, 1vw, 0.95rem);
	color: var(--ppdncs-navy);
}

.ppdncs-step4-file-name {
	margin: 0.4rem 0 0;
	font-size: clamp(0.78rem, 0.95vw, 0.88rem);
	color: var(--ppdncs-muted);
	word-break: break-word;
}

.ppdncs-step4-conduct-actions {
	margin-top: clamp(1.25rem, 2.5vw, 1.75rem);
}

.ppdncs-step4-agree-btn {
	min-width: min(100%, 12rem);
	background: linear-gradient(180deg, #2a2f5c 0%, var(--ppdncs-navy) 100%);
	color: #fff;
	border: none;
	border-radius: 999px;
	padding: clamp(0.75rem, 1.5vw, 0.95rem) clamp(2rem, 4vw, 2.75rem);
	font-weight: 800;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	cursor: pointer;
}

.ppdncs-step4-agree-btn:hover:not(:disabled) {
	filter: brightness(1.06);
}

.ppdncs-step4-conduct-done {
	margin: 0;
	padding: clamp(0.85rem, 2vw, 1.1rem);
	background: rgba(197, 160, 89, 0.12);
	border-radius: clamp(0.45rem, 1vw, 0.65rem);
	font-size: clamp(0.88rem, 1.05vw, 0.98rem);
	line-height: 1.5;
	color: var(--ppdncs-navy);
}

.ppdncs-step4-col--pay {
	padding: clamp(1.25rem, 3vw, 1.75rem);
	border-radius: clamp(0.55rem, 1.2vw, 0.85rem);
	background: linear-gradient(165deg, #fafbfd 0%, #f3f5fa 100%);
	border: 1px solid var(--ppdncs-border);
}

.ppdncs-step4-cert-kicker {
	margin: 0 0 0.35rem;
	font-size: clamp(0.78rem, 0.95vw, 0.88rem);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--ppdncs-navy);
}

.ppdncs-step4-cert-price {
	margin: 0;
	font-size: clamp(1.85rem, 4vw, 2.35rem);
	font-weight: 800;
	color: var(--ppdncs-navy);
	line-height: 1.1;
}

.ppdncs-step4-cert-note {
	margin: 0.35rem 0 clamp(1rem, 2.5vw, 1.5rem);
	font-size: clamp(0.8rem, 1vw, 0.92rem);
	color: var(--ppdncs-muted);
	font-weight: 600;
}

.ppdncs-step4-cert-pay-btn {
	appearance: none;
	border: none;
	cursor: pointer;
	width: 100%;
	padding: clamp(0.85rem, 1.8vw, 1.05rem) clamp(1.5rem, 3vw, 2rem);
	border-radius: 999px;
	font-family: inherit;
	font-weight: 800;
	font-size: clamp(0.85rem, 1.1vw, 1rem);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: #fff;
	background: linear-gradient(180deg, var(--ppdncs-gold-bright) 0%, var(--ppdncs-gold) 100%);
	box-shadow: 0 0.35rem 1rem rgba(197, 160, 89, 0.35);
	transition: transform 0.15s ease, box-shadow 0.15s ease, opacity 0.15s ease;
}

.ppdncs-step4-cert-pay-btn:hover:not(:disabled) {
	transform: translateY(-1px);
	box-shadow: 0 0.5rem 1.25rem rgba(197, 160, 89, 0.45);
}

.ppdncs-step4-cert-pay-btn:disabled {
	opacity: 0.55;
	cursor: not-allowed;
}

.ppdncs-app-pause-card--closed {
	border-color: rgba(179, 45, 46, 0.25);
}
