/* ==============================================
  NEW Content Display Styles (content-display-v2.css)
  ============================================== */

/* --- Main Content Wrapper --- */
.rich-content-wrapper {
	font-family: 'PinarRegular', sans-serif;
	color: #34495e; /* A softer black for better readability */
	line-height: 1.9;
	font-size: 17px;
}

/* --- Typography & Headings --- */
.rich-content-wrapper h1, 
.rich-content-wrapper h2, 
.rich-content-wrapper h3,
.rich-content-wrapper h4, 
.rich-content-wrapper h5, 
.rich-content-wrapper h6 {
	font-family: 'PinarBold', sans-serif;
	margin-top: 2em;
	margin-bottom: 1em;
	line-height: 1.5;
}
.rich-content-wrapper h1 { font-size: 2.4rem; color: var(--primary-color); }
.rich-content-wrapper h2 { font-size: 2rem; color: var(--secondary-color); border-bottom: 2px solid var(--medium-gray-color); padding-bottom: 10px; }
.rich-content-wrapper h3 { font-size: 1.6rem; color: var(--secondary-color); }
.rich-content-wrapper h4 { font-size: 1.3rem; color: var(--dark-gray-color); }
.rich-content-wrapper h5 { font-size: 1.1rem; color: var(--dark-gray-color); }
.rich-content-wrapper h6 { font-size: 1rem; color: var(--dark-gray-color); }

/* --- Paragraphs & Links --- */
.rich-content-wrapper p { 
	margin-bottom: 1.2em;
	text-align: justify; /* Justify text alignment */
}
.rich-content-wrapper a {
	color: var(--primary-color);
	text-decoration: none;
	border-bottom: 2px solid rgba(0, 82, 255, 0.2);
	transition: all 0.2s ease;
	display: inline-block;
	padding: 0 5px;
	border-radius: 5px;
}
.rich-content-wrapper a:hover {
	background-color: rgba(0, 82, 255, 0.1);
	border-bottom-color: var(--primary-color);
}
.rich-content-wrapper strong { font-weight: bold; color: var(--secondary-color); }
.rich-content-wrapper em { font-style: italic; }

/* --- Lists --- */
.rich-content-wrapper ul, .rich-content-wrapper ol {
	margin-bottom: 1.5em;
	padding-right: 25px;
}
.rich-content-wrapper li {
	margin-bottom: 0.8em;
	padding-right: 10px;
}
.rich-content-wrapper ul li::marker { color: var(--primary-color); }
.rich-content-wrapper ol li::marker { font-family: 'PinarBold', sans-serif; color: var(--primary-color); }

/* --- Blockquotes --- */
.rich-content-wrapper blockquote {
	margin: 2em 0;
	padding: 20px 25px 20px 20px;
	padding-right: 45px;
	border-right: 4px solid var(--primary-color);
	background-color: var(--light-gray-color);
	border-radius: 0 var(--border-radius) var(--border-radius) 0;
	position: relative;
}
	.rich-content-wrapper blockquote::before {
		content: "\201C"; /* fa-quote-right */
		font-family: "Font Awesome 6 Free";
		font-weight: 900;
		position: absolute;
		top: 20px;
		right: 15px;
		font-size: 1.5em;
		color: var(--primary-color);
		opacity: 0.8;
	}
.rich-content-wrapper blockquote p { margin-bottom: 0.5em; }
.rich-content-wrapper blockquote cite { display: block; text-align: left; font-size: 0.9em; color: var(--text-color-muted); margin-top: 1em; }

/* --- NEW: Alert Boxes --- */
.rich-content-wrapper .alert-box {
	margin: 2em 0;
	padding: 20px;
	border-radius: var(--border-radius);
	border: 1px solid transparent;
	display: flex;
	align-items: flex-start;
	gap: 15px;
}
.rich-content-wrapper .alert-box__icon {
	font-size: 1.5rem;
	margin-top: 2px;
}
.rich-content-wrapper .alert-box__content {
	flex-grow: 1;
}
.rich-content-wrapper .alert-box__title {
	font-family: 'PinarBold', sans-serif;
	font-size: 1.2rem;
	margin: 0 0 5px 0;
}
.rich-content-wrapper .alert-box p {
	margin-bottom: 0;
}

/* Info Alert */
.rich-content-wrapper .alert-box--info {
	background-color: #e7f3fe;
	border-color: #a0cff8;
	color: #0c5460;
}
.rich-content-wrapper .alert-box--info .alert-box__icon, 
.rich-content-wrapper .alert-box--info .alert-box__title {
	color: #3498db;
}

/* Success Alert */
.rich-content-wrapper .alert-box--success {
	background-color: #eafaf1;
	border-color: #a3e9a4;
	color: #155724;
}
.rich-content-wrapper .alert-box--success .alert-box__icon, 
.rich-content-wrapper .alert-box--success .alert-box__title {
	color: #28a745;
}

/* Warning Alert */
.rich-content-wrapper .alert-box--warning {
	background-color: #fff8e1;
	border-color: #ffecb3;
	color: #856404;
}
.rich-content-wrapper .alert-box--warning .alert-box__icon, 
.rich-content-wrapper .alert-box--warning .alert-box__title {
	color: #f39c12;
}

/* Danger Alert */
.rich-content-wrapper .alert-box--danger {
	background-color: #fbe9e7;
	border-color: #ffab91;
	color: #721c24;
}
.rich-content-wrapper .alert-box--danger .alert-box__icon, 
.rich-content-wrapper .alert-box--danger .alert-box__title {
	color: #dc3545;
}

/* --- NEW: Code Block --- */
.rich-content-wrapper .code-block-wrapper {
	margin: 2.5em 0;
	border-radius: var(--border-radius);
	box-shadow: 0 10px 30px rgba(0,0,0,0.1);
	overflow: hidden;
}
.rich-content-wrapper .code-block-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	background-color: #3c424f;
	padding: 10px 15px;
	color: #d4d4d4;
	font-size: 14px;
}
.rich-content-wrapper .code-block-lang { font-family: monospace; }
.rich-content-wrapper .copy-code-btn {
	background-color: transparent;
	color: #d4d4d4;
	border: 1px solid #5f6775;
	padding: 5px 10px;
	border-radius: 5px;
	cursor: pointer;
	font-size: 13px;
	transition: background-color 0.2s;
	display: flex;
	align-items: center;
	gap: 5px;
}
.rich-content-wrapper .copy-code-btn:hover { background-color: #5f6775; }
.rich-content-wrapper .copy-code-btn .fas { font-size: 14px; }
.rich-content-wrapper pre {
	background-color: #1e1e1e;
	color: #d4d4d4;
	padding: 1.5em;
	overflow-x: auto;
	margin: 0;
	white-space: pre-wrap;
	font-family: 'monospace', monospace;
	font-size: 15px;
	line-height: 1.6;
	direction: ltr;
	text-align: left;
}
.rich-content-wrapper pre code { 
	background-color: transparent; color: inherit; padding: 0; white-space: pre-wrap; 	
}

/* Inline Code */
.rich-content-wrapper p > code,
.rich-content-wrapper li > code {
	font-family: 'monospace', monospace;
	background-color: var(--medium-gray-color);
	color: var(--secondary-color);
	padding: 0.2em 0.4em;
	border-radius: 4px;
	font-size: 0.9em;
	white-space: nowrap;
}

/* Simulated Syntax Highlighting */
.rich-content-wrapper .code-keyword { color: #569cd6; }
.rich-content-wrapper .code-string { color: #ce9178; }
.rich-content-wrapper .code-comment { color: #6a9955; }
.rich-content-wrapper .code-function { color: #dcdcaa; }
.rich-content-wrapper .code-punctuation { color: #d4d4d4; }
.rich-content-wrapper .code-number { color: #b5cea8; }

/* --- NEW: Responsive Table --- */
.rich-content-wrapper .table-wrapper {
	overflow-x: auto;
	margin: 2.5em 0;
	border: 1px solid var(--medium-gray-color);
	border-radius: var(--border-radius);
}
.rich-content-wrapper table {
	width: 100%;
	border-collapse: collapse;
	font-size: 15px;
	text-align: right;
	min-width: 600px; /* Ensure horizontal scroll on small screens */
}
.rich-content-wrapper table th, .rich-content-wrapper table td {
	padding: 15px;
	border-bottom: 1px solid var(--medium-gray-color);
}
.rich-content-wrapper table thead th {
	background-color: var(--light-gray-color);
	font-family: 'PinarBold', sans-serif;
	white-space: nowrap;
}
.rich-content-wrapper table tbody tr:hover { background-color: #f9fafb; }
.rich-content-wrapper table tr:last-child td { border-bottom: none; }

/* --- Images & Figure --- */
.rich-content-wrapper figure { margin: 2.5em 0; }
.rich-content-wrapper img {
	width: 100%;
	height: auto;
	border-radius: var(--border-radius);
	box-shadow: var(--box-shadow);
	display: block;
	margin: 0 auto;
	cursor: pointer;
	transition: transform 0.3s ease;
}
.rich-content-wrapper img:hover { transform: scale(1.02); }
.rich-content-wrapper figcaption { font-size: 0.9em; color: var(--text-color-muted); margin-top: 1em; text-align: center; }

/* --- Horizontal Rule --- */
.rich-content-wrapper hr {
	border: none;
	height: 1px;
	background-color: var(--medium-gray-color);
	margin: 3em 0;
}

/* --- NEW: Promo Box Designs --- */
/* Style 1: Gradient Overlay */
.rich-content-wrapper .promo-box-gradient {
	position: relative;
	padding: 40px;
	border-radius: var(--border-radius);
	color: white;
	overflow: hidden;
	margin: 3em 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}
.rich-content-wrapper .promo-box-gradient__bg {
	position: absolute;
	top: 0; left: 0; width: 100%; height: 100%;
	object-fit: cover;
	z-index: 1;
}
.rich-content-wrapper .promo-box-gradient::after {
	content: '';
	position: absolute;
	top: 0; left: 0; width: 100%; height: 100%;
	background: linear-gradient(45deg, rgba(0, 82, 255, 0.85), rgba(44, 62, 80, 0.85));
	z-index: 2;
}
.rich-content-wrapper .promo-box-gradient__content { position: relative; z-index: 3; }
.rich-content-wrapper .promo-box-gradient__title { 
	font-family: 'PinarBold', sans-serif;
	font-size: 2rem; 
	color: white; 
	margin-top: 0; 
	margin-bottom: 0.5em; 
}
.rich-content-wrapper .promo-box-gradient p { font-size: 1.1rem; opacity: 0.9; max-width: 600px; margin-bottom: 1.5em; text-align: center;}
.rich-content-wrapper .promo-box-gradient .btn { background-color: white; color: var(--primary-color); font-weight: bold; }
.rich-content-wrapper .promo-box-gradient .btn:hover { background-color: var(--light-gray-color); }

/* --- REDESIGNED: Further Reading Box (List Style) --- */
.rich-content-wrapper .further-reading-container {
	margin: 3em 0;
}
.rich-content-wrapper .further-reading-header {
	display: flex;
	align-items: center;
	gap: 15px;
	margin-bottom: 20px;
	position: relative;
	padding-right: 20px; /* Space for the bar */
}
.rich-content-wrapper .further-reading-header::before {
	content: '';
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 5px;
	height: 100%;
	background-color: var(--error-color); /* Red color from image */
	border-radius: 3px;
}
.rich-content-wrapper .further-reading-header__title {
	font-family: 'PinarBold', sans-serif;
	font-size: 1.5rem;
	color: var(--secondary-color);
	margin: 0;
}
.rich-content-wrapper .further-reading-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 15px;
}
.rich-content-wrapper .further-reading-item a {
	display: flex;
	align-items: center;
	gap: 15px;
	text-decoration: none;
	border-bottom: none;
	padding: 10px;
	border-radius: var(--border-radius);
	transition: background-color 0.2s ease;
}
.rich-content-wrapper .further-reading-item a:hover {
	background-color: var(--light-gray-color);
	border-bottom: none;
}
.rich-content-wrapper .further-reading-item__image {
	width: 100px;
	height: 75px;
	object-fit: cover;
	border-radius: var(--border-radius);
	flex-shrink: 0;
}
	.rich-content-wrapper .further-reading-item__title {
		font-family: 'PinarRegular', sans-serif;
		font-size: 1.1rem;
		color: var(--secondary-color);
		line-height: 1.7;
		font-weight: 600;
		margin: 0;
	}

	.rich-content-wrapper .tosinso-internal-link {
		border: 1px solid #68af4a;
		border-radius: 5px;
		display: block;
		padding: 10px;
		margin: 40px 0;
		position: relative;
		background-color: #e5f8dd;
		color: black;
		font-weight: bold;
	}

		.rich-content-wrapper .tosinso-internal-link .remove {
			display: none;
		}

		.rich-content-wrapper .tosinso-internal-link img {
			width: 150px;
			height: auto;
			border-radius: 5px;
			display: inline;
			margin: 0 0 0 10px;
		}

		.rich-content-wrapper .tosinso-internal-link .read-more {
			position: absolute;
			left: 10px;
			bottom: 10px;
			background-color: #0065ff;
			border-radius: 5px;
			display: inline-block;
			padding: 2px 10px;
			color: white;
			font-weight: normal;
			font-size: 0.9em;
		}

	.rich-content-wrapper .content-embed-video {
		width: 100% !important;
	}

		.rich-content-wrapper .content-embed-video .uk-subnav {
			border-bottom: 1px solid gainsboro;
			margin: 0;
		}

			.rich-content-wrapper .content-embed-video .uk-subnav li {
				padding: 0;
				margin-left: 5px;
			}

				.rich-content-wrapper .content-embed-video .uk-subnav li a {
					background-color: transparent;
					color: gray;
					display: inline-block;
				}

		.rich-content-wrapper .content-embed-video video {
			width: 100%;
		}

/* --- NEW: Image Lightbox --- */
.image-lightbox {
	position: fixed;
	top: 0; left: 0; width: 100%; height: 100%;
	background-color: rgba(0, 0, 0, 0.85);
	z-index: 2000;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s ease, visibility 0.3s ease;
	backdrop-filter: blur(5px);
}
.image-lightbox.is-visible {
	opacity: 1;
	visibility: visible;
}
.image-lightbox__img {
	max-width: 90%;
	max-height: 90%;
	object-fit: contain;
	border-radius: var(--border-radius);
	transform: scale(0.9);
	transition: transform 0.3s ease;
}
.image-lightbox.is-visible .image-lightbox__img {
	transform: scale(1);
}
.image-lightbox__close-btn {
	position: absolute;
	top: 20px;
	right: 20px;
	background: none;
	border: none;
	color: white;
	font-size: 3rem;
	cursor: pointer;
	opacity: 0.8;
	transition: opacity 0.2s;
}
.image-lightbox__close-btn:hover { opacity: 1; }