/* TerraWorld custom visual layer – dark botanical ecommerce */

* { box-sizing: border-box; }

body.tw-theme {
	background: var(--tw-bg);
	color: var(--tw-ivory);
}

.tw-theme .site,
.tw-theme .site-header,
.tw-theme .site-footer,
.tw-theme .storefront-primary-navigation {
	background: var(--tw-bg);
	color: var(--tw-ivory);
}

.tw-theme .site-header {
	border-bottom: 1px solid var(--tw-border);
	box-shadow: 0 8px 24px rgba(0,0,0,.24);
}

.tw-theme .site-branding .site-title a,
.tw-theme .main-navigation ul li a,
.tw-theme .site-header-cart .cart-contents {
	color: var(--tw-ivory);
}

.tw-theme .main-navigation ul li a:hover,
.tw-theme .main-navigation ul li.current-menu-item > a {
	color: var(--tw-green-bright);
}

.tw-container {
	width: min(100% - 32px, var(--tw-container));
	margin-inline: auto;
}

.tw-front {
	background:
		radial-gradient(circle at 10% 10%, rgba(76,139,91,.18), transparent 28rem),
		radial-gradient(circle at 90% 20%, rgba(203,184,146,.10), transparent 24rem),
		var(--tw-bg);
	color: var(--tw-ivory);
}

.tw-section {
	padding: clamp(56px, 7vw, 96px) 0;
}

.tw-section__head {
	margin-bottom: 28px;
	max-width: 760px;
}

.tw-section__title,
.tw-hero__title,
.tw-newsletter__title {
	font-family: var(--tw-font-head);
	color: var(--tw-ivory);
	letter-spacing: -0.035em;
	line-height: 1.05;
	margin: 0 0 12px;
}

.tw-section__title {
	font-size: clamp(1.8rem, 3vw, 2.7rem);
}

.tw-section__lead,
.tw-hero__subtitle,
.tw-newsletter__lead {
	color: var(--tw-ivory-soft);
	font-size: 1.05rem;
	line-height: 1.65;
	margin: 0;
}

.tw-hero {
	position: relative;
	min-height: 620px;
	display: grid;
	align-items: center;
	overflow: hidden;
	background:
		linear-gradient(90deg, rgba(8,17,13,.98) 0%, rgba(8,17,13,.72) 48%, rgba(8,17,13,.30) 100%),
		radial-gradient(circle at 78% 50%, rgba(111,179,126,.22), transparent 26rem),
		linear-gradient(135deg, #08110D, #15261d);
	border-bottom: 1px solid var(--tw-border);
}

.tw-hero::after {
	content: "";
	position: absolute;
	inset: 8% 4% 8% auto;
	width: min(46vw, 620px);
	border-radius: 34px;
	background:
		linear-gradient(180deg, rgba(8,17,13,.05), rgba(8,17,13,.55)),
		radial-gradient(circle at 30% 25%, rgba(111,179,126,.46), transparent 7rem),
		radial-gradient(circle at 72% 40%, rgba(203,184,146,.26), transparent 8rem),
		linear-gradient(145deg, #1d3025, #07100c);
	box-shadow: var(--tw-shadow-lg);
	border: 1px solid var(--tw-border-strong);
}

.tw-hero__inner {
	position: relative;
	z-index: 2;
}

.tw-hero__content {
	max-width: 650px;
}

.tw-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	margin-bottom: 18px;
	color: var(--tw-sand-soft);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .13em;
	font-size: .78rem;
}

.tw-hero__title {
	font-size: clamp(2.7rem, 6vw, 5.7rem);
	max-width: 780px;
}

.tw-hero__subtitle {
	font-size: clamp(1.08rem, 1.5vw, 1.28rem);
	max-width: 590px;
}

.tw-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin-top: 30px;
}

.tw-btn,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
button,
input[type="submit"] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	padding: 12px 20px;
	border-radius: 999px;
	border: 1px solid transparent;
	font-weight: 800;
	text-decoration: none;
	transition: transform var(--tw-ease), background var(--tw-ease), border-color var(--tw-ease), color var(--tw-ease);
	cursor: pointer;
}

.tw-btn:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
	transform: translateY(-1px);
	text-decoration: none;
}

.tw-btn--primary,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
	background: linear-gradient(135deg, var(--tw-green), var(--tw-green-deep));
	color: #fff !important;
	box-shadow: 0 12px 28px rgba(47,93,59,.35);
}

.tw-btn--ghost {
	color: var(--tw-ivory) !important;
	background: rgba(243,239,227,.06);
	border-color: var(--tw-border-strong);
}

.tw-btn--ghost:hover {
	background: rgba(243,239,227,.11);
	color: var(--tw-sand-soft) !important;
}

.tw-cat-grid,
.tw-why-grid,
.tw-blog-grid {
	display: grid;
	gap: 18px;
}

.tw-cat-grid {
	grid-template-columns: repeat(6, minmax(0, 1fr));
}

.tw-cat-card,
.tw-why-card,
.tw-blog-card,
.tw-placeholder,
.tw-newsletter__box {
	background: linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025));
	border: 1px solid var(--tw-border);
	border-radius: var(--tw-radius-lg);
	box-shadow: var(--tw-shadow-sm);
	color: var(--tw-ivory);
}

.tw-cat-card {
	min-height: 245px;
	padding: 22px;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	position: relative;
	overflow: hidden;
	background-color: var(--tw-bg-2);
	background-size: cover;
	background-position: center;
	text-decoration: none;
	transition: transform var(--tw-ease), border-color var(--tw-ease), box-shadow var(--tw-ease);
}

.tw-cat-card:hover {
	transform: translateY(-4px);
	border-color: rgba(111,179,126,.45);
	box-shadow: var(--tw-shadow-md);
	text-decoration: none;
}

.tw-cat-card__icon {
	font-size: 2.3rem;
}

.tw-cat-card__body {
	display: grid;
	gap: 8px;
}

.tw-cat-card__title {
	font-family: var(--tw-font-head);
	font-size: 1.2rem;
	font-weight: 800;
	color: var(--tw-ivory);
}

.tw-cat-card__desc {
	color: var(--tw-ivory-soft);
	font-size: .92rem;
	line-height: 1.45;
}

.tw-cat-card__cta {
	color: var(--tw-green-bright);
	font-weight: 800;
	font-size: .92rem;
}

.tw-woo-grid ul.products,
.woocommerce ul.products {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 20px;
}

.tw-theme ul.products li.product,
.woocommerce ul.products li.product {
	float: none !important;
	width: auto !important;
	margin: 0 !important;
	background: rgba(255,255,255,.045);
	border: 1px solid var(--tw-border);
	border-radius: var(--tw-radius);
	padding: 14px;
	box-shadow: var(--tw-shadow-sm);
	transition: transform var(--tw-ease), border-color var(--tw-ease);
}

.tw-theme ul.products li.product:hover {
	transform: translateY(-3px);
	border-color: rgba(111,179,126,.36);
}

.tw-theme ul.products li.product img {
	border-radius: 14px;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	background: var(--tw-bg-3);
}

.tw-theme ul.products li.product .woocommerce-loop-product__title {
	color: var(--tw-ivory);
	font-family: var(--tw-font-head);
	font-size: 1rem;
}

.tw-theme .price {
	color: var(--tw-sand-soft) !important;
	font-weight: 900;
}

.tw-theme .onsale,
.tw-onsale {
	background: var(--tw-sale);
	color: #17110a;
	border: 0;
	border-radius: 999px;
	padding: .28rem .68rem;
	font-weight: 900;
}

.tw-section__more {
	text-align: center;
	margin-top: 30px;
}

.tw-why-grid {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.tw-why-card {
	padding: 24px;
}

.tw-why-card__icon {
	font-size: 2rem;
}

.tw-why-card__title {
	color: var(--tw-ivory);
	font-family: var(--tw-font-head);
	font-size: 1.05rem;
	line-height: 1.25;
	margin: 14px 0 10px;
}

.tw-why-card__text {
	color: var(--tw-ivory-soft);
	margin: 0;
	line-height: 1.55;
}

.tw-blog-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.tw-blog-card {
	overflow: hidden;
}

.tw-blog-card__media {
	display: grid;
	place-items: center;
	min-height: 210px;
	background: var(--tw-bg-3);
}

.tw-blog-card__media img {
	width: 100%;
	height: 240px;
	object-fit: cover;
}

.tw-blog-card__placeholder {
	font-size: 3rem;
}

.tw-blog-card__body {
	padding: 22px;
}

.tw-blog-card__date {
	color: var(--tw-muted);
	font-size: .82rem;
	font-weight: 700;
}

.tw-blog-card__title {
	font-size: 1.1rem;
	line-height: 1.25;
	margin: 8px 0 10px;
}

.tw-blog-card__title a {
	color: var(--tw-ivory);
	text-decoration: none;
}

.tw-blog-card__excerpt {
	color: var(--tw-ivory-soft);
	line-height: 1.55;
}

.tw-blog-card__link {
	color: var(--tw-green-bright);
	font-weight: 900;
	text-decoration: none;
}

.tw-newsletter__box {
	padding: clamp(28px, 5vw, 54px);
	display: grid;
	grid-template-columns: 1.1fr .9fr;
	gap: 28px;
	align-items: center;
	background:
		radial-gradient(circle at 90% 20%, rgba(111,179,126,.20), transparent 18rem),
		linear-gradient(135deg, rgba(255,255,255,.075), rgba(255,255,255,.025));
}

.tw-newsletter__form {
	display: flex;
	gap: 12px;
}

.tw-newsletter__form input {
	flex: 1;
	min-height: 48px;
	border-radius: 999px;
	border: 1px solid var(--tw-border-strong);
	background: rgba(255,255,255,.08);
	color: var(--tw-ivory);
	padding: 0 16px;
}

.tw-newsletter__note {
	grid-column: 1 / -1;
	color: var(--tw-muted);
	font-size: .9rem;
	margin: 0;
}

.tw-placeholder {
	padding: 24px;
	color: var(--tw-ivory-soft);
}

/* WooCommerce detail/cart/checkout dark base */
.tw-theme .woocommerce-message,
.tw-theme .woocommerce-info,
.tw-theme .woocommerce-error {
	background: var(--tw-bg-2);
	color: var(--tw-ivory);
	border-color: var(--tw-border-strong);
}

.tw-theme table.shop_table,
.tw-theme .cart_totals,
.tw-theme .woocommerce-checkout-review-order {
	background: rgba(255,255,255,.04);
	color: var(--tw-ivory);
	border-color: var(--tw-border);
}

/* Responsive */
@media (max-width: 1180px) {
	.tw-cat-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
	.tw-woo-grid ul.products,
	.woocommerce ul.products { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (max-width: 820px) {
	.tw-hero { min-height: 560px; }
	.tw-hero::after { opacity: .28; width: 80vw; inset: 12% -20% 8% auto; }
	.tw-cat-grid,
	.tw-why-grid,
	.tw-blog-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.tw-woo-grid ul.products,
	.woocommerce ul.products { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.tw-newsletter__box { grid-template-columns: 1fr; }
	.tw-newsletter__form { flex-direction: column; }
}

@media (max-width: 560px) {
	.tw-container { width: min(100% - 22px, var(--tw-container)); }
	.tw-section { padding: 46px 0; }
	.tw-cat-grid,
	.tw-why-grid,
	.tw-blog-grid,
	.tw-woo-grid ul.products,
	.woocommerce ul.products { grid-template-columns: 1fr; }
	.tw-hero__actions { flex-direction: column; align-items: stretch; }
	.tw-btn { width: 100%; }
}

/* Dynamic WooCommerce product category cards – sidebar/widget variant */
.tw-side-cats {
	display: flex;
	flex-direction: column;
	gap: 12px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.tw-side-cat {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 14px;
	background: #101915;
	border: 1px solid rgba(243,239,227,.12);
	border-radius: 16px;
	color: #f3efe3 !important;
	text-decoration: none !important;
	transition: transform .22s ease, background .22s ease, border-color .22s ease;
}

.tw-side-cat:hover {
	background: #16221C;
	border-color: #4c8b5b;
	transform: translateX(4px);
	color: #f3efe3 !important;
}

.tw-side-cat__media {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 999px;
	background: rgba(111,179,126,.12);
}

.tw-side-cat__icon {
	font-size: 15px;
	line-height: 1;
}

.tw-side-cat__body {
	display: grid;
	gap: 2px;
	min-width: 0;
	flex: 1 1 auto;
}

.tw-side-cat__title {
	color: #f3efe3;
	font-weight: 800;
	font-size: 14px;
	line-height: 1.2;
}

.tw-side-cat__desc {
	color: #9aa79c;
	font-size: 12px;
	line-height: 1.35;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.tw-side-cat__arrow {
	color: #6fb37e;
	font-weight: 900;
	margin-left: auto;
}

/* =========================================================
   TerraWorld dynamic category submenus
   Main categories + hover/focus subcategories
   ========================================================= */

.tw-cat-card-wrap,
.tw-side-cat-wrap {
	position: relative;
	min-width: 0;
}

.tw-cat-card-wrap {
	display: block;
}

.tw-cat-card-wrap .tw-cat-card {
	height: 100%;
}

.tw-side-cat-wrap {
	display: block;
}

.tw-side-cat-wrap .tw-side-cat {
	width: 100%;
}

.tw-side-cat-wrap.has-children .tw-side-cat__arrow,
.tw-cat-card-wrap.has-children .tw-cat-card__cta {
	color: #6fb37e !important;
}

.tw-side-children,
.tw-cat-children {
	display: none;
	background: #0d1712;
	border: 1px solid rgba(243,239,227,.12);
	box-shadow: 0 18px 40px rgba(0,0,0,.35);
	z-index: 50;
}

.tw-side-cat-wrap:hover > .tw-side-children,
.tw-side-cat-wrap:focus-within > .tw-side-children,
.tw-cat-card-wrap:hover > .tw-cat-children,
.tw-cat-card-wrap:focus-within > .tw-cat-children {
	display: flex;
}

/* Sidebar/dropdown pri produkte */
.tw-side-children {
	position: absolute;
	left: calc(100% + 10px);
	top: 0;
	min-width: 230px;
	max-width: 280px;
	padding: 10px;
	border-radius: 16px;
	flex-direction: column;
	gap: 8px;
}

.tw-side-children::before {
	content: "";
	position: absolute;
	left: -12px;
	top: 0;
	width: 12px;
	height: 100%;
}

.tw-side-children a,
.tw-cat-children a {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 10px 12px;
	border-radius: 12px;
	background: rgba(255,255,255,.035);
	border: 1px solid rgba(243,239,227,.08);
	color: #d8d2c2 !important;
	font-size: 13px;
	font-weight: 700;
	line-height: 1.25;
	text-decoration: none !important;
	transition: background .2s ease, border-color .2s ease, color .2s ease, transform .2s ease;
}

.tw-side-children a:hover,
.tw-cat-children a:hover {
	background: #16221C;
	border-color: #4c8b5b;
	color: #f3efe3 !important;
	transform: translateX(3px);
}

/* Homepage grid dropdown pod kartou */
.tw-cat-children {
	position: absolute;
	left: 0;
	right: 0;
	top: calc(100% + 8px);
	padding: 10px;
	border-radius: 18px;
	flex-direction: column;
	gap: 8px;
}

.tw-cat-card-wrap:hover,
.tw-cat-card-wrap:focus-within {
	z-index: 20;
}

/* Na mobile/tablete zobraz podkategórie priamo pod kartou, nie ako bočný hover dropdown */
@media (max-width: 1099px) {
	.tw-side-children,
	.tw-cat-children {
		position: static;
		left: auto;
		right: auto;
		top: auto;
		min-width: 0;
		max-width: none;
		width: 100%;
		margin-top: 8px;
		box-shadow: none;
	}

	.tw-side-cat-wrap:hover > .tw-side-children,
	.tw-side-cat-wrap:focus-within > .tw-side-children,
	.tw-cat-card-wrap:hover > .tw-cat-children,
	.tw-cat-card-wrap:focus-within > .tw-cat-children {
		display: flex;
	}
}


/* =========================================================
   TerraWorld FIX 1.0.3 - stable dynamic categories + subcategories
   This overrides hover-only dropdowns and forces readable cards.
   ========================================================= */

/* HOMEPAGE category section: always real card grid */
.tw-categories .tw-cat-grid,
.tw-dynamic-product-cats.tw-cat-grid {
	display: grid !important;
	grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)) !important;
	gap: 18px !important;
	align-items: stretch !important;
	width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
}

.tw-cat-card-wrap {
	display: flex !important;
	flex-direction: column !important;
	gap: 10px !important;
	position: relative !important;
	min-width: 0 !important;
	z-index: auto !important;
}

.tw-cat-card-wrap .tw-cat-card {
	display: flex !important;
	flex-direction: column !important;
	justify-content: space-between !important;
	min-height: 190px !important;
	height: auto !important;
	width: 100% !important;
	padding: 20px !important;
	background-color: var(--tw-bg-2, #101915) !important;
	background-size: cover !important;
	background-position: center !important;
	border: 1px solid rgba(243,239,227,.12) !important;
	border-radius: 22px !important;
	box-shadow: 0 14px 34px rgba(0,0,0,.22) !important;
	color: #f3efe3 !important;
	text-decoration: none !important;
	overflow: hidden !important;
}

.tw-cat-card__body {
	display: grid !important;
	gap: 8px !important;
}

.tw-cat-card__title {
	color: #f3efe3 !important;
	font-family: var(--tw-font-head, Inter, Arial, sans-serif) !important;
	font-size: 1.08rem !important;
	font-weight: 900 !important;
	line-height: 1.15 !important;
}

.tw-cat-card__desc {
	color: #d8d2c2 !important;
	font-size: .9rem !important;
	line-height: 1.35 !important;
}

.tw-cat-card__cta {
	color: #6fb37e !important;
	font-weight: 900 !important;
	font-size: .9rem !important;
}

/* Homepage subcategories: visible below the main card, not broken inline text */
.tw-cat-children {
	display: flex !important;
	position: static !important;
	left: auto !important;
	right: auto !important;
	top: auto !important;
	width: 100% !important;
	min-width: 0 !important;
	max-width: none !important;
	margin: 0 !important;
	padding: 10px !important;
	flex-direction: column !important;
	gap: 7px !important;
	background: #0d1712 !important;
	border: 1px solid rgba(243,239,227,.10) !important;
	border-radius: 16px !important;
	box-shadow: none !important;
	z-index: auto !important;
}

.tw-cat-children:empty {
	display: none !important;
}

.tw-cat-children a {
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	gap: 10px !important;
	padding: 8px 10px !important;
	border-radius: 11px !important;
	background: rgba(255,255,255,.035) !important;
	border: 1px solid rgba(243,239,227,.07) !important;
	color: #d8d2c2 !important;
	font-size: 12.5px !important;
	font-weight: 700 !important;
	line-height: 1.2 !important;
	text-decoration: none !important;
}

.tw-cat-children a:hover {
	background: #16221C !important;
	border-color: #4c8b5b !important;
	color: #f3efe3 !important;
}

/* Sidebar/product detail categories: subcategories visible under parent */
.tw-side-cats.tw-dynamic-product-cats {
	display: flex !important;
	flex-direction: column !important;
	gap: 12px !important;
	width: 100% !important;
}

.tw-side-cat-wrap {
	display: block !important;
	position: relative !important;
	width: 100% !important;
}

.tw-side-cat-wrap .tw-side-cat {
	display: flex !important;
	align-items: center !important;
	gap: 12px !important;
	width: 100% !important;
	min-height: 54px !important;
	padding: 12px !important;
	background: #101915 !important;
	border: 1px solid rgba(243,239,227,.12) !important;
	border-radius: 16px !important;
	color: #f3efe3 !important;
	text-decoration: none !important;
}

.tw-side-children {
	display: flex !important;
	position: static !important;
	left: auto !important;
	top: auto !important;
	min-width: 0 !important;
	max-width: none !important;
	width: calc(100% - 18px) !important;
	margin: 8px 0 0 18px !important;
	padding: 8px !important;
	flex-direction: column !important;
	gap: 6px !important;
	background: #0d1712 !important;
	border: 1px solid rgba(243,239,227,.10) !important;
	border-radius: 14px !important;
	box-shadow: none !important;
	z-index: auto !important;
}

.tw-side-children:empty {
	display: none !important;
}

.tw-side-children::before {
	display: none !important;
}

.tw-side-children a {
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	gap: 8px !important;
	padding: 8px 10px !important;
	border-radius: 10px !important;
	background: rgba(255,255,255,.035) !important;
	border: 1px solid rgba(243,239,227,.07) !important;
	color: #d8d2c2 !important;
	font-size: 12.5px !important;
	font-weight: 700 !important;
	line-height: 1.2 !important;
	text-decoration: none !important;
}

.tw-side-children a:hover {
	background: #16221C !important;
	border-color: #4c8b5b !important;
	color: #f3efe3 !important;
}

@media (max-width: 640px) {
	.tw-categories .tw-cat-grid,
	.tw-dynamic-product-cats.tw-cat-grid {
		grid-template-columns: 1fr !important;
	}
}


/* =========================================================================
   TerraWorld safe header logo + readable archive pages
   - scoped only to header/archive, does not change homepage grid/layout
   ========================================================================= */
.tw-theme .site-header .site-branding {
	max-width: 150px !important;
	width: auto !important;
	margin-right: 24px !important;
}

.tw-theme .site-header .site-branding .custom-logo-link {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	max-width: 130px !important;
	padding: 4px !important;
	border-radius: 12px !important;
	overflow: hidden !important;
	background: rgba(243,239,227,.05) !important;
}

.tw-theme .site-header .site-branding img.custom-logo,
.tw-theme .site-header .custom-logo-link img {
	width: auto !important;
	max-width: 120px !important;
	max-height: 82px !important;
	height: auto !important;
	object-fit: contain !important;
	display: block !important;
}

.tw-theme .site-header .site-title,
.tw-theme .site-header .site-description {
	color: var(--tw-ivory) !important;
}

.tw-theme .woocommerce-products-header__title,
.tw-theme .page-title,
.tw-theme .entry-title,
.tw-theme h1.product_title {
	color: var(--tw-ivory) !important;
}

.tw-theme .term-description,
.tw-theme .woocommerce-products-header,
.tw-theme .woocommerce-products-header p,
.tw-theme .woocommerce-products-header a {
	color: var(--tw-ivory-soft) !important;
}

.tw-theme .woocommerce-products-header a {
	color: var(--tw-green-bright) !important;
}

.tw-theme ul.products li.product-category h2,
.tw-theme ul.products li.product-category h2 mark,
.tw-theme ul.products li.product-category .woocommerce-loop-category__title {
	color: var(--tw-ivory) !important;
	background: transparent !important;
}

/* =========================================================
   TerraWorld FIX 1.0.9 - hero image rotator + blog CTA/menu
   ========================================================= */

/* Hero layout with real visual block instead of empty green square */
.tw-hero__inner {
	display: grid !important;
	grid-template-columns: minmax(0, 1fr) minmax(360px, 0.78fr) !important;
	gap: clamp(28px, 5vw, 72px) !important;
	align-items: center !important;
}

.tw-hero::after {
	display: none !important;
	content: none !important;
}

.tw-hero-visual {
	position: relative !important;
	min-height: clamp(320px, 38vw, 520px) !important;
	border-radius: 34px !important;
	overflow: hidden !important;
	border: 1px solid rgba(243,239,227,.16) !important;
	box-shadow: 0 28px 70px rgba(0,0,0,.48) !important;
	background: #101915 !important;
}

.tw-hero-visual::after {
	content: "" !important;
	position: absolute !important;
	inset: 0 !important;
	background:
		linear-gradient(180deg, rgba(8,17,13,.05), rgba(8,17,13,.55)),
		radial-gradient(circle at 28% 18%, rgba(111,179,126,.18), transparent 180px) !important;
	pointer-events: none !important;
	z-index: 3 !important;
}

.tw-hero-slider,
.tw-hero-slide {
	position: absolute !important;
	inset: 0 !important;
}

.tw-hero-slide {
	background-size: cover !important;
	background-position: center !important;
	opacity: 0 !important;
	transform: scale(1.045) !important;
	animation: twHeroSlide 18s infinite !important;
}

.tw-hero-slide--1 {
	background-image: url('../images/hero-slide-1.jpg') !important;
	animation-delay: 0s !important;
}

.tw-hero-slide--2 {
	background-image: url('../images/hero-slide-2.jpg') !important;
	animation-delay: 6s !important;
}

.tw-hero-slide--3 {
	background-image: url('../images/hero-slide-3.jpg') !important;
	animation-delay: 12s !important;
}

@keyframes twHeroSlide {
	0% { opacity: 0; transform: scale(1.05); }
	8% { opacity: 1; transform: scale(1.015); }
	31% { opacity: 1; transform: scale(1); }
	39% { opacity: 0; transform: scale(1.025); }
	100% { opacity: 0; transform: scale(1.05); }
}

.tw-hero-visual__badge {
	position: absolute !important;
	left: 20px !important;
	bottom: 20px !important;
	z-index: 5 !important;
	display: inline-flex !important;
	align-items: center !important;
	gap: 10px !important;
	padding: 12px 15px !important;
	border-radius: 999px !important;
	background: rgba(8,17,13,.72) !important;
	border: 1px solid rgba(243,239,227,.18) !important;
	backdrop-filter: blur(10px) !important;
	color: #f3efe3 !important;
	box-shadow: 0 12px 32px rgba(0,0,0,.32) !important;
}

.tw-hero-visual__badge strong {
	font-size: 13px !important;
	letter-spacing: .02em !important;
}

/* Blog link should be visible in header menu even if injected by fallback menu */
.tw-menu-blog-link > a {
	color: var(--tw-ivory, #f3efe3) !important;
	font-weight: 700 !important;
}

.tw-menu-blog-link > a:hover {
	color: var(--tw-green-bright, #6fb37e) !important;
}

.tw-blog-more {
	margin-top: 30px !important;
}

/* More reliable logo background override - keep logo visible but less aggressive */
.tw-theme .site-header .custom-logo-link,
.tw-theme .site-header .site-logo-anchor,
.tw-theme .site-header .site-branding a.custom-logo-link {
	background: rgba(243,239,227,.92) !important;
	border: 1px solid rgba(243,239,227,.35) !important;
	border-radius: 14px !important;
	padding: 6px 8px !important;
	box-shadow: 0 10px 28px rgba(0,0,0,.22) !important;
}

.tw-theme .site-header .custom-logo-link img,
.tw-theme .site-header img.custom-logo {
	max-width: 112px !important;
	max-height: 78px !important;
	width: auto !important;
	height: auto !important;
	object-fit: contain !important;
}

@media (max-width: 900px) {
	.tw-hero__inner {
		grid-template-columns: 1fr !important;
	}

	.tw-hero-visual {
		min-height: 320px !important;
	}
}


/* =========================================================
   TerraWorld Blog Index Layout - isolated to /blog/ posts page
   ========================================================= */

body.blog .site-content .col-full,
body.home.blog .site-content .col-full {
	max-width: none !important;
	width: 100% !important;
	margin: 0 !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
}

body.blog #primary,
body.blog .content-area,
body.blog #main {
	float: none !important;
	width: 100% !important;
	max-width: none !important;
	margin: 0 !important;
	padding: 0 !important;
}

body.blog #secondary,
body.blog .widget-area {
	display: none !important;
}

.tw-blog-index {
	background: #08110D !important;
	color: #d8d2c2 !important;
	width: 100% !important;
}

.tw-blog-hero {
	position: relative !important;
	padding: 92px 24px 52px !important;
	background:
		radial-gradient(circle at 18% 12%, rgba(111,179,126,.18), transparent 28%),
		radial-gradient(circle at 78% 20%, rgba(203,184,146,.13), transparent 30%),
		linear-gradient(180deg, #09130e 0%, #08110D 100%) !important;
	border-bottom: 1px solid rgba(243,239,227,.08) !important;
	overflow: hidden !important;
}

.tw-blog-hero::after {
	content: "" !important;
	position: absolute !important;
	inset: auto 7% -90px auto !important;
	width: 360px !important;
	height: 360px !important;
	border-radius: 50% !important;
	background: radial-gradient(circle, rgba(76,139,91,.22), transparent 64%) !important;
	pointer-events: none !important;
}

.tw-blog-hero__inner {
	position: relative !important;
	z-index: 1 !important;
	max-width: 1180px !important;
	margin: 0 auto !important;
}

.tw-blog-hero .tw-eyebrow {
	margin: 0 0 14px !important;
	color: #6fb37e !important;
	font-size: 12px !important;
	font-weight: 900 !important;
	letter-spacing: .14em !important;
	text-transform: uppercase !important;
}

.tw-blog-hero h1 {
	max-width: 820px !important;
	margin: 0 0 18px !important;
	color: #f3efe3 !important;
	font-family: Poppins, Inter, Arial, sans-serif !important;
	font-size: clamp(36px, 5vw, 68px) !important;
	line-height: .98 !important;
	font-weight: 800 !important;
}

.tw-blog-hero p:not(.tw-eyebrow) {
	max-width: 720px !important;
	margin: 0 !important;
	color: #c8c1b1 !important;
	font-size: 17px !important;
	line-height: 1.75 !important;
}

.tw-blog-index__content {
	padding: 54px 24px 86px !important;
}

.tw-blog-index__inner {
	max-width: 1280px !important;
	margin: 0 auto !important;
}

.tw-blog-index-grid {
	display: grid !important;
	grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
	gap: 28px !important;
	align-items: stretch !important;
}

.tw-blog-index-card {
	display: flex !important;
	flex-direction: column !important;
	min-width: 0 !important;
	background: #101915 !important;
	border: 1px solid rgba(243,239,227,.12) !important;
	border-radius: 24px !important;
	overflow: hidden !important;
	box-shadow: 0 20px 50px rgba(0,0,0,.28) !important;
	transition: transform .24s ease, border-color .24s ease, box-shadow .24s ease !important;
}

.tw-blog-index-card:hover {
	transform: translateY(-4px) !important;
	border-color: rgba(111,179,126,.38) !important;
	box-shadow: 0 24px 70px rgba(0,0,0,.36) !important;
}

.tw-blog-index-card__media {
	display: block !important;
	position: relative !important;
	aspect-ratio: 4 / 3 !important;
	background: radial-gradient(circle at 28% 22%, rgba(111,179,126,.28), transparent 32%), #0c1510 !important;
	overflow: hidden !important;
}

.tw-blog-index-card__media img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	display: block !important;
	transition: transform .35s ease !important;
}

.tw-blog-index-card:hover .tw-blog-index-card__media img {
	transform: scale(1.045) !important;
}

.tw-blog-index-card__placeholder {
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 100% !important;
	height: 100% !important;
	font-size: 54px !important;
	background:
		linear-gradient(135deg, rgba(111,179,126,.18), rgba(203,184,146,.08)),
		#0c1510 !important;
}

.tw-blog-index-card__body {
	display: flex !important;
	flex-direction: column !important;
	flex: 1 !important;
	padding: 22px !important;
}

.tw-blog-index-card__meta {
	display: flex !important;
	flex-wrap: wrap !important;
	gap: 8px !important;
	align-items: center !important;
	margin-bottom: 12px !important;
	color: #9aa79c !important;
	font-size: 12px !important;
	font-weight: 700 !important;
}

.tw-blog-index-card__meta a {
	color: #6fb37e !important;
	text-decoration: none !important;
}

.tw-blog-index-card__title {
	margin: 0 0 12px !important;
	font-size: 22px !important;
	line-height: 1.22 !important;
	font-family: Poppins, Inter, Arial, sans-serif !important;
	font-weight: 800 !important;
}

.tw-blog-index-card__title a {
	color: #f3efe3 !important;
	text-decoration: none !important;
}

.tw-blog-index-card__title a:hover {
	color: #6fb37e !important;
}

.tw-blog-index-card__excerpt {
	margin: 0 0 20px !important;
	color: #c8c1b1 !important;
	font-size: 14px !important;
	line-height: 1.65 !important;
}

.tw-blog-index-card__link {
	margin-top: auto !important;
	align-self: flex-start !important;
	color: #6fb37e !important;
	font-weight: 800 !important;
	text-decoration: none !important;
}

.tw-blog-index-card__link:hover {
	color: #f3efe3 !important;
}

.tw-blog-pagination {
	margin-top: 42px !important;
}

.tw-blog-pagination .nav-links {
	display: flex !important;
	gap: 10px !important;
	justify-content: center !important;
	flex-wrap: wrap !important;
}

.tw-blog-pagination .page-numbers {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-width: 42px !important;
	height: 42px !important;
	padding: 0 14px !important;
	border-radius: 999px !important;
	background: #101915 !important;
	border: 1px solid rgba(243,239,227,.12) !important;
	color: #f3efe3 !important;
	font-weight: 800 !important;
	text-decoration: none !important;
}

.tw-blog-pagination .page-numbers.current,
.tw-blog-pagination .page-numbers:hover {
	background: #4c8b5b !important;
	border-color: #4c8b5b !important;
	color: #06100b !important;
}

.tw-blog-empty {
	max-width: 760px !important;
	margin: 0 auto !important;
	padding: 42px !important;
	background: #101915 !important;
	border: 1px solid rgba(243,239,227,.12) !important;
	border-radius: 24px !important;
	text-align: center !important;
}

.tw-blog-empty h2 {
	color: #f3efe3 !important;
	margin-top: 0 !important;
}

.tw-blog-empty p {
	color: #c8c1b1 !important;
	margin-bottom: 0 !important;
}

@media (max-width: 1099px) {
	.tw-blog-index-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	}
}

@media (max-width: 700px) {
	.tw-blog-hero {
		padding: 62px 18px 36px !important;
	}

	.tw-blog-index__content {
		padding: 36px 18px 60px !important;
	}

	.tw-blog-index-grid {
		grid-template-columns: 1fr !important;
	}

	.tw-blog-index-card__body {
		padding: 18px !important;
	}
}


/* Blog category pills on /blog/ */
.tw-blog-categories {
	background: #08110D;
	padding: 0 0 38px;
}

.tw-blog-categories__inner {
	width: min(1180px, calc(100% - 48px));
	margin: 0 auto;
}

.tw-blog-categories__head {
	margin-bottom: 18px;
}

.tw-blog-categories__head h2 {
	color: #f3efe3;
	font-size: clamp(24px, 3vw, 38px);
	line-height: 1.1;
	margin: 0;
}

.tw-blog-category-pills {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.tw-blog-category-pill {
	display: inline-flex;
	align-items: center;
	gap: 9px;
	min-height: 46px;
	padding: 10px 14px;
	background: #101915;
	border: 1px solid rgba(243,239,227,.12);
	border-radius: 999px;
	color: #f3efe3 !important;
	font-weight: 800;
	font-size: 14px;
	text-decoration: none !important;
	box-shadow: 0 10px 26px rgba(0,0,0,.22);
	transition: transform .2s ease, border-color .2s ease, background .2s ease;
}

.tw-blog-category-pill:hover,
.tw-blog-category-pill.is-active {
	background: #16221C;
	border-color: #6fb37e;
	transform: translateY(-2px);
}

.tw-blog-category-pill__icon {
	width: 22px;
	height: 22px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	background: rgba(111,179,126,.16);
	font-size: 12px;
}

.tw-blog-category-pill small {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 22px;
	height: 22px;
	padding: 0 7px;
	border-radius: 999px;
	background: rgba(243,239,227,.10);
	color: #c9d3c7;
	font-size: 12px;
	font-weight: 800;
}

@media (max-width: 640px) {
	.tw-blog-categories__inner {
		width: min(100% - 28px, 1180px);
	}

	.tw-blog-category-pills {
		gap: 9px;
	}

	.tw-blog-category-pill {
		width: 100%;
		justify-content: flex-start;
		border-radius: 16px;
	}
}
