/* Theme 010 */

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800&family=Open+Sans:wght@400;600;700&display=swap');

body {
	--cs-heading-font: "Montserrat", system-ui, sans-serif;
	--cs-body-font: "Open Sans", system-ui, sans-serif;
}

/* --- TDM (single post) --- */
body.single-post .ruby-table-contents {
	border: none;
	border-radius: 10px;
	padding: 20px 24px;
	box-shadow: 0 6px 20px color-mix(in srgb, var(--noir) 10%, transparent);
	background: var(--blanc);
}
body.single-post .ruby-table-contents .toc-header {
	margin-bottom: 14px;
	padding-bottom: 10px;
	border-bottom: 1px solid color-mix(in srgb, var(--noir) 8%, transparent);
}
body.single-post .ruby-table-contents .toc-header span {
	font-size: 22px;
	font-weight: 700;
	font-family: var(--cs-heading-font);
	text-transform: initial;
	color: var(--noir);
	letter-spacing: -0.3px;
}
body.single-post .ruby-table-contents .toc-header .rbi-read:before {
	content: "\2630";
	font-family: initial;
	font-size: 26px;
	color: var(--g-color) !important;
	padding-right: 8px;
}
body.single-post .ruby-table-contents .inner {
	column-count: 1;
	margin-top: 0;
	padding-top: 0;
}
body.single-post .ruby-table-contents .inner a {
	position: relative;
	display: block;
	padding: 9px 12px 9px 28px;
	margin-bottom: 4px;
	color: var(--noir) !important;
	font-size: 15px;
	line-height: 20px;
	font-weight: 400;
	font-family: var(--cs-body-font);
	text-decoration: none !important;
	text-shadow: none !important;
	border-radius: 8px;
	transition: all .2s ease;
}
body.single-post .ruby-table-contents .inner a:hover {
	background: color-mix(in srgb, var(--g-color) 8%, transparent);
	color: var(--g-color) !important;
	font-weight: 600;
}
body.single-post .ruby-table-contents .inner a::before {
	content: "";
	position: absolute;
	left: 12px;
	top: 50%;
	transform: translateY(-50%);
	width: 8px;
	height: 8px;
	background: var(--g-color);
	border-radius: 3px;
}
body.single-post .ruby-table-contents .inner a::after {
	display: none !important;
}
body.single-post .ruby-table-contents .ruby-toc-toggle i:before {
	content: "\002B" !important;
	font-family: initial !important;
	font-size: 26px !important;
	font-weight: 700 !important;
	line-height: 1 !important;
	color: var(--g-color) !important;
}

/* --- POST (single article) --- */
body.single-post .s-feat-outer {
	width: 100%;
	margin-bottom: 28px;
}
body.single-post .s-feat img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: 10px;
}
body.single-post .s-cats {
	margin-bottom: 14px;
}
body.single-post .s-cats a,
body.single-post .s-cats .p-category,
body.single-post .s-cats .meta-category a {
	display: inline-block;
	padding: 5px 14px;
	border: none;
	border-radius: 8px;
	background: color-mix(in srgb, var(--g-color) 12%, var(--blanc));
	color: var(--g-color) !important;
	font-size: 12px;
	font-weight: 700;
	font-family: var(--cs-heading-font);
	text-transform: uppercase;
	letter-spacing: 0.8px;
	text-decoration: none;
}
body.single-post .single-meta,
body.single-post .single-meta a,
body.single-post .single-meta time,
body.single-post .single-meta .meta-date,
body.single-post .single-meta .meta-author,
body.single-post .single-meta .meta-author a,
body.single-post .single-meta .meta-category a,
body.single-post .single-meta .is-meta,
body.single-post .single-meta .smeta-in,
body.single-post .single-meta .smeta-extra,
body.single-post time {
	font-family: var(--cs-body-font);
}
body.single-post .s-title {
	font-size: 44px;
	line-height: 1.15;
	font-weight: 800;
	font-family: var(--cs-heading-font);
	margin: 14px 0 20px;
	letter-spacing: -0.5px;
}
body.single-post .entry-content.rbct {
	border: none;
	border-radius: 12px;
	padding: 32px 36px;
	box-shadow: 0 8px 30px color-mix(in srgb, var(--noir) 10%, transparent);
	background: var(--blanc);
}
body.single-post .entry-content.rbct h2,
body.single-post .entry-content.rbct h3 {
	font-weight: 700;
	font-family: var(--cs-heading-font);
	border-left: 5px solid var(--g-color);
	padding-left: 14px;
	margin-top: 32px;
}
body.single-post .entry-content.rbct h2 { font-size: 27px; }
body.single-post .entry-content.rbct h3 { font-size: 22px; }
body.single-post .entry-content.rbct p,
body.single-post .entry-content.rbct ol li,
body.single-post .entry-content.rbct ul li {
	font-size: 17px;
	line-height: 1.8;
	font-family: var(--cs-body-font);
}
body.single-post .entry-content.rbct blockquote {
	border-left: none;
	background: color-mix(in srgb, var(--g-color) 7%, var(--blanc));
	padding: 20px 26px;
	margin: 26px 0;
	font-style: normal;
	border-radius: 10px;
	box-shadow: 0 2px 8px color-mix(in srgb, var(--noir) 5%, transparent);
	font-family: var(--cs-body-font);
}
body.single-post .entry-content.rbct a {
	color: var(--g-color);
	text-decoration: underline;
	text-underline-offset: 3px;
}

/* --- MENU (sitewide) --- */
#site-header {
	background: var(--blanc);
	border-bottom: none;
	box-shadow: 0 2px 12px color-mix(in srgb, var(--noir) 8%, transparent);
}
#site-header .logo-sec-inner {
	padding: 20px 0;
}
#site-header .main-menu > li > a {
	color: var(--noir);
	font-weight: 600;
	font-family: var(--cs-heading-font);
	letter-spacing: 0.02em;
	text-transform: initial;
	padding: 6px 12px;
	border-radius: 6px;
	transition: background .2s ease;
}
#site-header .main-menu > li:hover > a,
#site-header .main-menu > li.current-menu-item > a {
	background: color-mix(in srgb, var(--g-color) 10%, transparent);
	color: var(--g-color);
}
#site-header .navbar-wrap {
	border-top: 1px solid color-mix(in srgb, var(--noir) 6%, transparent);
	background: var(--blanc);
}
#site-header .search-btn,
#site-header .dark-mode-toggle {
	color: var(--noir);
}
