/**
 * Professional Wiki Bootstrap CSS
 */

:root {
	/* Brand colors */
	--pw-color-brand-50: #f4f8fb;
	--pw-color-brand-50-rgb: 244, 248, 251;
	--pw-color-brand-100: #e7f0f7;
	--pw-color-brand-100-rgb: 231, 240, 247;
	--pw-color-brand-200: #cae0ed;
	--pw-color-brand-200-rgb: 202, 224, 237;
	--pw-color-brand-300: #9bc5de;
	--pw-color-brand-300-rgb: 155, 197, 222;
	--pw-color-brand-400: #66a7ca;
	--pw-color-brand-400-rgb: 102, 167, 202;
	--pw-color-brand-500: #428cb5;
	--pw-color-brand-500-rgb: 66, 140, 181;
	--pw-color-brand-600: #32739b;
	--pw-color-brand-600-rgb: 50, 115, 155;
	--pw-color-brand-700: #295b7b;
	--pw-color-brand-700-rgb: 41, 91, 123;
	--pw-color-brand-800: #254d67;
	--pw-color-brand-800-rgb: 37, 77, 103;
	--pw-color-brand-900: #234257;
	--pw-color-brand-900-rgb: 35, 66, 87;
	--pw-color-brand-950: #182b39;
	--pw-color-brand-950-rgb: 24, 43, 57;

	/* This needs to be manually updated because the height is calculated by its content */
	--pw-header-height: 3rem;
	--pw-page-gutter: 1rem;
}

/* Additional specificity to override Bootstrap defaults */
:root.theme-pw {
	--bs-heading-color: var(--bs-emphasis-color); /* Apply heading color */

	--bs-font-sans-serif: 'Open Sans', 'Open Sans-fallback', system-ui,
		-apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', 'Noto Sans',
		'Liberation Sans', Arial, sans-serif, 'Apple Color Emoji',
		'Segoe UI Emoji', 'Segoe UI Symbol', 'Noto Color Emoji';

	--bs-primary: var(--pw-color-brand-600);
	--bs-primary-rgb: var(--pw-color-brand-600-rgb);

	--bs-link-color: var(--pw-color-brand-600);
	--bs-link-hover-color: var(--pw-color-brand-700);
	--bs-link-color-rgb: var(--pw-color-brand-600-rgb);
	--bs-link-hover-color-rgb: var(--pw-color-brand-700-rgb);

	--bs-body-color: var(--pw-color-brand-900);
	--bs-body-color-rgb: var(--pw-color-brand-900-rgb);
	--bs-emphasis-color: var(--pw-color-brand-950);
	--bs-emphasis-color-rgb: var(--pw-color-brand-950-rgb);
	--bs-secondary-color: rgba(var(--pw-color-brand-900-rgb), 0.75);
	--bs-secondary-color-rgb: var(--pw-color-brand-900-rgb);
	--bs-secondary-bg: var(--pw-color-brand-50);
	--bs-secondary-bg-rgb: var(--pw-color-brand-50-rgb);
	--bs-tertiary-color: rgba(var(--pw-color-brand-900-rgb), 0.5);
	--bs-tertiary-color-rgb: var(--pw-color-brand-900-rgb);
	--bs-tertiary-bg: var(--pw-color-brand-100);
	--bs-tertiary-bg-rgb: var(--pw-color-brand-100-rgb);
}

.theme-pw body {
	background-color: var(--bs-secondary-bg);
}

.theme-pw a {
	/* Bootstrap 5 links are underlined by default (https://getbootstrap.com/docs/5.0/migration/#content-reboot-etc) */
	text-decoration: none;
}

.theme-pw h1,
.theme-pw h2,
.theme-pw h3,
.theme-pw h4,
.theme-pw h5,
.theme-pw h6,
.theme-pw .h1,
.theme-pw .h2,
.theme-pw .h3,
.theme-pw .h4,
.theme-pw .h5,
.theme-pw .h6 {
	font-weight: 600;
	letter-spacing: -0.025em;
}

.theme-pw .breadcrumb {
	--bs-breadcrumb-padding-x: 1rem;
	--bs-breadcrumb-padding-y: 0.25rem;
	--bs-breadcrumb-margin-bottom: 2rem;
	border-left: 4px solid var(--pw-color-brand-600);
	font-style: italic;
}

.theme-pw .btn {
	--bs-btn-font-weight: 600;
}

.theme-pw .btn-primary {
	--bs-btn-bg: var(--pw-color-brand-600);
	--bs-btn-border-color: var(--pw-color-brand-600);
	--bs-btn-hover-bg: var(--pw-color-brand-700);
	--bs-btn-hover-border-color: var(--pw-color-brand-700);
	--bs-btn-active-bg: var(--pw-color-brand-800);
	--bs-btn-active-border-color: var(--pw-color-brand-800);
	--bs-btn-focus-shadow-rgb: var(--pw-color-brand-600-rgb);
}

.theme-pw .btn-outline-primary {
	--bs-btn-color: var(--pw-color-brand-600);
	--bs-btn-border-color: var(--pw-color-brand-600);
	--bs-btn-hover-bg: var(--pw-color-brand-600);
	--bs-btn-hover-border-color: var(--pw-color-brand-600);
	--bs-btn-focus-shadow-rgb: var(--pw-color-brand-600-rgb);
	--bs-btn-active-bg: var(--pw-color-brand-600);
	--bs-btn-active-border-color: var(--pw-color-brand-600);
	--bs-btn-disabled-color: var(--pw-color-brand-600);
	--bs-btn-disabled-border-color: var(--pw-color-brand-600);
}

.theme-pw .btn-group-lg > .btn,
.theme-pw .btn-lg {
	--bs-btn-padding-x: 1.25rem;
	--bs-btn-padding-y: 0.75rem;
	--bs-btn-font-size: 1rem;
}

.theme-pw .card {
	box-shadow: 0 0 10px 7px rgb(0 0 0 / 0.04);
	transition: all ease-in-out 0.25s;
}

.theme-pw .card-footer {
	border-top: 0;
	background-color: transparent;
}

.theme-pw .display-1,
.theme-pw .display-2,
.theme-pw .display-3,
.theme-pw .display-4,
.theme-pw .display-5,
.theme-pw .display-6 {
	letter-spacing: -0.025em;
}

.theme-pw .navbar {
	--bs-navbar-color: var(--bs-body-color);
	--bs-navbar-padding-y: 0;
	--bs-navbar-brand-color: var(--bs-primary);
	--bs-navbar-brand-font-size: 1rem;
	--bs-navbar-brand-padding-y: 0.75rem;
	--bs-navbar-active-color: var(--bs-primary);
	--bs-navbar-toggler-border-color: transparent;
	--bs-navbar-toggler-font-size: 0.875rem;
	--bs-navbar-toggler-focus-width: 1px;
	border-bottom: var(--bs-border-width) var(--bs-border-style) transparent;
	transition: background-color 250ms ease, border-color 250ms ease;
}

.theme-pw .navbar.navbar--scrolled,
.theme-pw .navbar:has(.navbar-collapse:is(.show, .collapsing)) {
	background-color: var(--bs-body-bg);
	border-bottom-color: var(--bs-border-color);
}

.theme-pw .navbar .container-xxl {
	padding-inline: var(--pw-page-gutter);
}

.theme-pw .navbar-nav {
	--bs-nav-link-font-size: 0.875rem;
	--bs-nav-link-font-weight: 600;
	--bs-nav-link-padding-y: 0.5rem;

	margin-inline-start: auto;
	align-content: stretch;
	align-self: stretch;
}

.theme-pw .navbar-collapse {
	padding-block: 0.25rem;
}

.theme-pw .nav-item {
	display: flex;
	align-items: stretch;
}

.theme-pw .nav-link {
	display: flex;
	align-items: center;
}

.pw-page-gutter {
	padding-inline: 1rem;
}

.pw-page-gutter-negative {
	margin-inline: -1rem;
}

.pw-brand-wordmark {
	font-weight: 600;
	letter-spacing: -0.025em;
}

.pw-brand-wordmark-part {
	font-weight: 700;
}

.pw-language-links {
	display: flex;
	width: 100%;
	margin-top: 0.5rem;
	border-top: 1px solid var(--bs-border-color);
}

.pw-language-link {
	flex-grow: 1;
	justify-content: center;
}

.pw-language-link-separator {
	width: 1px;
	height: 1rem;
	background-color: var(--bs-border-color);
	align-self: center;
}

.pw-content-container {
	min-height: calc(100% - 296px);
	padding-top: var(--pw-header-height);
}

.pw-hero-container {
	padding-block: 5rem;
}

.pw-hero-container .display-3,
.pw-hero-container .lead {
	text-wrap: balance; /* Fallback for browsers that don't support pretty */
	text-wrap: pretty;
}

.pw-page-section > [class^='container'] {
	padding-inline: var(--pw-page-gutter);
	padding-block: 3rem; /* py-5 */
}

.pw-page-section:nth-of-type(even) {
	background-color: var(--bs-body-bg);
}

.pw-client-logos img {
	display: block;
	width: 96px;
	height: 48px;
	max-width: 100%;
	object-fit: contain;
}

.pw-link-image {
	display: block;
	overflow: hidden;

	> img {
		transition: transform 100ms ease;
	}

	&:hover > img {
		transform: scale(1.1);
	}
}

/* Large breakpoint */
@media (min-width: 992px) {
	.pw-language-links {
		margin-top: 0;
		border-top: none;
	}

	.pw-hero-container {
		padding-block: 6rem;
	}
}

/**
  * Start Bootstrap - Modern Business (https://startbootstrap.com/template-overviews/modern-business)
  * Copyright 2013-2017 Start Bootstrap
  * Licensed under MIT (https://github.com/BlackrockDigital/startbootstrap-logomodern-business-nav/blob/master/LICENSE)
  */

/* Make links distinguishable from "professional" class */
.plink {
	color: var(--bs-primary);
	text-decoration: underline;
}

footer .form-control.email {
	background: var(--bs-primary);
	color: #fff;
}

footer .form-control.email:active,
footer .form-control.email:focus {
	background: var(--pw-color-brand-900);
}

footer .validate input::placeholder {
	/* Chrome, Firefox, Opera, Safari 10.1+ */
	color: #fff;
	opacity: 0.6; /* Firefox */
	font-weight: 500;
}

.carousel {
	background-clip: border-box;
	border: 1px solid rgba(0, 0, 0, 0.125);
	border-radius: 0.25rem;
}

.carousel-item {
	min-height: 304px;
	background: no-repeat center center scroll;
	-webkit-background-size: cover;
	-moz-background-size: cover;
	-o-background-size: cover;
	background-size: cover;
	background-color: var(--bs-primary);
}

.carousel-header {
	position: static;
	color: black;
	height: 55px;
	padding-top: 15px;
	border-bottom: 1px solid rgba(0, 0, 0, 0.125);
	text-align: center;
}

.carousel-image {
	width: 100%;
}

.portfolio-item {
	margin-bottom: 30px;
}

.footer {
	position: relative;
	opacity: 1;
	clear: both;

	@media (max-width: 575px) {
		padding-left: 10%;
	}
}

.footer .footer-image {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.footer .footer-image img {
	object-fit: contain; /* This will ensure that the aspect ratio of the image is maintained */
	object-position: center center; /* Center the image within the element */
}

/* Ensure other elements in the footer have a higher z-index if needed */
.footer > .container {
	position: relative;
	z-index: 1;
}

.expanding-box {
	border-top: 1px solid;
}

br.box-align {
	display: none;
}
footer {
	padding: 6rem 0;
}
@media (min-width: 1200px) {
	br.box-align {
		display: inline;
	}
}

.wiki-feature-list i.fa {
	color: var(--bs-primary);
}

p code {
	color: #000;
	background-color: white;
	border: 1px solid #dddddd;
	border-radius: 2px;
	padding: 1px 4px;
	white-space: nowrap;
}

.stickyBox {
	position: sticky;
	top: calc(var(--pw-header-height) + 1rem);
	max-height: calc(100vh - var(--pw-header-height) - 1rem * 2);
	overflow-y: auto;
}

a.anchor-link {
	position: absolute;
	outline: none;
	margin-left: -1em;
	opacity: 0;
	user-select: none;
	transition: opacity 250ms;
}

a.anchor-link::before {
	content: '§';
	padding: 0 0.2em;
}

.header-anchors h1:hover > a.anchor-link,
.header-anchors h2:hover > a.anchor-link,
.header-anchors h3:hover > a.anchor-link,
.header-anchors h4:hover > a.anchor-link,
.header-anchors h5:hover > a.anchor-link,
.header-anchors h6:hover > a.anchor-link {
	opacity: 1;
}

a.contact-icon {
	display: flex;
	align-items: center;
}

a.contact-icon i {
	font-size: 1.5rem;
	margin-right: 10px;
}

.colored-checks i.fa-check {
	color: #58a118;
}

.colored-checks i.fa-times {
	color: #d40b2c;
}

#blogContent h3,
.header-underlined h3 {
	border-bottom: 1px solid var(--bs-border-color);
	padding-block: 0.5rem;
	margin-bottom: 1rem;
}

.city-image {
	box-shadow: 0px 7px 8px -4px rgba(0, 0, 0, 0.2),
		0px 12px 17px 2px rgba(0, 0, 0, 0.14),
		0px 5px 22px 4px rgba(0, 0, 0, 0.12) !important;
}

img.use-cases {
	max-width: 750px;
}

iframe.youtube {
	width: 100%;
	height: 412px;
	border: none;
	margin-bottom: 1rem;
}

div.youtube-gallery iframe.youtube {
	width: 100%;
	height: 200px;
}

.lead {
	font-size: 1.5rem;
	margin-bottom: 30px;
	margin-top: 20px;
}

/* home page blog items */
.blog-item {
	margin: 30px auto;
	padding: 30px;
	border-radius: 10px;
	max-width: 900px;
	background-color: #fff;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}
.blog-item p {
	font-size: 0.95rem;
	text-align: justify;
}
.blog-item .imgCover {
	display: flex;
	height: 100%;
}
.blog-item .imgCover img {
	object-fit: contain;
	border-radius: 5px !important;
}

.transparentBack {
	background-image: url('http://localhost:8000/img/Professional-MediaWiki-upgrades.jpg');
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	background-attachment: fixed;
	position: relative;
}
.transparentBack::before {
	content: '';
	width: 100%;
	height: 100%;
	background: var(--bs-primary);
	position: absolute;
	left: 0;
	top: 0;
	opacity: 0.9;
}
.transparentBack p {
	font-size: 2.2rem;
	max-width: 1000px;
	margin: 0 auto 30px;
}
.check-list {
	margin: 0;
	padding-left: 1.2rem;
	font-size: 1.1rem;
	display: inline-block;
	text-align: left;
}

.check-list li {
	position: relative;
	list-style-type: none;
	padding-left: 2.5rem;
	margin-bottom: 0.5rem;
}

.check-list li:before {
	content: '';
	display: block;
	position: absolute;
	left: 0;
	top: -2px;
	width: 5px;
	height: 11px;
	border-width: 0 2px 2px 0;
	border-style: solid;
	border-color: #00a8a8;
	transform-origin: bottom left;
	transform: rotate(45deg);
}
/* hosting plan box section */
.list-group-item {
	border: 0;
}

.card-header {
	font-size: 2.8571em;
	color: #232a34;
	font-size: 1.8em;
	margin-bottom: 0;
	border-bottom: 0;
	background: transparent;
	font-weight: 600;
	height: 1.88em;
	text-decoration: none;
	transition: all ease-in-out 0.25s;
}

.list-group-item {
	background: transparent;
}

li.hosting-item {
	padding: 1rem 1.25rem;
}

.form-control {
	height: calc(1.5em + 0.8rem + 13px);
}
input:active,
input:focus {
	border: 0;
	outline: none;
}

/* cookie bar / gdpr */
#cookie_bar {
	position: fixed;
	bottom: 10px;
	background: #000;
	padding: 15px;
	text-align: center;
	width: 100%;
	margin: 0 auto;
	max-width: 450px;
	border-radius: 5px;
	display: none;
	left: 50%;
	transform: translate(-50%);
}
#cookie_bar p {
	text-align: center;
	font-size: 14px;
}

/*************************************************************
 ***********************Wikis For Companies******************************************/

.fa-rss-square {
	color: var(--bs-primary);
	font-size: 25px;
}
.fa-rss-square:hover {
	color: var(--pw-color-brand-700);
	font-size: 25px;
}

.author_widget img {
	width: 40px;
	height: 40px;
	object-fit: cover;
	object-position: center;
	border-radius: 50%;
	margin-right: 5px;
}
.author_widget .author_item {
	margin-bottom: 10px;
}

/* single blog page */
.single_blog_section {
	padding: 30px;
	border: 1px solid #e0e0e0;
}
.sideabr_social_links li {
	display: inline;
	margin-right: 10px;
}
.sideabr_social_links li i {
	font-size: 20px;
}
.desktopBorderRight {
	border-right: 1px solid #ccc;
}

table.strengths-weaknesses th {
	width: 50%;
}

table.strengths-weaknesses ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

table.strengths-weaknesses li {
	margin-bottom: 2px;
	padding-left: 1rem;
}

table.strengths-weaknesses td:first-child li {
	color: darkgreen;
}

table.strengths-weaknesses td:last-child li {
	color: darkred;
}

.pro-bullet-list li {
	margin-bottom: 1rem;
}

.pro-bullet-list li::marker {
	color: var(--bs-primary);
	font-size: 1.1rem;
}

.pro-bullet-list li span {
	color: var(--bs-primary);
	font-size: 1.1rem;
	font-weight: bold;
	display: block;
}

div.pw-project-card a:hover {
	text-decoration: underline;
}

.showcase .showcase-text {
	padding: 3rem;
}
.showcase .showcase-img {
	min-height: 30rem;
	background-size: cover;
}
@media (min-width: 768px) {
	.showcase .showcase-text {
		padding: 7rem;
	}
}

.timeline {
	position: relative;
	padding: 0;
	list-style: none;
}
.timeline:before {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 40px;
	width: 2px;
	margin-left: -1.5px;
	content: '';
	background-color: #e9ecef;
}
.timeline > li {
	position: relative;
	min-height: 50px;
	margin-bottom: 50px;
}
.timeline > li:after,
.timeline > li:before {
	display: table;
	content: ' ';
}
.timeline > li:after {
	clear: both;
}
.timeline > li .timeline-panel {
	position: relative;
	float: right;
	width: 100%;
	padding: 0 20px 0 100px;
	text-align: left;
}
.timeline > li .timeline-panel:before {
	right: auto;
	left: -15px;
	border-right-width: 15px;
	border-left-width: 0;
}
.timeline > li .timeline-panel:after {
	right: auto;
	left: -14px;
	border-right-width: 14px;
	border-left-width: 0;
}
.timeline > li .timeline-image {
	position: absolute;
	z-index: 100;
	left: 0;
	width: 80px;
	height: 80px;
	margin-left: 0;
	text-align: center;
	color: white;
	border: 7px solid #e9ecef;
	border-radius: 100%;
	background-color: var(--bs-gray-100);
}
.timeline > li .timeline-image img {
	height: 100%;
	object-fit: cover;
}
.timeline > li .timeline-image h4,
.timeline > li .timeline-image .h4 {
	font-size: 10px;
	line-height: 14px;
	margin-top: 12px;
}
.timeline > li.timeline-inverted > .timeline-panel {
	float: right;
	padding: 0 20px 0 100px;
	text-align: left;
}
.timeline > li.timeline-inverted > .timeline-panel:before {
	right: auto;
	left: -15px;
	border-right-width: 15px;
	border-left-width: 0;
}
.timeline > li.timeline-inverted > .timeline-panel:after {
	right: auto;
	left: -14px;
	border-right-width: 14px;
	border-left-width: 0;
}
.timeline > li:last-child {
	margin-bottom: 0;
}
.timeline .timeline-heading h4,
.timeline .timeline-heading .h4 {
	margin-top: 0;
	color: inherit;
}
.timeline .timeline-heading h4.subheading,
.timeline .timeline-heading .subheading.h4 {
	text-transform: none;
}
.timeline .timeline-body > ul,
.timeline .timeline-body > p {
	margin-bottom: 0;
}

@media (min-width: 768px) {
	.timeline:before {
		left: 50%;
	}
	.timeline > li {
		min-height: 100px;
		margin-bottom: 100px;
	}
	.timeline > li .timeline-panel {
		float: left;
		width: 41%;
		padding: 0 20px 20px 30px;
		text-align: right;
	}
	.timeline > li .timeline-image {
		left: 50%;
		width: 100px;
		height: 100px;
		margin-left: -50px;
	}
	.timeline > li .timeline-image h4,
	.timeline > li .timeline-image .h4 {
		font-size: 13px;
		line-height: 18px;
		margin-top: 16px;
	}
	.timeline > li.timeline-inverted > .timeline-panel {
		float: right;
		padding: 0 30px 20px 20px;
		text-align: left;
	}
}
@media (min-width: 992px) {
	.timeline > li {
		min-height: 150px;
	}
	.timeline > li .timeline-panel {
		padding: 0 20px 20px;
	}
	.timeline > li .timeline-image {
		width: 150px;
		height: 150px;
		margin-left: -75px;
	}
	.timeline > li .timeline-image h4,
	.timeline > li .timeline-image .h4 {
		font-size: 18px;
		line-height: 26px;
		margin-top: 30px;
	}
	.timeline > li.timeline-inverted > .timeline-panel {
		padding: 0 20px 20px;
	}
}
@media (min-width: 1200px) {
	.timeline > li {
		min-height: 170px;
	}
	.timeline > li .timeline-panel {
		padding: 0 20px 20px 100px;
	}
	.timeline > li .timeline-image {
		width: 170px;
		height: 170px;
		margin-left: -85px;
	}
	.timeline > li .timeline-image h4,
	.timeline > li .timeline-image .h4 {
		margin-top: 40px;
	}
	.timeline > li.timeline-inverted > .timeline-panel {
		padding: 0 100px 20px 20px;
	}
}

.mediawiki-ai-sections {
	.black-text-decoration {
		text-decoration-color: #000000;
	}

	h3 {
		color: #000000;
	}

	.card {
		box-shadow: none;

		.semantic-mediawiki-image {
			max-height: 400px;

			@media (max-width: 768px) {
				max-height: 300px;
			}

			@media (max-width: 480px) {
				max-height: 200px;
			}
		}
	}

	.card-img-top {
		border-radius: 10px;
	}
}

.wikibase-services {
	img {
		height: 120px !important;
	}

	@media (min-width: 1090px) {
		h4 {
			white-space: nowrap;
		}
	}
}

.wikibase-helped-section {
	.row {
		gap: 20px;
	}

	.card {
		padding: 20px;
		max-width: 350px;

		.card-title {
			color: var(--bs-emphasis-color);
			display: block;
			font-weight: bold;
			font-size: 1.25rem;
			margin-bottom: 20px;
		}
	}
}

.longer-heading {
	white-space: nowrap;

	@media (max-width: 1150px) {
		white-space: normal;
		word-break: break-word;
		overflow-wrap: break-word;
		-webkit-line-break: after-white-space;
	}
}

@media (min-width: 768px) {
	.wikibase-link {
		margin-top: 41px;
	}

	.smw-link {
		margin-top: 12px;
	}
}
