.vdf-wrap,
.vdf-standalone {
	--vdf-primary: #030b29;
	--vdf-accent: #72d7f3;
	--vdf-gold: #a7905d;
	--vdf-blue: #1f9ed1;
	--vdf-indigo: #2b378b;
	--vdf-line: #e7e9ee;
	--vdf-muted: #667085;
	color: #172033;
	font-family: Tajawal, Inter, system-ui, sans-serif;
}

.vdf-wrap *,
.vdf-standalone * {
	box-sizing: border-box;
}

.vdf-wrap {
	width: min(1240px, calc(100% - 32px));
	max-width: 1240px;
	margin: 32px auto;
}

.vdf-access {
	position: relative;
	display: grid;
	grid-template-columns: minmax(300px, .92fr) minmax(360px, .72fr);
	gap: clamp(22px, 3vw, 42px);
	overflow: hidden;
	padding: clamp(24px, 3vw, 42px);
	border-radius: 34px;
	background:
		radial-gradient(circle at 88% 14%, rgba(114, 215, 243, .22), transparent 28%),
		radial-gradient(circle at 12% 90%, rgba(167, 144, 93, .20), transparent 28%),
		linear-gradient(135deg, #030b29 0%, #07143d 57%, #10247a 100%);
	box-shadow: 0 28px 80px rgba(3, 11, 41, .28);
}

.vdf-access::before {
	content: "";
	position: absolute;
	inset: 0;
	background: url("https://thedivex.com/wp-content/uploads/2026/06/Pattern-02-scaled.webp") right center / auto 120% no-repeat;
	opacity: .055;
	pointer-events: none;
}

.vdf-access > * {
	position: relative;
	z-index: 1;
}

.vdf-access-hero {
	min-height: 500px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 20px 8px 20px 18px;
	color: #fff;
}

.vdf-access-logo {
	width: min(310px, 70%);
	max-height: 86px;
	object-fit: contain;
	object-position: left center;
	margin-bottom: 28px;
	filter: drop-shadow(0 14px 24px rgba(0, 0, 0, .24));
}

.vdf-dash-logo {
	width: min(240px, 60%);
	max-height: 62px;
	object-fit: contain;
	object-position: left center;
	margin-bottom: 18px;
	filter: drop-shadow(0 12px 22px rgba(0, 0, 0, .22));
}

.vdf-access-hero .vdf-kicker,
.vdf-access-hero h2 {
	color: #fff;
}

.vdf-access-hero .vdf-kicker {
	color: #d8c18c;
}

.vdf-access-hero h2 {
	max-width: 560px;
	margin: 0;
	font: 700 clamp(34px, 4vw, 54px)/1 Alexandria, Tajawal, system-ui, sans-serif;
	letter-spacing: -.045em;
}

.vdf-access-hero p {
	max-width: 560px;
	margin: 22px 0 0;
	color: rgba(238, 249, 255, .72);
	font-size: 18px;
	line-height: 1.65;
}

.vdf-access-steps {
	display: grid;
	gap: 12px;
	max-width: 440px;
	margin-top: 36px;
}

.vdf-event-panel {
	display: grid;
	gap: 10px;
	margin-top: 24px;
}

.vdf-event-panel div {
	padding: 12px 14px;
	border: 1px solid rgba(114, 215, 243, .22);
	border-radius: 16px;
	background: rgba(255, 255, 255, .075);
}

.vdf-details .vdf-event-panel {
	margin-top: 22px;
}

.vdf-details .vdf-event-panel div {
	border-color: #e7e9ee;
	background: #f8fafc;
}

.vdf-event-panel small {
	display: block;
	margin-bottom: 3px;
	color: rgba(255, 255, 255, .54);
	font: 800 10px Alexandria, sans-serif;
	letter-spacing: .13em;
	text-transform: uppercase;
}

.vdf-details .vdf-event-panel small {
	color: #667085;
}

.vdf-event-panel strong,
.vdf-event-panel a {
	color: #fff;
	font-weight: 800;
	text-decoration: none;
}

.vdf-details .vdf-event-panel strong,
.vdf-details .vdf-event-panel a {
	color: #030b29;
}

.vdf-access-steps span {
	display: flex;
	align-items: center;
	gap: 13px;
	padding: 12px 14px;
	border: 1px solid rgba(255, 255, 255, .13);
	border-radius: 100px;
	background: rgba(255, 255, 255, .055);
	color: rgba(255, 255, 255, .84);
}

.vdf-access-steps b {
	width: 32px;
	height: 32px;
	display: grid;
	place-items: center;
	border-radius: 50%;
	background: rgba(114, 215, 243, .14);
	color: #72d7f3;
	font: 800 11px Alexandria, sans-serif;
}

.vdf-login {
	display: grid;
	min-height: 520px;
	place-items: center;
	padding: 24px;
	border-radius: 28px;
	background: radial-gradient(circle at 90% 5%, rgba(114, 215, 243, .22), transparent 28%), linear-gradient(145deg, #030b29, #07143d 56%, #071747);
}

.vdf-card {
	width: min(100%, 500px);
	padding: 42px;
	border: 1px solid rgba(255, 255, 255, .12);
	border-radius: 24px;
	background: rgba(255, 255, 255, .98);
	box-shadow: 0 24px 70px rgba(0, 0, 0, .24);
}

.vdf-access-card {
	align-self: center;
	justify-self: end;
	width: min(100%, 540px);
	border-color: rgba(255, 255, 255, .20);
	background: rgba(255, 255, 255, .96);
	backdrop-filter: blur(14px);
}

.vdf-card h2,
.vdf-dashboard h2,
.vdf-details h3 {
	margin: 0;
	color: var(--vdf-primary);
	font-family: Alexandria, Tajawal, system-ui, sans-serif;
}

.vdf-kicker {
	margin: 0 0 8px;
	color: var(--vdf-primary);
	font-family: Alexandria, Tajawal, system-ui, sans-serif;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: .16em;
	text-transform: uppercase;
}

.vdf-card p {
	line-height: 1.55;
}

.vdf-card form {
	display: grid;
	gap: 14px;
	margin-top: 24px;
}

.vdf-card label {
	font-size: 14px;
	font-weight: 700;
}

.vdf-card input {
	display: block;
	width: 100%;
	min-height: 48px;
	margin-top: 6px;
	padding: 10px 14px;
	border: 1px solid #cfd4dc;
	border-radius: 10px;
	font: inherit;
}

.vdf-card input:focus {
	outline: none;
	border-color: #72d7f3;
	box-shadow: 0 0 0 4px rgba(114, 215, 243, .18);
}

.vdf-two {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 12px;
}

.vdf-or {
	display: flex;
	align-items: center;
	gap: 12px;
	color: #667085;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: .08em;
	text-transform: uppercase;
}

.vdf-or::before,
.vdf-or::after {
	content: "";
	height: 1px;
	flex: 1;
	background: #e7e9ee;
}

.vdf-button {
	display: inline-flex;
	min-height: 46px;
	align-items: center;
	justify-content: center;
	padding: 10px 18px;
	border: 1px solid var(--vdf-primary) !important;
	border-radius: 10px;
	background: var(--vdf-primary) !important;
	color: #fff !important;
	cursor: pointer;
	font: 800 14px Alexandria, Tajawal, system-ui, sans-serif;
	text-decoration: none !important;
	box-shadow: none !important;
	transition: background .18s ease, border-color .18s ease, color .18s ease, transform .18s ease;
}

.vdf-copy-code {
	width: 42px;
	height: 42px;
	flex: 0 0 42px;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	padding: 0 !important;
	border: 1px solid rgba(114, 215, 243, .38) !important;
	border-radius: 12px;
	background: rgba(255, 255, 255, .08) !important;
	color: #fff !important;
	cursor: pointer;
	line-height: 1 !important;
	vertical-align: middle;
}

.vdf-copy-code svg {
	width: 22px;
	height: 22px;
	display: block;
	fill: none;
	stroke: currentColor;
	stroke-width: 1.9;
	stroke-linecap: round;
	stroke-linejoin: round;
	pointer-events: none;
}

.vdf-copy-code > span {
	position: absolute;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(0 0 0 0);
	white-space: nowrap;
}

.vdf-copy-code:hover,
.vdf-copy-code:focus {
	border-color: #72d7f3 !important;
	background: rgba(114, 215, 243, .18) !important;
	color: #fff !important;
}

.vdf-secondary {
	background: #fff !important;
	color: var(--vdf-primary) !important;
}

.vdf-wrap .vdf-button:hover,
.vdf-wrap .vdf-button:focus,
.vdf-wrap .vdf-button:active,
.vdf-standalone .vdf-button:hover,
.vdf-standalone .vdf-button:focus,
.vdf-standalone .vdf-button:active,
.vdf-wrap button.vdf-button:hover,
.vdf-wrap button.vdf-button:focus,
.vdf-wrap button.vdf-button:active {
	border-color: #1f9ed1 !important;
	background: #1f9ed1 !important;
	color: #fff !important;
	transform: translateY(-1px);
}

.vdf-wrap .vdf-secondary:hover,
.vdf-wrap .vdf-secondary:focus,
.vdf-wrap .vdf-secondary:active,
.vdf-standalone .vdf-secondary:hover,
.vdf-standalone .vdf-secondary:focus,
.vdf-standalone .vdf-secondary:active {
	border-color: #72d7f3 !important;
	background: #eefbff !important;
	color: #030b29 !important;
}

.vdf-alert {
	margin: 16px 0;
	padding: 12px;
	border: 1px solid #fecaca;
	background: #fff1f2;
	color: #9f1239;
}

.vdf-link {
	border: 0 !important;
	background: transparent !important;
	color: var(--vdf-primary) !important;
	cursor: pointer;
	font-weight: 700;
}

.vdf-dash-hero .vdf-link {
	min-height: 42px;
	padding: 0 16px;
	border: 1px solid rgba(255, 255, 255, .24) !important;
	border-radius: 999px;
	background: rgba(255, 255, 255, .08) !important;
	color: #fff !important;
}

.vdf-dash-hero .vdf-link:hover,
.vdf-dash-hero .vdf-link:focus,
.vdf-dash-hero .vdf-link:active {
	border-color: #72d7f3 !important;
	background: rgba(114, 215, 243, .18) !important;
	color: #fff !important;
}

.vdf-dashboard {
	position: relative;
	overflow: hidden;
	padding: 34px;
	border: 1px solid rgba(255, 255, 255, .12);
	border-radius: 34px;
	background:
		radial-gradient(circle at 88% 4%, rgba(114, 215, 243, .18), transparent 30%),
		linear-gradient(145deg, #030b29, #07143d 55%, #071747);
	box-shadow: 0 28px 80px rgba(3, 11, 41, .22);
}

.vdf-dashboard > header {
	display: flex;
	gap: 18px;
	justify-content: space-between;
	margin-bottom: 28px;
}

.vdf-dash-hero {
	align-items: flex-start;
	padding: 28px;
	border: 1px solid rgba(255, 255, 255, .12);
	border-radius: 26px;
	background: rgba(255, 255, 255, .055);
	color: #fff;
}

.vdf-dash-hero .vdf-kicker,
.vdf-dash-hero h2 {
	color: #fff;
}

.vdf-dash-hero .vdf-kicker {
	color: #d8c18c;
}

.vdf-dash-hero h2 {
	font-size: clamp(32px, 4vw, 58px);
	letter-spacing: -.055em;
}

.vdf-dash-hero p {
	max-width: 620px;
	margin: 10px 0 0;
	color: rgba(238, 249, 255, .70);
}

.vdf-code-box {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	margin-top: 18px;
	padding: 12px 14px;
	border: 1px solid rgba(114, 215, 243, .35);
	border-radius: 16px;
	background: rgba(114, 215, 243, .11);
}

.vdf-code-box span {
	color: rgba(255, 255, 255, .70);
	font: 700 11px Alexandria, sans-serif;
	letter-spacing: .14em;
	text-transform: uppercase;
}

.vdf-code-box code {
	color: #030b29;
	padding: 8px 10px;
	border-radius: 10px;
	background: #72d7f3;
	font: 900 16px ui-monospace, SFMono-Regular, Consolas, monospace;
	letter-spacing: .04em;
}

.vdf-code-box.is-copied {
	box-shadow: 0 0 0 4px rgba(114, 215, 243, .14);
}

.vdf-grid {
	display: grid;
	grid-template-columns: minmax(250px, .72fr) minmax(360px, 1fr);
	gap: 28px;
	align-items: start;
}

.vdf-info-column {
	display: grid;
	gap: 18px;
	align-items: start;
}

.vdf-details {
	padding: 26px;
	border: 1px solid rgba(255, 255, 255, .16);
	border-radius: 22px;
	background: rgba(255, 255, 255, .96);
	box-shadow: 0 18px 50px rgba(0, 0, 0, .16);
}

.vdf-details dl {
	margin: 16px 0 0;
}

.vdf-details dl > div {
	padding: 11px 0;
	border-bottom: 1px solid var(--vdf-line);
}

.vdf-details dt {
	color: var(--vdf-muted);
	font-size: 12px;
	font-weight: 700;
	text-transform: uppercase;
}

.vdf-details dd {
	margin: 3px 0 0;
	font-weight: 650;
}

.vdf-event-card {
	padding: 24px 26px;
	border: 1px solid rgba(255, 255, 255, .16);
	border-radius: 22px;
	background: rgba(255, 255, 255, .96);
	box-shadow: 0 18px 50px rgba(0, 0, 0, .14);
}

.vdf-event-card h3 {
	margin: 0 0 14px;
	color: #030b29;
	font-size: 24px;
}

.vdf-event-card .vdf-event-panel {
	margin-top: 0;
}

.vdf-event-card .vdf-event-panel div {
	border-color: #e7e9ee;
	background: #f8fafc;
}

.vdf-event-card .vdf-event-panel small {
	color: #667085;
}

.vdf-event-card .vdf-event-panel strong,
.vdf-event-card .vdf-event-panel a {
	color: #030b29;
}

.vdf-badge-shell {
	width: 100%;
}

.divex-badge-frame {
	width: min(100%, 430px);
	margin: 0 auto;
}

.divex-badge-viewport {
	position: relative;
	width: 100%;
	height: 573px;
}

.divex-badge-card {
	position: absolute;
	top: 0;
	left: 0;
	width: 1063px;
	height: 1417px;
	transform: scale(.4045);
	transform-origin: top left;
	overflow: hidden;
	border-radius: 54px;
	background: #fff;
	box-shadow: 0 55px 150px rgba(0, 0, 0, .28);
	text-align: center;
	contain: layout paint;
	font-family: Tajawal, sans-serif;
}

.divex-badge-top {
	position: relative;
	height: 270px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 48px 70px;
	background:
		radial-gradient(circle at 86% 10%, rgba(31, 158, 209, .50), transparent 34%),
		linear-gradient(135deg, #030b29 0%, #071747 58%, #2b378b 100%);
}

.divex-badge-top::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 10px;
	background: linear-gradient(90deg, #a7905d, #72d7f3, #1f9ed1);
}

.divex-badge-top img {
	width: 610px;
	max-height: 150px;
	object-fit: contain;
	filter: none;
}

.divex-badge-content {
	position: relative;
	isolation: isolate;
	height: 947px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 55px 72px 46px;
	background: #fff;
}

.divex-badge-content::before {
	display: none;
}

.divex-badge-content::after {
	content: "";
	position: absolute;
	z-index: 2;
	inset: 0;
	background: linear-gradient(180deg, rgba(255, 255, 255, .62), rgba(255, 255, 255, .48) 52%, rgba(255, 255, 255, .65));
}

.divex-badge-pattern {
	position: absolute;
	z-index: 0;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: .42;
	filter: saturate(1.55) contrast(1.15);
	pointer-events: none;
}

.divex-badge-watermark {
	position: absolute;
	z-index: 1;
	left: -72px;
	right: -72px;
	top: 430px;
	color: rgba(43, 55, 139, .045);
	font: 900 210px/.82 Alexandria, sans-serif;
	letter-spacing: -.08em;
	text-transform: uppercase;
	text-align: center;
	white-space: nowrap;
	pointer-events: none;
}

.badge-small-label,
.badge-info,
.divex-badge-qr-wrap {
	position: relative;
	z-index: 3;
}

.badge-small-label {
	display: inline-block;
	margin-bottom: 35px;
	color: #a7905d;
	font: 700 27px Alexandria, sans-serif;
	letter-spacing: 5px;
}

.badge-info {
	width: 100%;
	margin-bottom: 24px;
}

.badge-info small {
	display: block;
	margin-bottom: 12px;
	color: #2b378b;
	font: 700 22px Alexandria, sans-serif;
	letter-spacing: 2.4px;
}

.badge-info h3 {
	height: 122px;
	margin: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	color: #030b29;
	font: 700 62px/1.02 Alexandria, sans-serif;
	letter-spacing: -2.5px;
	text-transform: uppercase;
	overflow-wrap: anywhere;
}

.badge-info p {
	height: 78px;
	margin: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	color: #1f9ed1;
	font: 700 46px/1.06 Alexandria, sans-serif;
	text-transform: uppercase;
	overflow-wrap: anywhere;
}

.badge-company-name {
	color: #2b378b !important;
}

.divex-badge-qr-wrap {
	display: flex;
	gap: 35px;
	align-items: center;
	justify-content: center;
	margin-top: auto;
}

.divex-badge-qr {
	width: 220px;
	height: 220px;
	flex: 0 0 220px;
	display: grid;
	place-items: center;
	overflow: hidden;
	padding: 14px;
	border: 3px solid rgba(43, 55, 139, .16);
	border-radius: 24px;
	background: #fff;
	box-shadow: 0 22px 55px rgba(3, 11, 41, .12);
}

.divex-badge-qr canvas {
	width: 100% !important;
	height: 100% !important;
	display: block !important;
}

.divex-badge-qr img {
	width: 100% !important;
	height: 100% !important;
}

.divex-badge-qr-copy {
	max-width: 310px;
	text-align: left;
}

.divex-badge-qr-copy strong {
	display: block;
	color: #030b29;
	font: 700 27px/1.25 Alexandria, sans-serif;
}

.divex-badge-qr-copy span {
	display: block;
	margin-top: 10px;
	color: #2b378b;
	font: 500 21px/1.4 Tajawal, sans-serif;
}

.divex-badge-qr-copy code {
	display: inline-flex;
	margin-top: 18px;
	padding: 12px 16px;
	border-radius: 14px;
	background: #f2c04c;
	color: #030b29;
	font: 800 21px ui-monospace, SFMono-Regular, Consolas, monospace;
	letter-spacing: .04em;
}

.divex-badge-footer {
	height: 200px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 9px;
	padding: 30px 70px 28px;
	background: linear-gradient(135deg, #1f9ed1 0%, #2b378b 72%, #030b29 100%);
	color: #fff;
}

.divex-badge-type {
	font: 700 62px/1 Alexandria, sans-serif;
	letter-spacing: 8px;
}

.divex-badge-website {
	color: #fff !important;
	text-decoration: none !important;
	font: 600 28px Alexandria, sans-serif;
	letter-spacing: 1.5px;
}

.divex-badge-code {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 9px 18px;
	border-radius: 999px;
	background: rgba(255, 255, 255, .14);
	color: #fff;
	font: 800 23px Alexandria, sans-serif;
	letter-spacing: .05em;
}

.vdf-actions {
	display: flex;
	justify-content: center;
	gap: 10px;
	margin-top: 18px;
}

.vdf-status {
	min-height: 20px;
	margin: 10px 0 0;
	color: var(--vdf-muted);
	font-size: 13px;
	text-align: center;
}

.vdf-standalone {
	display: grid;
	min-height: 100vh;
	margin: 0;
	place-items: center;
	background: #eef1f5;
}

.vdf-standalone main {
	width: min(500px, calc(100vw - 32px));
	padding: 24px 0;
}

.vdf-site-footer {
	width: min(1240px, calc(100% - 32px));
	margin: -10px auto 34px;
	padding: 14px 20px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 6px 10px;
	color: #667085;
	text-align: center;
	font-size: 13px;
}

.vdf-site-footer a {
	color: #1f9ed1;
	font-weight: 800;
	text-decoration: none;
}

.vdf-site-footer a:hover {
	color: #030b29;
	text-decoration: underline;
}

@media (max-width: 1180px) {
	.vdf-access {
		grid-template-columns: minmax(300px, .82fr) minmax(340px, .72fr);
	}

	.vdf-card {
		padding: 34px;
	}

	.vdf-grid {
		grid-template-columns: minmax(250px, .82fr) minmax(360px, 1fr);
	}

	.divex-badge-frame {
		width: min(100%, 395px);
	}
}

@media (max-width: 880px) {
	.vdf-access {
		grid-template-columns: 1fr;
		padding: 24px;
	}

	.vdf-access-hero {
		min-height: auto;
		padding: 20px 4px;
	}

	.vdf-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 560px) {
	.vdf-dashboard,
	.vdf-login {
		padding: 18px;
	}

	.vdf-card {
		padding: 28px;
	}

	.vdf-two {
		grid-template-columns: 1fr;
	}

	.vdf-dashboard > header {
		flex-direction: column;
	}

	.vdf-code-box {
		align-items: flex-start;
		flex-direction: column;
	}

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