/*
Theme Name: Betta Care Fish Guide
Theme URI: https://www.bettacarefishguide.com/
Description: GeneratePress child theme for Betta Care Fish Guide. Fast, clean, reader-first design with an aquatic identity. Includes a custom homepage template, topic hubs, related posts, author box and reading-time meta.
Author: Betta Care Fish Guide
Template: generatepress
Version: 1.0.9
Requires at least: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: betta-care
*/

/* =========================================================
   1. DESIGN TOKENS
   Palette drawn from the crimson betta logo + aquatic blues.
   ========================================================= */
:root {
	/* Brand */
	--bc-crimson: #b41f3e;        /* logo red — primary accent / CTA */
	--bc-crimson-dark: #8e1830;
	--bc-crimson-soft: #fbeef1;

	--bc-teal: #0e7490;           /* links, secondary accent */
	--bc-teal-dark: #0a5b71;
	--bc-teal-soft: #e8f4f7;

	/* Ink & surfaces */
	--bc-ink: #122a3f;            /* deep ocean navy — headings */
	--bc-ink-2: #33495d;          /* body text */
	--bc-ink-3: #64798c;          /* muted meta text */
	--bc-bg: #ffffff;
	--bc-bg-soft: #f4f8fa;        /* ice-blue section background */
	--bc-border: #e3ebf0;

	/* Effects */
	--bc-radius: 14px;
	--bc-radius-sm: 8px;
	--bc-shadow: 0 8px 28px rgba(18, 42, 63, .09);
	--bc-shadow-sm: 0 2px 10px rgba(18, 42, 63, .07);
	--bc-shadow-hover: 0 14px 36px rgba(18, 42, 63, .14);

	/* Type */
	--bc-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	--bc-transition: .22s ease;
}

/* =========================================================
   2. BASE
   ========================================================= */
body {
	font-family: var(--bc-font);
	color: var(--bc-ink-2);
	background-color: var(--bc-bg);
	font-size: 17px;
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--bc-font);
	color: var(--bc-ink);
	font-weight: 800;
	line-height: 1.25;
	letter-spacing: -.01em;
}

a {
	color: var(--bc-teal);
	transition: color var(--bc-transition);
}

a:hover,
a:focus {
	color: var(--bc-crimson);
}

::selection {
	background: var(--bc-crimson);
	color: #fff;
}

:focus-visible {
	outline: 3px solid var(--bc-teal);
	outline-offset: 2px;
	border-radius: 2px;
}

/* =========================================================
   3. HEADER & NAVIGATION
   ========================================================= */
.site-header {
	background-color: #fff;
	border-bottom: 1px solid var(--bc-border);
}

.site-logo img,
.header-image.is-logo-image {
	max-height: 84px;
	width: auto;
}

/* Sticky nav (works when nav sits below or inside the header) */
#site-navigation {
	position: sticky;
	top: 0;
	z-index: 90;
	background-color: var(--bc-ink);
	box-shadow: var(--bc-shadow-sm);
}

.admin-bar #site-navigation {
	top: 32px;
}

.main-navigation .main-nav ul li a {
	color: #e9f1f6;
	font-weight: 600;
	font-size: 15px;
	line-height: 56px;
	padding-left: 18px;
	padding-right: 18px;
	transition: background-color var(--bc-transition), color var(--bc-transition);
}

/* Desktop: logo + all menu items on a single line */
@media (min-width: 769px) {
	#site-navigation {
		--bc-nav-font: clamp(12px, 0.72vw + 9px, 14px);
		--bc-nav-pad-x: clamp(7px, 0.65vw, 12px);
		--bc-nav-height: 50px;
	}

	#site-navigation .inside-navigation {
		flex-wrap: nowrap;
		gap: 0 6px;
	}

	#site-navigation .main-nav {
		flex: 1 1 auto;
		min-width: 0;
	}

	#site-navigation .main-nav > ul {
		flex-wrap: nowrap;
		flex: 1 1 auto;
		min-width: 0;
	}

	#site-navigation .main-nav > ul > li > a,
	#site-navigation .menu-bar-item > a {
		font-size: var(--bc-nav-font);
		line-height: var(--bc-nav-height);
		padding-left: var(--bc-nav-pad-x);
		padding-right: var(--bc-nav-pad-x);
		white-space: nowrap;
	}

	#site-navigation .menu-item-has-children > a {
		padding-right: 0;
	}

	#site-navigation .menu-item-has-children > a .dropdown-menu-toggle {
		padding-left: 3px;
		padding-right: clamp(6px, 0.5vw, 10px);
	}

	/* Logo inside the nav bar (GeneratePress branding or menu logo) */
	#site-navigation .navigation-branding img,
	#site-navigation .site-logo img,
	#site-navigation .header-image.is-logo-image {
		max-height: 44px;
		width: auto;
	}

	#site-navigation .navigation-branding {
		flex-shrink: 0;
		margin-right: 4px;
	}
}

.main-navigation .main-nav ul li:hover > a,
.main-navigation .main-nav ul li:focus-within > a,
.main-navigation .main-nav ul li[class*="current"] > a {
	color: #fff;
	background-color: rgba(255, 255, 255, .09);
}

.main-navigation .main-nav ul li[class*="current"] > a {
	box-shadow: inset 0 -3px 0 var(--bc-crimson);
}

/* Dropdowns */
.main-navigation ul ul {
	background-color: #fff;
	box-shadow: var(--bc-shadow);
	border-radius: 0 0 var(--bc-radius-sm) var(--bc-radius-sm);
	overflow: hidden;
}

.main-navigation .main-nav ul ul li a {
	color: var(--bc-ink-2);
	line-height: 1.4;
	padding: 12px 18px;
	font-size: 14.5px;
}

.main-navigation .main-nav ul ul li:hover > a,
.main-navigation .main-nav ul ul li[class*="current"] > a {
	background-color: var(--bc-teal-soft);
	color: var(--bc-teal-dark);
	box-shadow: none;
}

/* Toggle on dark nav bar — beat GP Customizer (.main-navigation .menu-toggle { color: var(--contrast) }) */
.main-navigation .menu-toggle,
.main-navigation .menu-toggle .mobile-menu,
.main-navigation .mobile-bar-items a {
	color: #fff;
}

.main-navigation .menu-toggle .gp-icon svg {
	fill: currentColor;
}

.main-navigation button.menu-toggle:hover,
.main-navigation button.menu-toggle:focus {
	color: #fff;
	opacity: .85;
}

@media (max-width: 768px) {
	/* nav-below-header: toggle lives inside dark #site-navigation */
	#site-navigation .menu-toggle,
	#site-navigation .menu-toggle .mobile-menu,
	#site-navigation button.menu-toggle,
	.main-navigation .menu-toggle,
	.main-navigation .menu-toggle .mobile-menu {
		color: #fff !important;
		-webkit-text-fill-color: #fff !important;
		opacity: 1 !important;
	}

	#site-navigation .menu-toggle:hover,
	#site-navigation .menu-toggle:focus,
	#site-navigation .menu-toggle:active,
	.main-navigation button.menu-toggle:hover,
	.main-navigation button.menu-toggle:focus {
		color: #fff !important;
		-webkit-text-fill-color: #fff !important;
		opacity: .85 !important;
	}

	#site-navigation .menu-toggle .gp-icon svg,
	.main-navigation .menu-toggle .gp-icon svg {
		fill: #fff !important;
	}

	/* GP inline toggle — hamburger in the white header row */
	.has-inline-mobile-toggle .inside-header {
		flex-direction: row !important;
		flex-wrap: wrap !important;
		align-items: center !important;
		justify-content: space-between !important;
		text-align: left !important;
	}

	/* Menu button — dark pill, always visible (not white-on-white) */
	.has-inline-mobile-toggle .mobile-menu-control-wrapper {
		display: flex !important;
		align-items: center;
		gap: 6px;
		margin-left: auto;
		padding: 0 14px;
		min-height: 48px;
		background-color: var(--bc-ink) !important;
		color: #fff !important;
		border-radius: var(--bc-radius-sm);
		flex-shrink: 0;
	}

	.has-inline-mobile-toggle .mobile-menu-control-wrapper .menu-toggle,
	.has-inline-mobile-toggle .mobile-menu-control-wrapper .menu-toggle .mobile-menu,
	.has-inline-mobile-toggle .mobile-menu-control-wrapper .menu-toggle:hover,
	.has-inline-mobile-toggle .mobile-menu-control-wrapper .menu-toggle:focus,
	.has-inline-mobile-toggle .mobile-menu-control-wrapper .menu-toggle:active {
		color: #fff !important;
		-webkit-text-fill-color: #fff !important;
		opacity: 1 !important;
		background-color: transparent !important;
	}

	.has-inline-mobile-toggle .mobile-menu-control-wrapper .gp-icon svg {
		fill: #fff !important;
	}

	#site-navigation,
	#site-navigation .inside-navigation,
	#site-navigation.main-navigation {
		background-color: var(--bc-ink) !important;
	}

	/* Open menu panel */
	.has-inline-mobile-toggle #site-navigation.toggled {
		background-color: var(--bc-ink) !important;
		margin-top: 0;
		padding: 4px 0 10px;
		border-radius: 0 0 var(--bc-radius-sm) var(--bc-radius-sm);
	}

	.has-inline-mobile-toggle #site-navigation.toggled .main-nav > ul > li > a,
	.has-inline-mobile-toggle #site-navigation.toggled .main-nav > ul > li > a:visited,
	.has-inline-mobile-toggle #site-navigation.toggled .menu-bar-item > a {
		color: #e9f1f6 !important;
		-webkit-text-fill-color: #e9f1f6 !important;
		background-color: transparent !important;
		line-height: 1.4;
		padding-top: 14px;
		padding-bottom: 14px;
	}

	.has-inline-mobile-toggle #site-navigation.toggled .main-nav > ul > li > a:hover,
	.has-inline-mobile-toggle #site-navigation.toggled .main-nav > ul > li > a:focus,
	.has-inline-mobile-toggle #site-navigation.toggled .main-nav > ul > li.sfHover > a {
		color: #fff !important;
		background-color: rgba(255, 255, 255, .1) !important;
	}

	.has-inline-mobile-toggle #site-navigation.toggled .dropdown-menu-toggle {
		color: #e9f1f6 !important;
	}

	.has-inline-mobile-toggle #site-navigation.toggled .dropdown-menu-toggle .gp-icon svg {
		fill: #e9f1f6 !important;
	}

	#site-navigation.toggled .main-nav ul ul,
	#site-navigation.toggled .main-nav ul ul.toggled-on {
		background-color: #fff !important;
	}

	#site-navigation.toggled .main-nav ul ul li a {
		color: var(--bc-ink-2) !important;
		-webkit-text-fill-color: var(--bc-ink-2) !important;
	}
}

/* =========================================================
   4. BUTTONS
   ========================================================= */
.button,
a.button,
button:not(.menu-toggle):not(.search-modal__close):not(.search-modal-fields button),
input[type="submit"],
.bc-btn {
	background-color: var(--bc-crimson);
	color: #fff;
	border: 0;
	border-radius: 999px;
	padding: 12px 26px;
	font-weight: 700;
	font-size: 15px;
	display: inline-block;
	text-decoration: none;
	cursor: pointer;
	transition: background-color var(--bc-transition), transform var(--bc-transition), box-shadow var(--bc-transition);
}

.button:hover,
a.button:hover,
input[type="submit"]:hover,
.bc-btn:hover,
.button:focus,
a.button:focus,
.bc-btn:focus {
	background-color: var(--bc-crimson-dark);
	color: #fff;
	transform: translateY(-1px);
	box-shadow: var(--bc-shadow-sm);
}

.bc-btn--ghost {
	background: transparent;
	border: 2px solid currentColor;
	color: var(--bc-teal-dark);
}

.bc-btn--ghost:hover,
.bc-btn--ghost:focus {
	background: var(--bc-teal-dark);
	border-color: var(--bc-teal-dark);
	color: #fff;
}

/* =========================================================
   5. FORMS
   ========================================================= */
input[type="text"],
input[type="email"],
input[type="url"],
input[type="search"],
input[type="password"],
textarea,
select {
	border: 1.5px solid var(--bc-border);
	border-radius: var(--bc-radius-sm);
	padding: 10px 14px;
	background-color: #fff;
	color: var(--bc-ink-2);
	transition: border-color var(--bc-transition), box-shadow var(--bc-transition);
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="search"]:focus,
input[type="password"]:focus,
textarea:focus,
select:focus {
	border-color: var(--bc-teal);
	box-shadow: 0 0 0 3px rgba(14, 116, 144, .15);
	outline: 0;
}

/* =========================================================
   6. ARCHIVES / BLOG — card grid
   ========================================================= */
.blog .site-main,
.archive .site-main,
.search-results .site-main {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
	gap: 28px;
	align-items: stretch;
}

/* Everything that is not a post card spans the full row */
.blog .site-main > *:not(article),
.archive .site-main > *:not(article),
.search-results .site-main > *:not(article) {
	grid-column: 1 / -1;
}

.blog .site-main article,
.archive .site-main article,
.search-results .site-main article {
	margin-bottom: 0;
	background-color: #fff;
	border: 1px solid var(--bc-border);
	border-radius: var(--bc-radius);
	overflow: hidden;
	box-shadow: var(--bc-shadow-sm);
	transition: box-shadow var(--bc-transition), transform var(--bc-transition);
}

.blog .site-main article:hover,
.archive .site-main article:hover,
.search-results .site-main article:hover {
	box-shadow: var(--bc-shadow-hover);
	transform: translateY(-3px);
}

.blog .site-main article .inside-article,
.archive .site-main article .inside-article,
.search-results .site-main article .inside-article {
	display: flex;
	flex-direction: column;
	height: 100%;
	padding: 0 0 22px;
}

/* Featured image on top, edge to edge */
.blog .site-main article .post-image,
.archive .site-main article .post-image,
.search-results .site-main article .post-image {
	order: -1;
	margin: 0 0 18px;
}

.blog .site-main article .post-image img,
.archive .site-main article .post-image img,
.search-results .site-main article .post-image img {
	width: 100%;
	aspect-ratio: 16 / 9;
	object-fit: cover;
	display: block;
}

.blog .site-main article .entry-header,
.archive .site-main article .entry-header,
.search-results .site-main article .entry-header,
.blog .site-main article .entry-summary,
.archive .site-main article .entry-summary,
.search-results .site-main article .entry-summary,
.blog .site-main article .entry-content,
.archive .site-main article .entry-content,
.search-results .site-main article .entry-content {
	padding-left: 22px;
	padding-right: 22px;
}

.blog .site-main article .entry-title,
.archive .site-main article .entry-title,
.search-results .site-main article .entry-title {
	font-size: 20px;
	margin-bottom: 8px;
}

.blog .site-main article .entry-title a,
.archive .site-main article .entry-title a,
.search-results .site-main article .entry-title a {
	color: var(--bc-ink);
}

.blog .site-main article .entry-title a:hover,
.archive .site-main article .entry-title a:hover,
.search-results .site-main article .entry-title a:hover {
	color: var(--bc-crimson);
}

.blog .site-main article .entry-meta,
.archive .site-main article .entry-meta,
.search-results .site-main article .entry-meta {
	font-size: 13px;
	color: var(--bc-ink-3);
}

.blog .site-main article .entry-summary,
.archive .site-main article .entry-summary {
	font-size: 15px;
	color: var(--bc-ink-2);
}

/* Archive page titles */
.archive .page-header {
	grid-column: 1 / -1;
	background: linear-gradient(135deg, var(--bc-ink) 0%, var(--bc-teal-dark) 100%);
	border-radius: var(--bc-radius);
	padding: 34px 34px;
	margin-bottom: 6px;
}

.archive .page-header h1 {
	color: #fff;
	margin-bottom: 0;
	font-size: clamp(1.5rem, 3vw, 2.1rem);
}

.archive .page-header .archive-description,
.archive .page-header .author-info,
.archive .page-header .taxonomy-description {
	color: #d6e5ec;
	margin-top: 12px;
	font-size: 15.5px;
	line-height: 1.65;
}

.archive .page-header .author-info a,
.archive .page-header .taxonomy-description a {
	color: #fff;
	text-decoration: underline;
	text-underline-offset: 2px;
}

.archive .page-header .author-info a:hover,
.archive .page-header .taxonomy-description a:hover {
	color: #f6d9e0;
}

.archive .page-header .archive-description p:last-child,
.archive .page-header .author-info p:last-child,
.archive .page-header .taxonomy-description p:last-child {
	margin-bottom: 0;
}

.archive .page-header .page-title .vcard {
	color: #fff;
}

.archive .page-header .page-title img.avatar {
	border-radius: 50%;
	vertical-align: middle;
	margin-right: 12px;
	border: 2px solid rgba(255, 255, 255, .35);
}

/* Pagination */
.paging-navigation .page-numbers {
	display: inline-block;
	min-width: 42px;
	text-align: center;
	padding: 9px 12px;
	border-radius: var(--bc-radius-sm);
	border: 1px solid var(--bc-border);
	background-color: #fff;
	color: var(--bc-ink-2);
	font-weight: 600;
	font-size: 14.5px;
	transition: all var(--bc-transition);
}

.paging-navigation .page-numbers:hover,
.paging-navigation .page-numbers.current {
	background-color: var(--bc-crimson);
	border-color: var(--bc-crimson);
	color: #fff;
}

/* =========================================================
   7. SINGLE POST — readability first
   ========================================================= */
.single .site-main .inside-article,
.page .site-main .inside-article {
	background-color: #fff;
}

.single .entry-title {
	font-size: clamp(1.65rem, 4vw, 2.35rem);
	margin-bottom: 10px;
}

.single .entry-meta {
	color: var(--bc-ink-3);
	font-size: 14px;
}

/* Featured image */
.single .site-main article .post-image {
	margin-top: 18px;
}

.single .site-main article .post-image img {
	border-radius: var(--bc-radius);
	box-shadow: var(--bc-shadow-sm);
}

/* Content typography */
.single .entry-content {
	font-size: 17.5px;
	line-height: 1.78;
}

.entry-content > p,
.entry-content > ul,
.entry-content > ol {
	margin-bottom: 1.4em;
}

.entry-content h2 {
	font-size: 1.55em;
	margin-top: 1.9em;
	margin-bottom: .7em;
	padding-bottom: .35em;
	border-bottom: 3px solid var(--bc-teal-soft);
	position: relative;
}

.entry-content h2::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -3px;
	width: 64px;
	height: 3px;
	background-color: var(--bc-crimson);
}

.entry-content h3 {
	font-size: 1.25em;
	margin-top: 1.6em;
	margin-bottom: .6em;
}

.entry-content img {
	border-radius: var(--bc-radius-sm);
}

.entry-content blockquote {
	border-left: 4px solid var(--bc-crimson);
	background-color: var(--bc-crimson-soft);
	border-radius: 0 var(--bc-radius-sm) var(--bc-radius-sm) 0;
	padding: 18px 22px;
	margin: 1.6em 0;
	font-style: normal;
	color: var(--bc-ink);
}

.entry-content blockquote p:last-child {
	margin-bottom: 0;
}

/* Tables (care sheets, parameter tables) */
.entry-content table {
	width: 100%;
	border-collapse: collapse;
	margin: 1.6em 0;
	font-size: .95em;
	border-radius: var(--bc-radius-sm);
	overflow: hidden;
	box-shadow: var(--bc-shadow-sm);
}

.entry-content table th {
	background-color: var(--bc-ink);
	color: #fff;
	text-align: left;
	padding: 12px 14px;
	font-weight: 700;
}

.entry-content table td {
	padding: 11px 14px;
	border-bottom: 1px solid var(--bc-border);
}

.entry-content table tr:nth-child(even) td {
	background-color: var(--bc-bg-soft);
}

/* Tags */
.single .entry-meta .cat-links a,
.single .entry-meta .tags-links a {
	display: inline-block;
	background-color: var(--bc-teal-soft);
	color: var(--bc-teal-dark);
	border-radius: 999px;
	padding: 3px 12px;
	font-size: 13px;
	font-weight: 600;
	margin: 3px 4px 3px 0;
}

.single .entry-meta .cat-links a:hover,
.single .entry-meta .tags-links a:hover {
	background-color: var(--bc-teal-dark);
	color: #fff;
}

/* =========================================================
   8. CUSTOM COMPONENTS (meta line, author box, related)
   ========================================================= */

/* Reading time / updated line under the title */
.bc-meta-extra {
	display: flex;
	flex-wrap: wrap;
	gap: 6px 18px;
	align-items: center;
	margin: 10px 0 4px;
	font-size: 13.5px;
	color: var(--bc-ink-3);
}

.bc-meta-extra svg {
	width: 14px;
	height: 14px;
	vertical-align: -2px;
	margin-right: 5px;
	fill: currentColor;
}

.bc-meta-extra .bc-updated {
	color: var(--bc-teal-dark);
	font-weight: 600;
}

/* Author box */
.bc-author-box {
	display: flex;
	gap: 20px;
	align-items: flex-start;
	background-color: var(--bc-bg-soft);
	border: 1px solid var(--bc-border);
	border-radius: var(--bc-radius);
	padding: 24px;
	margin-top: 40px;
}

.bc-author-box img {
	border-radius: 50%;
	flex-shrink: 0;
	width: 72px;
	height: 72px;
}

.bc-author-box__label {
	text-transform: uppercase;
	letter-spacing: .08em;
	font-size: 11.5px;
	font-weight: 700;
	color: var(--bc-crimson);
	margin-bottom: 2px;
}

.bc-author-box__name {
	font-size: 18px;
	margin: 0 0 6px;
}

.bc-author-box__bio {
	font-size: 15px;
	margin: 0;
	color: var(--bc-ink-2);
}

/* Related posts */
.bc-related {
	margin: 44px 0 0;
}

.bc-related__title {
	font-size: 22px;
	margin-bottom: 18px;
	position: relative;
	padding-left: 14px;
}

.bc-related__title::before {
	content: "";
	position: absolute;
	left: 0;
	top: 4px;
	bottom: 4px;
	width: 4px;
	border-radius: 4px;
	background-color: var(--bc-crimson);
}

.bc-related__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
	gap: 20px;
}

.bc-card {
	background-color: #fff;
	border: 1px solid var(--bc-border);
	border-radius: var(--bc-radius);
	overflow: hidden;
	box-shadow: var(--bc-shadow-sm);
	transition: box-shadow var(--bc-transition), transform var(--bc-transition);
	display: flex;
	flex-direction: column;
}

.bc-card:hover {
	box-shadow: var(--bc-shadow-hover);
	transform: translateY(-3px);
}

.bc-card__media {
	display: block;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background-color: var(--bc-teal-soft);
}

.bc-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .35s ease;
}

.bc-card:hover .bc-card__media img {
	transform: scale(1.04);
}

.bc-card__body {
	padding: 16px 18px 18px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	flex-grow: 1;
}

.bc-card__cat {
	align-self: flex-start;
	font-size: 11.5px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .07em;
	color: var(--bc-teal-dark);
	background-color: var(--bc-teal-soft);
	border-radius: 999px;
	padding: 3px 10px;
	text-decoration: none;
}

a.bc-card__cat:hover {
	background-color: var(--bc-teal-dark);
	color: #fff;
}

.bc-card__title {
	font-size: 16.5px;
	line-height: 1.35;
	margin: 0;
}

.bc-card__title a {
	color: var(--bc-ink);
	text-decoration: none;
}

.bc-card__title a:hover {
	color: var(--bc-crimson);
}

.bc-card__excerpt {
	font-size: 14.5px;
	color: var(--bc-ink-2);
	margin: 0;
}

.bc-card__meta {
	margin-top: auto;
	font-size: 13px;
	color: var(--bc-ink-3);
}

/* Reading progress bar */
.bc-progress {
	position: fixed;
	top: 0;
	left: 0;
	height: 3px;
	width: 0;
	background: linear-gradient(90deg, var(--bc-teal), var(--bc-crimson));
	z-index: 9999;
	transition: width .1s linear;
}

/* Back to top */
.bc-top {
	position: fixed;
	right: 22px;
	bottom: 22px;
	width: 46px;
	height: 46px;
	border-radius: 50%;
	background-color: var(--bc-ink);
	color: #fff;
	border: 0;
	cursor: pointer;
	display: grid;
	place-items: center;
	box-shadow: var(--bc-shadow);
	opacity: 0;
	visibility: hidden;
	transform: translateY(8px);
	transition: opacity var(--bc-transition), transform var(--bc-transition), visibility var(--bc-transition), background-color var(--bc-transition);
	z-index: 9000;
	padding: 0;
}

.bc-top.is-visible {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.bc-top:hover {
	background-color: var(--bc-crimson);
}

.bc-top svg {
	width: 18px;
	height: 18px;
	fill: #fff;
}

/* =========================================================
   9. SIDEBAR
   ========================================================= */
.sidebar .widget {
	background-color: #fff;
	border: 1px solid var(--bc-border);
	border-radius: var(--bc-radius);
	padding: 24px;
	box-shadow: var(--bc-shadow-sm);
}

.sidebar .widget .widget-title,
.sidebar .widget .wp-block-heading {
	font-size: 16px;
	text-transform: uppercase;
	letter-spacing: .06em;
	padding-bottom: 10px;
	margin-bottom: 14px;
	border-bottom: 2px solid var(--bc-teal-soft);
	position: relative;
}

.sidebar .widget .widget-title::after,
.sidebar .widget .wp-block-heading::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -2px;
	width: 48px;
	height: 2px;
	background-color: var(--bc-crimson);
}

/* Auto sidebar blocks */
.bc-sidebar-block {
	margin-bottom: 28px;
}

.bc-sidebar-search__form {
	display: flex;
	align-items: stretch;
	gap: 8px;
}

.bc-sidebar-search__field {
	flex: 1;
	min-width: 0;
	margin: 0;
}

.bc-sidebar-search__form .search-field {
	width: 100%;
	margin: 0;
	padding: 11px 14px;
	font-size: 15px;
	border-radius: var(--bc-radius-sm);
}

.bc-sidebar-search__submit {
	flex-shrink: 0;
	display: grid;
	place-items: center;
	width: 46px;
	height: auto;
	min-height: 46px;
	padding: 0;
	border: 0;
	border-radius: var(--bc-radius-sm);
	background-color: var(--bc-teal);
	color: #fff;
	cursor: pointer;
	transition: background-color var(--bc-transition);
}

.bc-sidebar-search__submit:hover,
.bc-sidebar-search__submit:focus {
	background-color: var(--bc-teal-dark);
	color: #fff;
}

.bc-sidebar-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.bc-sidebar-list li + li {
	border-top: 1px solid var(--bc-border);
}

.bc-sidebar-list a {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 12px;
	padding: 11px 0;
	color: var(--bc-ink-2);
	text-decoration: none;
	font-size: 14.5px;
	line-height: 1.4;
	transition: color var(--bc-transition);
}

.bc-sidebar-list a:hover,
.bc-sidebar-list a:focus {
	color: var(--bc-crimson);
}

.bc-sidebar-list__label {
	flex: 1;
	min-width: 0;
}

.bc-sidebar-list__meta {
	flex-shrink: 0;
	font-size: 12px;
	font-weight: 700;
	color: var(--bc-ink-3);
	background: var(--bc-bg-soft);
	border-radius: 999px;
	padding: 2px 8px;
}

.bc-sidebar-list--posts a {
	display: block;
}

.bc-sidebar-list--posts .bc-sidebar-list__label {
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* E-book promo */
.sidebar .widget.bc-sidebar-ebook {
	padding: 0;
	overflow: hidden;
}

.bc-sidebar-ebook__inner {
	background:
		radial-gradient(420px 220px at 110% 0%, rgba(255, 255, 255, .14), transparent 60%),
		linear-gradient(145deg, var(--bc-crimson) 0%, #7e1430 100%);
	padding: 24px 22px;
	color: #fff;
}

.bc-sidebar-ebook__badge {
	display: inline-block;
	margin: 0 0 10px;
	padding: 4px 10px;
	border-radius: 999px;
	background: rgba(255, 255, 255, .16);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
}

.bc-sidebar-ebook__title {
	font-size: 1.15rem;
	line-height: 1.3;
	color: #fff;
	margin: 0 0 10px;
}

.bc-sidebar-ebook__text {
	font-size: 14px;
	line-height: 1.55;
	color: #f6d9e0;
	margin: 0 0 14px;
}

.bc-sidebar-ebook__perks {
	list-style: none;
	margin: 0 0 18px;
	padding: 0;
	font-size: 13.5px;
	color: #fce8ee;
}

.bc-sidebar-ebook__perks li {
	position: relative;
	padding-left: 20px;
	margin-bottom: 7px;
}

.bc-sidebar-ebook__perks li::before {
	content: "";
	position: absolute;
	left: 0;
	top: .55em;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #fff;
	opacity: .85;
}

.bc-sidebar-ebook__btn {
	display: block;
	width: 100%;
	text-align: center;
	background: #fff;
	color: var(--bc-crimson);
	padding: 12px 18px;
}

.bc-sidebar-ebook__btn:hover,
.bc-sidebar-ebook__btn:focus {
	background: var(--bc-ink);
	color: #fff;
}

/* =========================================================
   10. COMMENTS
   ========================================================= */
.comments-area {
	margin-top: 36px;
	background-color: var(--bc-bg-soft);
	border-radius: var(--bc-radius);
	padding: 28px;
}

.comment-body {
	background-color: #fff;
	border-radius: var(--bc-radius-sm);
	border: 1px solid var(--bc-border);
	padding: 18px 20px;
}

/* =========================================================
   11. CONTENT ↔ FOOTER SPACING
   GP zeroes margin on .site-main > *:last-child — compensate here.
   ========================================================= */
body:not(.page-template-template-home) .site-main {
	padding-bottom: 48px;
}

body:not(.page-template-template-home) .inside-right-sidebar,
body:not(.page-template-template-home) .inside-left-sidebar {
	padding-bottom: 48px;
}

body:not(.page-template-template-home) .site-footer {
	margin-top: 40px;
}

body:not(.page-template-template-home) .paging-navigation {
	margin-bottom: 0;
}

.blog .site-main .paging-navigation,
.archive .site-main .paging-navigation,
.search-results .site-main .paging-navigation {
	margin-top: 8px;
}

/* =========================================================
   12. FOOTER
   ========================================================= */
.footer-widgets {
	background-color: var(--bc-ink);
	color: #b9cad6;
	font-size: 15px;
}

.footer-widgets .widget-title,
.footer-widgets .wp-block-heading {
	color: #fff;
	font-size: 16px;
	text-transform: uppercase;
	letter-spacing: .06em;
	margin-bottom: 16px;
}

.footer-widgets a {
	color: #b9cad6;
}

.footer-widgets a:hover {
	color: #fff;
}

.site-info {
	background-color: #0c1d2c;
	color: #8aa0b1;
	font-size: 13.5px;
	padding: 18px 0;
}

.site-info a {
	color: #c3d4de;
}

.site-info a:hover {
	color: #fff;
}

/* =========================================================
   13. UTILITIES & RESPONSIVE
   ========================================================= */
.bc-section-title {
	font-size: clamp(1.35rem, 2.6vw, 1.75rem);
	margin-bottom: 4px;
}

.bc-section-sub {
	color: var(--bc-ink-3);
	font-size: 15.5px;
	margin-bottom: 22px;
}

@media (max-width: 768px) {
	body {
		font-size: 16px;
	}

	.site-logo img,
	.header-image.is-logo-image {
		max-height: 64px;
	}

	.bc-author-box {
		flex-direction: column;
		align-items: center;
		text-align: center;
	}

	.archive .page-header {
		padding: 24px 22px;
	}

	.bc-top {
		right: 14px;
		bottom: 14px;
	}
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		transition-duration: .01ms !important;
		animation-duration: .01ms !important;
	}
}
