/*
Theme Name: Blockstarter ML
Theme URI: https://nasiothemes.com/themes/blockstarter/
Template: blockstarter
Author: Wei Hsiang Liao
Author URI: https://weihsiangliao.com
Version: 1.1.0.1771272518
Updated: 2026-02-16 21:08:38

*/

:root {
	--real-vh: 1vh; /* fallback, override by javascript */
}

html {
	-webkit-text-size-adjust: 100%; /* Prevent iOS Safari from auto-enlarging text in landscape mode */
}

body {
	--ml-padding-vertical: 30px;
	--ml-padding-horizontal: 20px;
	--ml-global-max-width: 1140px;
	--ml-footer-height: 72px;
	--ml-header-submenu-width: 170px;
	--ml-header-blocks-width: 300px; /* used in desktop */
	--ml-header-blocks-height: 120px; /* used in mobile */
	--ml-content-blocks-width: calc(var(--ml-global-max-width) - var(--ml-header-blocks-width));
	--ml-admin-bar-height: var(--wp-admin--admin-bar--height, 0px);
	--ml-full-vh: calc(var(--real-vh) * 100);
}

.ml-main-blocks.wide-content {
	--ml-header-blocks-width: 170px;
}

.ml-main-blocks {
	padding: var(--ml-padding-vertical) var(--ml-padding-horizontal);
	max-width: var(--ml-global-max-width);
	margin: 0 auto; /* centers horizontally */
	gap: 20px;
}

.ml-header-blocks,
.ml-content-blocks {

}

header nav {
	padding: 0 !important; /* override parent style */
}

.no-underline a {
	text-decoration: none;
}

.ml-header {
	font-size: 16px;
	font-weight: 400;
	position: fixed;
	z-index: 9;
}
.ml-header a {
	color: var(--wp--preset--color--custom-links) !important;
	text-decoration: none;
	/* text-transform: lowercase; */
}
.ml-header a:hover {
	color: var(--wp--preset--color--custom-links-hover) !important;
}

.ml-footer-blocks {
	max-width: var(--ml-global-max-width);
	margin: 0 auto; /* centers horizontally */
}
.ml-footer {
	height: var(--ml-footer-height);
	position: fixed;
	bottom: 0;
	padding: 0px var(--ml-padding-horizontal) 10px var(--ml-padding-horizontal);
	margin-top: 0; /* override margin-block-start: 1rem */
	gap: 0 !important;
	justify-content: flex-end;
}
.ml-footer h6 {
	font-size: 12px;
	color: var(--wp--preset--color--footer);
}

.ml-navigation {
	flex-direction: column;
	align-items: flex-start;
	gap: 0 !important;
}

.ml-site-title {
	font-size: 40px;
	text-transform: uppercase !important;
	letter-spacing: -0.03em;
	line-height: 0.8;
	font-weight: 500;
	white-space: normal;
	word-break: normal;
	overflow-wrap: normal;
	/* z-index: 100001; */
	margin-bottom: 20px !important;
	display: flex;
	flex-direction: column;
	justify-content: center;
	max-width: 150px;
}

.ml-page-title {
	margin-top: 0; /* override margin-block-start: 1rem */
	display: none;
	white-space: pre;
	height: 30px;
	align-items: center;
	position: relative;
}
.ml-page-title::before {
	font-family: system-ui, sans-serif;
	content: '›';
	position: absolute;
	left: -12px;
}

.ml-page-list {
	display: none;
}

.wp-block-navigation__responsive-dialog {
	width: 100%;
	display: grid !important;
	grid-template-columns: min-content auto;
	align-items: start;
	justify-content: start;
	gap: 0 20px !important;  /* row-gap column-gap */
}

.wp-block-navigation__responsive-dialog .wp-block-navigation__responsive-container-content {
	grid-column: 1;
}

.wp-block-navigation__responsive-dialog .ml-page-list {
	grid-column: 2;
	display: flex;
}

.wp-block-navigation__responsive-dialog .ml-site-title {
	grid-column: 1 / -1;
}

.wp-block-navigation__responsive-dialog * {
	padding: 0;
	margin: 0;
}

.ml-page-list > ul,
.wp-block-navigation__responsive-container-content > ul {
	display: block;
	width: 100%;
}
.ml-page-list > ul > li,
.wp-block-navigation__responsive-container-content > ul > li {
	display: flex; /* "block" will cause layout problem */
	height: 30px;
	white-space: pre;
	position: relative;
	align-items: center;
}
.ml-page-list h6 {
	display: flex;
	align-items: center;
}
.wp-block-navigation__responsive-container-content > ul > li:not(.wp-block-navigation-link) {
	padding-top: 20px !important; /* make some room between main menu and social links  */
	align-items: center !important;
	flex-direction: row !important;
}

.is-menu-open.has-modal-open .wp-block-navigation__container .wp-block-navigation-item__content {
	padding: 0 !important; /* to override default style */
}
.is-menu-open.has-modal-open .wp-block-navigation__container .wp-block-social-links {
	margin-left: 0 !important; /* to override default style  */
}

.ml-page-list .wp-block-post-title  {
	font-size: 16px;
}

.personal-series .wp-block-navigation__responsive-container-content ul li a[href$="/personal-series/"]::before,
.wp-block-navigation__responsive-container-content ul li.current-menu-item a::before,
.ml-page-list ul li a.is-current-page::before {
	font-family: system-ui, sans-serif;
	content: '›';
	position: absolute;
	left: -12px;
}

.wp-block-navigation__responsive-container.is-menu-open {
	padding: var(--ml-padding-vertical) var(--ml-padding-horizontal) !important;
	margin-top: var(--ml-admin-bar-height);
}

.has-modal-open .is-menu-open .wp-block-navigation__responsive-dialog {
	margin-top: 0 !important;
}

.wp-block-navigation__responsive-container.is-menu-open > div {
	/* to override margin and max-width in global style */
	margin: 0 !important;
	max-width: 100% !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content,
.wp-block-navigation__responsive-container.is-menu-open .ml-page-list {
	padding-top: 0 !important;
}

.wp-block-navigation__responsive-container:not(.is-menu-open) .wp-block-site-title,
.wp-block-navigation__responsive-container:not(.is-menu-open) .ml-site-title {
	display: none;
}
.wp-block-navigation__responsive-container.is-menu-open .wp-block-site-title,
.wp-block-navigation__responsive-container.is-menu-open .ml-site-title {
	display: flex;
}

.ml-content-heading {
	max-width: 50em;
}
.page .ml-content-blocks > .ml-content-heading {
	display: none; /* hide post title and date */
}
.page .ml-content-blocks > .wp-block-post-content {
	margin-top: 0 !important;
}

.ml-content-blocks .wp-block-post-content .wp-block-query > ul > li:nth-child(n+2) {
	margin-top: 50px;
}
.ml-content-blocks .wp-block-post-title {
	margin: 0 !important;
}
.ml-content-blocks .wp-block-post-date {
	color: var(--wp--preset--color--secondary);
	margin-top: 0 !important;
}

.ml-block-full {
	width: 100%;
}
.ml-block-twothird {
	width: 67%;
}
.ml-block-half {
	width: 50%;
}
.ml-block-onethird {
	width: 33%;
}
.ml-content-blocks .wp-block-post-content > p {
	max-width: 50em;
	margin-left: 0;
	margin-right: auto;
	text-align: justify;
}
.ml-content-blocks .wp-block-post-content > p.center-align {
	max-width: 50em;
	margin-left: auto;
	margin-right: auto;
}
.ml-content-blocks .wp-block-post-content > p.right-align {
	max-width: 50em;
	margin-left: auto;
	margin-right: 0;
}

.ml-scroll-top {
	cursor: pointer;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s ease, visibility 0.3s ease;
}
.ml-scroll-top.show {
	opacity: 1;
	visibility: visible;
}

.vp-portfolio__layout-elements-bottom {
	margin-top: 52px;
}
.vp-pagination__load-more-no-more {
	pointer-events: auto;
	cursor: pointer;
}
.vp-pagination__item a {
	color: var(--wp--preset--color--custom-links) !important;
}
.vp-pagination__item a:hover {
	color: var(--wp--preset--color--custom-links-hover) !important;
}
.vp-portfolio__item-meta {
	padding:0.5em 0 !important;
}
.vp-portfolio__item-meta a:hover {
	color: var(--wp--preset--color--custom-links-hover) !important;
}
.vp-portfolio__items-style-default .vp-portfolio__item-img img,
.vp-portfolio__items-style-fade .vp-portfolio__item-img img {
	transform: none !important;
}
.vp-portfolio__items-style-default .vp-portfolio__item-meta > * {
	margin-bottom: 0 !important;
}
.vp-portfolio__items-style-default .vp-portfolio__item-meta-date {
	color: var(--wp--preset--color--secondary);
}
.vp-portfolio__items-style-default .vp-portfolio__item-meta-date .vp-portfolio__item-meta-part-icon {
	display: none;
}

@keyframes overlay-menu__fade-in-animation {
	from {
		opacity: 0;
	}

	to {
		opacity: 1;
	}
}

@media not (prefers-reduced-motion) {
	.wp-block-navigation__responsive-container.is-menu-open {
		animation: overlay-menu__fade-in-animation 0.2s ease-in-out forwards;
	}
}

@media only screen and (min-width: 782px) {
	.wp-block-navigation__responsive-container.is-menu-open {
		display: none !important;
	}
	.ml-page-list > ul > li a {
		max-width: var(--ml-header-submenu-width);
		overflow: hidden;
		text-overflow: ellipsis;
		transition: max-width 0.3s ease;
	}
	.ml-page-list > ul > li a:hover {
		max-width: 320px;
		background: white;
		text-overflow: clip;
		padding-right: 10px;
	}
	.ml-scroll-top {

	}
	.ml-header-blocks {
		flex: 0 0 var(--ml-header-blocks-width) !important;
	}
	.ml-content-blocks {
		flex: 1 1 var(--ml-content-blocks-width) !important;
	}
}

@media only screen and (max-width: 782px) {
	.vp-portfolio__item-overlay {
		opacity: 1 !important; /* fix link requires double tap on mobile */
	}
	.wp-block-navigation__responsive-container:not(.hidden-by-default):not(.is-menu-open) {
		display: none !important;
	}
	.wp-block-navigation__responsive-container-open {
		display: flex !important;
	}
	.wp-block-navigation__responsive-container-open svg,
	.wp-block-navigation__responsive-container-close svg {
		width: 40px;
		height: 40px;
	}
	.wp-block-navigation__responsive-container-open svg rect {

	}
	.wp-block-navigation__responsive-container-close svg path {

	}
	.wp-block-navigation__responsive-container-close {
		margin-left: auto !important;
		padding: 4px;
	}
	.ml-main-blocks {
		gap: 0 !important;
		padding: var(--ml-padding-vertical) var(--ml-padding-horizontal);
	}
	.ml-header-blocks {
		height: var(--ml-header-blocks-height);
	}
	.ml-site-title {
		height: 48px;
		font-size: 32px;
		max-width: calc(100vw - 2*var(--ml-padding-horizontal) - 48px);
	}
	.ml-content-blocks {
		min-height: calc(var(--ml-full-vh) - var(--ml-header-blocks-height) - var(--ml-footer-height) - 2*var(--ml-padding-vertical) - var(--ml-admin-bar-height)) !important;
	}
	.ml-navigation {
		flex-direction: row;
		align-items: flex-start;
	}
	.ml-page-title {
		display: flex;
	}
	.home .ml-page-title {
		display: none; /* hide page title for home page */
	}
	nav.wp-block-navigation {
		margin-left: auto !important;
		align-self: start;
	}
	.ml-header {
		top: auto;
		left: auto;
		width: 100%;
		position: relative;
	}
	.ml-footer {
		position: relative;
	}
	.ml-scroll-top {
		position: fixed;
		z-index: 10;
		left: var(--ml-padding-horizontal) !important;
		bottom: 32px !important;
	}
}

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

}
