/* ICON Verification System — Public Styles v1.2.1 */

/* ── 1. Design Tokens ─────────────────────────────────────── */

:root {
	--icon-vs-primary:        #ffd08e;
	--icon-vs-primary-dark:   #e6b668;
	--icon-vs-primary-glow:   rgba(255, 208, 142, 0.22);
	--icon-vs-primary-border: rgba(255, 208, 142, 0.22);
	--icon-vs-valid:          #4ade80;
	--icon-vs-valid-dim:      rgba(74, 222, 128, 0.12);
	--icon-vs-invalid:        #f87171;
	--icon-vs-invalid-dim:    rgba(248, 113, 113, 0.12);
	--icon-vs-text:           #f0f0f0;
	--icon-vs-text-secondary: #8b949e;
	--icon-vs-text-muted:     rgba(240, 240, 240, 0.35);
	--icon-vs-border:         rgba(255, 208, 142, 0.15);
	--icon-vs-border-subtle:  rgba(255, 255, 255, 0.07);
	--icon-vs-surface:        #141414;
	--icon-vs-surface-raised: #1c1c1e;
	--icon-vs-surface-deep:   #0f0f0f;
	--icon-vs-bg:             #0b0b0b;
	--icon-vs-radius:         14px;
	--icon-vs-shadow:         0 4px 20px rgba(0, 0, 0, 0.55);
	--icon-vs-shadow-lg:      0 20px 60px rgba(0, 0, 0, 0.8);
	--icon-vs-shadow-card:    0 0 0 1px rgba(255, 208, 142, 0.1), 0 20px 60px rgba(0, 0, 0, 0.8);
}

/* ── 2. Reset ─────────────────────────────────────────────── */

*, *::before, *::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

/* ── 3. Card Wrapper ──────────────────────────────────────── */

.icon-vs-card {
	background: var(--icon-vs-surface);
	border-radius: var(--icon-vs-radius);
	border: 1px solid var(--icon-vs-border);
	box-shadow: var(--icon-vs-shadow-card);
	overflow: hidden;
	animation: icon-vs-fade-in 0.45s ease both;
	color: var(--icon-vs-text);
}

@keyframes icon-vs-fade-in {
	from { opacity: 0; transform: translateY(10px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* ── 4. Certificate Header (3-col: badge | ID | brand) ─────── */

.icon-vs-cert-header {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 20px;
	padding: 22px 28px;
	background: linear-gradient(135deg, #0a0a0a 0%, #111827 100%);
	position: relative;
}

.icon-vs-cert-header::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 1px;
	background: linear-gradient(90deg, transparent 0%, var(--icon-vs-primary) 50%, transparent 100%);
	opacity: 0.5;
}

/* LEFT — premium seal badge */
.icon-vs-cert-badge {
	display: flex;
	align-items: center;
	gap: 10px;
}

.icon-vs-cert-badge-emblem {
	width: 46px;
	height: 46px;
	flex-shrink: 0;
}

.icon-vs-cert-badge-emblem svg {
	width: 100%;
	height: 100%;
}

.icon-vs-cert-badge--valid   .icon-vs-cert-badge-emblem {
	color: var(--icon-vs-primary);
	filter: drop-shadow(0 0 8px rgba(255, 208, 142, 0.4));
}

.icon-vs-cert-badge--invalid .icon-vs-cert-badge-emblem {
	color: var(--icon-vs-invalid);
}

.icon-vs-cert-badge-text {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.icon-vs-cert-badge-label {
	font-size: 0.9375rem;
	font-weight: 700;
	line-height: 1.2;
}

.icon-vs-cert-badge--valid   .icon-vs-cert-badge-label { color: var(--icon-vs-primary); }
.icon-vs-cert-badge--invalid .icon-vs-cert-badge-label { color: var(--icon-vs-invalid); }

.icon-vs-cert-badge-sub {
	font-size: 0.625rem;
	color: var(--icon-vs-text-muted);
	line-height: 1.3;
	text-transform: uppercase;
	letter-spacing: 0.07em;
}

/* CENTER — verification ID pill */
.icon-vs-cert-id {
	text-align: center;
	padding: 10px 18px;
	background: rgba(255, 208, 142, 0.06);
	border: 1px solid var(--icon-vs-primary-border);
	border-radius: 10px;
	flex-shrink: 0;
}

.icon-vs-cert-id-label {
	font-size: 0.5625rem;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--icon-vs-primary);
	margin-bottom: 4px;
}

.icon-vs-cert-id-value {
	font-size: 1rem;
	font-weight: 700;
	font-family: 'Courier New', Courier, monospace;
	color: var(--icon-vs-text);
	letter-spacing: 0.1em;
}

/* RIGHT — brand logo */
.icon-vs-cert-brand {
	text-align: right;
}

.icon-vs-cert-logo {
	display: inline-flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 4px;
}

.icon-vs-cert-logo-name {
	font-size: 0.875rem;
	font-weight: 800;
	color: var(--icon-vs-primary);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	line-height: 1;
}

.icon-vs-cert-logo-tag {
	font-size: 0.5rem;
	font-weight: 600;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--icon-vs-text-muted);
}

/* ── 5. Certificate Body (2-col: image | details) ─────────── */

.icon-vs-cert-body {
	display: grid;
	grid-template-columns: 1fr 1.7fr;
}

/* Left: image column */
.icon-vs-cert-image-col {
	padding: 28px;
	background: var(--icon-vs-surface-deep);
	border-right: 1px solid var(--icon-vs-border-subtle);
	display: flex;
	align-items: flex-start;
	justify-content: center;
}

.icon-vs-cert-frame {
	width: 100%;
	border-radius: 8px;
	overflow: hidden;
	background: #1c1c1e;
	box-shadow:
		0 0 0 2px var(--icon-vs-primary),
		0 0 0 5px rgba(255, 208, 142, 0.08),
		0 12px 32px rgba(0, 0, 0, 0.65);
}

.icon-vs-cert-frame img,
.icon-vs-item-image {
	width: 100%;
	height: auto;
	display: block;
	object-fit: cover;
}

.icon-vs-cert-image-col--empty .icon-vs-cert-frame-empty {
	width: 100%;
	aspect-ratio: 3 / 4;
	background: #1a1a1a;
	border-radius: 8px;
	border: 1px dashed rgba(255, 208, 142, 0.18);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 12px;
	color: rgba(255, 255, 255, 0.18);
}

.icon-vs-cert-frame-empty svg  { width: 40px; height: 40px; }
.icon-vs-cert-frame-empty span { font-size: 0.8125rem; font-weight: 500; }

/* Right: details column */
.icon-vs-cert-details-col {
	padding: 28px;
	display: flex;
	flex-direction: column;
	gap: 18px;
}

/* ── 6. Certificate Details ───────────────────────────────── */

.icon-vs-item-name {
	font-size: 1.375rem;
	font-weight: 700;
	letter-spacing: -0.02em;
	line-height: 1.3;
	color: var(--icon-vs-text);
}

.icon-vs-details-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px;
}

.icon-vs-detail-item {
	display: flex;
	flex-direction: column;
	gap: 3px;
}

.icon-vs-detail-label {
	font-size: 0.625rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--icon-vs-text-secondary);
}

.icon-vs-detail-value {
	font-size: 0.9375rem;
	font-weight: 500;
	color: var(--icon-vs-text);
}

.icon-vs-description {
	padding: 14px;
	background: rgba(255, 255, 255, 0.04);
	border-radius: 10px;
	border: 1px solid var(--icon-vs-border-subtle);
}

.icon-vs-description h3 {
	font-size: 0.625rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--icon-vs-text-secondary);
	margin-bottom: 7px;
}

.icon-vs-description p {
	font-size: 0.875rem;
	color: var(--icon-vs-text);
	line-height: 1.7;
}

/* Certification code block */
.icon-vs-cert-code {
	background: linear-gradient(135deg, #0a0a0a 0%, #111827 100%);
	border: 1px solid var(--icon-vs-primary-border);
	border-radius: 10px;
	padding: 14px 18px;
	text-align: center;
}

.icon-vs-cert-label {
	font-size: 0.5625rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--icon-vs-primary);
	margin-bottom: 5px;
}

.icon-vs-cert-value {
	font-size: 1.125rem;
	font-weight: 700;
	font-family: 'Courier New', Courier, monospace;
	color: var(--icon-vs-text);
	letter-spacing: 0.1em;
}

/* ── 7. Certificate Footer ────────────────────────────────── */

.icon-vs-cert-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 12px 28px;
	border-top: 1px solid var(--icon-vs-border-subtle);
	background: var(--icon-vs-surface-deep);
	gap: 16px;
}

.icon-vs-cert-footer-brand {
	display: flex;
	align-items: center;
	gap: 7px;
	font-size: 0.8125rem;
	color: var(--icon-vs-text-secondary);
	font-weight: 500;
}

.icon-vs-shield-icon {
	width: 16px;
	height: 16px;
	color: var(--icon-vs-primary);
}

.icon-vs-cert-footer-meta {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 2px;
}

.icon-vs-cert-timestamp {
	font-size: 0.6875rem;
	color: var(--icon-vs-text-muted);
}

/* ── 8. Action Buttons ────────────────────────────────────── */

.icon-vs-action-btns {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 10px;
	padding: 14px 28px;
	border-top: 1px solid var(--icon-vs-border-subtle);
	background: var(--icon-vs-surface);
}

/* Button base */
.icon-vs-btn {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	padding: 9px 16px;
	border-radius: 8px;
	font-size: 0.875rem;
	font-weight: 600;
	cursor: pointer;
	transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
	border: 1px solid transparent;
	font-family: inherit;
	text-decoration: none;
	white-space: nowrap;
	line-height: 1;
}

.icon-vs-btn:active { opacity: 0.8; }

.icon-vs-btn svg {
	width: 14px;
	height: 14px;
	flex-shrink: 0;
}

.icon-vs-btn-primary {
	background: var(--icon-vs-primary);
	color: #0b0b0b;
	border-color: var(--icon-vs-primary);
}

.icon-vs-btn-primary:hover {
	background: var(--icon-vs-primary-dark);
	border-color: var(--icon-vs-primary-dark);
	color: #0b0b0b;
	text-decoration: none;
}

.icon-vs-btn-outline {
	background: transparent;
	color: var(--icon-vs-text);
	border-color: var(--icon-vs-border-subtle);
}

.icon-vs-btn-outline:hover {
	background: rgba(255, 255, 255, 0.06);
	border-color: rgba(255, 255, 255, 0.14);
	color: var(--icon-vs-text);
	text-decoration: none;
}

/* ── 9. Not-Found / Error / Loading ───────────────────────── */

.icon-vs-not-found {
	padding: 56px 40px;
	text-align: center;
	animation: icon-vs-fade-in 0.45s ease both;
}

.icon-vs-not-found-icon {
	width: 72px;
	height: 72px;
	margin: 0 auto 20px;
	color: var(--icon-vs-text-secondary);
	opacity: 0.45;
}

.icon-vs-not-found-icon svg { width: 100%; height: 100%; }

.icon-vs-not-found h2 {
	font-size: 1.625rem;
	font-weight: 700;
	letter-spacing: -0.02em;
	color: var(--icon-vs-text);
	margin-bottom: 10px;
}

.icon-vs-not-found-code {
	font-size: 0.9375rem;
	color: var(--icon-vs-text);
	margin-bottom: 6px;
}

.icon-vs-not-found-hint {
	font-size: 0.875rem;
	color: var(--icon-vs-text-secondary);
	max-width: 420px;
	margin: 0 auto 24px;
	line-height: 1.6;
}

.icon-vs-error {
	padding: 12px 16px;
	background: var(--icon-vs-invalid-dim);
	color: var(--icon-vs-invalid);
	border-radius: 8px;
	border: 1px solid rgba(248, 113, 113, 0.25);
	font-size: 0.875rem;
}

.icon-vs-loading {
	text-align: center;
	padding: 48px 28px;
	background: var(--icon-vs-surface);
	border-radius: var(--icon-vs-radius);
	border: 1px solid var(--icon-vs-border);
	animation: icon-vs-fade-in 0.3s ease both;
}

.icon-vs-loading p {
	margin-top: 14px;
	font-size: 0.9375rem;
	color: var(--icon-vs-text-secondary);
	font-weight: 500;
}

.icon-vs-spinner {
	width: 40px;
	height: 40px;
	margin: 0 auto;
	border: 3px solid var(--icon-vs-border-subtle);
	border-top-color: var(--icon-vs-primary);
	border-radius: 50%;
	animation: icon-vs-spin 0.7s linear infinite;
}

@keyframes icon-vs-spin { to { transform: rotate(360deg); } }

/* Field note */
.icon-vs-field-note {
	font-size: 0.8125rem;
	color: var(--icon-vs-text-secondary);
	margin-top: 8px;
	word-break: break-all;
}

.icon-vs-field-note code {
	background: rgba(255, 255, 255, 0.07);
	padding: 2px 6px;
	border-radius: 4px;
	font-size: 0.8125rem;
	font-family: 'Courier New', Courier, monospace;
}

/* ── 10. Verification Form — Inline 3-column ──────────────── */

.icon-vs-form-wrap {
	width: 100%;
}

.icon-vs-form-inline {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 24px;
	padding: 20px 28px;
	background: var(--icon-vs-surface);
	border-radius: var(--icon-vs-radius);
	border: 1px solid var(--icon-vs-border);
	box-shadow: var(--icon-vs-shadow-card);
	animation: icon-vs-fade-in 0.4s ease both;
}

/* LEFT: brand icon column */
.icon-vs-form-brand-col {
	flex-shrink: 0;
}

.icon-vs-form-brand-icon {
	width: 52px;
	height: 52px;
	background: rgba(255, 208, 142, 0.08);
	border: 1px solid var(--icon-vs-primary-border);
	border-radius: 14px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--icon-vs-primary);
}

.icon-vs-form-brand-icon svg {
	width: 26px;
	height: 26px;
}

/* CENTER: heading + description */
.icon-vs-form-text-col {
	min-width: 0;
}

.icon-vs-form-title {
	font-size: 1rem;
	font-weight: 700;
	color: var(--icon-vs-text);
	letter-spacing: -0.01em;
	margin-bottom: 3px;
	line-height: 1.3;
}

.icon-vs-form-subtitle {
	font-size: 0.8125rem;
	color: var(--icon-vs-text-secondary);
	line-height: 1.5;
}

/* RIGHT: input + button */
.icon-vs-form-input-col {
	flex-shrink: 0;
}

.icon-vs-verify-form {
	/* form as grid cell */
}

.icon-vs-form-field {
	display: flex;
	gap: 8px;
	align-items: center;
}

.icon-vs-code-input {
	width: 196px;
	padding: 10px 14px;
	background: var(--icon-vs-surface-deep);
	border: 1px solid var(--icon-vs-border-subtle);
	border-radius: 8px;
	font-size: 0.9375rem;
	font-family: 'Courier New', Courier, monospace;
	color: var(--icon-vs-text);
	letter-spacing: 0.04em;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	outline: none;
}

.icon-vs-code-input:focus {
	border-color: var(--icon-vs-primary-border);
	box-shadow: 0 0 0 3px rgba(255, 208, 142, 0.1);
}

.icon-vs-code-input::placeholder {
	color: var(--icon-vs-text-muted);
	font-family: 'Courier New', Courier, monospace;
}

.icon-vs-verify-btn {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	padding: 10px 18px;
	background: var(--icon-vs-primary);
	color: #0b0b0b;
	border: none;
	border-radius: 8px;
	font-size: 0.875rem;
	font-weight: 700;
	cursor: pointer;
	transition: background 0.18s ease;
	white-space: nowrap;
	font-family: inherit;
	line-height: 1;
}

.icon-vs-verify-btn:hover { background: var(--icon-vs-primary-dark); }
.icon-vs-verify-btn:active { opacity: 0.85; }

.icon-vs-verify-btn svg {
	width: 15px;
	height: 15px;
}

.icon-vs-form-hint {
	margin-top: 6px;
	font-size: 0.6875rem;
	color: var(--icon-vs-text-muted);
	text-align: right;
}

.icon-vs-verify-result { margin-top: 20px; }

/* Popup mode: hide inline result container */
.icon-vs-form-wrap--popup .icon-vs-verify-result { display: none; }

/* ── 11. Popup System ─────────────────────────────────────── */

.icon-vs-popup {
	position: fixed;
	inset: 0;
	z-index: 999999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 16px;
}

.icon-vs-popup[hidden] { display: none; }

.icon-vs-popup-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.82);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	animation: icon-vs-backdrop-in 0.2s ease both;
}

@keyframes icon-vs-backdrop-in {
	from { opacity: 0; }
	to   { opacity: 1; }
}

.icon-vs-popup-modal {
	position: relative;
	z-index: 1;
	background: var(--icon-vs-surface);
	border: 1px solid var(--icon-vs-primary-border);
	border-radius: 18px;
	width: 100%;
	max-width: 720px;
	max-height: 92vh;
	overflow-y: auto;
	box-shadow:
		0 0 0 1px rgba(255, 208, 142, 0.08),
		0 32px 80px rgba(0, 0, 0, 0.92),
		0 0 60px rgba(255, 208, 142, 0.04);
	animation: icon-vs-modal-in 0.28s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

@keyframes icon-vs-modal-in {
	from { opacity: 0; transform: scale(0.93) translateY(10px); }
	to   { opacity: 1; transform: scale(1)    translateY(0);    }
}

/* Close button — gold themed */
.icon-vs-popup-close {
	position: absolute;
	top: 12px;
	right: 12px;
	z-index: 2;
	width: 34px;
	height: 34px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(255, 208, 142, 0.1);
	border: 1px solid rgba(255, 208, 142, 0.25);
	border-radius: 50%;
	cursor: pointer;
	color: var(--icon-vs-primary);
	transition: background 0.15s ease;
}

.icon-vs-popup-close:hover {
	background: rgba(255, 208, 142, 0.2);
}

.icon-vs-popup-close svg { width: 14px; height: 14px; }

/* Card inside popup */
.icon-vs-popup-body .icon-vs-card {
	border-radius: 18px;
	border: none;
	box-shadow: none;
}

/* ── 12. Responsive ───────────────────────────────────────── */

/* Form: collapse to stacked at 720px */
@media ( max-width: 720px ) {
	.icon-vs-form-inline {
		grid-template-columns: 1fr;
		gap: 14px;
		padding: 18px 20px;
	}

	.icon-vs-form-brand-col { display: none; }

	.icon-vs-code-input { width: 100%; }

	.icon-vs-form-field {
		flex-direction: column;
	}

	.icon-vs-verify-btn {
		width: 100%;
		justify-content: center;
	}

	.icon-vs-form-hint { text-align: center; }
}

/* Certificate: stack at 640px */
@media ( max-width: 640px ) {
	.icon-vs-cert-header {
		grid-template-columns: 1fr;
		gap: 14px;
		padding: 18px 20px;
		text-align: center;
	}

	.icon-vs-cert-badge  { justify-content: center; }
	.icon-vs-cert-brand  { text-align: center; }
	.icon-vs-cert-logo   { align-items: center; }
	.icon-vs-cert-id     { padding: 8px 14px; }

	.icon-vs-cert-body   { grid-template-columns: 1fr; }

	.icon-vs-cert-image-col {
		border-right: none;
		border-bottom: 1px solid var(--icon-vs-border-subtle);
		padding: 20px;
	}

	.icon-vs-cert-details-col { padding: 20px; }

	.icon-vs-cert-footer {
		flex-direction: column;
		align-items: flex-start;
		gap: 6px;
		padding: 12px 20px;
	}

	.icon-vs-cert-footer-meta { align-items: flex-start; }

	.icon-vs-action-btns {
		flex-direction: column;
		padding: 14px 20px;
	}

	.icon-vs-action-btns .icon-vs-btn {
		width: 100%;
		justify-content: center;
	}

	.icon-vs-not-found { padding: 40px 24px; }
}

/* ── 13. Print — removed: handled exclusively by isolated iframe/window in public.js ── */

/* ── 14. Premium Form [icon_verify_premium] ───────────────── */

.icon-vs-premium-wrap {
        position: relative;
        background:
                radial-gradient(ellipse at 50% -10%, rgba(255,208,142,0.07) 0%, transparent 60%),
                #0b0b0b;
        border: 1px solid rgba(255,208,142,0.55);
        border-radius: 20px;
        padding: 36px 36px 28px;
        max-width: 460px;
        margin: 0 auto;
        text-align: center;
        box-shadow:
                0 0 0 1px rgba(255,208,142,0.06),
                0 0 40px rgba(255,208,142,0.07),
                0 32px 80px rgba(0,0,0,0.9),
                inset 0 1px 0 rgba(255,208,142,0.1);
        animation: icon-vs-fade-in 0.45s ease both;
        overflow: hidden;
}

/* Corner accents */
.icon-vs-premium-corner {
        position: absolute;
        width: 18px;
        height: 18px;
        pointer-events: none;
}
.icon-vs-premium-corner--tl { top:10px; left:10px; border-top:2px solid rgba(255,208,142,0.6); border-left:2px solid rgba(255,208,142,0.6); border-radius:4px 0 0 0; }
.icon-vs-premium-corner--tr { top:10px; right:10px; border-top:2px solid rgba(255,208,142,0.6); border-right:2px solid rgba(255,208,142,0.6); border-radius:0 4px 0 0; }
.icon-vs-premium-corner--bl { bottom:10px; left:10px; border-bottom:2px solid rgba(255,208,142,0.6); border-left:2px solid rgba(255,208,142,0.6); border-radius:0 0 0 4px; }
.icon-vs-premium-corner--br { bottom:10px; right:10px; border-bottom:2px solid rgba(255,208,142,0.6); border-right:2px solid rgba(255,208,142,0.6); border-radius:0 0 4px 0; }

/* Logo */
.icon-vs-premium-logo-wrap { margin-bottom: 16px; }
.icon-vs-premium-logo-img {
        max-width: 260px;
        width: 100%;
        height: auto;
        display: block;
        margin: 0 auto;
        filter: drop-shadow(0 2px 14px rgba(255,208,142,0.22));
}

/* Heading */
.icon-vs-premium-heading {
        font-size: 1.25rem;
        font-weight: 700;
        letter-spacing: 0.06em;
        text-transform: uppercase;
        color: #f0f0f0;
        margin: 0 0 8px;
        line-height: 1.2;
}

/* Divider */
.icon-vs-premium-divider {
        display: flex;
        align-items: center;
        margin: 16px 0;
}
.icon-vs-premium-divider::before,
.icon-vs-premium-divider::after {
        content: '';
        flex: 1;
        height: 1px;
        background: linear-gradient(90deg, transparent, rgba(255,208,142,0.4));
}
.icon-vs-premium-divider::after {
        background: linear-gradient(90deg, rgba(255,208,142,0.4), transparent);
}
.icon-vs-premium-divider span {
        font-size: 0.45rem;
        color: rgba(255,208,142,0.55);
        padding: 0 8px;
        flex-shrink: 0;
}
.icon-vs-premium-divider--footer { margin: 16px 0 12px; }

/* Description */
.icon-vs-premium-description {
        font-size: 0.875rem;
        color: rgba(240,240,240,0.55);
        line-height: 1.6;
        margin: 0 0 18px;
}

/* Input group — single clean border */
.icon-vs-premium-input-group {
        display: flex;
        align-items: stretch;
        background: #111;
        border: 1px solid rgba(255,208,142,0.28);
        border-radius: 10px;
        overflow: hidden;
        margin-bottom: 10px;
        transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.icon-vs-premium-input-group:focus-within {
        border-color: rgba(255,208,142,0.65);
        box-shadow: 0 0 0 3px rgba(255,208,142,0.1);
}
.icon-vs-premium-prefix {
        display: flex;
        align-items: center;
        padding: 0 14px;
        font-size: 0.9375rem;
        font-family: 'Courier New', Courier, monospace;
        font-weight: 700;
        color: #ffd08e;
        letter-spacing: 0.06em;
        white-space: nowrap;
        border-right: 1px solid rgba(255,208,142,0.15);
        background: rgba(255,208,142,0.04);
        flex-shrink: 0;
        user-select: none;
}

/* Override base input styles when inside premium group */
.icon-vs-premium-input.icon-vs-code-input {
        flex: 1;
        width: auto !important;
        background: transparent !important;
        border: none !important;
        border-radius: 0 !important;
        padding: 13px 14px !important;
        box-shadow: none !important;
        outline: none !important;
        font-size: 1rem !important;
        color: #f0f0f0 !important;
        letter-spacing: 0.06em;
}
.icon-vs-premium-input.icon-vs-code-input:focus {
        border: none !important;
        box-shadow: none !important;
}
.icon-vs-premium-input.icon-vs-code-input::placeholder {
        color: rgba(240,240,240,0.2) !important;
        font-family: 'Courier New', Courier, monospace;
}

/* Verify button */
.icon-vs-premium-btn {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
        width: 100%;
        padding: 13px 24px;
        background: #ffd08e;
        color: #0b0b0b !important;
        border: none;
        border-radius: 10px;
        font-size: 0.9375rem;
        font-weight: 800;
        letter-spacing: 0.12em;
        text-transform: uppercase;
        cursor: pointer;
        transition: filter 0.18s ease, box-shadow 0.18s ease, transform 0.1s ease;
        font-family: inherit;
        line-height: 1;
        box-shadow: 0 4px 18px rgba(255,208,142,0.22), inset 0 1px 0 rgba(255,255,255,0.18);
        margin-bottom: 8px;
        position: relative;
        overflow: hidden;
}
.icon-vs-premium-btn:hover {
        filter: brightness(0.92);
        box-shadow: 0 6px 24px rgba(255,208,142,0.35);
        color: #0b0b0b !important;
}
.icon-vs-premium-btn:active { transform: scale(0.99); }
.icon-vs-premium-btn-icon { width: 15px; height: 15px; flex-shrink: 0; color: #0b0b0b; }

/* Hint */
.icon-vs-premium-hint {
        font-size: 0.6875rem;
        color: rgba(240,240,240,0.25);
        margin: 0;
        letter-spacing: 0.02em;
}

/* Footer */
.icon-vs-premium-footer {
        font-size: 0.6875rem;
        letter-spacing: 0.06em;
        color: rgba(240,240,240,0.28);
        margin: 0;
}
.icon-vs-premium-footer strong { color: rgba(255,208,142,0.5); font-weight: 600; }

@media ( max-width: 520px ) {
        .icon-vs-premium-wrap { padding: 28px 18px 22px; }
        .icon-vs-premium-logo-img { max-width: 200px; }
}

/* ── 15. Logo in cert header & footer + status bar ─────────── */

/* Header brand columns */
.icon-vs-cert-brand {
        display: flex;
        align-items: center;
        justify-content: flex-start;
}

.icon-vs-cert-brand-text {
        text-align: right;
        display: flex;
        flex-direction: column;
        align-items: flex-end;
        justify-content: center;
}

/* Logo image sizing — strict caps */
.icon-vs-cert-logo-img {
        max-width: 180px;
        max-height: 80px;
        width: auto;
        height: auto;
        display: block;
        object-fit: contain;
        filter: drop-shadow(0 0 8px rgba(255,208,142,0.18));
}

.icon-vs-cert-footer-logo {
        max-width: 80px;
        max-height: 32px;
        width: auto;
        height: auto;
        display: block;
        object-fit: contain;
        opacity: 0.65;
}

/* Status bar — appears between header and body */
.icon-vs-status-bar {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 10px 20px;
        border-bottom: 1px solid rgba(255,208,142,0.1);
}

.icon-vs-status-bar--valid {
        background: linear-gradient(90deg, rgba(180,142,50,0.12), transparent);
        color: #ffd08e;
}

.icon-vs-status-bar--invalid {
        background: linear-gradient(90deg, rgba(180,60,60,0.12), transparent);
        color: #ff8888;
}

.icon-vs-status-bar-emblem {
        width: 28px;
        height: 28px;
        flex-shrink: 0;
        opacity: 0.85;
}

.icon-vs-status-bar-emblem svg {
        width: 100%;
        height: 100%;
}

.icon-vs-status-bar-text {
        display: flex;
        flex-direction: column;
        gap: 1px;
}

.icon-vs-status-bar-label {
        font-size: 0.8125rem;
        font-weight: 700;
        letter-spacing: 0.08em;
        text-transform: uppercase;
}

.icon-vs-status-bar-sub {
        font-size: 0.6875rem;
        opacity: 0.65;
        letter-spacing: 0.02em;
}

@media ( max-width: 600px ) {
        .icon-vs-cert-logo-img { max-width: 150px; max-height: 60px; }
}

/* ── 16. "Ready to Verify" premium screen ─────────────────── */

.icon-vs-ready-screen {
        background:
                radial-gradient(ellipse at 50% 0%, rgba(255,208,142,0.06) 0%, transparent 65%),
                #0b0b0b;
        border: 1px solid rgba(255,208,142,0.45);
        border-radius: 18px;
        padding: 48px 40px 36px;
        max-width: 500px;
        margin: 0 auto;
        text-align: center;
        box-shadow: 0 0 0 1px rgba(255,208,142,0.06), 0 24px 60px rgba(0,0,0,0.85);
        animation: icon-vs-fade-in 0.45s ease both;
}

.icon-vs-ready-logo {
        max-width: 200px;
        width: 100%;
        height: auto;
        display: block;
        margin: 0 auto 8px;
        filter: drop-shadow(0 2px 12px rgba(255,208,142,0.2));
}

.icon-vs-ready-divider {
        display: flex;
        align-items: center;
        margin: 16px 0;
        gap: 0;
}
.icon-vs-ready-divider::before,
.icon-vs-ready-divider::after {
        content: '';
        flex: 1;
        height: 1px;
        background: linear-gradient(90deg, transparent, rgba(255,208,142,0.35));
}
.icon-vs-ready-divider::after { background: linear-gradient(90deg, rgba(255,208,142,0.35), transparent); }
.icon-vs-ready-divider span { font-size: 0.45rem; color: rgba(255,208,142,0.5); padding: 0 8px; }

.icon-vs-ready-heading {
        font-size: 1.375rem;
        font-weight: 700;
        color: #f0f0f0;
        letter-spacing: -0.01em;
        margin: 0 0 12px;
}

.icon-vs-ready-text {
        font-size: 0.9375rem;
        color: rgba(240,240,240,0.55);
        line-height: 1.65;
        margin: 0 0 28px;
}

.icon-vs-ready-actions {
        display: flex;
        gap: 10px;
        justify-content: center;
        flex-wrap: wrap;
        margin-bottom: 24px;
}

.icon-vs-ready-btn {
        display: inline-flex;
        align-items: center;
        gap: 7px;
        padding: 11px 22px;
        border-radius: 9px;
        font-size: 0.875rem;
        font-weight: 700;
        cursor: pointer;
        text-decoration: none;
        transition: background 0.18s ease, color 0.18s ease;
        line-height: 1;
        letter-spacing: 0.04em;
        border: none;
}
.icon-vs-ready-btn--primary {
        background: #ffd08e;
        color: #0b0b0b;
}
.icon-vs-ready-btn--primary:hover {
        background: #e8bc74;
        color: #0b0b0b;
        text-decoration: none;
}

.icon-vs-ready-hint {
        font-size: 0.75rem;
        color: rgba(240,240,240,0.3);
        margin: 0;
        letter-spacing: 0.04em;
}
.icon-vs-ready-hint strong { color: rgba(255,208,142,0.5); }

@media ( max-width: 540px ) {
        .icon-vs-ready-screen { padding: 36px 20px 28px; }
        .icon-vs-ready-logo { max-width: 160px; }
}

/* ── 17. Print safety rules removed — fully isolated iframe/window used ── */

/* ────────────────────────────────────────────────────────────
 * v1.2.3 Final frontend responsive polish
 * - smaller ICON Witnessed logo on /verify and popup cards
 * - compact mobile certificate header
 * - stronger mobile popup/card responsiveness
 * ──────────────────────────────────────────────────────────── */

/* Keep the brand mark premium but not oversized */
.icon-vs-cert-logo-img,
.icon-vs-card .icon-vs-cert-logo-img,
.icon-vs-popup-body .icon-vs-cert-logo-img {
    max-width: 132px !important;
    max-height: 58px !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
}

.icon-vs-cert-brand {
    min-width: 0 !important;
}

.icon-vs-cert-brand-text {
    min-width: 0 !important;
}

/* Popup should fit viewports cleanly */
.icon-vs-popup-modal {
    width: min(96vw, 1040px) !important;
    max-height: 94vh !important;
    overflow: hidden !important;
}

.icon-vs-popup-body {
    max-height: 94vh !important;
    overflow: auto !important;
    -webkit-overflow-scrolling: touch;
}

.icon-vs-popup-body .icon-vs-card {
    width: 100% !important;
}

/* Make certificate media flexible everywhere */
.icon-vs-cert-frame img,
.icon-vs-item-image {
    max-width: 100% !important;
    height: auto !important;
}

@media (max-width: 900px) {
    .icon-vs-popup-modal {
        width: min(96vw, 760px) !important;
    }

    .icon-vs-cert-header {
        grid-template-columns: minmax(0, 1fr) auto !important;
        gap: 12px !important;
        padding: 16px 18px !important;
        align-items: center !important;
        text-align: left !important;
    }

    .icon-vs-cert-brand {
        justify-content: flex-start !important;
        text-align: left !important;
    }

    .icon-vs-cert-id {
        justify-self: end !important;
        padding: 8px 12px !important;
        max-width: 100% !important;
    }

    .icon-vs-cert-brand-text {
        grid-column: 1 / -1 !important;
        align-items: center !important;
        text-align: center !important;
        padding-top: 4px !important;
    }

    .icon-vs-cert-logo-name {
        font-size: 0.78rem !important;
        letter-spacing: 0.09em !important;
        white-space: normal !important;
        line-height: 1.2 !important;
    }

    .icon-vs-cert-logo-tag {
        font-size: 0.46rem !important;
        letter-spacing: 0.12em !important;
    }

    .icon-vs-cert-id-value {
        font-size: 0.86rem !important;
        letter-spacing: 0.07em !important;
        white-space: nowrap !important;
    }
}

@media (max-width: 640px) {
    .icon-vs-popup {
        padding: 10px !important;
    }

    .icon-vs-popup-modal {
        width: 96vw !important;
        max-height: 92vh !important;
        border-radius: 16px !important;
    }

    .icon-vs-popup-body {
        max-height: 92vh !important;
    }

    .icon-vs-popup-close {
        top: 8px !important;
        right: 8px !important;
        z-index: 20 !important;
    }

    /* Override previous single-column header: keep header compact, not one item under another */
    .icon-vs-cert-header {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) auto !important;
        gap: 10px !important;
        padding: 14px 14px 12px !important;
        text-align: left !important;
    }

    .icon-vs-cert-logo-img,
    .icon-vs-card .icon-vs-cert-logo-img,
    .icon-vs-popup-body .icon-vs-cert-logo-img {
        max-width: 108px !important;
        max-height: 48px !important;
    }

    .icon-vs-cert-id {
        justify-self: end !important;
        padding: 7px 9px !important;
        border-radius: 9px !important;
    }

    .icon-vs-cert-id-label {
        font-size: 0.48rem !important;
        letter-spacing: 0.11em !important;
        margin-bottom: 3px !important;
    }

    .icon-vs-cert-id-value {
        font-size: 0.72rem !important;
        letter-spacing: 0.045em !important;
    }

    .icon-vs-cert-brand-text {
        grid-column: 1 / -1 !important;
        width: 100% !important;
        align-items: center !important;
        text-align: center !important;
        padding-top: 2px !important;
    }

    .icon-vs-cert-logo-name {
        font-size: 0.72rem !important;
        letter-spacing: 0.08em !important;
    }

    .icon-vs-cert-logo-tag {
        font-size: 0.42rem !important;
        letter-spacing: 0.1em !important;
    }

    .icon-vs-status-bar {
        padding: 8px 14px !important;
        gap: 9px !important;
    }

    .icon-vs-status-bar-emblem {
        width: 22px !important;
        height: 22px !important;
    }

    .icon-vs-status-bar-label {
        font-size: 0.7rem !important;
    }

    .icon-vs-status-bar-sub {
        font-size: 0.58rem !important;
        line-height: 1.35 !important;
    }

    .icon-vs-cert-body {
        grid-template-columns: 1fr !important;
    }

    .icon-vs-cert-image-col {
        padding: 14px !important;
        border-right: none !important;
        border-bottom: 1px solid var(--icon-vs-border-subtle) !important;
    }

    .icon-vs-cert-frame {
        max-width: min(100%, 340px) !important;
        margin: 0 auto !important;
    }

    .icon-vs-cert-details-col {
        padding: 16px 14px !important;
    }

    .icon-vs-item-name {
        font-size: 1.35rem !important;
        line-height: 1.2 !important;
    }

    .icon-vs-details-grid {
        grid-template-columns: 1fr !important;
        gap: 14px !important;
    }

    .icon-vs-cert-code {
        padding: 14px !important;
    }

    .icon-vs-cert-value {
        font-size: 1rem !important;
        letter-spacing: 0.08em !important;
        overflow-wrap: anywhere !important;
    }

    .icon-vs-cert-footer,
    .icon-vs-action-btns {
        padding-left: 14px !important;
        padding-right: 14px !important;
    }
}

@media (max-width: 420px) {
    .icon-vs-cert-header {
        grid-template-columns: 1fr !important;
        text-align: center !important;
    }

    .icon-vs-cert-brand,
    .icon-vs-cert-id,
    .icon-vs-cert-brand-text {
        justify-self: center !important;
        justify-content: center !important;
        text-align: center !important;
        align-items: center !important;
    }

    .icon-vs-cert-logo-img,
    .icon-vs-card .icon-vs-cert-logo-img,
    .icon-vs-popup-body .icon-vs-cert-logo-img {
        max-width: 120px !important;
        max-height: 52px !important;
    }
}

/* ────────────────────────────────────────────────────────────
 * v1.2.4 Final UI alignment with ICON Signings site
 * - Montserrat typography
 * - compact result logo
 * - header stays in one premium row on mobile/tablet
 * - detail fields use clean columns
 * - footer brand/date stay left/right
 * - site-style radius, gold borders and premium shadows
 * ──────────────────────────────────────────────────────────── */

.icon-vs-card,
.icon-vs-popup,
.icon-vs-popup-modal,
.icon-vs-premium-wrap,
.icon-vs-ready-screen,
.icon-vs-btn,
.icon-vs-code-input,
.icon-vs-premium-input,
.icon-vs-form-inline {
    font-family: "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
}

/* Match the website product-card look: dark box, gold border, soft shadow */
.icon-vs-card,
.icon-vs-popup-modal,
.icon-vs-premium-wrap,
.icon-vs-ready-screen {
    background: #121212 !important;
    border: 1px solid rgba(255, 208, 142, 0.42) !important;
    border-radius: 16px !important;
    box-shadow: 0 0 0 1px rgba(255,208,142,0.06), 0 18px 48px rgba(0,0,0,0.76), 0 0 28px rgba(255,208,142,0.055) !important;
}

/* Header: logo left, brand title center, ID right. Do not push title into a second row. */
.icon-vs-cert-header,
.icon-vs-popup-body .icon-vs-cert-header {
    display: grid !important;
    grid-template-columns: minmax(90px, 0.8fr) minmax(160px, 1.4fr) minmax(150px, auto) !important;
    grid-template-areas: "brand title id" !important;
    align-items: center !important;
    gap: 16px !important;
    padding: 18px 24px !important;
    text-align: initial !important;
}

.icon-vs-cert-brand,
.icon-vs-popup-body .icon-vs-cert-brand {
    grid-area: brand !important;
    justify-content: flex-start !important;
    text-align: left !important;
    min-width: 0 !important;
}

.icon-vs-cert-brand-text,
.icon-vs-popup-body .icon-vs-cert-brand-text {
    grid-area: title !important;
    grid-column: auto !important;
    justify-self: center !important;
    align-items: center !important;
    text-align: center !important;
    padding-top: 0 !important;
    min-width: 0 !important;
}

.icon-vs-cert-id,
.icon-vs-popup-body .icon-vs-cert-id {
    grid-area: id !important;
    justify-self: end !important;
    min-width: 0 !important;
    padding: 10px 16px !important;
    border-radius: 11px !important;
    background: rgba(255, 208, 142, 0.055) !important;
    border-color: rgba(255, 208, 142, 0.36) !important;
}

/* Keep ICON Witnessed logo tasteful on both /verify and popup */
.icon-vs-cert-logo-img,
.icon-vs-card .icon-vs-cert-logo-img,
.icon-vs-popup-body .icon-vs-cert-logo-img {
    max-width: 92px !important;
    max-height: 48px !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
}

.icon-vs-cert-logo-name {
    font-family: "Montserrat", sans-serif !important;
    font-size: clamp(0.9rem, 1.7vw, 1.28rem) !important;
    line-height: 1.05 !important;
    letter-spacing: 0.12em !important;
    color: #ffd08e !important;
    white-space: nowrap !important;
}

.icon-vs-cert-logo-tag {
    font-size: clamp(0.45rem, 0.78vw, 0.62rem) !important;
    line-height: 1.2 !important;
    letter-spacing: 0.14em !important;
    white-space: nowrap !important;
}

/* Status row should be refined, not visually dominant */
.icon-vs-status-bar {
    padding: 8px 24px !important;
    gap: 10px !important;
    background: linear-gradient(90deg, rgba(255,208,142,0.07), rgba(255,208,142,0.018), transparent) !important;
}
.icon-vs-status-bar-emblem { width: 22px !important; height: 22px !important; }
.icon-vs-status-bar-label { font-size: 0.72rem !important; letter-spacing: 0.08em !important; }
.icon-vs-status-bar-sub { font-size: 0.62rem !important; line-height: 1.35 !important; }

/* Details: keep data in elegant columns on desktop/tablet instead of long separate rows */
.icon-vs-details-grid,
.icon-vs-popup-body .icon-vs-details-grid {
    display: grid !important;
    grid-template-columns: repeat(5, minmax(92px, 1fr)) !important;
    gap: 16px 18px !important;
    align-items: start !important;
}

.icon-vs-detail-label {
    font-size: 0.58rem !important;
    letter-spacing: 0.13em !important;
    color: rgba(240,240,240,0.62) !important;
}
.icon-vs-detail-value {
    font-size: 0.92rem !important;
    line-height: 1.35 !important;
    font-weight: 600 !important;
}

/* Footer: logo/brand left, date/time right, even on mobile. */
.icon-vs-cert-footer,
.icon-vs-popup-body .icon-vs-cert-footer {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 14px !important;
    padding: 12px 24px !important;
}
.icon-vs-cert-footer-brand { min-width: 0 !important; }
.icon-vs-cert-footer-meta {
    align-items: flex-end !important;
    text-align: right !important;
    flex-shrink: 0 !important;
}

/* Popup desktop: reduce internal scroll unless needed and make wider card breathe. */
.icon-vs-popup-modal {
    width: min(96vw, 1120px) !important;
    max-height: 94vh !important;
}
.icon-vs-popup-body { max-height: 94vh !important; }

@media (max-width: 1050px) {
    .icon-vs-details-grid,
    .icon-vs-popup-body .icon-vs-details-grid {
        grid-template-columns: repeat(3, minmax(110px, 1fr)) !important;
    }
}

@media (max-width: 760px) {
    .icon-vs-cert-header,
    .icon-vs-popup-body .icon-vs-cert-header {
        grid-template-columns: minmax(70px, 0.7fr) minmax(120px, 1.25fr) minmax(112px, auto) !important;
        grid-template-areas: "brand title id" !important;
        gap: 8px !important;
        padding: 14px 12px !important;
    }

    .icon-vs-cert-logo-img,
    .icon-vs-card .icon-vs-cert-logo-img,
    .icon-vs-popup-body .icon-vs-cert-logo-img {
        max-width: 74px !important;
        max-height: 38px !important;
    }

    .icon-vs-cert-id,
    .icon-vs-popup-body .icon-vs-cert-id {
        padding: 7px 8px !important;
        border-radius: 9px !important;
    }

    .icon-vs-cert-id-label { font-size: 0.43rem !important; letter-spacing: 0.1em !important; }
    .icon-vs-cert-id-value { font-size: 0.66rem !important; letter-spacing: 0.035em !important; white-space: nowrap !important; }
    .icon-vs-cert-logo-name { font-size: 0.72rem !important; letter-spacing: 0.075em !important; white-space: normal !important; }
    .icon-vs-cert-logo-tag { font-size: 0.38rem !important; letter-spacing: 0.08em !important; white-space: normal !important; }

    .icon-vs-status-bar { padding: 7px 12px !important; }

    .icon-vs-details-grid,
    .icon-vs-popup-body .icon-vs-details-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 13px 14px !important;
    }

    .icon-vs-cert-footer,
    .icon-vs-popup-body .icon-vs-cert-footer {
        flex-direction: row !important;
        align-items: center !important;
        justify-content: space-between !important;
        padding: 10px 12px !important;
    }

    .icon-vs-cert-footer-brand {
        font-size: 0.68rem !important;
        gap: 5px !important;
    }

    .icon-vs-cert-timestamp { font-size: 0.58rem !important; }
}

@media (max-width: 480px) {
    .icon-vs-popup { padding: 8px !important; }
    .icon-vs-popup-modal { width: 97vw !important; border-radius: 14px !important; }

    .icon-vs-cert-header,
    .icon-vs-popup-body .icon-vs-cert-header {
        grid-template-columns: 62px minmax(92px, 1fr) minmax(92px, auto) !important;
        gap: 6px !important;
        padding: 12px 10px !important;
    }

    .icon-vs-cert-logo-img,
    .icon-vs-card .icon-vs-cert-logo-img,
    .icon-vs-popup-body .icon-vs-cert-logo-img {
        max-width: 58px !important;
        max-height: 34px !important;
    }

    .icon-vs-cert-logo-name { font-size: 0.62rem !important; letter-spacing: 0.055em !important; }
    .icon-vs-cert-logo-tag { display: none !important; }
    .icon-vs-cert-id-label { display: none !important; }
    .icon-vs-cert-id-value { font-size: 0.58rem !important; }

    .icon-vs-details-grid,
    .icon-vs-popup-body .icon-vs-details-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 12px !important;
    }

    .icon-vs-detail-label { font-size: 0.52rem !important; }
    .icon-vs-detail-value { font-size: 0.82rem !important; }

    .icon-vs-cert-footer-brand span { overflow-wrap: anywhere !important; }
}

/* ────────────────────────────────────────────────────────────
 * v1.2.5 Final desktop composition + verify-page logo sizing
 * - desktop-only larger image column
 * - details use two-row grid on desktop
 * - verify/ready page logo reduced desktop/mobile
 * ──────────────────────────────────────────────────────────── */

/* Dedicated verify page / ready card logo: keep branded image premium, not oversized */
.icon-vs-ready-screen .icon-vs-ready-logo,
.icon-vs-ready-logo {
    max-width: 220px !important;
    max-height: 150px !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
}

/* Desktop-only result card refinements */
@media (min-width: 901px) {
    /* Give the product image column real visual weight on desktop only */
    .icon-vs-card .icon-vs-cert-body,
    .icon-vs-popup-body .icon-vs-cert-body {
        grid-template-columns: minmax(260px, 31%) minmax(0, 1fr) !important;
    }

    .icon-vs-card .icon-vs-cert-image-col,
    .icon-vs-popup-body .icon-vs-cert-image-col {
        padding: 30px 26px !important;
        align-items: flex-start !important;
        justify-content: center !important;
    }

    .icon-vs-card .icon-vs-cert-frame,
    .icon-vs-popup-body .icon-vs-cert-frame {
        width: 100% !important;
        max-width: 260px !important;
        margin: 0 auto !important;
    }

    /* Five details should not appear as one long row on desktop.
       Use a clean two-row composition: 3 items row one, 2 items row two. */
    .icon-vs-card .icon-vs-details-grid,
    .icon-vs-popup-body .icon-vs-details-grid {
        grid-template-columns: repeat(3, minmax(145px, 1fr)) !important;
        gap: 20px 24px !important;
        align-items: start !important;
    }

    .icon-vs-card .icon-vs-detail-item,
    .icon-vs-popup-body .icon-vs-detail-item {
        min-width: 0 !important;
    }

    .icon-vs-card .icon-vs-detail-label,
    .icon-vs-popup-body .icon-vs-detail-label {
        margin-bottom: 7px !important;
    }

    .icon-vs-card .icon-vs-detail-value,
    .icon-vs-popup-body .icon-vs-detail-value {
        font-size: 0.98rem !important;
        line-height: 1.35 !important;
        word-break: normal !important;
    }
}

@media (min-width: 1180px) {
    .icon-vs-card .icon-vs-cert-body,
    .icon-vs-popup-body .icon-vs-cert-body {
        grid-template-columns: minmax(300px, 32%) minmax(0, 1fr) !important;
    }

    .icon-vs-card .icon-vs-cert-frame,
    .icon-vs-popup-body .icon-vs-cert-frame {
        max-width: 300px !important;
    }
}

@media (max-width: 760px) {
    .icon-vs-ready-screen .icon-vs-ready-logo,
    .icon-vs-ready-logo {
        max-width: 170px !important;
        max-height: 115px !important;
    }
}

@media (max-width: 480px) {
    .icon-vs-ready-screen .icon-vs-ready-logo,
    .icon-vs-ready-logo {
        max-width: 145px !important;
        max-height: 96px !important;
    }
}

/* ────────────────────────────────────────────────────────────
 * v1.2.6 Final polish: desktop popup fit, outside close button,
 * balanced actions, premium ready card corners/dividers.
 * ──────────────────────────────────────────────────────────── */

/* Ready/verify empty-state box: match premium form certificate frame */
.icon-vs-ready-screen {
    position: relative !important;
    border: 1px solid rgba(255, 208, 142, 0.68) !important;
    border-radius: 18px !important;
    box-shadow: 0 0 0 1px rgba(255,208,142,0.08), 0 24px 70px rgba(0,0,0,0.76), inset 0 0 28px rgba(255,208,142,0.035) !important;
    background:
        radial-gradient(circle at 50% 0%, rgba(255,208,142,0.08), transparent 34%),
        linear-gradient(180deg, #141414 0%, #0b0b0b 100%) !important;
    overflow: hidden !important;
}
.icon-vs-ready-screen::before {
    content: "";
    position: absolute;
    inset: 13px;
    pointer-events: none;
    border-radius: 12px;
    background:
        linear-gradient(#ffd08e,#ffd08e) left top/38px 1px no-repeat,
        linear-gradient(#ffd08e,#ffd08e) left top/1px 38px no-repeat,
        linear-gradient(#ffd08e,#ffd08e) right top/38px 1px no-repeat,
        linear-gradient(#ffd08e,#ffd08e) right top/1px 38px no-repeat,
        linear-gradient(#ffd08e,#ffd08e) left bottom/38px 1px no-repeat,
        linear-gradient(#ffd08e,#ffd08e) left bottom/1px 38px no-repeat,
        linear-gradient(#ffd08e,#ffd08e) right bottom/38px 1px no-repeat,
        linear-gradient(#ffd08e,#ffd08e) right bottom/1px 38px no-repeat;
    opacity: .55;
}
.icon-vs-ready-divider,
.icon-vs-premium-divider {
    max-width: 310px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Popup close button: outside the card, gold themed */
.icon-vs-popup-modal {
    overflow: visible !important;
}
.icon-vs-popup-body {
    overflow-y: auto !important;
    overflow-x: hidden !important;
    border-radius: 18px !important;
}
.icon-vs-popup-close {
    top: -16px !important;
    right: -16px !important;
    width: 36px !important;
    height: 36px !important;
    background: #ffd08e !important;
    color: #0b0b0b !important;
    border: 2px solid rgba(11,11,11,0.95) !important;
    box-shadow: 0 10px 26px rgba(0,0,0,0.5), 0 0 0 1px rgba(255,208,142,0.45) !important;
}
.icon-vs-popup-close:hover {
    background: #e6b668 !important;
    color: #0b0b0b !important;
}

/* Popup/result data must never clip horizontally */
.icon-vs-card,
.icon-vs-popup-body .icon-vs-card,
.icon-vs-cert-body,
.icon-vs-cert-details-col,
.icon-vs-details-grid,
.icon-vs-detail-item,
.icon-vs-detail-value {
    min-width: 0 !important;
}
.icon-vs-popup-body .icon-vs-cert-details-col,
.icon-vs-cert-details-col {
    overflow: hidden !important;
}
.icon-vs-popup-body .icon-vs-detail-value,
.icon-vs-card .icon-vs-detail-value {
    overflow-wrap: anywhere !important;
    word-break: normal !important;
}

/* Desktop-only: keep image large but give details safe room */
@media (min-width: 901px) {
    .icon-vs-popup-modal {
        width: min(96vw, 1180px) !important;
    }
    .icon-vs-popup-body .icon-vs-cert-body,
    .icon-vs-card .icon-vs-cert-body {
        grid-template-columns: minmax(300px, 36%) minmax(0, 1fr) !important;
    }
    .icon-vs-popup-body .icon-vs-cert-frame,
    .icon-vs-card .icon-vs-cert-frame {
        max-width: 340px !important;
    }
    .icon-vs-popup-body .icon-vs-details-grid,
    .icon-vs-card .icon-vs-details-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 20px 34px !important;
        width: 100% !important;
    }
    .icon-vs-popup-body .icon-vs-detail-value,
    .icon-vs-card .icon-vs-detail-value {
        font-size: 1rem !important;
        line-height: 1.35 !important;
    }
    .icon-vs-popup-body .icon-vs-cert-code,
    .icon-vs-card .icon-vs-cert-code {
        margin-top: 6px !important;
    }
}

@media (min-width: 1280px) {
    .icon-vs-popup-modal {
        width: min(94vw, 1240px) !important;
    }
    .icon-vs-popup-body .icon-vs-cert-body,
    .icon-vs-card .icon-vs-cert-body {
        grid-template-columns: minmax(330px, 37%) minmax(0, 1fr) !important;
    }
    .icon-vs-popup-body .icon-vs-cert-frame,
    .icon-vs-card .icon-vs-cert-frame {
        max-width: 370px !important;
    }
}

/* Action buttons: print left, verify another right */
.icon-vs-action-btns,
.icon-vs-popup-body .icon-vs-action-btns {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 16px !important;
}
.icon-vs-action-btns .icon-vs-btn,
.icon-vs-popup-body .icon-vs-action-btns .icon-vs-btn {
    min-width: 220px !important;
    justify-content: center !important;
}

@media (max-width: 760px) {
    .icon-vs-popup-close {
        top: -10px !important;
        right: -10px !important;
        width: 32px !important;
        height: 32px !important;
    }
    .icon-vs-action-btns,
    .icon-vs-popup-body .icon-vs-action-btns {
        flex-direction: column !important;
        justify-content: center !important;
    }
    .icon-vs-action-btns .icon-vs-btn,
    .icon-vs-popup-body .icon-vs-action-btns .icon-vs-btn {
        width: 100% !important;
        min-width: 0 !important;
    }
}

/* ────────────────────────────────────────────────────────────
 * v1.2.8 Normal Form Premium Alignment
 * Polishes the original [icon_verify_form] only.
 * Keeps premium form, popup, verify card and print untouched.
 * ──────────────────────────────────────────────────────────── */
.icon-vs-form-wrap {
    max-width: 1280px;
    margin-left: auto;
    margin-right: auto;
    padding-left: 12px;
    padding-right: 12px;
}

.icon-vs-form-inline {
    position: relative;
    overflow: hidden;
    display: grid !important;
    grid-template-columns: 76px minmax(260px, 1fr) minmax(430px, 0.95fr) !important;
    align-items: center !important;
    gap: 26px !important;
    padding: 26px 34px !important;
    min-height: 132px;
    background:
        radial-gradient(circle at 12% 0%, rgba(255,208,142,0.10), transparent 34%),
        linear-gradient(135deg, #151515 0%, #101010 48%, #15120d 100%) !important;
    border: 1px solid rgba(255, 208, 142, 0.34) !important;
    border-radius: 22px !important;
    box-shadow:
        0 0 0 1px rgba(255,208,142,0.06),
        0 18px 44px rgba(0,0,0,0.55),
        inset 0 1px 0 rgba(255,255,255,0.035) !important;
}

.icon-vs-form-inline::before,
.icon-vs-form-inline::after {
    content: "";
    position: absolute;
    width: 72px;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255,208,142,0.65), transparent);
    pointer-events: none;
    opacity: 0.72;
}

.icon-vs-form-inline::before { top: 18px; left: 28px; }
.icon-vs-form-inline::after { bottom: 18px; right: 28px; }

.icon-vs-form-brand-col {
    position: relative;
    z-index: 1;
}

.icon-vs-form-brand-icon {
    width: 68px !important;
    height: 68px !important;
    border-radius: 18px !important;
    background:
        linear-gradient(145deg, rgba(255,208,142,0.16), rgba(255,208,142,0.035)) !important;
    border: 1px solid rgba(255,208,142,0.38) !important;
    color: #ffd08e !important;
    box-shadow:
        inset 0 0 24px rgba(255,208,142,0.055),
        0 10px 26px rgba(0,0,0,0.45) !important;
}

.icon-vs-form-brand-icon svg {
    width: 31px !important;
    height: 31px !important;
}

.icon-vs-form-text-col {
    position: relative;
    z-index: 1;
    min-width: 0;
}

.icon-vs-form-title {
    font-family: "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
    font-size: clamp(1.15rem, 1.55vw, 1.55rem) !important;
    font-weight: 800 !important;
    line-height: 1.15 !important;
    margin: 0 0 8px !important;
    color: #f8f8f8 !important;
    letter-spacing: -0.03em !important;
}

.icon-vs-form-subtitle {
    font-family: "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
    font-size: 0.95rem !important;
    line-height: 1.45 !important;
    color: rgba(240,240,240,0.66) !important;
    max-width: 520px;
}

.icon-vs-form-input-col {
    position: relative;
    z-index: 1;
    width: 100%;
    justify-self: end;
    min-width: 0;
}

.icon-vs-form-field {
    width: 100%;
    display: grid !important;
    grid-template-columns: minmax(220px, 1fr) auto !important;
    gap: 12px !important;
    align-items: stretch !important;
}

.icon-vs-code-input {
    width: 100% !important;
    min-width: 0 !important;
    height: 56px !important;
    padding: 0 20px !important;
    border-radius: 13px !important;
    background: #0d0d0d !important;
    border: 1px solid rgba(255,208,142,0.28) !important;
    color: #f4f4f4 !important;
    font-size: 1rem !important;
    letter-spacing: 0.08em !important;
    box-shadow: inset 0 1px 12px rgba(0,0,0,0.35) !important;
}

.icon-vs-code-input:focus {
    border-color: rgba(255,208,142,0.72) !important;
    box-shadow:
        inset 0 1px 12px rgba(0,0,0,0.35),
        0 0 0 3px rgba(255,208,142,0.11) !important;
}

.icon-vs-verify-btn {
    min-width: 152px !important;
    height: 56px !important;
    padding: 0 26px !important;
    justify-content: center !important;
    border-radius: 13px !important;
    background: linear-gradient(135deg, #ffe0a9 0%, #ffd08e 46%, #eeb96b 100%) !important;
    color: #0b0b0b !important;
    border: 1px solid rgba(255,208,142,0.5) !important;
    box-shadow: 0 10px 22px rgba(255,208,142,0.13) !important;
    font-weight: 800 !important;
    letter-spacing: 0.02em !important;
}

.icon-vs-verify-btn:hover,
.icon-vs-verify-btn:focus {
    background: linear-gradient(135deg, #fff0c8 0%, #ffd89e 46%, #f0bd72 100%) !important;
    color: #0b0b0b !important;
    transform: translateY(-1px);
}

.icon-vs-form-hint {
    margin-top: 9px !important;
    color: rgba(240,240,240,0.46) !important;
    font-size: 0.75rem !important;
    text-align: right !important;
}

@media (max-width: 1024px) {
    .icon-vs-form-inline {
        grid-template-columns: 72px 1fr !important;
        gap: 20px !important;
        padding: 24px !important;
    }

    .icon-vs-form-input-col {
        grid-column: 1 / -1;
        justify-self: stretch;
    }

    .icon-vs-form-subtitle {
        max-width: none;
    }
}

@media (max-width: 640px) {
    .icon-vs-form-wrap {
        padding-left: 10px;
        padding-right: 10px;
    }

    .icon-vs-form-inline {
        grid-template-columns: 1fr !important;
        text-align: center !important;
        gap: 16px !important;
        padding: 24px 18px !important;
        border-radius: 18px !important;
    }

    .icon-vs-form-brand-col {
        justify-self: center;
    }

    .icon-vs-form-brand-icon {
        width: 62px !important;
        height: 62px !important;
    }

    .icon-vs-form-subtitle {
        font-size: 0.9rem !important;
    }

    .icon-vs-form-field {
        grid-template-columns: 1fr !important;
        gap: 10px !important;
    }

    .icon-vs-verify-btn {
        width: 100% !important;
    }

    .icon-vs-form-hint {
        text-align: center !important;
    }
}

/* ────────────────────────────────────────────────────────────
 * v1.2.9 Client polish patch
 * - remove premium corner brackets
 * - improve form contrast/autofill behavior
 * - popup close visibility
 * - flexible image/signed-by layout
 * - subtle premium glow
 * ──────────────────────────────────────────────────────────── */

/* Remove the circled corner pieces from premium form and ready/verify empty state */
.icon-vs-premium-corner,
.icon-vs-ready-screen::before {
    display: none !important;
    content: none !important;
}

/* Premium form: use soft glow border instead of corner brackets */
.icon-vs-premium-wrap {
    border-color: rgba(255, 208, 142, 0.72) !important;
    box-shadow:
        0 0 0 1px rgba(255,208,142,0.10),
        0 0 28px rgba(255,208,142,0.12),
        0 28px 80px rgba(0,0,0,0.88),
        inset 0 1px 0 rgba(255,208,142,0.10) !important;
}

/* Simplify and clean footer microcopy */
.icon-vs-premium-footer {
    color: rgba(240,240,240,0.38) !important;
    letter-spacing: 0.02em !important;
}
.icon-vs-premium-footer strong {
    color: rgba(255,208,142,0.72) !important;
}

/* Better normal verification input visibility without changing placement/slider spacing */
.icon-vs-form-inline::before,
.icon-vs-form-inline::after {
    display: none !important;
    content: none !important;
}
.icon-vs-code-input,
.icon-vs-premium-input-group {
    border-color: rgba(255,208,142,0.46) !important;
    box-shadow:
        inset 0 1px 14px rgba(0,0,0,0.42),
        0 0 0 1px rgba(255,208,142,0.04) !important;
}
.icon-vs-code-input:focus,
.icon-vs-premium-input-group:focus-within {
    border-color: rgba(255,208,142,0.82) !important;
    box-shadow:
        inset 0 1px 14px rgba(0,0,0,0.42),
        0 0 0 3px rgba(255,208,142,0.13),
        0 0 22px rgba(255,208,142,0.06) !important;
}

/* Make close button clearly show an X and keep it visually clean */
.icon-vs-popup-close {
    color: #0b0b0b !important;
    background: #ffd08e !important;
    border-color: rgba(255,208,142,0.92) !important;
}
.icon-vs-popup-close svg {
    display: block !important;
    width: 18px !important;
    height: 18px !important;
    stroke: currentColor !important;
    stroke-width: 3 !important;
}
.icon-vs-popup-close::before {
    content: "×";
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    line-height: 1;
    font-weight: 800;
    color: #0b0b0b;
    pointer-events: none;
}
.icon-vs-popup-close svg { opacity: 0; }

/* Add better breathing room in the popup/card header */
.icon-vs-cert-header {
    column-gap: clamp(22px, 3vw, 46px) !important;
}
.icon-vs-cert-brand {
    padding-right: 8px !important;
}
.icon-vs-cert-brand-text {
    padding-left: 8px !important;
}

/* Product photo area: allow images to expand without squishing */
.icon-vs-cert-image-col {
    align-items: flex-start !important;
}
.icon-vs-cert-frame {
    width: 100% !important;
    min-height: 210px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}
.icon-vs-item-image {
    width: 100% !important;
    height: auto !important;
    max-height: 360px !important;
    object-fit: contain !important;
}

/* Signed-by field must support multiple names gracefully */
.icon-vs-details-grid .icon-vs-detail-item:first-child {
    grid-column: 1 / -1 !important;
}
.icon-vs-details-grid .icon-vs-detail-item:first-child .icon-vs-detail-value {
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    word-break: normal !important;
    line-height: 1.35 !important;
}
.icon-vs-detail-value {
    white-space: normal !important;
}

/* Keep popup body balanced on desktop after signed-by expansion */
@media (min-width: 901px) {
    .icon-vs-popup-body .icon-vs-cert-body {
        grid-template-columns: minmax(360px, 40%) minmax(0, 1fr) !important;
    }
    .icon-vs-popup-body .icon-vs-cert-frame {
        max-width: 430px !important;
    }
    .icon-vs-popup-body .icon-vs-details-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        align-items: start !important;
    }
}

@media (max-width: 640px) {
    .icon-vs-popup-close {
        top: 10px !important;
        right: 10px !important;
        width: 34px !important;
        height: 34px !important;
    }
    .icon-vs-cert-header {
        gap: 16px !important;
    }
    .icon-vs-cert-frame {
        min-height: 160px !important;
    }
    .icon-vs-item-image {
        max-height: 280px !important;
    }
}

/* v1.3.0 Verification page premium certification polish */
.icon-vs-card {
        box-shadow:
                0 24px 80px rgba(0,0,0,.52),
                0 0 0 1px rgba(255,208,142,.18),
                inset 0 1px 0 rgba(255,255,255,.06) !important;
}
.icon-vs-card::after {
        content: "ICON WITNESSED";
        position: absolute;
        right: 34px;
        bottom: 28px;
        font-size: clamp(34px, 6vw, 78px);
        letter-spacing: .14em;
        font-weight: 900;
        color: rgba(255,208,142,.035);
        pointer-events: none;
        z-index: 0;
        white-space: nowrap;
}
.icon-vs-card > * { position: relative; z-index: 1; }
.icon-vs-cert-header,
.icon-vs-cert-footer,
.icon-vs-cert-body {
        gap: clamp(14px, 2vw, 26px) !important;
}
.icon-vs-card .icon-vs-cert-logo-img {
        filter: drop-shadow(0 8px 18px rgba(255,208,142,.12));
}
.icon-vs-detail-item {
        background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.018)) !important;
        border-color: rgba(255,208,142,.18) !important;
}
.icon-vs-detail-label { color: rgba(255,208,142,.78) !important; }
.icon-vs-detail-value { line-height: 1.32 !important; }
.icon-vs-cert-frame {
        box-shadow: 0 16px 44px rgba(0,0,0,.38), 0 0 0 1px rgba(255,208,142,.18) !important;
}
@media (max-width: 767px) {
        .icon-vs-card::after { display: none; }
        .icon-vs-cert-header { gap: 10px !important; }
}


/* v1.3.1 — certificate watermark + detail-field spacing polish */
.icon-vs-card {
    position: relative !important;
    overflow: hidden !important;
}

/* Remove the old text-only watermark so the real ICON Witnessed mark does not appear cut off. */
.icon-vs-card::after {
    content: none !important;
    display: none !important;
}

/* Add the ICON Witnessed logo as a subtle centered certificate watermark. */
.icon-vs-card--valid::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    pointer-events: none !important;
    z-index: 0 !important;
    background-image: url('../images/icon-witnessed-logo.png') !important;
    background-repeat: no-repeat !important;
    background-position: center 62% !important;
    background-size: min(58%, 620px) auto !important;
    opacity: 0.055 !important;
    filter: saturate(1.04) contrast(1.05) !important;
}

.icon-vs-card > * {
    position: relative !important;
    z-index: 1 !important;
}

/* Give the detail fields proper breathing room inside their dark panels. */
.icon-vs-details-grid {
    gap: clamp(14px, 1.8vw, 22px) !important;
}

.icon-vs-detail-item {
    padding: 18px 22px !important;
    min-height: 86px !important;
    justify-content: center !important;
    border: 1px solid rgba(255, 208, 142, 0.12) !important;
    border-radius: 10px !important;
    background: linear-gradient(180deg, rgba(255,255,255,.052), rgba(255,255,255,.018)) !important;
}

.icon-vs-detail-label {
    display: block !important;
    margin-bottom: 10px !important;
    line-height: 1.15 !important;
}

.icon-vs-detail-value {
    display: block !important;
    line-height: 1.35 !important;
}

.icon-vs-cert-code {
    padding: 22px 24px !important;
    margin-top: 4px !important;
}

/* Keep long signer names readable without breaking the certificate layout. */
.icon-vs-details-grid .icon-vs-detail-item:first-child {
    min-height: auto !important;
}

.icon-vs-details-grid .icon-vs-detail-item:first-child .icon-vs-detail-value {
    white-space: normal !important;
    overflow-wrap: anywhere !important;
}

@media (max-width: 767px) {
    .icon-vs-card--valid::before {
        background-size: 82% auto !important;
        background-position: center 58% !important;
        opacity: 0.04 !important;
    }
    .icon-vs-detail-item {
        padding: 14px 16px !important;
        min-height: auto !important;
    }
    .icon-vs-detail-label {
        margin-bottom: 6px !important;
    }
    .icon-vs-cert-code {
        padding: 18px 16px !important;
    }
}

/* v1.3.2 — compact detail panels + full certificate body watermark */
.icon-vs-cert-body {
    position: relative !important;
    overflow: hidden !important;
    isolation: isolate !important;
}

/* Move the ICON Witnessed watermark from only the right/details area to the full body section. */
.icon-vs-cert-body::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    pointer-events: none !important;
    z-index: 0 !important;
    background-image: url('../images/icon-witnessed-logo.png') !important;
    background-repeat: no-repeat !important;
    background-position: center center !important;
    background-size: min(72%, 780px) auto !important;
    opacity: 0.045 !important;
    filter: saturate(1.08) contrast(1.05) !important;
}

/* Disable the older card-level watermark so it does not sit only in the details column. */
.icon-vs-card--valid::before {
    content: none !important;
    display: none !important;
}

.icon-vs-cert-image-col,
.icon-vs-cert-details-col {
    position: relative !important;
    z-index: 1 !important;
}

/* Keep the body panels dark, but slightly transparent so the watermark feels integrated behind both columns. */
.icon-vs-cert-image-col {
    background: rgba(10, 10, 10, 0.72) !important;
}

.icon-vs-cert-details-col {
    background: rgba(12, 12, 12, 0.58) !important;
}

/* Reduce excessive field padding/height so popup height stays compact. */
.icon-vs-details-grid {
    gap: 12px 16px !important;
}

.icon-vs-detail-item {
    padding: 12px 15px !important;
    min-height: 62px !important;
    justify-content: center !important;
    border-radius: 10px !important;
}

.icon-vs-detail-label {
    margin-bottom: 6px !important;
    font-size: 0.64rem !important;
    line-height: 1.12 !important;
}

.icon-vs-detail-value {
    font-size: 0.98rem !important;
    line-height: 1.25 !important;
}

.icon-vs-cert-code {
    padding: 16px 18px !important;
    margin-top: 2px !important;
}

.icon-vs-cert-label {
    margin-bottom: 6px !important;
}

@media (min-width: 901px) {
    .icon-vs-popup-body .icon-vs-cert-details-col,
    .icon-vs-cert-details-col {
        gap: 14px !important;
        padding: 24px 28px !important;
    }

    .icon-vs-popup-body .icon-vs-details-grid,
    .icon-vs-card .icon-vs-details-grid {
        gap: 12px 16px !important;
    }

    .icon-vs-popup-body .icon-vs-detail-item,
    .icon-vs-card .icon-vs-detail-item {
        padding: 12px 15px !important;
        min-height: 62px !important;
    }

    .icon-vs-popup-body .icon-vs-detail-value,
    .icon-vs-card .icon-vs-detail-value {
        font-size: 0.98rem !important;
        line-height: 1.25 !important;
    }
}

@media (max-width: 767px) {
    .icon-vs-cert-body::before {
        background-size: 95% auto !important;
        opacity: 0.035 !important;
    }

    .icon-vs-detail-item {
        padding: 12px 14px !important;
        min-height: auto !important;
    }

    .icon-vs-cert-code {
        padding: 15px 14px !important;
    }
}

/* v1.3.3 — professional integrated watermark polish */
.icon-vs-card--valid .icon-vs-cert-body,
.icon-vs-cert-body {
    position: relative !important;
    overflow: hidden !important;
    isolation: isolate !important;
    background:
        radial-gradient(circle at 38% 48%, rgba(255, 208, 142, 0.055), transparent 34%),
        linear-gradient(135deg, rgba(10,10,10,0.98), rgba(17,17,17,0.98)) !important;
}

/* Use ICON Witnessed as a subtle official certificate watermark behind BOTH columns. */
.icon-vs-card--valid .icon-vs-cert-body::before,
.icon-vs-cert-body::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    z-index: 0 !important;
    pointer-events: none !important;
    background-image: url('../images/icon-witnessed-logo.png') !important;
    background-repeat: no-repeat !important;
    background-position: 50% 52% !important;
    background-size: min(48%, 560px) auto !important;
    opacity: 0.026 !important;
    filter: grayscale(0.1) saturate(0.9) contrast(1.05) !important;
}

/* Soft overlay keeps watermark premium/subtle instead of looking like a pasted image. */
.icon-vs-cert-body::after {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    z-index: 0 !important;
    pointer-events: none !important;
    background:
        linear-gradient(90deg, rgba(8,8,8,0.78) 0%, rgba(8,8,8,0.28) 46%, rgba(8,8,8,0.55) 100%),
        radial-gradient(circle at center, transparent 0%, rgba(0,0,0,0.28) 72%) !important;
}

.icon-vs-cert-image-col,
.icon-vs-cert-details-col {
    position: relative !important;
    z-index: 2 !important;
}

/* Keep detail panels readable while preserving the watermark around the full body. */
.icon-vs-cert-details-col {
    background: rgba(11, 11, 11, 0.42) !important;
}

.icon-vs-cert-image-col {
    background: rgba(8, 8, 8, 0.50) !important;
}

.icon-vs-detail-item {
    background: linear-gradient(180deg, rgba(28,28,28,0.92), rgba(17,17,17,0.86)) !important;
    border: 1px solid rgba(255,208,142,0.22) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.035), 0 10px 24px rgba(0,0,0,0.18) !important;
}

.icon-vs-detail-label {
    color: rgba(255,208,142,0.9) !important;
}

@media (max-width: 767px) {
    .icon-vs-card--valid .icon-vs-cert-body::before,
    .icon-vs-cert-body::before {
        background-size: 78% auto !important;
        background-position: 50% 48% !important;
        opacity: 0.022 !important;
    }

    .icon-vs-cert-body::after {
        background: linear-gradient(180deg, rgba(8,8,8,0.70), rgba(8,8,8,0.42), rgba(8,8,8,0.72)) !important;
    }
}

/* v1.3.4 — Final premium visual polish pass
   Scope: frontend certificate/result, popup, verify page, forms, loading/error states.
   No verification logic changes. */

.icon-vs-card,
.icon-vs-form-inline,
.icon-vs-premium-wrap,
.icon-vs-loading,
.icon-vs-not-found {
    font-family: "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
}

/* Overall certificate/result card: more high-end authentication portal feel */
.icon-vs-card {
    border-radius: 22px !important;
    border: 1px solid rgba(255, 208, 142, 0.30) !important;
    background:
        linear-gradient(145deg, rgba(18,18,18,0.98), rgba(7,7,7,0.98)) !important;
    box-shadow:
        0 0 0 1px rgba(255,208,142,0.045),
        0 26px 70px rgba(0,0,0,0.72),
        0 0 42px rgba(255,208,142,0.055) !important;
}

/* Header hierarchy */
.icon-vs-cert-header {
    grid-template-columns: minmax(145px, 0.95fr) auto minmax(145px, 0.95fr) !important;
    gap: clamp(16px, 2.4vw, 34px) !important;
    padding: 22px 30px !important;
    background:
        radial-gradient(circle at 10% 0%, rgba(255,208,142,0.11), transparent 34%),
        linear-gradient(135deg, #070707 0%, #121212 100%) !important;
}

.icon-vs-cert-header::after {
    height: 2px !important;
    background: linear-gradient(90deg, transparent, rgba(255,208,142,0.15), #ffd08e, rgba(255,208,142,0.15), transparent) !important;
    opacity: 0.62 !important;
}

.icon-vs-cert-logo-img {
    max-width: 150px !important;
    max-height: 62px !important;
    object-fit: contain !important;
    filter: drop-shadow(0 5px 14px rgba(255,208,142,0.10)) !important;
}

.icon-vs-cert-brand-text {
    text-align: right !important;
}

.icon-vs-cert-logo-name {
    font-size: 0.82rem !important;
    letter-spacing: 0.14em !important;
    color: #ffd08e !important;
}

.icon-vs-cert-logo-tag {
    font-size: 0.52rem !important;
    letter-spacing: 0.18em !important;
    color: rgba(255,255,255,0.46) !important;
}

.icon-vs-cert-id {
    padding: 11px 22px !important;
    border-radius: 999px !important;
    background: linear-gradient(180deg, rgba(255,208,142,0.12), rgba(255,208,142,0.045)) !important;
    border: 1px solid rgba(255,208,142,0.35) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.04), 0 10px 26px rgba(0,0,0,0.28) !important;
}

.icon-vs-cert-id-label {
    font-size: 0.54rem !important;
    letter-spacing: 0.20em !important;
}

.icon-vs-cert-id-value {
    font-size: 1.02rem !important;
    letter-spacing: 0.09em !important;
}

/* Official authentication status band */
.icon-vs-status-bar {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    padding: 14px 30px !important;
    background:
        linear-gradient(90deg, rgba(255,208,142,0.085), rgba(255,255,255,0.018), rgba(255,208,142,0.055)) !important;
    border-bottom: 1px solid rgba(255,208,142,0.14) !important;
}

.icon-vs-status-bar-emblem {
    width: 38px !important;
    height: 38px !important;
    color: #ffd08e !important;
    filter: drop-shadow(0 0 14px rgba(255,208,142,0.20)) !important;
    flex: 0 0 auto !important;
}

.icon-vs-status-bar-label {
    display: block !important;
    color: #ffd08e !important;
    font-weight: 800 !important;
    letter-spacing: 0.10em !important;
    text-transform: uppercase !important;
    font-size: 0.92rem !important;
    line-height: 1.2 !important;
}

.icon-vs-status-bar-sub {
    display: block !important;
    color: rgba(255,255,255,0.55) !important;
    font-size: 0.72rem !important;
    line-height: 1.35 !important;
    margin-top: 2px !important;
}

/* Full-body watermark as official certification mark, not pasted artwork */
.icon-vs-card--valid .icon-vs-cert-body,
.icon-vs-cert-body {
    background:
        radial-gradient(circle at 50% 48%, rgba(255,208,142,0.055), transparent 34%),
        linear-gradient(135deg, rgba(8,8,8,0.98), rgba(17,17,17,0.99)) !important;
}

.icon-vs-card--valid .icon-vs-cert-body::before,
.icon-vs-cert-body::before {
    background-size: min(44%, 500px) auto !important;
    background-position: center center !important;
    opacity: 0.020 !important;
    filter: grayscale(0.08) saturate(0.8) contrast(1.05) !important;
}

.icon-vs-cert-body::after {
    background:
        radial-gradient(circle at 50% 50%, rgba(0,0,0,0.08), rgba(0,0,0,0.42) 72%),
        linear-gradient(90deg, rgba(7,7,7,0.70) 0%, rgba(7,7,7,0.18) 48%, rgba(7,7,7,0.62) 100%) !important;
}

/* Body spacing */
.icon-vs-cert-body {
    grid-template-columns: minmax(280px, 0.95fr) minmax(0, 1.55fr) !important;
}

.icon-vs-cert-image-col {
    padding: 28px !important;
    background: rgba(6,6,6,0.42) !important;
}

.icon-vs-cert-details-col {
    padding: 28px 30px !important;
    gap: 16px !important;
    background: rgba(8,8,8,0.30) !important;
}

.icon-vs-cert-frame {
    border-radius: 16px !important;
    background: #080808 !important;
    box-shadow:
        0 0 0 1px rgba(255,208,142,0.50),
        0 0 0 6px rgba(255,208,142,0.045),
        0 18px 44px rgba(0,0,0,0.66),
        inset 0 1px 0 rgba(255,255,255,0.04) !important;
}

.icon-vs-cert-frame img,
.icon-vs-item-image {
    aspect-ratio: 4 / 3 !important;
    object-fit: contain !important;
    background: #050505 !important;
}

.icon-vs-item-name {
    font-size: clamp(1.25rem, 2.1vw, 1.75rem) !important;
    font-weight: 760 !important;
    color: #ffffff !important;
    letter-spacing: -0.03em !important;
    margin-bottom: 2px !important;
}

/* Field cards: polished but compact */
.icon-vs-details-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
}

.icon-vs-detail-item {
    padding: 13px 15px !important;
    min-height: 62px !important;
    border-radius: 13px !important;
    border: 1px solid rgba(255,208,142,0.18) !important;
    background:
        linear-gradient(180deg, rgba(255,255,255,0.048), rgba(255,255,255,0.018)) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.035), 0 10px 20px rgba(0,0,0,0.18) !important;
}

.icon-vs-detail-item:hover {
    border-color: rgba(255,208,142,0.28) !important;
    background: linear-gradient(180deg, rgba(255,208,142,0.055), rgba(255,255,255,0.018)) !important;
}

.icon-vs-detail-label {
    color: rgba(255,208,142,0.92) !important;
    font-size: 0.61rem !important;
    letter-spacing: 0.14em !important;
    margin-bottom: 5px !important;
}

.icon-vs-detail-value {
    color: rgba(255,255,255,0.92) !important;
    font-size: 0.95rem !important;
    font-weight: 560 !important;
    line-height: 1.28 !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
}

.icon-vs-description {
    border-radius: 14px !important;
    border-color: rgba(255,208,142,0.14) !important;
    background: rgba(255,255,255,0.032) !important;
}

.icon-vs-cert-code {
    border-radius: 14px !important;
    padding: 15px 18px !important;
    background: linear-gradient(135deg, rgba(255,208,142,0.08), rgba(10,10,10,0.72)) !important;
    border: 1px solid rgba(255,208,142,0.28) !important;
}

.icon-vs-cert-value {
    font-size: 1.05rem !important;
    letter-spacing: 0.09em !important;
}

/* Footer and action buttons */
.icon-vs-cert-footer {
    padding: 14px 30px !important;
    background: linear-gradient(90deg, #080808, #111) !important;
}

.icon-vs-cert-footer-brand,
.icon-vs-cert-timestamp {
    color: rgba(255,255,255,0.60) !important;
}

.icon-vs-action-btns {
    padding: 16px 30px !important;
    justify-content: space-between !important;
    background: linear-gradient(180deg, #111, #0b0b0b) !important;
}

.icon-vs-btn {
    border-radius: 999px !important;
    padding: 11px 18px !important;
    font-weight: 700 !important;
}

.icon-vs-btn-primary {
    background: linear-gradient(135deg, #ffd08e, #d4a12f) !important;
    box-shadow: 0 12px 24px rgba(255,208,142,0.16) !important;
}

.icon-vs-btn-outline {
    border-color: rgba(255,208,142,0.22) !important;
    color: #ffd08e !important;
    background: rgba(255,208,142,0.04) !important;
}

.icon-vs-btn-outline:hover {
    background: rgba(255,208,142,0.10) !important;
    color: #ffd08e !important;
}

/* Popup: cleaner, less plugin-like */
.icon-vs-popup-backdrop {
    background: rgba(0,0,0,0.88) !important;
    backdrop-filter: blur(10px) saturate(1.1) !important;
    -webkit-backdrop-filter: blur(10px) saturate(1.1) !important;
}

.icon-vs-popup-modal {
    max-width: 890px !important;
    border-radius: 24px !important;
    border: 1px solid rgba(255,208,142,0.30) !important;
    overflow: visible !important;
    background: transparent !important;
}

.icon-vs-popup-body {
    max-height: 92vh !important;
    overflow-y: auto !important;
    border-radius: 24px !important;
}

.icon-vs-popup-close {
    top: -16px !important;
    right: -16px !important;
    width: 38px !important;
    height: 38px !important;
    background: linear-gradient(135deg, #ffd08e, #d4a12f) !important;
    color: #0b0b0b !important;
    border: 1px solid rgba(255,208,142,0.70) !important;
    box-shadow: 0 12px 28px rgba(0,0,0,0.45) !important;
}

/* Forms: luxury polish */
.icon-vs-form-inline,
.icon-vs-premium-wrap {
    border-radius: 22px !important;
    border-color: rgba(255,208,142,0.34) !important;
    background:
        radial-gradient(circle at top left, rgba(255,208,142,0.10), transparent 36%),
        linear-gradient(145deg, #101010, #181818) !important;
    box-shadow:
        0 0 0 1px rgba(255,208,142,0.045),
        0 22px 56px rgba(0,0,0,0.55),
        0 0 34px rgba(255,208,142,0.045) !important;
}

.icon-vs-form-title,
.icon-vs-premium-heading {
    color: #ffffff !important;
    font-weight: 760 !important;
}

.icon-vs-form-subtitle,
.icon-vs-premium-description,
.icon-vs-form-hint {
    color: rgba(255,255,255,0.58) !important;
}

.icon-vs-code-input,
.icon-vs-premium-input-group {
    border-color: rgba(255,208,142,0.33) !important;
    background: rgba(5,5,5,0.86) !important;
}

.icon-vs-code-input:focus,
.icon-vs-premium-input-group:focus-within {
    border-color: rgba(255,208,142,0.78) !important;
    box-shadow: 0 0 0 4px rgba(255,208,142,0.10), 0 0 28px rgba(255,208,142,0.08) !important;
}

.icon-vs-verify-btn,
.icon-vs-premium-btn {
    background: linear-gradient(135deg, #ffd08e, #d4a12f) !important;
    color: #0b0b0b !important;
    box-shadow: 0 12px 24px rgba(255,208,142,0.18) !important;
}

.icon-vs-verify-btn:hover,
.icon-vs-premium-btn:hover {
    filter: brightness(1.04) !important;
    transform: translateY(-1px) !important;
}

/* Better branded empty/loading/error states */
.icon-vs-loading,
.icon-vs-not-found {
    background:
        radial-gradient(circle at top, rgba(255,208,142,0.10), transparent 34%),
        linear-gradient(145deg, #101010, #171717) !important;
    border: 1px solid rgba(255,208,142,0.30) !important;
    border-radius: 22px !important;
    box-shadow: 0 24px 60px rgba(0,0,0,0.55) !important;
}

.icon-vs-not-found h2 {
    color: #ffd08e !important;
}

.icon-vs-error {
    border-radius: 14px !important;
}

/* Responsive polish */
@media (max-width: 767px) {
    .icon-vs-card {
        border-radius: 18px !important;
    }

    .icon-vs-cert-header {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
        padding: 18px 16px !important;
    }

    .icon-vs-cert-brand,
    .icon-vs-cert-brand-text {
        text-align: center !important;
    }

    .icon-vs-cert-logo-img {
        max-width: 128px !important;
        max-height: 54px !important;
        margin: 0 auto !important;
    }

    .icon-vs-cert-id {
        width: 100% !important;
    }

    .icon-vs-status-bar {
        padding: 13px 16px !important;
        align-items: flex-start !important;
    }

    .icon-vs-cert-body {
        grid-template-columns: 1fr !important;
    }

    .icon-vs-card--valid .icon-vs-cert-body::before,
    .icon-vs-cert-body::before {
        background-size: 72% auto !important;
        opacity: 0.018 !important;
    }

    .icon-vs-cert-image-col,
    .icon-vs-cert-details-col {
        padding: 18px !important;
    }

    .icon-vs-details-grid {
        grid-template-columns: 1fr !important;
    }

    .icon-vs-detail-item {
        min-height: auto !important;
    }

    .icon-vs-action-btns {
        padding: 14px 18px !important;
        flex-direction: column !important;
    }

    .icon-vs-popup {
        padding: 12px !important;
    }

    .icon-vs-popup-close {
        top: -12px !important;
        right: -8px !important;
    }
}
