/**
 * Tadbeer Medical — Front-End Styles
 *
 * Covers: registration form, card selection, digital card display,
 * verification page, and shared utilities.
 *
 * @package Tadbeer_Medical
 */

/* ================================================================
   CSS Custom Properties
   ================================================================ */
:root {
	/* Unified with theme footer green #1A5C38 */
	--tdb-green:       #1A5C38;
	--tdb-green-light: #e8f3eb;
	--tdb-green-badge: #1A5C38;
	--tdb-dark:        #1a1a1a;
	--tdb-grey:        #666;
	--tdb-grey-light:  #999;
	--tdb-border:      #ddd;
	--tdb-bg:          #fafafa;
	--tdb-white:       #fff;
	--tdb-red:         #c62828;
	--tdb-red-light:   #ffebee;
	--tdb-radius:      8px;
	--tdb-shadow:      0 2px 12px rgba(0,0,0,.08);
	--tdb-font:        -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
	                   "Helvetica Neue", Arial, sans-serif;
}

/* ================================================================
   Shared / Reset
   ================================================================ */
.tadbeer-form-wrap,
.tadbeer-card-selection-wrap,
.tadbeer-my-card-wrap,
.tadbeer-verify-wrap {
	font-family: var(--tdb-font);
	max-width: 720px;
	margin: 0 auto 40px;
	color: var(--tdb-dark);
	line-height: 1.5;
}

/* ================================================================
   Notices
   ================================================================ */
.tadbeer-notice {
	padding: 14px 20px;
	border-radius: var(--tdb-radius);
	margin-bottom: 24px;
	font-size: 15px;
}
.tadbeer-notice--success {
	background: var(--tdb-green-light);
	color: var(--tdb-green);
	border: 1px solid #a5d6a7;
}
.tadbeer-notice--error {
	background: var(--tdb-red-light);
	color: var(--tdb-red);
	border: 1px solid #ef9a9a;
}

/* ================================================================
   Registration Form
   ================================================================ */
.tadbeer-form-title {
	font-size: 24px;
	font-weight: 700;
	margin-bottom: 28px;
	color: var(--tdb-green);
	border-bottom: 3px solid var(--tdb-green);
	padding-bottom: 12px;
}

.tadbeer-field {
	margin-bottom: 20px;
}

.tadbeer-field label {
	display: block;
	font-weight: 600;
	font-size: 14px;
	margin-bottom: 6px;
	color: var(--tdb-dark);
}

.tadbeer-field label .required {
	color: var(--tdb-red);
}

.tadbeer-input {
	width: 100%;
	padding: 10px 14px;
	font-size: 15px;
	border: 1px solid var(--tdb-border);
	border-radius: 6px;
	background: var(--tdb-white);
	transition: border-color .2s;
	box-sizing: border-box;
}

.tadbeer-input:focus {
	outline: none;
	border-color: var(--tdb-green);
	box-shadow: 0 0 0 3px rgba(27, 94, 32, .1);
}

.tadbeer-input[readonly] {
	background: var(--tdb-bg);
	color: var(--tdb-grey);
}

.tadbeer-input.tadbeer-rtl {
	text-align: right;
	font-family: "Segoe UI", Tahoma, Arial, sans-serif;
}

.tadbeer-input.tadbeer-input--error {
	border-color: var(--tdb-red);
}

/* Radio / checkbox groups */
.tadbeer-radio-group {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
}

.tadbeer-radio-group label {
	font-weight: 400;
	font-size: 14px;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	cursor: pointer;
}

/* Error messages */
.tadbeer-error {
	display: none;
	color: var(--tdb-red);
	font-size: 13px;
	margin-top: 4px;
}
.tadbeer-error.active {
	display: block;
}

.tadbeer-hint {
	font-size: 13px;
	color: var(--tdb-grey-light);
	margin-bottom: 12px;
}

/* ================================================================
   Family Members Section
   ================================================================ */
.tadbeer-family-section {
	background: var(--tdb-bg);
	border: 1px solid var(--tdb-border);
	border-radius: var(--tdb-radius);
	padding: 20px;
	margin-bottom: 24px;
}

.tadbeer-family-section h3 {
	font-size: 18px;
	color: var(--tdb-green);
	margin-top: 0;
	margin-bottom: 8px;
}

.tadbeer-family-row {
	display: flex;
	align-items: flex-end;
	gap: 12px;
	padding: 12px 0;
	border-bottom: 1px solid var(--tdb-border);
}

.tadbeer-family-row:last-child {
	border-bottom: none;
}

.tadbeer-family-row-fields {
	display: flex;
	flex: 1;
	gap: 12px;
}

.tadbeer-field--inline {
	flex: 1;
	margin-bottom: 0;
}

/* ================================================================
   Buttons
   ================================================================ */
.tadbeer-btn {
	display: inline-block;
	padding: 10px 24px;
	font-size: 15px;
	font-weight: 600;
	border: none;
	border-radius: 6px;
	cursor: pointer;
	transition: background .2s, transform .1s;
	text-decoration: none;
	text-align: center;
}

.tadbeer-btn:active {
	transform: scale(.97);
}

.tadbeer-btn--primary {
	background: var(--tdb-green);
	color: var(--tdb-white);
	width: 100%;
	padding: 14px;
	font-size: 16px;
}

.tadbeer-btn--primary:hover {
	background: #145217;
}

.tadbeer-btn--secondary {
	background: var(--tdb-green-light);
	color: var(--tdb-green);
	margin-top: 12px;
}

.tadbeer-btn--secondary:hover {
	background: #c8e6c9;
}

.tadbeer-btn--remove-member {
	background: var(--tdb-red-light);
	color: var(--tdb-red);
	font-size: 13px;
	padding: 8px 14px;
	white-space: nowrap;
}

.tadbeer-btn--remove-member:hover {
	background: #ffcdd2;
}

/* ================================================================
   Card Selection Page
   ================================================================ */
.tadbeer-card-selection-wrap {
	text-align: center;
}

.tadbeer-card-selection-wrap h2 {
	font-size: 24px;
	color: var(--tdb-green);
	margin-bottom: 8px;
}

.tadbeer-card-selection-wrap .tadbeer-subtitle {
	color: var(--tdb-grey);
	margin-bottom: 32px;
}

.tadbeer-card-options {
	display: flex;
	gap: 24px;
	justify-content: center;
	flex-wrap: wrap;
}

.tadbeer-card-option {
	background: var(--tdb-white);
	border: 2px solid var(--tdb-border);
	border-radius: 12px;
	padding: 32px 28px;
	width: 280px;
	text-align: center;
	box-shadow: var(--tdb-shadow);
	transition: border-color .2s, transform .2s;
}

.tadbeer-card-option:hover {
	border-color: var(--tdb-green);
	transform: translateY(-4px);
}

.tadbeer-card-option h3 {
	font-size: 22px;
	margin-bottom: 8px;
	color: var(--tdb-dark);
}

.tadbeer-card-option .tadbeer-price {
	font-size: 32px;
	font-weight: 700;
	color: var(--tdb-green);
	margin-bottom: 8px;
}

.tadbeer-card-option .tadbeer-price-period {
	font-size: 14px;
	color: var(--tdb-grey);
	margin-bottom: 20px;
}

.tadbeer-card-option .tadbeer-features {
	list-style: none;
	padding: 0;
	margin: 0 0 24px;
	text-align: left;
}

.tadbeer-card-option .tadbeer-features li {
	padding: 6px 0;
	font-size: 14px;
	color: var(--tdb-grey);
	border-bottom: 1px solid var(--tdb-bg);
}

.tadbeer-card-option .tadbeer-features li::before {
	content: "\2713";
	color: var(--tdb-green);
	font-weight: 700;
	margin-right: 8px;
}

/* ================================================================
   Digital Card (My Card)
   ================================================================ */
.tadbeer-digital-card {
	max-width: 600px;
	margin: 0 auto;
	background: var(--tdb-white);
	border-left: 8px solid var(--tdb-green);
	border-radius: var(--tdb-radius);
	box-shadow: 0 4px 24px rgba(0,0,0,.1);
	padding: 32px 28px 24px;
	position: relative;
}

.tadbeer-card-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	margin-bottom: 20px;
}

.tadbeer-card-badge {
	display: inline-block;
	background: var(--tdb-green-badge);
	color: var(--tdb-white);
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .8px;
	padding: 4px 14px;
	border-radius: 20px;
}

.tadbeer-card-logo {
	max-height: 48px;
	width: auto;
}

.tadbeer-card-logo-text {
	font-size: 20px;
	font-weight: 700;
	color: var(--tdb-green);
}

/* Card holder names */
.tadbeer-card-holder-label {
	font-size: 11px;
	color: var(--tdb-grey-light);
	text-transform: uppercase;
	letter-spacing: .6px;
	margin-bottom: 4px;
}

.tadbeer-card-name-en {
	font-size: 22px;
	font-weight: 700;
	color: var(--tdb-dark);
	margin-bottom: 2px;
}

.tadbeer-card-name-ar {
	font-size: 18px;
	font-weight: 500;
	color: var(--tdb-dark);
	direction: rtl;
	text-align: right;
	margin-bottom: 20px;
}

/* Two-column details */
.tadbeer-card-details {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
	margin-bottom: 20px;
}

.tadbeer-card-detail-label {
	font-size: 11px;
	color: var(--tdb-grey-light);
	text-transform: uppercase;
	letter-spacing: .6px;
	margin-bottom: 2px;
}

.tadbeer-card-detail-value {
	font-size: 16px;
	font-weight: 700;
	color: var(--tdb-dark);
}

/* Family members on card */
.tadbeer-card-family {
	border-top: 1px solid var(--tdb-border);
	padding-top: 16px;
	margin-top: 8px;
}

.tadbeer-card-family-label {
	font-size: 11px;
	color: var(--tdb-grey-light);
	text-transform: uppercase;
	letter-spacing: .6px;
	margin-bottom: 8px;
}

.tadbeer-card-family-list {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 6px 24px;
}

.tadbeer-card-family-name {
	font-size: 14px;
	font-weight: 600;
	color: var(--tdb-dark);
}

/* Print button */
.tadbeer-print-btn {
	display: block;
	max-width: 600px;
	margin: 16px auto 0;
	text-align: center;
}

/* Login prompt */
.tadbeer-login-prompt {
	text-align: center;
	padding: 60px 20px;
	max-width: 480px;
	margin: 0 auto;
}

.tadbeer-login-prompt p {
	font-size: 16px;
	color: var(--tdb-grey);
	margin-bottom: 20px;
}

/* ================================================================
   Verification Page
   ================================================================ */
.tadbeer-verify-wrap {
	text-align: center;
}

.tadbeer-verify-wrap h2 {
	color: var(--tdb-green);
	font-size: 24px;
	margin-bottom: 8px;
}

.tadbeer-verify-wrap .tadbeer-subtitle {
	color: var(--tdb-grey);
	margin-bottom: 28px;
}

.tadbeer-verify-form {
	display: flex;
	gap: 12px;
	max-width: 480px;
	margin: 0 auto 32px;
}

.tadbeer-verify-form .tadbeer-input {
	flex: 1;
	font-size: 16px;
	text-align: center;
	letter-spacing: 1px;
}

.tadbeer-verify-result {
	max-width: 480px;
	margin: 0 auto;
	padding: 28px;
	border-radius: var(--tdb-radius);
}

.tadbeer-verify-result--valid {
	background: var(--tdb-green-light);
	border: 2px solid #66bb6a;
}

.tadbeer-verify-result--invalid {
	background: var(--tdb-red-light);
	border: 2px solid #ef5350;
}

.tadbeer-verify-badge {
	display: inline-block;
	font-size: 18px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 1px;
	padding: 8px 24px;
	border-radius: 30px;
	margin-bottom: 16px;
}

.tadbeer-verify-badge--valid {
	background: var(--tdb-green);
	color: var(--tdb-white);
}

.tadbeer-verify-badge--invalid {
	background: var(--tdb-red);
	color: var(--tdb-white);
}

.tadbeer-verify-name {
	font-size: 20px;
	font-weight: 600;
	color: var(--tdb-dark);
	margin-bottom: 4px;
}

.tadbeer-verify-expiry {
	font-size: 14px;
	color: var(--tdb-grey);
}

/* ================================================================
   Print Styles
   ================================================================ */
@media print {
	body * {
		visibility: hidden !important;
	}
	.tadbeer-digital-card,
	.tadbeer-digital-card * {
		visibility: visible !important;
	}
	.tadbeer-digital-card {
		position: absolute;
		left: 0;
		top: 0;
		box-shadow: none;
		border-radius: 0;
	}
	.tadbeer-print-btn {
		display: none !important;
	}
}

/* ================================================================
   Responsive
   ================================================================ */
@media (max-width: 600px) {
	.tadbeer-card-options {
		flex-direction: column;
		align-items: center;
	}
	.tadbeer-card-option {
		width: 100%;
	}
	.tadbeer-card-details {
		grid-template-columns: 1fr;
	}
	.tadbeer-card-family-list {
		grid-template-columns: 1fr;
	}
	.tadbeer-family-row {
		flex-direction: column;
		align-items: stretch;
	}
	.tadbeer-family-row-fields {
		flex-direction: column;
	}
	.tadbeer-verify-form {
		flex-direction: column;
	}
}

/* ─── RTL Overrides for Arabic ─── */

[dir="rtl"] .rw,
[dir="rtl"] .tdb,
[dir="rtl"] .tvf {
	direction: rtl;
	text-align: right;
}

[dir="rtl"] .rw,
[dir="rtl"] .tdb,
[dir="rtl"] .tvf,
[dir="rtl"] .rw h1, [dir="rtl"] .rw h2, [dir="rtl"] .rw h3,
[dir="rtl"] .rw h4, [dir="rtl"] .rw p, [dir="rtl"] .rw a,
[dir="rtl"] .rw label, [dir="rtl"] .rw button,
[dir="rtl"] .rw span:not(.material-symbols-outlined):not([class*="material"]),
[dir="rtl"] .tdb h1, [dir="rtl"] .tdb h2, [dir="rtl"] .tdb h3,
[dir="rtl"] .tdb h4, [dir="rtl"] .tdb p, [dir="rtl"] .tdb a,
[dir="rtl"] .tdb label, [dir="rtl"] .tdb button,
[dir="rtl"] .tdb span:not(.material-symbols-outlined):not([class*="material"]),
[dir="rtl"] .tvf h1, [dir="rtl"] .tvf h2, [dir="rtl"] .tvf h3,
[dir="rtl"] .tvf h4, [dir="rtl"] .tvf p, [dir="rtl"] .tvf a,
[dir="rtl"] .tvf label, [dir="rtl"] .tvf button,
[dir="rtl"] .tvf span:not(.material-symbols-outlined):not([class*="material"]) {
	font-family: 'Tajawal', sans-serif;
}

[dir="rtl"] .rw input,
[dir="rtl"] .rw select,
[dir="rtl"] .rw textarea,
[dir="rtl"] .tdb input,
[dir="rtl"] .tdb select,
[dir="rtl"] .tvf input {
	text-align: right;
	direction: rtl;
}

[dir="rtl"] .rw-sidebar {
	order: 2;
}

[dir="rtl"] .rw-main {
	order: 1;
}

[dir="rtl"] .rw-progress-step {
	flex-direction: row-reverse;
}

[dir="rtl"] .rw-step-actions {
	flex-direction: row-reverse;
}

[dir="rtl"] .rw-plan-features li::before {
	margin-right: 0;
	margin-left: 0.5rem;
}

[dir="rtl"] .tdb-card-top,
[dir="rtl"] .tdb-card-bottom {
	flex-direction: row-reverse;
}

[dir="rtl"] .tdb-stat {
	text-align: right;
}

[dir="rtl"] .tdb-family-member {
	flex-direction: row-reverse;
}

[dir="rtl"] .tdb-hospitals-header {
	flex-direction: row-reverse;
}

[dir="rtl"] .tvf-result-card {
	flex-direction: row-reverse;
}

[dir="rtl"] .tvf-search-icon {
	left: auto;
	right: 1rem;
}

[dir="rtl"] .tvf-search-input {
	padding-left: 1rem;
	padding-right: 3rem;
}

[dir="rtl"] .tvf-search-btn {
	right: auto;
	left: 0.5rem;
}
