/* --- Main Tab List (Headers) --- */
.tosinso-tabs__list {
	display: flex;
	flex-wrap: wrap;
	border-bottom: 1px solid var(--medium-gray-color);
}

.tosinso-tabs__tab {
	padding: 15px 20px;
	cursor: pointer;
	font-weight: 600;
	color: var(--dark-gray-color);
	background: none;
	border: none;
	border-bottom: 2px solid transparent;
	margin-bottom: 0px; /* Overlap the main border */
	transition: color 0.3s, border-color 0.3s, background-color 0.3s;
	font-size: 1rem;
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.tosinso-tabs__tab:hover {
	color: var(--primary-color);
	background-color: var(--light-gray-color);
}

.tosinso-tabs__tab.active {
	color: var(--primary-color);
	border-bottom-color: var(--primary-color);
}

/* MODIFIED: Removed the default blue outline on focus for a more subtle effect */
.tosinso-tabs__tab:focus-visible {
	outline: 2px solid var(--primary-color);
	outline-offset: 2px;
	border-radius: var(--border-radius) var(--border-radius) 0 0;
	z-index: 1;
}
.tosinso-tabs__tab:focus {
	outline: none;
}


/* --- Tab Content Panel --- */
.tosinso-tabs__panel {
	display: none;
	padding: 25px; /* Add some padding */
	animation: fadeIn 0.5s ease-in-out;
}

.tosinso-tabs__panel.active {
	display: block;
}

/* NEW: Style to handle content overflow, especially for <pre> tags */
.tosinso-tabs__panel pre {
	white-space: pre-wrap;       /* CSS3 */
	white-space: -moz-pre-wrap;  /* Mozilla, since 1999 */
	white-space: -pre-wrap;      /* Opera 4-6 */
	white-space: -o-pre-wrap;    /* Opera 7 */
	word-wrap: break-word;       /* Internet Explorer 5.5+ */
	background-color: #f8f9fa;
	padding: 15px;
	border-radius: var(--border-radius);
	border: 1px solid var(--medium-gray-color);
}


/* MODIFIED: Style for AJAX loading state */
.tosinso-tabs__panel.is-loading {
	display: flex;
	justify-content: center;
	align-items: center;
	min-height: 200px; /* Ensure spinner is visible with more height */
}

@keyframes fadeIn {
	from { opacity: 0; transform: translateY(10px); }
	to { opacity: 1; transform: translateY(0); }
}

/* --- Style Variation: Bordered --- */
.tosinso-tabs--bordered .tosinso-tabs__list {
	border-bottom: none;
}
.tosinso-tabs--bordered .tosinso-tabs__tab {
	border: 1px solid var(--medium-gray-color);
	border-bottom: none;
	border-radius: var(--border-radius) var(--border-radius) 0 0;
	margin-right: 5px;
	background-color: var(--light-gray-color);
}
.tosinso-tabs--bordered .tosinso-tabs__tab.active {
	background-color: #fff;
	border-bottom: 1px solid #fff;
}
.tosinso-tabs--bordered .tosinso-tabs__content {
	border: 1px solid var(--medium-gray-color);
	border-top: none;
	border-radius: 0 0 var(--border-radius) var(--border-radius);
	padding: 20px;
}

/* --- Style Variation: Vertical --- */
.tosinso-tabs--vertical {
	display: flex;
	gap: 20px;
}
.tosinso-tabs--vertical .tosinso-tabs__list {
	flex-direction: column;
	border-bottom: none;
	border-left: 2px solid var(--medium-gray-color);
	flex-shrink: 0;
}
.tosinso-tabs--vertical .tosinso-tabs__tab {
	border-bottom: none;
	border-left: 3px solid transparent;
	margin-bottom: 0;
	margin-left: -2px; /* Overlap the main border */
	justify-content: flex-start;
	width: 100%;
}
.tosinso-tabs--vertical .tosinso-tabs__tab.active {
	border-color: var(--primary-color);
	background-color: #eaf4ff;
}
.tosinso-tabs--vertical .tosinso-tabs__content {
	flex-grow: 1;
}
.tosinso-tabs--vertical .tosinso-tabs__tab:focus-visible {
	border-radius: var(--border-radius);
}