/* ============================================================
   Karmasu Premium Homepage — scoped under #karmasu-home so it
   never bleeds into cart/checkout/account/product pages.
   Mobile-first: base rules = mobile, min-width queries scale up.
   ============================================================ */

#karmasu-home {
	--maroon: #6B1F1F;
	--saffron: #D98324;
	--gold: #B8860B;
	--cream: #FFF8F0;
	--cream-dark: #F5E6C8;
	--text: #2B2B2B;
	font-family: 'Inter', 'Noto Sans', sans-serif;
	color: var(--text);
	background: var(--cream);
}

#karmasu-home * { box-sizing: border-box; }
#karmasu-home img { max-width: 100%; display: block; }

/* ---------- Hero ---------- */
.karmasu-hero {
	background: linear-gradient(135deg, var(--maroon), #4a1414);
	color: #fff;
	padding: 48px 20px;
	text-align: center;
}
.karmasu-hero__title { font-size: 28px; margin: 0 0 10px; font-weight: 700; }
.karmasu-hero__sub { font-size: 15px; opacity: .9; margin: 0 0 24px; }
.karmasu-hero__search { display: flex; max-width: 480px; margin: 0 auto 20px; }
.karmasu-hero__search input {
	flex: 1; padding: 12px 14px; border: none; border-radius: 6px 0 0 6px; font-size: 15px;
}
.karmasu-hero__search button {
	background: var(--saffron); color: #fff; border: none; padding: 0 18px; border-radius: 0 6px 6px 0; cursor: pointer;
}
.karmasu-hero__ctas { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

.karmasu-btn {
	display: inline-block; padding: 12px 22px; border-radius: 6px; text-decoration: none;
	font-weight: 600; font-size: 14px; transition: transform .15s ease;
}
.karmasu-btn:hover { transform: translateY(-2px); }
.karmasu-btn--primary { background: var(--saffron); color: #fff; }
.karmasu-btn--outline { border: 1.5px solid #fff; color: #fff; }
.karmasu-btn--sm { padding: 8px 14px; font-size: 13px; background: var(--maroon); color: #fff; width: 100%; text-align: center; }

/* ---------- Section shell ---------- */
.karmasu-section { padding: 36px 16px; max-width: 1200px; margin: 0 auto; }
.karmasu-section__head { display: flex; justify-content: space-between; align-items: baseline; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.karmasu-section__head h2 { font-size: 22px; color: var(--maroon); margin: 0; border-left: 4px solid var(--saffron); padding-left: 10px; }
.karmasu-section__head p { font-size: 13px; color: #777; margin: 4px 0 0; flex-basis: 100%; }
.karmasu-viewall { color: var(--saffron); font-size: 13px; font-weight: 600; text-decoration: none; }

/* ---------- Category grid ---------- */
.karmasu-cat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.karmasu-cat-card {
	text-align: center; text-decoration: none; color: var(--text); background: #fff;
	border-radius: 10px; padding: 12px; border: 1px solid var(--cream-dark);
}
.karmasu-cat-card img { border-radius: 8px; margin: 0 auto 8px; object-fit: cover; aspect-ratio: 1/1; }
.karmasu-cat-card span { font-size: 12.5px; font-weight: 600; }

/* ---------- Product rows / cards ---------- */
.karmasu-row { display: grid; grid-auto-flow: column; grid-auto-columns: 62%; gap: 12px; overflow-x: auto; padding-bottom: 6px; scroll-snap-type: x mandatory; }
.karmasu-row::-webkit-scrollbar { height: 5px; }
.karmasu-row::-webkit-scrollbar-thumb { background: var(--cream-dark); border-radius: 5px; }

.karmasu-card { background: #fff; border: 1px solid var(--cream-dark); border-radius: 10px; overflow: hidden; scroll-snap-align: start; }
.karmasu-card__img-wrap { position: relative; display: block; aspect-ratio: 1/1; overflow: hidden; background: #fafafa; }
.karmasu-card__img-wrap img { width: 100%; height: 100%; object-fit: cover; }
.karmasu-badge { position: absolute; top: 8px; left: 8px; background: var(--saffron); color: #fff; font-size: 11px; padding: 3px 8px; border-radius: 4px; }
.karmasu-card__title { font-size: 13.5px; margin: 10px 10px 4px; line-height: 1.3; height: 34px; overflow: hidden; }
.karmasu-card__title a { color: var(--text); text-decoration: none; }
.karmasu-card__price { margin: 0 10px 10px; font-weight: 700; color: var(--maroon); font-size: 14px; }
.karmasu-card__actions { margin: 0 10px 12px; }
.karmasu-out-of-stock { font-size: 12px; color: #999; }

/* ---------- Widgets (Puja Assistant / Gemstone Finder) ---------- */
.karmasu-widget { background: var(--cream-dark); border-radius: 14px; margin: 24px 16px; }
.karmasu-widget__box { background: #fff; border-radius: 10px; padding: 16px; }
#karmasu-puja-input { width: 100%; padding: 12px 14px; border: 1px solid #ddd; border-radius: 6px; font-size: 15px; }
.karmasu-suggestions { background: #fff; border: 1px solid #eee; border-radius: 6px; margin-top: 4px; }
.karmasu-suggestions div { padding: 10px 14px; cursor: pointer; font-size: 14px; }
.karmasu-suggestions div:hover { background: var(--cream); }

.karmasu-puja-results { margin-top: 16px; display: grid; gap: 10px; }
.karmasu-item-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 10px 12px; border: 1px solid #eee; border-radius: 8px; font-size: 13.5px; }
.karmasu-item-row img { width: 40px; height: 40px; object-fit: cover; border-radius: 4px; }
.karmasu-item-avail { color: #1a7a3c; font-weight: 600; }
.karmasu-item-missing { color: #a33; }

.karmasu-gem-tabs button { background: none; border: 1px solid var(--maroon); color: var(--maroon); padding: 8px 14px; border-radius: 20px; font-size: 13px; margin-right: 8px; cursor: pointer; }
.karmasu-gem-tabs button.active { background: var(--maroon); color: #fff; }
.karmasu-gem-options { margin-top: 14px; display: flex; flex-wrap: wrap; gap: 8px; }
.karmasu-chip { border: 1px solid var(--saffron); background: #fff; color: var(--saffron); padding: 8px 14px; border-radius: 20px; font-size: 13px; cursor: pointer; }
.karmasu-chip.active { background: var(--saffron); color: #fff; }
.karmasu-gem-results { margin-top: 16px; display: grid; gap: 12px; }
.karmasu-gem-result-card { border: 1px solid #eee; border-radius: 10px; padding: 14px; }
.karmasu-gem-result-card h4 { margin: 0 0 6px; color: var(--maroon); }
.karmasu-gem-result-card table { width: 100%; font-size: 13px; border-collapse: collapse; margin: 8px 0; }
.karmasu-gem-result-card td { padding: 3px 0; }
.karmasu-whatsapp-btn { display: inline-block; background: #25D366; color: #fff; padding: 9px 16px; border-radius: 6px; font-size: 13px; text-decoration: none; font-weight: 600; }

/* ---------- Why choose us ---------- */
.karmasu-why-grid { display: grid; gap: 16px; grid-template-columns: 1fr 1fr; }
.karmasu-why-grid > div { background: #fff; border-radius: 10px; padding: 18px; text-align: center; border: 1px solid var(--cream-dark); }
.karmasu-why-grid span { font-size: 26px; }
.karmasu-why-grid h3 { font-size: 14px; margin: 8px 0 4px; color: var(--maroon); }
.karmasu-why-grid p { font-size: 12.5px; color: #666; margin: 0; }

/* ---------- Reviews / Blog ---------- */
.karmasu-review-card { min-width: 70%; background: #fff; border-radius: 10px; padding: 16px; border: 1px solid var(--cream-dark); scroll-snap-align: start; }
.karmasu-review-card__stars { color: var(--gold); margin-bottom: 6px; }
.karmasu-blog-card { min-width: 70%; background: #fff; border-radius: 10px; overflow: hidden; text-decoration: none; color: var(--text); border: 1px solid var(--cream-dark); scroll-snap-align: start; }
.karmasu-blog-card h3 { font-size: 14px; margin: 10px; }

/* ---------- Newsletter ---------- */
.karmasu-newsletter { background: var(--maroon); color: #fff; text-align: center; padding: 40px 20px; }
.karmasu-newsletter__form { display: flex; max-width: 420px; margin: 16px auto 0; }
.karmasu-newsletter__form input { flex: 1; padding: 12px; border: none; border-radius: 6px 0 0 6px; }
.karmasu-newsletter__form button { background: var(--saffron); border: none; color: #fff; padding: 0 18px; border-radius: 0 6px 6px 0; cursor: pointer; }

/* ---------- Floating WhatsApp ---------- */
.karmasu-whatsapp-float {
	position: fixed; bottom: 18px; right: 18px; background: #25D366; width: 54px; height: 54px;
	border-radius: 50%; display: flex; align-items: center; justify-content: center;
	box-shadow: 0 4px 14px rgba(0,0,0,.25); z-index: 999;
}

/* ============ Tablet / Desktop scale-up ============ */
@media (min-width: 768px) {
	.karmasu-hero { padding: 80px 20px; }
	.karmasu-hero__title { font-size: 42px; }
	.karmasu-cat-grid { grid-template-columns: repeat(5, 1fr); }
	.karmasu-row { grid-auto-columns: 23%; }
	.karmasu-why-grid { grid-template-columns: repeat(4, 1fr); }
}
@media (min-width: 1024px) {
	.karmasu-row { grid-auto-columns: 18.5%; }
}
