/* Radio_Schedule — CodyChat-aligned layout */
.rs_schedule_week .rs_day_title {
	margin-bottom: 6px;
}
.rs_slot_row {
	padding: 6px 0;
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
	table-layout: auto;
	width: 100%;
}
.rs_slot_row:last-child {
	border-bottom: none;
}
.rs_slot_outer_main {
	min-width: 0;
	width: 100%;
	vertical-align: middle;
}
.rs_slot_meta {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
	gap: 10px;
	width: 100%;
	min-width: 0;
}
.rs_slot_meta_text {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 4px;
}
/* Username + RJ/DJ on one row beside avatar; time on next line aligned with text */
.rs_slot_user_type_row {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	width: 100%;
	min-width: 0;
}
.rs_slot_name_rank {
	display: inline-flex;
	flex-direction: row;
	flex-wrap: wrap;
	align-items: center;
	gap: 4px;
	flex: 1;
	min-width: 0;
}
.rs_slot_name_rank .username {
	margin: 0;
	max-width: 100%;
	overflow-wrap: anywhere;
	word-break: break-word;
}
.rs_slot_name_rank .icrank {
	line-height: 1;
	flex-shrink: 0;
}
.rs_slot_type {
	white-space: nowrap;
	flex-shrink: 0;
}
.rs_detail_name_rank {
	display: inline-flex;
	flex-direction: row;
	flex-wrap: wrap;
	align-items: center;
	gap: 6px;
	min-width: 0;
}
.rs_detail_name_rank .username {
	margin: 0;
	max-width: 100%;
	overflow-wrap: anywhere;
	word-break: break-word;
}
.rs_detail_name_rank .icrank {
	line-height: 1;
	flex-shrink: 0;
}
.rs_slot_time_row {
	margin: 0;
	width: 100%;
	line-height: 1.35;
	overflow-wrap: anywhere;
	word-break: break-word;
	text-align: left;
}
.rs_slot_avatar_wrap {
	flex-shrink: 0;
}
.rs_slot_avatar_wrap img {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	object-fit: cover;
	display: block;
}
.rs_time_row .bcell_mid {
	vertical-align: middle;
}
/* Info control: solid theme blue circle, white "i" (uses .theme_btn from active theme) */
button.rs_info_trigger.theme_btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	min-width: 24px;
	margin: 0;
	padding: 0;
	border: none;
	border-radius: 50%;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.18);
	line-height: 1;
	cursor: pointer;
	vertical-align: middle;
	-webkit-appearance: none;
	appearance: none;
	font-family: inherit;
	/* background + text color from .theme_btn in theme CSS */
}
button.rs_info_trigger.theme_btn:hover,
button.rs_info_trigger.theme_btn:focus {
	filter: brightness(0.92);
	outline: none;
}
/* FA6 solid: must use weight 900 + icon font or glyph renders as plain text */
button.rs_info_trigger.theme_btn .fa {
	font-family: "Font Awesome 6 Free" !important;
	font-weight: 900 !important;
	font-style: normal !important;
	font-size: 11px;
	line-height: 1;
	color: #fff;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
.modal_content.rs-modal .rs_time_row select.full_input {
	margin-bottom: 0;
}
/* Book modal — textarea same width as other full-width inputs */
.modal_content.rs-modal textarea#rs_description,
.modal_content.rs-modal .setting_element textarea.full_area {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	display: block;
	min-width: 0;
}
.modal_content.rs-modal .setting_element {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
}
/* Modal: contain long unbroken text */
.modal_content.rs-modal {
	overflow-x: hidden;
	max-width: 100%;
	box-sizing: border-box;
}
/* Book + detail modal — prominent top title (larger than body text) */
.modal_content.rs-modal .rs_modal_show_title,
.modal_content.rs-modal .rs_modal_book_title {
	display: block;
	width: 100%;
	margin: 0 0 12px;
	padding: 0 28px 0 0;
	box-sizing: border-box;
	font-size: 1.35rem;
	line-height: 1.3;
	letter-spacing: 0.02em;
	text-align: left;
	overflow-wrap: anywhere;
	word-break: break-word;
	-webkit-font-smoothing: antialiased;
}
.rs_modal_about {
	overflow-wrap: anywhere;
	word-break: break-word;
	max-width: 100%;
	overflow-x: hidden;
}
.rs_detail_host {
	width: 100%;
	table-layout: auto;
}
.rs_detail_host .maxflow {
	min-width: 0;
}
.rs_detail_avatar_wrap img {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	object-fit: cover;
}
.rs_last_seen {
	margin: 0;
}
/* Detail modal — Close + Delete */
.modal_content.rs-modal .modal_control.rs_modal_control {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 8px;
}
