
/* Pagination Style Start */

.pagination {
	margin-top: 6.25rem;
}
.pagination .page-numbers {
	margin: 0;
	padding: 0;
	list-style-type: none;
	display: flex;
	justify-content: center;
	align-items: center;
	column-gap: 1.875rem; /* 30px */
}
.pagination .page-numbers .page-numbers {
	text-decoration: none;
	color: var(--bubb-color-dark);
	width: 2.375rem;
	height: 2.375rem;
	display: flex;
	align-items: center;
	justify-content: center;
	border: 0.063rem solid transparent;
	border-radius: 50%;
	font-weight: 400;
	transition: background-color var(--bubb-transition), color var(--bubb-transition);
}
.pagination .page-numbers .page-numbers:not(.current):hover {
	background-color: var(--bubb-color-subtle);
	color: var(--bubb-color-primary);
}
.pagination .page-numbers .page-numbers.current {
	color: var(--bubb-color-light);
	background-color: var(--bubb-color-primary);
	font-weight: 700;
}
.pagination .prev span, .pagination .next span {
	display: flex;
	align-items: center;
}

@media only screen and (max-width:991px) {

	.pagination{
		margin-top: 4.375rem; /* 70px */
	}

}
@media only screen and (max-width:767px) {

	.pagination{
		margin-top: 3.125rem; /* 50px */
	}
	.pagination .page-numbers {
		column-gap: .625rem; /* 10px */
	}
	.pagination .page-numbers .page-numbers {
		width: 2rem; /* 32px */
		height: 2rem; /* 32px */
		font-size: 0.875rem; /* 14px */
	}
	.pagination .prev svg,
	.pagination .next svg {
		width: 1rem; /* 16px */
	}
}

/* Pagination Style End */


/* =============================================================================
   SEARCH
   ============================================================================= */

.search-results-header {
	background: var(--bubb-color-subtle);
	padding-bottom: 2.5rem;
	border-bottom: 0.0625rem solid var(--bubb-color-subtle);
}

.search-results-header-inner {
	max-width: 50rem; /* 800px */
	margin: 0 auto;
	text-align: center;
}

.search-results-title {
	font-size: 2.5rem; /* 40px */
	font-weight: 700;
	color: var(--bubb-color-primary);
	margin: 0 0 1rem 0; /* 16px */
	line-height: 1.2;
}

.search-results-title .search-query {
	color: var(--bubb-color-accent);
}

.search-results-count {
	font-size: 1.125rem; /* 18px */
	color: var(--bubb-color-mid);
	margin: 0;
}

.search-section-header {
	margin-bottom: 2.5rem; /* 40px */
}

.search-section-title {
	font-size: 1.875rem; /* 30px */
	font-weight: 700;
	color: var(--bubb-color-primary);
	margin: 0;
	padding-bottom: 1rem; /* 16px */
	border-bottom: 0.1875rem solid var(--bubb-color-accent); /* 3px */
	display: inline-block;
}

.blog-search-bar {
	border-bottom: 0.0625rem solid var(--bubb-color-subtle);
}

.search-form {
	display: flex;
	gap: 0.625rem;
}

.search-field {
	flex: 1;
	padding: 0.625rem 1rem;
	font-size: 0.9375rem;
	font-family: var(--bubb-font-body);
	color: var(--bubb-color-text);
	background-color: var(--bubb-color-background);
	border: 0.0625rem solid var(--bubb-color-subtle);
	border-radius: var(--bubb-border-radius-sm);
	transition: border-color var(--bubb-transition);
	box-sizing: border-box;
	outline: none;
}

.search-field:focus {
	border-color: var(--bubb-color-primary);
}

.search-submit {
	padding: 0.625rem 1.25rem;
	font-size: 0.875rem;
	font-weight: 600;
	font-family: var(--bubb-font-body);
	background-color: var(--bubb-color-button);
	color: var(--bubb-color-light);
	border: none;
	border-radius: var(--bubb-btn-border-radius);
	cursor: pointer;
	transition: background-color var(--bubb-transition);
	white-space: nowrap;
}

.search-submit:hover {
	background-color: var(--bubb-color-button-hover);
}

.blog-search-bar .search-form {
	max-width: 36rem;
}

.no-results {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}

.no-results .page-title {
	font-size: clamp(1.375rem, 3vw, 1.75rem);
	font-weight: 800;
	color: var(--bubb-color-heading);
	margin-bottom: 0.75rem;
}

.no-results .page-content p {
	font-size: 1rem;
	color: var(--bubb-color-mid);
	line-height: 1.7;
	margin-bottom: 1.75rem;
}

.no-results .search-form,
.search-no-results .search-form {
	max-width: 30rem;
	margin: 0 auto;
}

.search-result-count {
	margin: 0.5rem 0 0;
	font-size: 0.9375rem;
	color: var(--bubb-color-mid);
}

.search-results-group + .search-results-group {
	border-top: 0.0625rem solid var(--bubb-color-subtle);
}

.search-results-group__title {
	display: flex;
	align-items: center;
	gap: 0.625rem;
	font-size: 1.375rem;
	font-weight: 800;
	line-height: 1.1;
	margin: 0 0 1.75rem;
	color: var(--bubb-color-text);
}

.search-results-group__count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 1.625rem;
	height: 1.625rem;
	padding: 0 0.4375rem;
	font-size: 0.8125rem;
	font-weight: 700;
	color: var(--bubb-color-primary);
	background-color: color-mix(in srgb, var(--bubb-color-primary) 10%, transparent);
	border-radius: var(--bubb-border-radius-sm);
}

.search-no-results {
	text-align: center;
	padding: 4rem 0;
}

.search-no-results__text {
	font-size: 1.0625rem;
	color: var(--bubb-color-mid);
	margin-bottom: 2rem;
}


/* =============================================================================
   404 PAGE
   ============================================================================= */

.error-404 {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 70vh;
	text-align: center;
}

.error-404-wrapper {
	position: relative;
	max-width: 40rem;
	margin: 0 auto;
}

.error-404-wrapper::before {
	content: '';
	position: absolute;
	top: -2rem;
	left: 50%;
	transform: translateX(-50%);
	width: 40rem;
	height: 26rem;
	background: radial-gradient(ellipse at center, color-mix(in srgb, var(--bubb-color-primary) 10%, transparent) 0%, transparent 70%);
	pointer-events: none;
	z-index: -1;
}

.error-404-number {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	line-height: 1;
	margin-bottom: 2rem;
}

.error-404-number span {
	font-size: clamp(7rem, 22vw, 13rem);
	font-weight: 900;
	color: var(--bubb-color-primary);
	letter-spacing: -0.05em;
	background: linear-gradient(145deg, var(--bubb-color-primary) 0%, var(--bubb-color-secondary) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.error-404-number span:nth-child(2) {
	opacity: 0.25;
}

.error-404-title {
	font-size: clamp(1.375rem, 3.5vw, 2rem);
	font-weight: 800;
	color: var(--bubb-color-heading);
	margin: 0 0 0.875rem;
	line-height: 1.2;
}

.error-404-text {
	font-size: 1.0625rem;
	color: var(--bubb-color-mid);
	line-height: 1.7;
	margin: 0 auto 2.5rem;
	max-width: 34rem; /* 544px */
}

.error-404-actions {
	justify-content: center;
}

@media (max-width: 767px) {
	.error-404-number {
		gap: 0.5rem;
	}

	.error-404-actions {
		margin-bottom: 2rem;
	}

	.error-404-actions .site-btn {
		width: 100%;
		justify-content: center;
	}
}


/* =============================================================================
   BREADCRUMB
   ============================================================================= */

.bubble-stop-breadcrumb {
	font-size: 0.8125rem;
	align-items: center;
	gap: 0.375rem;
	padding-top: 0.875rem;
	padding-bottom: 0.875rem;
	margin-top: 0;
	margin-bottom: 0;
	color: var(--bubb-color-mid);
}

.bubble-stop-breadcrumb a {
	color: var(--bubb-color-mid);
	text-decoration: none;
	transition: color var(--bubb-transition);
}

.bubble-stop-breadcrumb a:hover {
	color: var(--bubb-color-primary);
}

.bubble-stop-breadcrumb .breadcrumb-separator {
	color: var(--bubb-color-mid);
	opacity: 0.4;
}

.bubble-stop-breadcrumb .current {
	color: var(--bubb-color-text);
	font-weight: 500;
}


/*
=============================================================================
   Back to Top
=============================================================================
*/

.back-to-top {
    position: fixed;
    bottom: 2rem;
    right: 2rem;
    width: 2.75rem;
    height: 2.75rem;
    background: var(--bubb-color-primary);
    color: var(--bubb-color-light);
    border: none;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    opacity: 0;
    visibility: hidden;
    transform: translateY(0.5rem);
    transition: opacity var(--bubb-transition), visibility var(--bubb-transition), transform var(--bubb-transition), background-color var(--bubb-transition);
    z-index: 999;
}

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

.back-to-top:hover {
    background: var(--bubb-color-secondary);
}

.back-to-top:focus-visible {
    outline: 0.125rem solid var(--bubb-color-primary);
    outline-offset: 0.25rem;
}

/*
=============================================================================
   Single Post
=============================================================================
*/

/* Constrain and centre the post body — narrower than the site container
   for comfortable line length */
body.single-post .post-inner {
	max-width: 50rem; /* 800px */
	margin-left: auto;
	margin-right: auto;
}

/* ── Featured Image ─────────────────────────────────────────────────────── */

.single-post .post-thumbnail {
	width: 100%;
	max-height: 34rem;
	overflow: hidden;
}

.single-post .post-thumbnail picture,
.single-post .post-thumbnail-image {
	display: block;
	width: 100%;
	height: 100%;
	max-height: 34rem;
	object-fit: cover;
}

/* ── Entry Header ────────────────────────────────────────────────────────── */

.entry-header {
	padding-bottom: 2rem;
	border-bottom: 0.0625rem solid var(--bubb-color-subtle);
}

.entry-title {
	line-height: 1.15;
	margin-bottom: 0;
}

/* Categories */
.entry-categories {
	display: flex;
	flex-wrap: wrap;
	gap: 0.375rem;
}

.entry-category {
	display: inline-block;
	font-size: 0.8125rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--bubb-color-primary);
	text-decoration: none;
	background-color: var(--bubb-color-subtle);
	padding: 0.25rem 0.625rem;
	border-radius: var(--bubb-border-radius-sm);
	transition: background-color var(--bubb-transition), color var(--bubb-transition);
}

.entry-category:hover {
	background-color: var(--bubb-color-primary);
	color: var(--bubb-color-light);
}

/* Meta */
.entry-meta {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.5rem 1.25rem;
	font-size: 0.9375rem;
	color: var(--bubb-color-mid);
}

.entry-date,
.entry-author {
	color: var(--bubb-color-mid);
}

/* ── Entry Footer — Tags ──────────────────────────────────────────────────── */

.entry-footer {
	border-top: 0.0625rem solid var(--bubb-color-subtle);
	padding-top: 1.75rem;
}

.post-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.post-tag {
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--bubb-color-mid);
	text-decoration: none;
	border: 0.0625rem solid var(--bubb-color-subtle);
	padding: 0.25rem 0.75rem;
	border-radius: var(--bubb-border-radius-sm);
	transition: border-color var(--bubb-transition), color var(--bubb-transition);
}

.post-tag::before {
	content: '#';
	opacity: 0.5;
}

.post-tag:hover {
	border-color: var(--bubb-color-primary);
	color: var(--bubb-color-primary);
}

/* ── Responsive ─────────────────────────────────────────────────────────── */

@media only screen and (max-width: 767px) {
	.single-post .post-thumbnail {
		max-height: 18rem;
	}

	.single-post .post-thumbnail-image {
		max-height: 18rem;
	}
}


/* =============================================================================
   BLOG ARCHIVE
   ============================================================================= */

/* ── Blog index header ───────────────────────────────────────────────────── */

.blog-page-header {
	padding-top: 3.125rem;
	padding-bottom: 2rem;
	border-bottom: 0.0625rem solid var(--bubb-color-subtle);
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 1rem;
	flex-wrap: wrap;
}

.blog-page-title {
	font-size: 2.5rem;
	font-weight: 800;
	line-height: 1;
	margin: 0;
	color: var(--bubb-color-text);
}

.blog-page-count {
	font-size: 0.875rem;
	color: var(--bubb-color-mid);
	white-space: nowrap;
	padding-bottom: 0.25rem;
}

/* ── Archive header (category / tag / date / author) ─────────────────────── */

.archive-header {
	padding-bottom: 2rem;
	border-bottom: 0.0625rem solid var(--bubb-color-subtle);
}

.archive-label {
	display: inline-flex;
	align-items: center;
	font-size: 0.6875rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--bubb-color-primary);
	background-color: color-mix(in srgb, var(--bubb-color-primary) 10%, transparent);
	padding: 0.25rem 0.625rem;
	border-radius: var(--bubb-border-radius-sm);
	margin-bottom: 0.875rem;
}

.archive-title {
	font-size: 2rem;
	font-weight: 800;
	line-height: 1.1;
	margin: 0 0 0.75rem;
	color: var(--bubb-color-text);
}

.archive-description {
	font-size: 1rem;
	color: var(--bubb-color-mid);
	max-width: 40rem;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.archive-description p {
	margin-bottom: 0;
}


/* =============================================================================
   POST CARDS
   ============================================================================= */

/* ── Grid override ───────────────────────────────────────────────────────── */

.blog-grid {
	gap: 1.875rem;
}

@media only screen and (min-width: 768px) and (max-width: 991px) {
	.blog-grid.columns-3 {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* ── Base card ───────────────────────────────────────────────────────────── */

.post-card {
	display: flex;
	flex-direction: column;
	border: 0.0625rem solid var(--bubb-color-subtle);
	border-radius: var(--bubb-border-radius);
	overflow: hidden;
	background-color: var(--bubb-color-background);
	transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.post-card:hover {
	transform: translateY(-0.25rem);
	box-shadow: 0 0.5rem 1.5rem color-mix(in srgb, var(--bubb-color-text) 7%, transparent);
	border-color: color-mix(in srgb, var(--bubb-color-primary) 35%, transparent);
}

/* ── Media ───────────────────────────────────────────────────────────────── */

.post-card__media {
	display: block;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background-color: var(--bubb-color-subtle);
	flex-shrink: 0;
}

.post-card__image {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
}

.post-card:hover .post-card__image {
	transform: scale(1.04);
}

/* ── Placeholder (no featured image) ─────────────────────────────────────── */

.post-card__placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	min-height: 12rem;
	background-color: color-mix(in srgb, var(--bubb-color-primary) 8%, var(--bubb-color-background));
	font-size: 0.8125rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--bubb-color-primary);
}

/* ── Content area ────────────────────────────────────────────────────────── */

.post-card__content {
	display: flex;
	flex-direction: column;
	flex: 1;
	padding: 1.375rem 1.5rem 1.5rem;
	gap: 0.625rem;
}

/* ── Meta row ────────────────────────────────────────────────────────────── */

.post-card__meta {
	display: flex;
	align-items: center;
	gap: 0.375rem 0.625rem;
	flex-wrap: wrap;
}

.post-card__category {
	font-size: 0.6875rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.07em;
	color: var(--bubb-color-primary);
	text-decoration: none;
	background-color: color-mix(in srgb, var(--bubb-color-primary) 10%, transparent);
	padding: 0.2rem 0.5rem;
	border-radius: var(--bubb-border-radius-sm);
	transition: background-color var(--bubb-transition), color var(--bubb-transition);
}

.post-card__category:hover {
	background-color: var(--bubb-color-primary);
	color: var(--bubb-color-light);
}

.post-card__date-wrap {
	display: flex;
	align-items: center;
	gap: 0.375rem;
	font-size: 0.8125rem;
	color: var(--bubb-color-mid);
}

/* ── Title ───────────────────────────────────────────────────────────────── */

.post-card__title {
	font-size: 1.0625rem;
	font-weight: 700;
	line-height: 1.3;
	margin: 0;
}

.post-card__title a {
	color: var(--bubb-color-text);
	text-decoration: none;
	transition: color var(--bubb-transition);
}

.post-card__title a:hover,
.post-card:hover .post-card__title a {
	color: var(--bubb-color-primary);
}

/* ── Excerpt ─────────────────────────────────────────────────────────────── */

.post-card__excerpt {
	font-size: 0.9375rem;
	color: var(--bubb-color-mid);
	line-height: 1.6;
	margin: 0;
}

/* ── Read link ───────────────────────────────────────────────────────────── */

.post-card__link {
	display: inline-flex;
	align-items: center;
	gap: 0.375rem;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--bubb-color-primary);
	text-decoration: none;
	margin-top: auto;
	padding-top: 0.5rem;
	transition: gap var(--bubb-transition);
}

.post-card__link:hover {
	gap: 0.625rem;
}

.post-card__link-icon {
	display: inline-block;
	transition: transform var(--bubb-transition);
}

.post-card:hover .post-card__link-icon {
	transform: translateX(0.1875rem);
}

/* ── Featured variant ────────────────────────────────────────────────────── */

.post-card--featured {
	grid-column: 1 / -1;
}

.post-card--featured .post-card__media {
	aspect-ratio: 21 / 9;
}

.post-card--featured .post-card__content {
	padding: 1.75rem 2rem 2rem;
}

.post-card--featured .post-card__title {
	font-size: 1.75rem;
	line-height: 1.2;
}

.post-card--featured .post-card__excerpt {
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

@media only screen and (max-width: 767px) {
	.post-card--featured .post-card__media {
		aspect-ratio: 16 / 9;
	}

	.post-card--featured .post-card__title {
		font-size: 1.375rem;
	}
}


/* =============================================================================
   COMMENTS
   ============================================================================= */

/* ── Wrapper ─────────────────────────────────────────────────────────────── */

.comments-wrap {
	border-top: 0.0625rem solid var(--bubb-color-subtle);
	padding-top: 3.125rem;
}

/* ── Section Titles ──────────────────────────────────────────────────────── */

.comments-title {
	font-size: 1.25rem;
	font-weight: 700;
	margin-top: 0;
	margin-bottom: 2rem;
	color: var(--bubb-color-text);
}

.comment-reply-title {
	font-size: 1.25rem;
	font-weight: 700;
	margin-top: 0;
	margin-bottom: 1.5rem;
	color: var(--bubb-color-text);
}

.comment-reply-title small {
	font-size: 0.875rem;
	font-weight: 400;
	margin-left: 0.5rem;
}

/* ── Comment List ────────────────────────────────────────────────────────── */

.comment-list {
	list-style: none;
	padding: 0;
	margin: 0 0 3rem;
}

.comment-list .children {
	list-style: none;
	padding: 0 0 0 1.5rem;
	margin: 0;
	border-left: 0.1875rem solid color-mix(in srgb, var(--bubb-color-primary) 20%, transparent);
}

/* ── Single Comment ──────────────────────────────────────────────────────── */

.comment {
	padding: 1.75rem 0;
	border-bottom: 0.0625rem solid var(--bubb-color-subtle);
}

.comment:last-child {
	border-bottom: none;
}

/* ── Comment header: footer.comment-meta wraps author div + metadata div ─── */

.comment-meta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
	margin-bottom: 0.75rem;
}

/* ── Author: avatar + name inline ────────────────────────────────────────── */

.comment-author {
	display: flex;
	align-items: center;
	gap: 0.625rem;
}

.comment-author .avatar {
	width: 2.5rem !important;
	height: 2.5rem !important;
	border-radius: 50%;
	flex-shrink: 0;
	object-fit: cover;
}

.comment-author .fn {
	font-size: 0.9375rem;
	font-weight: 700;
	font-style: normal;
	color: var(--bubb-color-text);
}

.comment-author .fn a {
	color: inherit;
	text-decoration: none;
}

.comment-author .fn a:hover {
	color: var(--bubb-color-primary);
}

.comment-author .says {
	display: none;
}

/* ── Date ────────────────────────────────────────────────────────────────── */

.comment-metadata {
	font-size: 0.8125rem;
	color: var(--bubb-color-mid);
	white-space: nowrap;
}

.comment-metadata a {
	color: var(--bubb-color-mid);
	text-decoration: none;
	transition: color var(--bubb-transition);
}

.comment-metadata a:hover {
	color: var(--bubb-color-primary);
}

.comment-metadata .edit-link {
	margin-left: 0.5rem;
}

.comment-metadata .comment-edit-link {
	color: var(--bubb-color-primary);
}

/* ── Content & reply — indent to align with name (avatar + gap) ──────────── */

.comment-content,
.reply {
	padding-left: calc(2.5rem + 0.625rem);
}

.comment-content {
	font-size: 1rem;
	line-height: 1.65;
}

.comment-content p {
	margin-bottom: 0.75rem;
}

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

.reply {
	margin-top: 0.625rem;
}

.comment-reply-link {
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--bubb-color-primary);
	text-decoration: none;
	transition: opacity var(--bubb-transition);
}

.comment-reply-link:hover {
	opacity: 0.7;
}

/* ── Awaiting Moderation ─────────────────────────────────────────────────── */

.comment-awaiting-moderation {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--bubb-color-accent);
	background-color: color-mix(in srgb, var(--bubb-color-accent) 12%, transparent);
	padding: 0.125rem 0.5rem;
	border-radius: var(--bubb-border-radius-sm);
	margin-bottom: 0.5rem;
}

/* ── Comment Form ────────────────────────────────────────────────────────── */

.comment-respond {
	padding-top: 2.5rem;
	border-top: 0.0625rem solid var(--bubb-color-subtle);
	margin-top: 1rem;
}

.comment-respond a {
	color: var(--bubb-color-primary);
	text-decoration: none;
}

.comment-respond a:hover {
	text-decoration: underline;
}

#commentform {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.25rem;
}

#commentform p {
	margin: 0;
}

#commentform .comment-notes,
#commentform .comment-form-comment,
#commentform .comment-form-url,
#commentform .comment-form-cookies-consent,
#commentform .form-submit {
	grid-column: 1 / -1;
}

#commentform .comment-notes {
	font-size: 0.875rem;
	color: var(--bubb-color-mid);
}

#commentform label {
	display: block;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--bubb-color-text);
	margin-bottom: 0.375rem;
}

#commentform .comment-form-cookies-consent label {
	display: inline;
	font-weight: 400;
}

#commentform input[type="text"],
#commentform input[type="email"],
#commentform input[type="url"],
#commentform textarea {
	display: block;
	width: 100%;
	padding: 0.625rem 0.875rem;
	font-size: 0.9375rem;
	font-family: var(--bubb-font-body);
	color: var(--bubb-color-text);
	background-color: var(--bubb-color-background);
	border: 0.0625rem solid var(--bubb-color-subtle);
	border-radius: var(--bubb-border-radius-sm);
	transition: border-color var(--bubb-transition);
	box-sizing: border-box;
}

#commentform input[type="text"]:focus,
#commentform input[type="email"]:focus,
#commentform input[type="url"]:focus,
#commentform textarea:focus {
	outline: none;
	border-color: var(--bubb-color-primary);
	border-radius: var(--bubb-border-radius-sm);
}

#commentform textarea {
	min-height: 9rem;
	resize: vertical;
	border-radius: var(--bubb-border-radius-sm);
}

#commentform #submit {
	display: inline-flex;
	align-items: center;
	padding: var(--bubb-btn-padding-y) var(--bubb-btn-padding-x);
	font-size: var(--bubb-btn-font-size);
	line-height: 1.875rem;
	font-family: var(--bubb-font-body);
	font-weight: var(--bubb-btn-font-weight);
	background-color: var(--bubb-color-button);
	color: var(--bubb-color-light);
	border: 2px solid var(--bubb-color-button);
	border-radius: var(--bubb-btn-border-radius);
	cursor: pointer;
	transition: all var(--bubb-transition);
	appearance: none;
	-webkit-appearance: none;
}

#commentform #submit:hover {
	background-color: var(--bubb-color-button-hover);
	border-color: var(--bubb-color-button-hover);
	color: var(--bubb-color-light);
}

/* ── Responsive ──────────────────────────────────────────────────────────── */

@media only screen and (max-width: 767px) {
	.comment-list .children {
		padding-left: 0.875rem;
	}

	.comment-meta {
		flex-wrap: wrap;
	}

	.comment-author .avatar {
		width: 2rem !important;
		height: 2rem !important;
	}

	.comment-content,
	.reply {
		padding-left: calc(2rem + 0.625rem);
	}

	#commentform {
		grid-template-columns: 1fr;
	}

	#commentform .comment-form-author,
	#commentform .comment-form-email {
		grid-column: 1;
	}
}
