/*
Theme Name: ColorMag Child Custom Premium Additions
Description: Premium template additions and layout fixes for ColorMag child theme.
Author: Codex
Version: 1.0.1
Template: colormag
*/

:root {
	--cmgc-color-bg: #ffffff;
	--cmgc-color-surface: #f4f6f8;
	--cmgc-color-surface-strong: #e9edf2;
	--cmgc-color-text: #14181f;
	--cmgc-color-text-soft: #566171;
	--cmgc-color-heading: #0f1720;
	--cmgc-color-accent: #c51621;
	--cmgc-color-accent-dark: #97131b;
	--cmgc-color-border: #d9e0e8;
	--cmgc-color-dark: #15191f;
	--cmgc-shadow-sm: 0 8px 24px rgba(16, 24, 32, 0.06);
	--cmgc-shadow-md: 0 18px 40px rgba(16, 24, 32, 0.09);
	--cmgc-shadow-lg: 0 28px 60px rgba(16, 24, 32, 0.13);
	--cmgc-radius-sm: 14px;
	--cmgc-radius-md: 20px;
	--cmgc-radius-lg: 28px;
	--cmgc-container: 1280px;
	--cmgc-container-wide: 1440px;
	--cmgc-page-gutter: 16px;
}

html,
body {
	max-width: 100%;
	overflow-x: hidden;
}

body {
	color: var(--cmgc-color-text);
	background: var(--cmgc-color-bg);
}

#page,
.site,
.site-content,
.content-area,
.tg-container,
.container,
.elementor-section-wrap,
.elementor-widget-wrap,
.elementor-column-wrap,
.elementor-container,
.elementor,
.elementor-location-single,
.elementor-location-archive {
	box-sizing: border-box;
}

#page,
.site {
	width: 100%;
	max-width: 100%;
	margin-left: auto;
	margin-right: auto;
	overflow-x: clip;
}

.site-content,
.content-area,
.content-wrapper,
.tg-container,
.inner-wrap,
.main-content-section,
.cmgc-page {
	width: 100%;
	max-width: var(--cmgc-container-wide);
	margin-left: auto;
	margin-right: auto;
}

.tg-container,
.inner-wrap,
.main-content-section {
	padding-left: var(--cmgc-page-gutter);
	padding-right: var(--cmgc-page-gutter);
}

.home .site-content,
.blog .site-content,
.home .content-area,
.blog .content-area,
.home .tg-container,
.blog .tg-container,
.home .main-content-section,
.blog .main-content-section {
	width: 100%;
	max-width: var(--cmgc-container-wide);
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--cmgc-page-gutter);
	padding-right: var(--cmgc-page-gutter);
}

.home .elementor-section.elementor-section-boxed > .elementor-container,
.blog .elementor-section.elementor-section-boxed > .elementor-container,
.home .elementor-container,
.blog .elementor-container {
	width: 100%;
	max-width: var(--cmgc-container-wide);
	margin-left: auto;
	margin-right: auto;
	padding-left: 0;
	padding-right: 0;
}

.home .elementor-widget-wrap,
.blog .elementor-widget-wrap,
.home .elementor-column,
.blog .elementor-column,
.home .elementor-element,
.blog .elementor-element {
	min-width: 0;
}

.home .container,
.blog .container {
	max-width: var(--cmgc-container-wide);
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--cmgc-page-gutter);
	padding-right: var(--cmgc-page-gutter);
}

.home .container-fluid,
.blog .container-fluid {
	width: 100%;
	padding-left: var(--cmgc-page-gutter);
	padding-right: var(--cmgc-page-gutter);
	margin-left: auto;
	margin-right: auto;
}

.home .row,
.blog .row {
	margin-left: 0;
	margin-right: 0;
}

.home .row > *,
.blog .row > * {
	max-width: 100%;
	padding-left: 12px;
	padding-right: 12px;
}

.home .alignwide,
.blog .alignwide,
.home .alignfull,
.blog .alignfull {
	margin-left: auto;
	margin-right: auto;
}

.home .elementor-section.elementor-section-full_width,
.blog .elementor-section.elementor-section-full_width {
	width: 100%;
}

.home .entry-content,
.blog .entry-content {
	margin-left: 0;
	margin-right: 0;
}

img,
iframe,
video,
embed,
object {
	max-width: 100%;
	height: auto;
}

.cmgc-page {
	max-width: var(--cmgc-container);
	margin: 0 auto;
	padding: 28px var(--cmgc-page-gutter) 64px;
}

.cmgc-section-title,
.cmgc-archive-title,
.cmgc-author-name,
.cmgc-entry-title,
.cmgc-card__title,
.cmgc-related__title,
.cmgc-empty__title {
	color: var(--cmgc-color-heading);
	line-height: 1.12;
	letter-spacing: -0.02em;
}

.cmgc-kicker {
	display: inline-flex;
	align-items: center;
	padding: 8px 12px;
	border-radius: 999px;
	background: rgba(197, 22, 33, 0.08);
	color: var(--cmgc-color-accent);
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.cmgc-card,
.cmgc-panel,
.cmgc-author-box,
.cmgc-comments-wrap,
.cmgc-search-empty,
.cmgc-navigation-box {
	background: #fff;
	border: 1px solid var(--cmgc-color-border);
	border-radius: var(--cmgc-radius-md);
	box-shadow: var(--cmgc-shadow-sm);
}

.cmgc-card {
	height: 100%;
	overflow: hidden;
	transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.cmgc-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--cmgc-shadow-md);
	border-color: #c7d1dc;
}

.cmgc-card__media,
.cmgc-featured-card__media,
.cmgc-related__media,
.cmgc-hero__media {
	position: relative;
	display: block;
	overflow: hidden;
	background: var(--cmgc-color-surface);
}

.cmgc-card__media img,
.cmgc-featured-card__media img,
.cmgc-related__media img,
.cmgc-hero__media img,
.cmgc-sidebar-card img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.cmgc-card__media {
	aspect-ratio: 16 / 10;
}

.cmgc-card__body,
.cmgc-featured-card__body,
.cmgc-related__body {
	padding: 18px;
}

.cmgc-card__meta,
.cmgc-entry-meta,
.cmgc-related__meta,
.cmgc-author-meta,
.cmgc-listing-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 14px;
	font-size: 0.82rem;
	color: var(--cmgc-color-text-soft);
	font-weight: 700;
}

.cmgc-card__title,
.cmgc-related__title {
	margin: 12px 0 10px;
	font-size: 1.16rem;
	font-weight: 800;
}

.cmgc-card__excerpt,
.cmgc-entry-excerpt,
.cmgc-author-description {
	color: var(--cmgc-color-text-soft);
	line-height: 1.72;
}

.cmgc-hero {
	position: relative;
	margin-bottom: 28px;
	border-radius: var(--cmgc-radius-lg);
	overflow: hidden;
	background: var(--cmgc-color-dark);
	box-shadow: var(--cmgc-shadow-lg);
}

.cmgc-hero__media {
	aspect-ratio: 16 / 7;
}

.cmgc-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(12, 18, 25, 0.12) 0%, rgba(12, 18, 25, 0.75) 100%);
}

.cmgc-hero__content {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding: 28px;
	color: #fff;
}

.cmgc-entry-title {
	margin: 14px 0 14px;
	font-size: clamp(2rem, 4vw, 3.6rem);
	font-weight: 800;
	color: #fff;
}

.cmgc-content-grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 320px;
	gap: 28px;
	align-items: start;
}

.cmgc-main-column {
	min-width: 0;
}

.cmgc-sidebar {
	position: sticky;
	top: 104px;
	display: grid;
	gap: 18px;
}

.cmgc-article {
	font-size: 1.06rem;
	line-height: 1.85;
}

.cmgc-article > * + * {
	margin-top: 1.2em;
}

.cmgc-article p,
.cmgc-article li {
	color: var(--cmgc-color-text);
}

.cmgc-article h2,
.cmgc-article h3,
.cmgc-article h4 {
	margin-top: 1.8em;
	color: var(--cmgc-color-heading);
	font-weight: 800;
}

.cmgc-article blockquote {
	margin: 1.6em 0;
	padding: 1.2rem 1.4rem;
	border-left: 4px solid var(--cmgc-color-accent);
	background: #fafbfc;
	border-radius: 0 var(--cmgc-radius-sm) var(--cmgc-radius-sm) 0;
	font-size: 1.08rem;
}

.cmgc-share-rail {
	position: sticky;
	top: 120px;
	display: grid;
	gap: 10px;
}

.cmgc-share-rail a,
.cmgc-share-inline a,
.cmgc-scroll-top {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 42px;
	height: 42px;
	border-radius: 999px;
	background: #fff;
	border: 1px solid var(--cmgc-color-border);
	color: var(--cmgc-color-heading);
	box-shadow: var(--cmgc-shadow-sm);
	transition: transform 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.cmgc-share-rail a:hover,
.cmgc-share-inline a:hover,
.cmgc-scroll-top:hover {
	transform: translateY(-2px);
	border-color: rgba(197, 22, 33, 0.28);
	color: var(--cmgc-color-accent);
}

.cmgc-share-inline {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 24px;
}

.cmgc-author-box {
	padding: 24px;
	display: grid;
	grid-template-columns: 88px minmax(0, 1fr);
	gap: 18px;
	align-items: start;
}

.cmgc-author-box img {
	border-radius: 50%;
}

.cmgc-author-name {
	margin: 0 0 8px;
	font-size: 1.3rem;
	font-weight: 800;
}

.cmgc-navigation-grid,
.cmgc-related-grid,
.cmgc-post-grid {
	display: grid;
	gap: 20px;
}

.cmgc-navigation-grid {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.cmgc-related-grid,
.cmgc-post-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cmgc-navigation-box {
	padding: 20px;
}

.cmgc-pagination-wrap {
	margin-top: 28px;
}

.cmgc-pagination {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	padding: 0;
	margin: 0;
	list-style: none;
}

.cmgc-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 42px;
	height: 42px;
	padding: 0 14px;
	border-radius: 999px;
	background: #fff;
	border: 1px solid var(--cmgc-color-border);
	color: var(--cmgc-color-heading);
	font-weight: 700;
}

.cmgc-pagination .current,
.cmgc-btn,
.cmgc-search-form button,
.form-submit input[type="submit"] {
	background: linear-gradient(135deg, var(--cmgc-color-accent) 0%, var(--cmgc-color-accent-dark) 100%);
	color: #fff;
	border-color: transparent;
}

.cmgc-btn,
.cmgc-search-form input,
.comment-form input:not([type="submit"]),
.comment-form textarea {
	border-radius: 14px;
}

.cmgc-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.9rem 1.2rem;
	font-weight: 800;
}

.cmgc-archive-header,
.cmgc-search-header,
.cmgc-author-hero,
.cmgc-404 {
	margin-bottom: 28px;
	padding: 28px;
	border-radius: var(--cmgc-radius-lg);
	background: linear-gradient(180deg, #fff 0%, #f7f9fb 100%);
	border: 1px solid var(--cmgc-color-border);
	box-shadow: var(--cmgc-shadow-sm);
}

.cmgc-featured-card {
	display: grid;
	grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
	overflow: hidden;
	border-radius: var(--cmgc-radius-lg);
	background: #fff;
	border: 1px solid var(--cmgc-color-border);
	box-shadow: var(--cmgc-shadow-md);
	margin-bottom: 24px;
}

.cmgc-featured-card__media {
	min-height: 100%;
}

.cmgc-featured-card__media img {
	min-height: 100%;
}

.cmgc-sidebar-card {
	display: grid;
	grid-template-columns: 88px minmax(0, 1fr);
	gap: 12px;
	padding: 12px;
	border-radius: 16px;
	background: #fff;
	border: 1px solid var(--cmgc-color-border);
}

.cmgc-sidebar-card__thumb {
	aspect-ratio: 1;
	overflow: hidden;
	border-radius: 12px;
}

.cmgc-comments-wrap {
	padding: 24px;
}

.cmgc-comments-wrap .comment-list {
	padding-left: 0;
	list-style: none;
}

.cmgc-comments-wrap .comment-body {
	padding: 18px 0;
	border-bottom: 1px solid var(--cmgc-color-border);
}

.cmgc-search-form {
	display: flex;
	gap: 10px;
	flex-wrap: wrap;
}

.cmgc-search-form input {
	flex: 1 1 260px;
	min-height: 52px;
	padding: 0 16px;
	border: 1px solid var(--cmgc-color-border);
	background: #fff;
}

.cmgc-search-form button,
.form-submit input[type="submit"] {
	min-height: 52px;
	padding: 0 18px;
	border: 0;
	font-weight: 800;
}

.cmgc-scroll-top {
	position: fixed;
	right: 20px;
	bottom: 20px;
	z-index: 60;
	opacity: 0;
	visibility: hidden;
}

.cmgc-scroll-top.is-visible {
	opacity: 1;
	visibility: visible;
}

@media (max-width: 991.98px) {
	.cmgc-content-grid,
	.cmgc-featured-card,
	.cmgc-navigation-grid,
	.cmgc-related-grid,
	.cmgc-post-grid {
		grid-template-columns: 1fr;
	}

	.cmgc-sidebar,
	.cmgc-share-rail {
		position: static;
	}
}

@media (max-width: 767.98px) {
	:root {
		--cmgc-page-gutter: 12px;
	}

	.home .row > *,
	.blog .row > * {
		padding-left: 10px;
		padding-right: 10px;
	}

	.cmgc-page {
		padding: 18px var(--cmgc-page-gutter) 48px;
	}

	.cmgc-hero__content,
	.cmgc-archive-header,
	.cmgc-search-header,
	.cmgc-author-hero,
	.cmgc-404,
	.cmgc-comments-wrap,
	.cmgc-author-box {
		padding: 18px;
	}

	.cmgc-entry-title {
		font-size: 2rem;
	}

	.cmgc-author-box {
		grid-template-columns: 1fr;
	}

	.cmgc-share-rail {
		display: none;
	}
}
.cmgc-share-inline-wrap {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 14px;
	margin-top: 24px;
	padding-top: 20px;
	border-top: 1px solid #d9e0e8;
}

.cmgc-share-inline-label {
	flex: 0 0 auto;
	color: #0f1720;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	line-height: 1;
}

.cmgc-share-inline {
	display: flex !important;
	flex-direction: row !important;
	flex-wrap: wrap !important;
	align-items: center;
	gap: 10px;
	margin-top: 0;
	width: 100%;
}

.cmgc-share-inline a,
.cmgc-share-inline__btn {
	display: inline-flex !important;
	flex: 0 0 auto !important;
	align-items: center;
	justify-content: center;
	gap: 8px;
	min-height: 44px;
	padding: 0 14px;
	border-radius: 999px;
	background: #fff;
	border: 1px solid #d9e0e8;
	color: #0f1720;
	text-decoration: none;
	line-height: 1;
	white-space: nowrap;
	float: none !important;
	width: auto !important;
	max-width: none !important;
	margin: 0 !important;
}

.cmgc-share-inline a:hover,
.cmgc-share-inline__btn:hover {
	color: #c51621;
	border-color: rgba(197, 22, 33, 0.28);
}

@media (max-width: 767.98px) {
	.cmgc-share-inline {
		gap: 8px;
	}

	.cmgc-share-inline a,
	.cmgc-share-inline__btn {
		min-height: 42px;
		padding: 0 12px;
	}
}

