/* ════════════════════════════════════════════════════════════════
   استایل پنل بیمار
   ════════════════════════════════════════════════════════════════ */

/* ───── CTA Card ───── */
.ad-cta-card {
	display: flex;
	align-items: center;
	gap: var(--ad-sp-3);
	padding: var(--ad-sp-4);
	background: var(--ad-surface);
	border: 1px solid var(--ad-primary-tint);
	border-radius: var(--ad-r-lg);
	cursor: pointer;
	transition: all var(--ad-dur-fast) var(--ad-easing);
	margin-top: 0;
	margin-bottom: var(--ad-sp-4);
	position: relative;
	z-index: 1;
}
.ad-cta-card:hover {
	border-color: var(--ad-primary);
}
.ad-cta-card:active { transform: scale(.99); }
.ad-cta-card__icon {
	width: 56px;
	height: 56px;
	border-radius: var(--ad-r-md);
	background: linear-gradient(135deg, var(--ad-primary) 0%, var(--ad-primary-dark) 100%);
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}
.ad-cta-card__body { flex: 1; min-width: 0; }
.ad-cta-card__title {
	margin: 0 0 4px;
	font-size: var(--ad-fs-md);
	font-weight: 700;
	color: var(--ad-text);
}
.ad-cta-card__sub {
	margin: 0;
	font-size: var(--ad-fs-sm);
	color: var(--ad-text-3);
}
.ad-cta-card__arrow {
	color: var(--ad-text-faint);
	flex-shrink: 0;
}

/* ───── Specialty grid (home) ───── */
.ad-spec-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--ad-sp-2);
}
@media (max-width: 360px) {
	.ad-spec-grid { grid-template-columns: repeat(3, 1fr); }
}
.ad-spec-tile {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 12px 6px;
	background: var(--ad-surface);
	border: 1px solid var(--ad-border-soft);
	border-radius: var(--ad-r-lg);
	cursor: pointer;
	transition: all var(--ad-dur-fast) var(--ad-easing);
	text-align: center;
	color: var(--ad-text);
	font-family: inherit;
}
.ad-spec-tile:hover {
	border-color: var(--ad-primary);
}
.ad-spec-tile__icon {
	width: 36px;
	height: 36px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--ad-primary-tint);
	color: var(--ad-primary-dark);
	border-radius: var(--ad-r-md);
}
.ad-spec-tile__name {
	font-size: 11px;
	font-weight: 500;
	color: var(--ad-text);
	line-height: 1.3;
}

/* ───── Doctor List ───── */
.ad-doctor-list {
	display: flex;
	flex-direction: column;
	gap: var(--ad-sp-3);
}
.ad-doctor-card {
	display: flex;
	gap: var(--ad-sp-3);
	padding: var(--ad-sp-3);
	background: var(--ad-surface);
	border: 1px solid var(--ad-border-soft);
	border-radius: var(--ad-r-lg);
	cursor: pointer;
	transition: all var(--ad-dur-fast) var(--ad-easing);
	text-align: right;
	font-family: inherit;
	color: inherit;
	width: 100%;
}
.ad-doctor-card:hover {
	border-color: var(--ad-primary-light);
}
.ad-doctor-card__avatar {
	width: 64px;
	height: 64px;
	border-radius: var(--ad-r-md);
	overflow: hidden;
	background: var(--ad-primary-tint);
	flex-shrink: 0;
}
.ad-doctor-card__avatar img { width: 100%; height: 100%; object-fit: cover; }
.ad-doctor-card__body { flex: 1; min-width: 0; }
.ad-doctor-card__name {
	font-size: var(--ad-fs-md);
	font-weight: 600;
	color: var(--ad-text);
	margin: 0 0 4px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.ad-doctor-card__spec {
	font-size: var(--ad-fs-sm);
	color: var(--ad-text-3);
	margin: 0 0 8px;
}
.ad-doctor-card__price {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: var(--ad-fs-sm);
	font-weight: 600;
	color: var(--ad-primary-dark);
}
.ad-doctor-card__cta {
	flex-shrink: 0;
	display: flex;
	align-items: center;
}
.ad-doctor-card__cta-btn {
	width: 36px;
	height: 36px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--ad-primary-tint);
	color: var(--ad-primary-dark);
	border-radius: var(--ad-r-pill);
	transition: all var(--ad-dur-fast) var(--ad-easing);
}
.ad-doctor-card:hover .ad-doctor-card__cta-btn {
	background: var(--ad-primary);
	color: #fff;
}

/* ───── Doctor Detail (in sheet) ───── */
.ad-doctor-detail__header {
	display: flex;
	gap: var(--ad-sp-3);
	margin-bottom: var(--ad-sp-4);
	padding-bottom: var(--ad-sp-4);
	border-bottom: 1px solid var(--ad-border-soft);
}
.ad-doctor-detail__avatar {
	width: 84px;
	height: 84px;
	border-radius: var(--ad-r-lg);
	overflow: hidden;
	background: var(--ad-primary-tint);
	flex-shrink: 0;
}
.ad-doctor-detail__avatar img { width: 100%; height: 100%; object-fit: cover; }
.ad-doctor-detail__name {
	font-size: var(--ad-fs-lg);
	font-weight: 700;
	color: var(--ad-text);
	margin: 0 0 6px;
}
.ad-doctor-detail__spec {
	font-size: var(--ad-fs-sm);
	color: var(--ad-text-3);
	margin: 0 0 8px;
}
.ad-doctor-detail__bio {
	font-size: var(--ad-fs-sm);
	color: var(--ad-text-2);
	line-height: 1.7;
	margin-top: var(--ad-sp-3);
}

/* ───── Date scroller (30 days) ───── */
.ad-day-scroller {
	display: flex;
	gap: 8px;
	overflow-x: auto;
	padding: 4px 0;
	margin-bottom: var(--ad-sp-3);
	scrollbar-width: none;
	-ms-overflow-style: none;
}
.ad-day-scroller::-webkit-scrollbar { display: none; }

.ad-day {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 4px;
	min-width: 60px;
	padding: 8px 6px;
	background: var(--ad-surface);
	border: 1px solid var(--ad-border);
	border-radius: var(--ad-r-md);
	cursor: pointer;
	transition: all var(--ad-dur-fast) var(--ad-easing);
	flex-shrink: 0;
	font-family: inherit;
	color: var(--ad-text-2);
}
.ad-day:hover:not(:disabled) { border-color: var(--ad-primary-light); }
.ad-day.is-active {
	background: var(--ad-primary);
	border-color: var(--ad-primary);
	color: #fff;
}
.ad-day:disabled, .ad-day.is-disabled {
	opacity: .35;
	cursor: not-allowed;
}
.ad-day__weekday {
	font-size: 11px;
	font-weight: 500;
	opacity: .85;
}
.ad-day__date {
	font-size: var(--ad-fs-md);
	font-weight: 700;
	font-feature-settings: "tnum";
}
.ad-day__count {
	font-size: 10px;
	opacity: .75;
}

/* ───── Slots Grid ───── */
.ad-slots {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--ad-sp-2);
}
.ad-slot {
	padding: 10px 8px;
	background: var(--ad-surface);
	border: 1px solid var(--ad-border);
	border-radius: var(--ad-r-md);
	cursor: pointer;
	transition: all var(--ad-dur-fast) var(--ad-easing);
	font-family: inherit;
	font-feature-settings: "tnum";
	font-size: var(--ad-fs-md);
	font-weight: 600;
	color: var(--ad-text);
	text-align: center;
	min-height: 42px;
}
.ad-slot:hover { border-color: var(--ad-primary); color: var(--ad-primary-dark); }
.ad-slot.is-selected {
	background: var(--ad-primary);
	color: #fff;
	border-color: var(--ad-primary);
}

/* ───── Booking Summary (sheet) ───── */
.ad-booking-summary__row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 12px 0;
	border-bottom: 1px dashed var(--ad-border-soft);
	font-size: var(--ad-fs-sm);
}
.ad-booking-summary__row:last-child { border-bottom: 0; }
.ad-booking-summary__label { color: var(--ad-text-3); }
.ad-booking-summary__value { font-weight: 600; color: var(--ad-text); }
.ad-booking-summary__value--price {
	font-weight: 700;
	color: var(--ad-primary-dark);
	font-size: var(--ad-fs-md);
}
.ad-booking-summary__row--final {
	background: var(--ad-primary-tint);
	margin: 8px -16px -16px;
	padding: 16px;
	border-radius: 0 0 var(--ad-r-md) var(--ad-r-md);
	border-bottom: 0;
}

/* ───── Discount Box ───── */
.ad-discount-box {
	display: flex;
	gap: 8px;
	margin: var(--ad-sp-3) 0;
}
.ad-discount-box .ad-input { flex: 1; }
.ad-discount-applied {
	display: flex;
	align-items: center;
	justify-content: space-between;
	background: var(--ad-success-tint);
	color: #047857;
	padding: 10px 14px;
	border-radius: var(--ad-r-md);
	font-size: var(--ad-fs-sm);
	font-weight: 500;
	margin: var(--ad-sp-3) 0;
}
.ad-discount-applied__remove {
	background: transparent;
	border: 0;
	color: inherit;
	cursor: pointer;
	padding: 4px;
	border-radius: 4px;
}

/* ───── Booking Card (in list) ───── */
.ad-booking-card {
	display: flex;
	gap: var(--ad-sp-3);
	padding: var(--ad-sp-3);
	background: var(--ad-surface);
	border: 1px solid var(--ad-border-soft);
	border-radius: var(--ad-r-lg);
	cursor: pointer;
	transition: all var(--ad-dur-fast) var(--ad-easing);
	margin-bottom: var(--ad-sp-2);
	width: 100%;
	text-align: right;
	font-family: inherit;
	color: inherit;
}
.ad-booking-card:hover { border-color: var(--ad-primary-light); }
.ad-booking-card__avatar {
	width: 48px;
	height: 48px;
	border-radius: var(--ad-r-md);
	overflow: hidden;
	background: var(--ad-primary-tint);
	flex-shrink: 0;
}
.ad-booking-card__avatar img { width: 100%; height: 100%; object-fit: cover; }
.ad-booking-card__body { flex: 1; min-width: 0; }
.ad-booking-card__top {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 8px;
	margin-bottom: 4px;
}
.ad-booking-card__name {
	font-size: var(--ad-fs-md);
	font-weight: 600;
	color: var(--ad-text);
	margin: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.ad-booking-card__date {
	font-size: var(--ad-fs-sm);
	color: var(--ad-text-2);
	display: flex;
	align-items: center;
	gap: 6px;
}
.ad-booking-card__date-icon { color: var(--ad-text-muted); }
