/*
Theme Name:  Mow Child – ItsMagz
Theme URI:   https://www.itsmagz.com
Description: Child theme of Mow for ItsMagz.com. Adds a Digital Products engine (custom post type, categories, formats, purchase-platform metadata), ad placeholder slots (Google AdSense / Monetag), brand palette, and a black footer treatment. All customisations live here so Mow parent updates never overwrite them.
Author:      ItsMagz
Author URI:  https://www.itsmagz.com
Template:    mow
Version:     1.0.0
License:     GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: mow-child
Tags:        blog, magazine, two-columns, custom-menu, featured-images
*/

/* =========================================================
   1. ItsMagz brand tokens
   ========================================================= */
:root {
	--im-gold:        #C0973F;
	--im-gold-light:  #D8B568;
	--im-gold-dark:   #9C7A30;
	--im-gold-text:   #6D5522; /* AA-contrast gold for text on light bg */
	--im-espresso:    #2A211B;
	--im-espresso-2:  #3E322A;
	--im-black:       #0B0908; /* warm black — footer */
	--im-cream:       #EAE0CB;
	--im-cream-soft:  #F7F2E8;
	--im-border:      #DCD2BE;
	--im-body:        #5B5048;
	--im-white:       #FFFFFF;
	--im-success:     #4F7942;
	--im-radius:      12px;
	--im-shadow:      0 6px 24px rgba(42, 33, 27, .08);
	--im-shadow-lg:   0 12px 36px rgba(42, 33, 27, .16);
}

/* =========================================================
   2. Layout container (aligned to typical Mow/Elementor width;
      adjust --im-container-max on staging if Mow differs)
   ========================================================= */
:root { --im-container-max: 1200px; }

.itsmagz-container {
	width: 100%;
	max-width: var(--im-container-max);
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
	box-sizing: border-box;
}

.itsmagz-main { padding: 40px 0 64px; }

/* =========================================================
   3. Product grid + cards (fully responsive, no JS required)
   ========================================================= */
.im-products-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
	gap: 28px;
	margin: 0;
	padding: 0;
	list-style: none;
}
.im-products-grid.im-cols-2 { grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); }
.im-products-grid.im-cols-4 { grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); }

.im-product-card {
	background: var(--im-white);
	border: 1px solid var(--im-border);
	border-radius: var(--im-radius);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform .18s ease, box-shadow .18s ease;
	position: relative;
}
.im-product-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--im-shadow-lg);
}
.im-product-card__media {
	display: block;
	background: var(--im-cream-soft);
	aspect-ratio: 4 / 5;
	overflow: hidden;
}
.im-product-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .3s ease;
}
.im-product-card:hover .im-product-card__media img { transform: scale(1.04); }

.im-product-card__media--empty {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--im-gold-dark);
	font-size: 42px;
}

.im-product-card__body {
	padding: 18px 18px 20px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	flex: 1;
}
.im-product-card__format {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--im-gold-text);
}
.im-product-card__title {
	font-size: 17px;
	line-height: 1.35;
	margin: 0;
	color: var(--im-espresso);
}
.im-product-card__title a { color: inherit; text-decoration: none; }
.im-product-card__title a:hover { color: var(--im-gold-dark); }

.im-product-card__meta {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 13px;
	color: var(--im-body);
	flex-wrap: wrap;
}
.im-product-card__footer {
	margin-top: auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	padding-top: 10px;
	border-top: 1px dashed var(--im-border);
}
.im-product-card__price {
	font-size: 18px;
	font-weight: 800;
	color: var(--im-espresso);
}

/* Platform badge */
.im-platform {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .04em;
	padding: 4px 10px;
	border-radius: 999px;
	text-transform: uppercase;
	white-space: nowrap;
}
.im-platform--amazon  { background: #232F3E; color: #FF9900; }
.im-platform--etsy    { background: #FDEBD2; color: #C45500; }
.im-platform--gumroad { background: #FFE9F0; color: #C2185B; }

/* Star rating (partial-fill via width overlay) */
.im-stars {
	position: relative;
	display: inline-block;
	font-size: 15px;
	line-height: 1;
	letter-spacing: 2px;
	color: var(--im-border);
	white-space: nowrap;
}
.im-stars__fill {
	position: absolute;
	top: 0;
	left: 0;
	overflow: hidden;
	color: var(--im-gold);
	white-space: nowrap;
}
.im-rating-count { font-size: 13px; color: var(--im-body); }

/* =========================================================
   4. Single product page
   ========================================================= */
.im-product-hero {
	display: grid;
	grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
	gap: 48px;
	align-items: start;
	margin-bottom: 48px;
}
.im-product-hero__media {
	border-radius: var(--im-radius);
	overflow: hidden;
	border: 1px solid var(--im-border);
	background: var(--im-cream-soft);
	box-shadow: var(--im-shadow);
	position: sticky;
	top: 100px;
}
.im-product-hero__media img { width: 100%; height: auto; display: block; }

.im-product-hero__title {
	font-size: clamp(26px, 4vw, 38px);
	line-height: 1.2;
	color: var(--im-espresso);
	margin: 6px 0 14px;
}
.im-product-hero__cats { display: flex; gap: 8px; flex-wrap: wrap; }
.im-cat-badge {
	display: inline-block;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .07em;
	text-transform: uppercase;
	color: var(--im-gold-text);
	background: var(--im-cream-soft);
	border: 1px solid var(--im-border);
	border-radius: 999px;
	padding: 5px 12px;
	text-decoration: none;
}
.im-cat-badge:hover { background: var(--im-cream); color: var(--im-espresso); }

.im-product-rating-row {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
	margin-bottom: 18px;
}
.im-product-price {
	font-size: clamp(26px, 3.4vw, 34px);
	font-weight: 800;
	color: var(--im-espresso);
	margin: 4px 0 18px;
}
.im-product-price .im-currency { font-size: .6em; vertical-align: super; color: var(--im-gold-dark); }

/* Spec list: format, pages, platform */
.im-product-specs {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
	gap: 12px;
	margin: 0 0 24px;
	padding: 0;
	list-style: none;
}
.im-product-specs li {
	background: var(--im-cream-soft);
	border: 1px solid var(--im-border);
	border-radius: var(--im-radius);
	padding: 12px 14px;
}
.im-product-specs .im-spec-label {
	display: block;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--im-body);
	margin-bottom: 4px;
}
.im-product-specs .im-spec-value {
	font-size: 15px;
	font-weight: 700;
	color: var(--im-espresso);
}
.im-product-specs .im-spec-value a { color: var(--im-gold-text); text-decoration: none; }

/* Buy button */
.im-buy-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	width: 100%;
	max-width: 420px;
	padding: 16px 28px;
	border-radius: 999px;
	background: var(--im-gold);
	color: var(--im-espresso);
	font-size: 17px;
	font-weight: 800;
	letter-spacing: .02em;
	text-decoration: none;
	border: 2px solid var(--im-gold);
	transition: background .15s ease, transform .15s ease, box-shadow .15s ease;
	box-shadow: 0 8px 20px rgba(192, 151, 63, .35);
	cursor: pointer;
	text-align: center;
}
.im-buy-btn:hover {
	background: var(--im-gold-light);
	transform: translateY(-2px);
	color: var(--im-espresso);
}
.im-buy-btn:focus-visible { outline: 3px solid var(--im-espresso); outline-offset: 2px; }
.im-buy-note { font-size: 12.5px; color: var(--im-body); margin-top: 10px; }

.im-product-content { max-width: 820px; margin: 0 auto 48px; }
.im-product-content h2 { color: var(--im-espresso); }

/* Related products */
.im-related { margin-top: 56px; }
.im-section-title {
	font-size: 22px;
	color: var(--im-espresso);
	margin: 0 0 20px;
	padding-bottom: 10px;
	border-bottom: 3px solid var(--im-gold);
	display: inline-block;
}

/* =========================================================
   5. Archive header
   ========================================================= */
.im-archive-header { margin-bottom: 34px; }
.im-archive-header h1 {
	font-size: clamp(26px, 4vw, 36px);
	color: var(--im-espresso);
	margin: 0 0 8px;
}
.im-archive-header .im-archive-desc { color: var(--im-body); max-width: 720px; }
.im-archive-count { font-size: 13px; color: var(--im-body); margin-top: 6px; }

/* Category tiles shortcode */
.im-cat-tiles {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 20px;
	padding: 0;
	margin: 0;
	list-style: none;
}
.im-cat-tile {
	display: block;
	background: var(--im-espresso);
	color: var(--im-cream);
	border-radius: var(--im-radius);
	padding: 26px 22px;
	text-decoration: none;
	transition: transform .15s ease, background .15s ease;
	position: relative;
	overflow: hidden;
}
.im-cat-tile::after {
	content: "";
	position: absolute;
	inset: auto -30px -30px auto;
	width: 90px;
	height: 90px;
	border-radius: 50%;
	background: rgba(192, 151, 63, .25);
}
.im-cat-tile:hover { transform: translateY(-3px); background: var(--im-espresso-2); color: var(--im-white); }
.im-cat-tile__name { font-size: 17px; font-weight: 800; display: block; margin-bottom: 4px; }
.im-cat-tile__count { font-size: 12.5px; color: var(--im-gold-light); }

/* Pagination (inherits parent styles where present) */
.im-pagination { margin-top: 40px; text-align: center; }
.im-pagination .page-numbers {
	display: inline-block;
	min-width: 40px;
	padding: 9px 12px;
	margin: 0 3px;
	border: 1px solid var(--im-border);
	border-radius: 8px;
	color: var(--im-espresso);
	text-decoration: none;
	font-weight: 700;
}
.im-pagination .page-numbers.current,
.im-pagination .page-numbers:hover { background: var(--im-gold); border-color: var(--im-gold); color: var(--im-espresso); }

/* =========================================================
   6. Ad slots
   ========================================================= */
.im-ad-slot {
	margin: 28px auto;
	text-align: center;
	max-width: 100%;
	overflow: hidden;
	clear: both;
}
.im-ad-slot > ins, .im-ad-slot > div { margin: 0 auto; }
.im-ad-slot__label {
	display: block;
	font-size: 10px;
	letter-spacing: .12em;
	text-transform: uppercase;
	color: #A9A099;
	margin-bottom: 6px;
}
/* Placeholder box (shown until real ad code is pasted) */
.im-ad-placeholder {
	border: 2px dashed var(--im-border);
	background: var(--im-cream-soft);
	border-radius: var(--im-radius);
	color: var(--im-body);
	font-size: 13px;
	letter-spacing: .04em;
	padding: 34px 20px;
	min-height: 90px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 4px;
}
.im-ad-placeholder strong { color: var(--im-gold-text); text-transform: uppercase; font-size: 11px; letter-spacing: .1em; }

/* =========================================================
   7. Black footer treatment
      NOTE: Mow builds its footer via Elementor; if these selectors
      don't catch it on staging, set the footer section background
      to #0B0908 in the Elementor footer template instead (see README).
   ========================================================= */
footer.site-footer,
.site-footer,
#colophon,
.elementor-location-footer,
.elementor-location-footer .elementor-section:first-child,
.footer-area {
	background-color: var(--im-black) !important;
	color: var(--im-cream) !important;
}
.site-footer a, #colophon a, .elementor-location-footer a, .footer-area a { color: var(--im-cream); }
.site-footer a:hover, #colophon a:hover, .elementor-location-footer a:hover, .footer-area a:hover { color: var(--im-gold-light); }

/* ItsMagz footer brand block ([itsmagz_footer_brand] shortcode) */
.im-footer-brand { text-align: center; padding: 34px 20px 26px; }
.im-footer-brand__logo img { max-height: 64px; width: auto; margin: 0 auto 14px; display: inline-block; }
.im-footer-brand__tagline { color: var(--im-cream); font-size: 14px; margin: 0 0 16px; opacity: .85; }
.im-footer-brand__menu { list-style: none; margin: 0 0 14px; padding: 0; display: flex; gap: 22px; justify-content: center; flex-wrap: wrap; }
.im-footer-brand__menu a { color: var(--im-cream); font-size: 13px; text-decoration: none; }
.im-footer-brand__menu a:hover { color: var(--im-gold-light); }
.im-footer-brand__copyright { font-size: 12.5px; color: rgba(234, 224, 203, .6); margin: 0; }

/* =========================================================
   8. Responsive breakpoints
   ========================================================= */
@media (max-width: 1024px) {
	.im-product-hero { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 32px; }
}
@media (max-width: 768px) {
	.itsmagz-main { padding: 28px 0 48px; }
	.im-product-hero { grid-template-columns: 1fr; gap: 26px; }
	.im-product-hero__media { position: static; max-width: 420px; margin: 0 auto; }
	.im-products-grid { gap: 18px; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); }
	.im-buy-btn { max-width: none; }
}
@media (max-width: 480px) {
	.im-products-grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 14px; }
	.im-product-card__body { padding: 12px 12px 14px; }
	.im-product-card__title { font-size: 14.5px; }
	.im-product-card__price { font-size: 15px; }
	.im-product-specs { grid-template-columns: 1fr 1fr; }
}

/* Accessibility helpers */
.screen-reader-text {
	border: 0; clip: rect(1px, 1px, 1px, 1px); clip-path: inset(50%);
	height: 1px; width: 1px; margin: -1px; overflow: hidden;
	padding: 0; position: absolute !important; word-wrap: normal !important;
}
