/* 
 * BDEO 2026 Registration System - Modern Clean Design
 * Minimal gradients, clean layout, responsive
 */

/* ===== GOOGLE FONTS ===== */
@import url("https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=Outfit:wght@300;400;500;600;700&family=Rubik:wght@300;400;500;600;700&display=swap");

/* ===== CSS VARIABLES ===== */
:root {
	--primary-color: #2c3e50;
	--secondary-color: #4a90e2;
	--success-color: #27ae60;
	--error-color: #e74c3c;
	--warning-color: #f39c12;
	--background-color: #f8f9fa;
	--white: #ffffff;
	--text-color: #2d3748;
	--text-light: #718096;
	--text-muted: #a0aec0;
	--border-color: #e2e8f0;
	--input-border: #cbd5e0;
	--shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.05);
	--shadow: 0 4px 6px rgba(0, 0, 0, 0.07);
	--shadow-lg: 0 10px 25px rgba(0, 0, 0, 0.1);
	--border-radius: 12px;
	--border-radius-sm: 8px;
	--transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ===== RESET & BASE STYLES ===== */
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

body {
	font-family: "Outfit", "Rubik", ui-sans-serif, system-ui, -apple-system,
		sans-serif;
	line-height: 1.6;
	color: var(--text-color);
	background: var(--background-color);
	min-height: 100vh;
	padding: 20px;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* ===== CONTAINER ===== */
.container {
	max-width: 680px;
	margin: 0 auto;
}

/* ===== REGISTRATION WRAPPER ===== */
.registration-wrapper,
.thankyou-wrapper {
	background: var(--white);
	border-radius: var(--border-radius);
	box-shadow: var(--shadow-lg);
	padding: 50px 45px;
	margin-bottom: 40px;
}

/* ===== LOGO ===== */
.logo-container {
	text-align: center;
	margin-bottom: 35px;
}

.logo-placeholder {
	width: 120px;
	height: 120px;
	margin: 0 auto 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	/* border-radius: 20px;
	box-shadow: var(--shadow); */
}

.logo-placeholder img {
	max-width: 98%;
	max-height: 98%;
	object-fit: contain;
	border-radius: 20px;
}

.logo-placeholder-text {
	color: var(--white);
	font-family: "Syne", sans-serif;
	font-size: 2rem;
	font-weight: 700;
	letter-spacing: 1px;
}

/* ===== ANIMATIONS ===== */
@keyframes shake {
	0%,
	100% {
		transform: translateX(0);
	}
	10%,
	30%,
	50%,
	70%,
	90% {
		transform: translateX(-8px);
	}
	20%,
	40%,
	60%,
	80% {
		transform: translateX(8px);
	}
}

.shake {
	animation: shake 0.5s;
}

/* ===== HEADER ===== */
.header {
	text-align: center;
	margin-bottom: 40px;
}

.header h1 {
	font-family: "Syne", sans-serif;
	color: var(--primary-color);
	font-size: 2rem;
	margin-bottom: 12px;
	font-weight: 700;
	letter-spacing: -0.5px;
}

.header-subtitle {
	font-size: 1.05rem;
	color: var(--text-light);
	font-weight: 400;
	margin-bottom: 8px;
}

.subtitle {
	color: var(--text-light);
	font-size: 0.95rem;
	line-height: 1.7;
	margin-top: 20px;
}

.subtitle p {
	margin-bottom: 12px;
	text-align: left;
}

.prep-link {
	text-align: center;
	margin-top: 20px;
	margin-bottom: 0;
}

.btn-link {
	color: var(--secondary-color);
	text-decoration: none;
	font-weight: 600;
	font-size: 0.95rem;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	transition: var(--transition);
}

.btn-link:hover {
	color: #3a7bc8;
	text-decoration: underline;
}

/* ===== IMPORTANT DATES & CONTACT INFO ===== */
.important-dates,
.contact-info {
	background: #f8fafc;
	border: 1px solid #e2e8f0;
	border-left: 4px solid var(--secondary-color);
	padding: 24px 24px;
	margin-bottom: 28px;
	border-radius: var(--border-radius-sm);
	box-shadow: var(--shadow-sm);
	transition: var(--transition);
}

.important-dates:hover,
.contact-info:hover {
	box-shadow: var(--shadow);
	border-left-width: 5px;
}

.important-dates h3,
.contact-info h3 {
	font-family: "Syne", sans-serif;
	color: var(--primary-color);
	font-size: 1.25rem;
	margin-bottom: 16px;
	font-weight: 600;
	letter-spacing: -0.3px;
}

.important-dates ul {
	list-style: none;
	margin-left: 0;
}

.important-dates li {
	margin-bottom: 14px;
	padding: 10px 12px;
	padding-left: 44px;
	position: relative;
	font-size: 0.95rem;
	background: white;
	border-radius: 6px;
	line-height: 1.5;
	transition: var(--transition);
	border: 1px solid transparent;
}

.important-dates li:hover {
	background: #fefefe;
	border-color: var(--border-color);
	transform: translateX(4px);
	box-shadow: var(--shadow-sm);
}

.important-dates li::before {
	content: "";
	position: absolute;
	left: 12px;
	top: 50%;
	transform: translateY(-50%);
	width: 24px;
	height: 24px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ef4444' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E");
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
}

.important-dates li strong {
	color: var(--primary-color);
	font-weight: 600;
}

.note {
	font-size: 0.875rem;
	color: var(--text-muted);
	margin-top: 16px;
	font-style: italic;
	line-height: 1.6;
	padding: 12px;
	background: white;
	border-radius: 6px;
}

.contact-info p {
	margin-bottom: 12px;
	font-size: 0.95rem;
	display: flex;
	align-items: center;
	gap: 8px;
}

.contact-info strong {
	color: var(--primary-color);
	font-weight: 600;
	min-width: 85px;
}

.contact-info a {
	color: var(--secondary-color);
	text-decoration: none;
	font-weight: 500;
	transition: var(--transition);
}

.contact-info a:hover {
	color: #3a7bc8;
	text-decoration: underline;
}

/* ===== FORM SEPARATOR ===== */
.form-separator {
	height: 1px;
	background: linear-gradient(
		to right,
		transparent,
		var(--border-color),
		transparent
	);
	margin: 35px 0;
}

/* ===== FORM STYLES ===== */
.form-group {
	margin-bottom: 24px;
}

/* ===== ALERT MESSAGES ===== */
.alert {
	padding: 16px 20px;
	border-radius: var(--border-radius-sm);
	margin-bottom: 24px;
	font-size: 0.95rem;
	line-height: 1.6;
	border-left: 4px solid;
}

.alert strong {
	font-weight: 600;
}

.alert-error {
	background: #fef2f2;
	color: #991b1b;
	border-left-color: var(--error-color);
}

.alert-success {
	background: #f0fdf4;
	color: #166534;
	border-left-color: var(--success-color);
}

.form-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
}

label {
	display: block;
	font-weight: 500;
	color: var(--text-color);
	margin-bottom: 8px;
	font-size: 0.95rem;
}

.required {
	color: var(--error-color);
	font-weight: 600;
}

.form-control,
select {
	width: 100%;
	padding: 12px 16px;
	border: 2px solid var(--input-border);
	border-radius: var(--border-radius-sm);
	font-size: 1rem;
	font-family: inherit;
	transition: var(--transition);
	background: var(--white);
	color: var(--text-color);
}

.form-control::placeholder,
select::placeholder {
	color: var(--text-muted);
}

.form-control:focus,
select:focus {
	outline: none;
	border-color: var(--secondary-color);
	box-shadow: 0 0 0 3px rgba(74, 144, 226, 0.1);
}

.form-control.error,
select.error {
	border-color: var(--error-color);
	background: #fff5f5;
}

.form-control.error:focus,
select.error:focus {
	box-shadow: 0 0 0 3px rgba(231, 76, 60, 0.1);
}

/* ===== PHONE INPUT GROUP ===== */
.phone-input-group {
	display: flex;
	align-items: stretch;
	gap: 0;
	position: relative;
	border: 2px solid var(--border-color);
	border-radius: var(--border-radius-sm);
	background: var(--white);
	transition: var(--transition);
}

.phone-input-group:focus-within {
	border-color: var(--secondary-color);
	box-shadow: 0 0 0 3px rgba(66, 153, 225, 0.1);
}

.phone-prefix {
	background: transparent;
	color: var(--text-color);
	padding: 12px 16px;
	font-weight: 500;
	white-space: nowrap;
	display: flex;
	align-items: center;
	border: none;
	position: relative;
	font-size: 0.95rem;
}

.phone-prefix::after {
	content: "";
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 1px;
	height: 24px;
	background: var(--border-color);
}

.phone-input {
	border: none !important;
	border-radius: 0 var(--border-radius-sm) var(--border-radius-sm) 0 !important;
	flex: 1;
	padding-left: 16px !important;
	box-shadow: none !important;
}

.phone-input:focus {
	outline: none !important;
	box-shadow: none !important;
}

.help-text {
	display: block;
	font-size: 0.85rem;
	color: var(--text-muted);
	margin-top: 6px;
}

/* ===== ERROR MESSAGE ===== */
.error-message {
	display: block;
	color: var(--error-color);
	font-size: 0.875rem;
	margin-top: 6px;
	font-weight: 500;
}

/* ===== CHECKBOX GROUP ===== */
.checkbox-group {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 10px;
	margin-top: 10px;
}

.checkbox-label {
	display: flex;
	align-items: center;
	gap: 10px;
	font-weight: 400;
	cursor: pointer;
	padding: 10px 12px;
	border-radius: var(--border-radius-sm);
	transition: var(--transition);
	border: 1px solid transparent;
}

.checkbox-label:hover {
	background: var(--background-color);
	border-color: var(--border-color);
}

.checkbox-label input[type="checkbox"] {
	width: 20px;
	height: 20px;
	cursor: pointer;
	accent-color: var(--secondary-color);
	border-radius: 4px;
}

/* ===== RADIO GROUP ===== */
.radio-group {
	display: flex;
	gap: 20px;
	margin-top: 10px;
}

.radio-label {
	display: flex;
	align-items: center;
	gap: 10px;
	font-weight: 400;
	cursor: pointer;
	padding: 10px 20px;
	border-radius: var(--border-radius-sm);
	transition: var(--transition);
	border: 2px solid var(--border-color);
	background: var(--white);
}

.radio-label:hover {
	background: var(--background-color);
	border-color: var(--secondary-color);
}

.radio-label input[type="radio"] {
	width: 20px;
	height: 20px;
	cursor: pointer;
	accent-color: var(--secondary-color);
}

.radio-label input[type="radio"]:checked + * {
	font-weight: 600;
}

.radio-label:has(input[type="radio"]:checked) {
	border-color: var(--secondary-color);
	background: rgba(66, 153, 225, 0.05);
}

.inline-input {
	margin-left: 5px;
	padding: 8px 12px;
	width: 180px;
	display: inline-block;
	border: 2px solid var(--input-border);
	border-radius: var(--border-radius-sm);
	font-size: 0.95rem;
}

/* ===== TERMS BOX ===== */
.terms-box {
	background: #f8fafc;
	padding: 24px;
	border-radius: var(--border-radius-sm);
	margin-bottom: 18px;
	border: 1px solid #e2e8f0;
	box-shadow: var(--shadow-sm);
}

.terms-box h4 {
	font-family: "Syne", sans-serif;
	color: var(--primary-color);
	margin-bottom: 14px;
	font-size: 1.15rem;
	font-weight: 600;
	letter-spacing: -0.3px;
}

.terms-box p {
	font-size: 0.925rem;
	line-height: 1.75;
	color: var(--text-color);
}

.terms-checkbox {
	padding: 16px 18px;
	background: linear-gradient(to right, #fffbeb, #fefcf3);
	border: 1px solid #fde68a;
	border-left: 4px solid var(--warning-color);
	border-radius: var(--border-radius-sm);
	display: flex;
	align-items: start;
	gap: 12px;
	box-shadow: var(--shadow-sm);
	transition: var(--transition);
}

.terms-checkbox:hover {
	background: linear-gradient(to right, #fef3c7, #fffbeb);
	border-color: #fbbf24;
}

.terms-checkbox input[type="checkbox"] {
	margin-top: 3px;
	width: 20px;
	height: 20px;
	accent-color: var(--warning-color);
	flex-shrink: 0;
	cursor: pointer;
}

.terms-checkbox label {
	margin: 0;
	font-weight: 500;
	color: var(--text-color);
	cursor: pointer;
	line-height: 1.5;
}

/* ===== reCAPTCHA ===== */
.g-recaptcha {
	margin: 15px 0;
	display: inline-block;
}

/* ===== BUTTONS ===== */
.btn-submit,
.btn-secondary,
.btn-social {
	display: inline-block;
	padding: 14px 32px;
	font-size: 1.05rem;
	font-weight: 600;
	text-align: center;
	text-decoration: none;
	border: none;
	border-radius: var(--border-radius-sm);
	cursor: pointer;
	transition: var(--transition);
	font-family: "Syne", sans-serif;
	letter-spacing: 0.3px;
}

.btn-submit {
	width: 100%;
	background: var(--secondary-color);
	color: var(--white);
	box-shadow: var(--shadow);
	margin-top: 10px;
}

.btn-submit:hover {
	background: #3a7bc8;
	transform: translateY(-1px);
	box-shadow: var(--shadow-lg);
}

.btn-submit:active {
	transform: translateY(0);
}

.btn-secondary {
	background: var(--primary-color);
	color: var(--white);
	box-shadow: var(--shadow);
}

.btn-secondary:hover {
	background: #1a252f;
	transform: translateY(-1px);
	box-shadow: var(--shadow-lg);
}

.btn-social {
	background: #4267b2;
	color: var(--white);
	box-shadow: var(--shadow);
}

.btn-social:hover {
	background: #365899;
	transform: translateY(-1px);
	box-shadow: var(--shadow-lg);
}

/* ===== THANK YOU PAGE ===== */
.thankyou-wrapper {
	text-align: center;
}

.success-icon {
	margin: 0 auto 30px;
	animation: scaleIn 0.5s ease-out;
}

@keyframes scaleIn {
	from {
		transform: scale(0);
		opacity: 0;
	}
	to {
		transform: scale(1);
		opacity: 1;
	}
}

.thankyou-wrapper h1 {
	color: var(--success-color);
	font-size: 2.5rem;
	margin-bottom: 20px;
}

.success-message {
	font-size: 1.2rem;
	color: var(--text-color);
	margin-bottom: 30px;
}

.confirmation-details {
	background: var(--background-color);
	padding: 30px;
	border-radius: var(--border-radius);
	margin-bottom: 30px;
	text-align: left;
}

.confirmation-details h2 {
	color: var(--primary-color);
	margin-bottom: 20px;
	text-align: center;
}

.detail-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 15px;
}

.detail-item {
	display: flex;
	flex-direction: column;
	gap: 5px;
}

.detail-label {
	font-weight: 600;
	color: var(--primary-color);
	font-size: 0.9rem;
}

.detail-value {
	color: var(--text-color);
	font-size: 1rem;
	word-break: break-word;
}

.next-steps,
.important-dates-box,
.social-links {
	background: #e8f4f8;
	padding: 25px;
	border-radius: var(--border-radius);
	margin-bottom: 25px;
	text-align: left;
}

.next-steps h2,
.important-dates-box h3,
.social-links h3 {
	color: var(--primary-color);
	margin-bottom: 15px;
}

.next-steps ul,
.important-dates-box ul {
	list-style: none;
	margin-left: 0;
}

.next-steps li,
.important-dates-box li {
	margin-bottom: 12px;
	padding-left: 30px;
	position: relative;
}

.next-steps li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 6px;
	width: 18px;
	height: 18px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2327ae60' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
}

.important-dates-box li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 3px;
	width: 18px;
	height: 18px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ef4444' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E");
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
}

.next-steps a,
.important-dates-box a {
	color: var(--secondary-color);
	text-decoration: none;
	font-weight: 600;
}

.next-steps a:hover,
.important-dates-box a:hover {
	text-decoration: underline;
}

.action-buttons {
	margin-top: 30px;
}

/* ===== RESPONSIVE DESIGN ===== */
@media (max-width: 768px) {
	body {
		padding: 10px;
	}

	.registration-wrapper,
	.thankyou-wrapper {
		padding: 30px 20px;
	}

	.logo-placeholder {
		width: 100px;
		height: 100px;
	}

	.header h1,
	.thankyou-wrapper h1 {
		font-size: 1.75rem;
	}

	.subtitle {
		font-size: 0.9rem;
	}

	.form-row {
		grid-template-columns: 1fr;
	}

	.checkbox-group {
		grid-template-columns: 1fr;
	}

	.radio-group {
		flex-direction: column;
		gap: 10px;
	}

	.radio-label {
		width: 100%;
	}

	.phone-input-group {
		flex-direction: row;
	}

	.phone-prefix {
		padding: 12px 14px;
		font-size: 0.9rem;
	}

	.phone-prefix::after {
		height: 20px;
	}

	.phone-input {
		padding-left: 14px !important;
	}

	.inline-input {
		width: 100%;
		margin-left: 0;
		margin-top: 5px;
	}

	.detail-grid {
		grid-template-columns: 1fr;
	}

	.btn-submit,
	.btn-secondary,
	.btn-social {
		padding: 12px 28px;
		font-size: 1rem;
	}

	.important-dates,
	.contact-info {
		padding: 20px 18px;
	}

	.important-dates li {
		padding-left: 40px;
		font-size: 0.9rem;
	}

	.important-dates li::before {
		width: 22px;
		height: 22px;
		left: 10px;
	}

	.important-dates h3,
	.contact-info h3 {
		font-size: 1.1rem;
	}
}

@media (max-width: 480px) {
	.logo-placeholder {
		width: 80px;
		height: 80px;
	}

	.header h1,
	.thankyou-wrapper h1 {
		font-size: 1.5rem;
	}

	.registration-wrapper,
	.thankyou-wrapper {
		padding: 25px 15px;
	}

	.important-dates,
	.contact-info,
	.confirmation-details,
	.next-steps,
	.important-dates-box,
	.social-links {
		padding: 18px 15px;
	}

	.important-dates li {
		padding: 8px 10px;
		padding-left: 36px;
		font-size: 0.875rem;
	}

	.important-dates li::before {
		left: 8px;
		width: 20px;
		height: 20px;
	}

	.note {
		font-size: 0.8rem;
		padding: 10px;
	}

	.terms-box {
		padding: 18px;
	}

	.terms-checkbox {
		padding: 12px 14px;
	}
}

/* ===== PRINT STYLES ===== */
@media print {
	body {
		background: white;
		padding: 0;
	}

	.registration-wrapper,
	.thankyou-wrapper {
		box-shadow: none;
		padding: 20px;
	}

	.btn-submit,
	.btn-secondary,
	.btn-social,
	.action-buttons {
		display: none;
	}
}

/* ===== EMAIL CONFIRMATION & MATCHING ===== */
.email-match-indicator {
	display: block;
	margin-top: 4px;
	font-size: 0.85rem;
	font-weight: 500;
}

.email-match-indicator.match {
	color: var(--success-color);
}

.email-match-indicator.mismatch {
	color: var(--error-color);
}

/* ===== CONFIRMATION MODAL ===== */
.modal {
	display: none;
	position: fixed;
	z-index: 10000;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.7);
	backdrop-filter: blur(4px);
	animation: fadeIn 0.3s ease;
	overflow-y: auto;
	padding: 20px;
}

@keyframes fadeIn {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}

.modal.show {
	display: flex;
	align-items: center;
	justify-content: center;
}

.modal-content {
	background: var(--white);
	border-radius: 20px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
	max-width: 550px;
	width: 100%;
	animation: slideUp 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
	margin: auto;
}

@keyframes slideUp {
	from {
		opacity: 0;
		transform: translateY(50px) scale(0.95);
	}
	to {
		opacity: 1;
		transform: translateY(0) scale(1);
	}
}

.modal-header {
	text-align: center;
	padding: 40px 30px 20px;
	border-bottom: 1px solid var(--border-color);
}

.modal-icon {
	width: 70px;
	height: 70px;
	margin: 0 auto 20px;
	background: linear-gradient(135deg, #4a90e2 0%, #2c3e50 100%);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 8px 20px rgba(74, 144, 226, 0.3);
}

.modal-icon svg {
	width: 40px;
	height: 40px;
	color: var(--white);
	stroke-width: 2.5;
}

.modal-header h2 {
	font-family: "Syne", "Outfit", sans-serif;
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--text-color);
	margin: 0;
}

.modal-body {
	padding: 30px;
}

.modal-description {
	text-align: center;
	color: var(--text-light);
	font-size: 1rem;
	margin-bottom: 25px;
	line-height: 1.6;
}

.email-display {
	background: linear-gradient(135deg, #f0f7ff 0%, #e8f4f8 100%);
	border: 2px solid #4a90e2;
	border-radius: 12px;
	padding: 20px;
	margin-bottom: 25px;
	text-align: center;
}

.email-label {
	font-size: 0.85rem;
	color: var(--text-light);
	margin-bottom: 8px;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.email-value {
	font-size: 1.25rem;
	font-weight: 600;
	color: var(--primary-color);
	word-break: break-word;
	font-family: "Courier New", monospace;
}

.timer-container {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	margin-bottom: 25px;
	padding: 15px;
	background: var(--background-color);
	border-radius: 10px;
}

.timer-text {
	font-size: 0.95rem;
	color: var(--text-light);
	font-weight: 500;
}

.timer-display {
	font-size: 2rem;
	font-weight: 700;
	color: var(--secondary-color);
	min-width: 50px;
	text-align: center;
	font-family: "Syne", sans-serif;
}

.timer-label {
	font-size: 0.95rem;
	color: var(--text-light);
	font-weight: 500;
}

/* Critical Warning Box - Attention Grabbing */
.critical-warning {
	background: linear-gradient(135deg, #ff4444 0%, #cc0000 100%);
	border: 3px solid #ff0000;
	border-radius: 12px;
	padding: 20px;
	margin-bottom: 20px;
	display: flex;
	gap: 15px;
	align-items: center;
	box-shadow: 0 8px 25px rgba(255, 0, 0, 0.4);
	animation: pulseGlow 2s ease-in-out infinite;
	position: relative;
	overflow: hidden;
}

@keyframes pulseGlow {
	0%,
	100% {
		box-shadow: 0 8px 25px rgba(255, 0, 0, 0.4);
		transform: scale(1);
	}
	50% {
		box-shadow: 0 8px 35px rgba(255, 0, 0, 0.6),
			0 0 20px rgba(255, 0, 0, 0.3);
		transform: scale(1.01);
	}
}

.critical-warning::before {
	content: "";
	position: absolute;
	top: 0;
	left: -100%;
	width: 100%;
	height: 100%;
	background: linear-gradient(
		90deg,
		transparent,
		rgba(255, 255, 255, 0.3),
		transparent
	);
	animation: shimmer 3s infinite;
}

@keyframes shimmer {
	0% {
		left: -100%;
	}
	100% {
		left: 100%;
	}
}

.warning-icon-pulse {
	width: 60px;
	height: 60px;
	background: rgba(255, 255, 255, 0.95);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	animation: iconPulse 1.5s ease-in-out infinite;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
	position: relative;
	z-index: 1;
}

@keyframes iconPulse {
	0%,
	100% {
		transform: scale(1);
	}
	50% {
		transform: scale(1.1);
	}
}

.warning-icon-pulse svg {
	width: 36px;
	height: 36px;
	color: #ff0000;
	stroke-width: 2.5;
	filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.2));
}

.warning-content {
	flex: 1;
	position: relative;
	z-index: 1;
}

.warning-title {
	font-size: 1.15rem;
	font-weight: 800;
	color: #ffffff;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin-bottom: 10px;
	text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
	animation: titleFlash 2s ease-in-out infinite;
}

@keyframes titleFlash {
	0%,
	100% {
		opacity: 1;
	}
	50% {
		opacity: 0.9;
	}
}

.warning-message {
	font-size: 0.95rem;
	color: #ffffff;
	line-height: 1.6;
	text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.2);
	font-weight: 500;
}

.warning-message strong {
	font-weight: 800;
	text-decoration: underline;
	font-size: 1.05rem;
}

.action-required {
	margin-top: 12px;
	padding: 12px 15px;
	background: rgba(255, 255, 255, 0.95);
	color: #cc0000;
	border-radius: 8px;
	font-weight: 700;
	font-size: 1rem;
	text-align: center;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
	animation: bounce 2s ease-in-out infinite;
}

@keyframes bounce {
	0%,
	100% {
		transform: translateY(0);
	}
	50% {
		transform: translateY(-5px);
	}
}

.important-notice {
	background: #fff9e6;
	border-left: 4px solid var(--warning-color);
	border-radius: 8px;
	padding: 15px;
	display: flex;
	gap: 15px;
	align-items: flex-start;
}

.important-notice svg {
	width: 24px;
	height: 24px;
	color: var(--warning-color);
	flex-shrink: 0;
	margin-top: 2px;
}

.important-notice strong {
	color: var(--warning-color);
	font-weight: 600;
}

.important-notice ul {
	margin: 8px 0 0 0;
	padding-left: 20px;
	color: var(--text-color);
	font-size: 0.9rem;
}

.important-notice li {
	margin-bottom: 6px;
	line-height: 1.5;
}

.modal-footer {
	padding: 20px 30px 30px;
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
}

.btn-modal {
	flex: 1;
	min-width: 140px;
	padding: 14px 24px;
	font-size: 1rem;
	font-weight: 600;
	border: none;
	border-radius: 10px;
	cursor: pointer;
	transition: all 0.3s ease;
	font-family: "Outfit", sans-serif;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
}

.btn-secondary {
	background: var(--background-color);
	color: var(--text-color);
	border: 2px solid var(--border-color);
}

.btn-secondary:hover {
	background: var(--white);
	border-color: var(--primary-color);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.btn-primary {
	background: linear-gradient(135deg, #4a90e2 0%, #2c3e50 100%);
	color: var(--white);
	box-shadow: 0 4px 15px rgba(74, 144, 226, 0.3);
}

.btn-primary:hover:not(:disabled) {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(74, 144, 226, 0.4);
}

.btn-primary:disabled {
	background: var(--text-muted);
	cursor: not-allowed;
	opacity: 0.6;
	box-shadow: none;
}

/* Mobile Responsiveness */
@media (max-width: 600px) {
	.modal {
		padding: 10px;
	}

	.modal-content {
		border-radius: 16px;
		max-width: 100%;
	}

	.modal-header {
		padding: 30px 20px 15px;
	}

	.modal-icon {
		width: 60px;
		height: 60px;
	}

	.modal-icon svg {
		width: 32px;
		height: 32px;
	}

	.modal-header h2 {
		font-size: 1.4rem;
	}

	.modal-body {
		padding: 20px;
	}

	.email-value {
		font-size: 1.05rem;
	}

	.timer-display {
		font-size: 1.75rem;
		min-width: 45px;
	}

	.modal-footer {
		padding: 15px 20px 25px;
		flex-direction: column;
	}

	.btn-modal {
		width: 100%;
		min-width: auto;
	}

	.important-notice {
		font-size: 0.85rem;
	}

	.critical-warning {
		padding: 15px;
		flex-direction: column;
		text-align: center;
		gap: 12px;
	}

	.warning-icon-pulse {
		width: 50px;
		height: 50px;
		margin: 0 auto;
	}

	.warning-icon-pulse svg {
		width: 28px;
		height: 28px;
	}

	.warning-title {
		font-size: 1rem;
	}

	.warning-message {
		font-size: 0.88rem;
	}

	.action-required {
		font-size: 0.92rem;
		padding: 10px 12px;
	}
}

/* ===== EXAM ACCESS SECTION (THANKYOU PAGE) ===== */
.exam-access-box {
	background: linear-gradient(135deg, #f8f9ff 0%, #f0f4ff 100%);
	border: 2px solid var(--secondary-color);
	border-radius: var(--border-radius);
	padding: 28px 30px;
	margin-bottom: 30px;
	box-shadow: var(--shadow);
}

.exam-access-box h3 {
	font-family: "Syne", sans-serif;
	color: var(--primary-color);
	font-size: 1.5rem;
	margin-bottom: 15px;
	font-weight: 700;
}

.exam-access-intro {
	color: var(--text-color);
	font-size: 1.05rem;
	line-height: 1.7;
	margin-bottom: 25px;
}

.exam-link {
	color: var(--secondary-color);
	text-decoration: none;
	font-weight: 600;
	transition: var(--transition);
}

.exam-link:hover {
	color: var(--primary-color);
	text-decoration: underline;
}

.mock-tests-list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 18px;
	margin-bottom: 25px;
}

.mock-test-card {
	background: var(--white);
	border: 1px solid var(--border-color);
	border-radius: var(--border-radius-sm);
	padding: 18px 20px;
	transition: var(--transition);
	box-shadow: var(--shadow-sm);
}

.mock-test-card:hover {
	border-color: var(--secondary-color);
	transform: translateY(-2px);
	box-shadow: var(--shadow);
}

.mock-test-badge {
	display: inline-block;
	background: linear-gradient(
		135deg,
		var(--secondary-color) 0%,
		var(--primary-color) 100%
	);
	color: var(--white);
	padding: 6px 14px;
	border-radius: 20px;
	font-size: 0.85rem;
	font-weight: 600;
	font-family: "Syne", sans-serif;
	margin-bottom: 12px;
}

.mock-test-info-detail {
	display: flex;
	align-items: center;
	gap: 10px;
	color: var(--text-light);
	font-size: 0.95rem;
	margin-bottom: 8px;
}

.mock-test-info-detail:last-child {
	margin-bottom: 0;
}

.mock-test-info-detail svg {
	flex-shrink: 0;
	color: var(--secondary-color);
}

.exam-access-action {
	text-align: center;
}

.btn-start-test {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	background: linear-gradient(
		135deg,
		var(--secondary-color) 0%,
		var(--primary-color) 100%
	);
	color: var(--white);
	text-decoration: none;
	padding: 14px 32px;
	border-radius: var(--border-radius-sm);
	font-weight: 600;
	font-size: 1rem;
	font-family: "Syne", sans-serif;
	box-shadow: var(--shadow);
	transition: var(--transition);
}

.btn-start-test:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-lg);
}

.btn-start-test svg {
	flex-shrink: 0;
}

@media (max-width: 768px) {
	.exam-access-box {
		padding: 22px 20px;
	}

	.exam-access-box h3 {
		font-size: 1.3rem;
	}

	.exam-access-intro {
		font-size: 0.95rem;
	}

	.mock-tests-list {
		grid-template-columns: 1fr;
		gap: 14px;
	}

	.btn-start-test {
		width: 100%;
		padding: 12px 24px;
		font-size: 0.95rem;
	}
}

@media (max-width: 480px) {
	.exam-access-box {
		padding: 18px 16px;
	}

	.exam-access-box h3 {
		font-size: 1.15rem;
	}

	.exam-access-intro {
		font-size: 0.9rem;
	}

	.mock-test-card {
		padding: 14px 16px;
	}

	.mock-test-badge {
		font-size: 0.8rem;
		padding: 5px 12px;
	}

	.mock-test-info-detail {
		font-size: 0.88rem;
	}

	.btn-start-test {
		padding: 11px 20px;
		font-size: 0.9rem;
		gap: 8px;
	}

	.btn-start-test svg {
		width: 18px;
		height: 18px;
	}
}
