/*
Theme Name: Kundali Mitra
Theme URI: https://kundalimitra.com
Author: Kundali Mitra
Description: A saffron-robed, palm-leaf manuscript inspired Vedic astrology theme — जन्म कुण्डली, गुण मिलान and Jyotisha wisdom in the voice of the ancient guru parampara.
Version: 1.0.0
License: GPL-2.0+
Text Domain: kundalimitra
*/

/* ============ palette & foundations ============ */
:root {
	--km-saffron: #e8720c;        /* bhagwa of the yogi's robe */
	--km-saffron-bright: #ff9933; /* kesariya */
	--km-saffron-deep: #b4530a;
	--km-gold: #c99700;
	--km-gold-light: #e7c65a;
	--km-ink: #3b2308;            /* iron-gall ink on old leaf */
	--km-maroon: #4a1e05;
	--km-leaf: #f0dcb4;           /* dried palm leaf */
	--km-leaf-deep: #e2c48d;
	--km-parchment: #f8ecd4;
	--km-night: #2e1503;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
	margin: 0;
	font-family: 'Martel', 'Tiro Devanagari Hindi', Georgia, serif;
	font-size: 17px;
	line-height: 1.75;
	color: var(--km-ink);
	background-color: var(--km-leaf);
	/* palm-leaf fibre: fine horizontal writing lines over aged gradient */
	background-image:
		repeating-linear-gradient(0deg, rgba(140, 90, 20, 0.05) 0 1px, transparent 1px 27px),
		repeating-linear-gradient(90deg, rgba(160, 110, 40, 0.03) 0 2px, transparent 2px 90px),
		radial-gradient(ellipse at 50% -10%, #fbf1da 0%, var(--km-leaf) 55%, #e6cb96 100%);
	background-attachment: fixed;
}
h1, h2, h3, h4, .km-display {
	font-family: 'Yatra One', 'Martel', serif;
	font-weight: 400;
	color: var(--km-maroon);
	line-height: 1.3;
}
a { color: var(--km-saffron-deep); }
a:hover { color: var(--km-saffron); }
img { max-width: 100%; height: auto; }

.km-wrap { max-width: 1120px; margin: 0 auto; padding: 0 20px; }

/* ============ header ============ */
.km-header {
	background:
		linear-gradient(180deg, rgba(0,0,0,0.08), transparent 30%),
		linear-gradient(90deg, var(--km-saffron-deep), var(--km-saffron) 30%, var(--km-saffron-bright) 60%, var(--km-saffron) 100%);
	border-bottom: 4px solid var(--km-gold);
	box-shadow: 0 3px 18px rgba(74, 30, 5, 0.35);
	position: relative;
	z-index: 50;
}
.km-header-inner { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 14px 20px; max-width: 1120px; margin: 0 auto; flex-wrap: wrap; }
.km-brand { display: flex; align-items: center; gap: 14px; text-decoration: none; }
.km-brand-om {
	font-size: 2.6rem; line-height: 1; color: #fff3d6;
	text-shadow: 0 0 18px rgba(255, 243, 214, 0.9), 0 2px 3px rgba(74, 30, 5, 0.6);
}
.km-brand-text { display: flex; flex-direction: column; }
.km-brand-hi { font-family: 'Yatra One', serif; font-size: 1.5rem; color: #fff8ea; letter-spacing: 1px; text-shadow: 0 2px 4px rgba(74,30,5,.5); }
.km-brand-en { font-size: 0.78rem; letter-spacing: 3.5px; text-transform: uppercase; color: #ffe9bf; }
.km-nav { display: flex; gap: 4px; flex-wrap: wrap; }
.km-nav a {
	color: #fff3d6; text-decoration: none; font-weight: 700; font-size: 0.95rem;
	padding: 8px 15px; border-radius: 20px; transition: background 0.2s;
}
.km-nav a:hover, .km-nav a.km-active { background: rgba(74, 30, 5, 0.35); color: #ffe9bf; }

/* ============ hero ============ */
.km-hero { position: relative; text-align: center; padding: 72px 20px 60px; overflow: hidden; }
.km-hero-mandala {
	position: absolute; top: 50%; left: 50%; width: 760px; height: 760px;
	transform: translate(-50%, -50%);
	opacity: 0.16; pointer-events: none;
	animation: km-rotate 240s linear infinite;
}
@keyframes km-rotate { from { transform: translate(-50%, -50%) rotate(0deg); } to { transform: translate(-50%, -50%) rotate(360deg); } }
.km-hero-shloka {
	font-family: 'Yatra One', serif; font-size: clamp(1.5rem, 4vw, 2.3rem);
	color: var(--km-saffron-deep); margin: 0 0 4px; position: relative;
}
.km-hero-shloka-tr { font-style: italic; color: #7a5a2e; font-size: 0.95rem; margin: 0 0 26px; position: relative; }
.km-hero h1 { font-size: clamp(2.1rem, 5.5vw, 3.4rem); margin: 0 0 18px; position: relative; }
.km-hero-sub { max-width: 660px; margin: 0 auto 34px; font-size: 1.1rem; color: #5c3a10; position: relative; }
.km-hero-ctas { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; position: relative; }

.km-cta {
	display: inline-block; padding: 15px 36px; border-radius: 40px; text-decoration: none;
	font-weight: 700; font-size: 1.05rem; letter-spacing: 0.4px;
	transition: transform 0.15s, box-shadow 0.15s;
}
.km-cta-solid {
	background: linear-gradient(180deg, var(--km-saffron), var(--km-saffron-deep));
	color: #fff8ea !important; box-shadow: 0 5px 16px rgba(180, 83, 10, 0.45);
}
.km-cta-ghost { border: 2px solid var(--km-saffron-deep); color: var(--km-saffron-deep) !important; background: rgba(255, 252, 242, 0.5); }
.km-cta:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(180, 83, 10, 0.5); }

/* ornamental divider */
.km-divider { display: flex; align-items: center; gap: 14px; justify-content: center; margin: 8px auto 40px; max-width: 480px; }
.km-divider::before, .km-divider::after { content: ''; flex: 1; height: 2px; background: linear-gradient(90deg, transparent, var(--km-gold)); }
.km-divider::after { background: linear-gradient(90deg, var(--km-gold), transparent); }
.km-divider span { color: var(--km-gold); font-size: 1.3rem; }

/* ============ sections ============ */
.km-section-band { padding: 56px 0; }
.km-section-band.km-alt { background: rgba(255, 250, 235, 0.55); border-top: 1px solid var(--km-leaf-deep); border-bottom: 1px solid var(--km-leaf-deep); }
.km-sec-head { text-align: center; margin-bottom: 8px; font-size: clamp(1.7rem, 4vw, 2.3rem); }
.km-sec-sub { text-align: center; color: #7a5a2e; max-width: 640px; margin: 0 auto 36px; }

/* feature cards — like leaves of a pothi manuscript */
.km-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 22px; }
.km-card {
	background:
		repeating-linear-gradient(0deg, rgba(140, 90, 20, 0.05) 0 1px, transparent 1px 24px),
		linear-gradient(165deg, var(--km-parchment), var(--km-leaf));
	border: 2px solid var(--km-leaf-deep);
	border-radius: 4px 18px 4px 18px;
	padding: 26px 24px;
	box-shadow: 3px 4px 0 rgba(180, 140, 70, 0.25), 6px 8px 18px rgba(74, 30, 5, 0.15);
	transition: transform 0.2s;
	position: relative;
}
.km-card:hover { transform: translateY(-4px) rotate(-0.4deg); }
.km-card-icon { font-size: 2.1rem; margin-bottom: 8px; display: block; }
.km-card h3 { margin: 0 0 8px; font-size: 1.2rem; }
.km-card p { margin: 0; font-size: 0.94rem; color: #5c3a10; }

/* sources strip */
.km-sources { display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; }
.km-source-chip {
	background: var(--km-maroon); color: var(--km-gold-light); padding: 10px 22px;
	border-radius: 30px; font-size: 0.92rem; border: 1px solid var(--km-gold);
	text-decoration: none;
}
.km-source-chip:hover { background: #5f2a08; color: #ffe9bf; }

/* ============ content pages ============ */
.km-page { padding: 48px 0 70px; }
.km-page-title { text-align: center; font-size: clamp(1.9rem, 5vw, 2.7rem); margin: 0 0 6px; }
.km-page-sub { text-align: center; color: #7a5a2e; margin: 0 auto 40px; max-width: 680px; }
.km-prose { max-width: 820px; margin: 0 auto; }
.km-prose h2 { margin-top: 44px; border-bottom: 1px solid var(--km-gold); padding-bottom: 6px; }
.km-prose blockquote {
	margin: 26px 0; padding: 18px 26px; border-left: 4px solid var(--km-gold);
	background: rgba(255, 250, 235, 0.7); font-style: italic; border-radius: 0 10px 10px 0;
}
.km-shloka-block { text-align: center; font-family: 'Yatra One', serif; font-size: 1.3rem; color: var(--km-saffron-deep); }

/* source book cards */
.km-books { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 22px; margin-top: 30px; }
.km-book {
	border: 2px solid var(--km-leaf-deep); border-radius: 10px; padding: 24px;
	background: linear-gradient(165deg, var(--km-parchment), var(--km-leaf));
	box-shadow: 4px 5px 16px rgba(74, 30, 5, 0.12);
}
.km-book h3 { margin: 0 0 4px; color: var(--km-saffron-deep); }
.km-book .km-book-meta { font-size: 0.82rem; color: #96702f; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 10px; }
.km-book p { font-size: 0.95rem; margin: 0; }

/* ============ footer ============ */
.km-footer {
	margin-top: 60px;
	background:
		radial-gradient(ellipse at 50% 0%, #47230a, var(--km-night) 70%);
	color: #d9b98a;
	border-top: 4px solid var(--km-gold);
	padding: 48px 20px 26px;
	text-align: center;
}
.km-footer-om { font-size: 2.2rem; color: var(--km-saffron-bright); text-shadow: 0 0 22px rgba(255, 153, 51, 0.6); }
.km-footer-mantra { font-family: 'Yatra One', serif; font-size: 1.15rem; color: var(--km-gold-light); margin: 10px 0 4px; }
.km-footer-mantra-tr { font-size: 0.85rem; font-style: italic; color: #b08d55; margin-bottom: 26px; }
.km-footer-nav { display: flex; gap: 22px; justify-content: center; flex-wrap: wrap; margin-bottom: 22px; }
.km-footer-nav a { color: #e7c65a; text-decoration: none; font-size: 0.92rem; }
.km-footer-nav a:hover { color: #fff3d6; }
.km-footer-disclaimer { max-width: 760px; margin: 0 auto 18px; font-size: 0.78rem; color: #9a7a4d; }
.km-footer-copy { font-size: 0.8rem; color: #8a6c42; }

/* ============ misc ============ */
.km-entry-content { max-width: 880px; margin: 0 auto; }
.wp-block-image img { border: 4px solid var(--km-leaf-deep); border-radius: 6px; }

@media (max-width: 640px) {
	.km-header-inner { justify-content: center; }
	.km-hero { padding: 48px 16px 44px; }
}

/* ============ the Enlightenment hero ============ */
.km-hero-dawn {
	padding: 34px 20px 64px;
	border-bottom: 4px solid var(--km-gold);
	background:
		radial-gradient(ellipse 70% 45% at 50% 72%, rgba(255, 153, 51, 0.42), transparent 70%),
		linear-gradient(180deg, #170a02 0%, #2e1503 34%, #522108 58%, #7e370b 78%, #a34a0c 100%);
}
.km-hero-dawn .km-hero-mandala { opacity: 0.10; }
.km-hero-dawn .km-hero-mandala text { display: none; }

/* scene container */
.km-scene { position: relative; max-width: 900px; margin: 0 auto; pointer-events: none; }
.km-scene-svg { display: block; width: 100%; height: clamp(300px, 46vw, 500px); animation: km-awaken 2.2s cubic-bezier(0.22, 1, 0.36, 1) both; }
@keyframes km-awaken {
	from { opacity: 0; transform: scale(0.55) translateY(50px); }
	60%  { opacity: 1; }
	to   { opacity: 1; transform: scale(1) translateY(0); }
}

/* god-rays — counter-rotating fans of light */
.km-rays { transform-origin: 450px 380px; }
.km-rays-a { animation: km-spin 90s linear infinite; }
.km-rays-b { animation: km-spin-rev 140s linear infinite; }
@keyframes km-spin     { from { transform: rotate(0deg); }   to { transform: rotate(360deg); } }
@keyframes km-spin-rev { from { transform: rotate(360deg); } to { transform: rotate(0deg); } }

/* breathing halo & aura */
.km-halo { transform-origin: 450px 380px; animation: km-breathe 7s ease-in-out infinite; }
.km-aura { transform-origin: 450px 310px; animation: km-breathe 4.5s ease-in-out infinite; }
@keyframes km-breathe {
	0%, 100% { transform: scale(1); opacity: 0.85; }
	50%      { transform: scale(1.07); opacity: 1; }
}

/* the awakening third eye */
.km-thirdeye {
	animation: km-eye-glow 2.6s ease-in-out infinite;
}
@keyframes km-eye-glow {
	0%, 100% { opacity: 0.55; r: 3.4px; }
	50%      { opacity: 1; r: 5px; }
}
.km-ripple {
	fill: none; stroke: #ffe9bf; stroke-width: 1.6;
	transform-box: fill-box; transform-origin: center;
	animation: km-ripple 4.2s cubic-bezier(0.25, 0.6, 0.4, 1) infinite;
	opacity: 0;
}
@keyframes km-ripple {
	0%   { transform: scale(0.4); opacity: 0.9; stroke-width: 2.2; }
	100% { transform: scale(10); opacity: 0; stroke-width: 0.3; }
}

/* rising Om above the crown */
.km-om-rise { animation: km-om-rise 6.5s ease-in-out infinite; opacity: 0; }
@keyframes km-om-rise {
	0%   { transform: translateY(16px); opacity: 0; }
	22%  { opacity: 0.9; }
	60%  { opacity: 0.75; }
	100% { transform: translateY(-30px); opacity: 0; }
}

/* twinkling stars */
.km-star { fill: #ffe9bf; animation: km-twinkle 2.8s ease-in-out infinite alternate; }
@keyframes km-twinkle {
	from { opacity: 0.15; }
	to   { opacity: 0.95; }
}

/* floating diya embers */
.km-ember {
	position: absolute; bottom: -8px; border-radius: 50%;
	background: radial-gradient(circle, #fff3d6 0%, #ffb54d 55%, rgba(255, 153, 51, 0) 75%);
	filter: blur(0.4px);
	opacity: 0;
	animation-name: km-rise-a; animation-timing-function: linear; animation-iteration-count: infinite;
}
.km-ember-b { animation-name: km-rise-b; }
@keyframes km-rise-a {
	0%   { transform: translate(0, 0) scale(1); opacity: 0; }
	8%   { opacity: 0.9; }
	85%  { opacity: 0.5; }
	100% { transform: translate(38px, -520px) scale(0.5); opacity: 0; }
}
@keyframes km-rise-b {
	0%   { transform: translate(0, 0) scale(1); opacity: 0; }
	8%   { opacity: 0.85; }
	85%  { opacity: 0.45; }
	100% { transform: translate(-34px, -540px) scale(0.45); opacity: 0; }
}

/* hero text on the dark dawn */
.km-hero-text { position: relative; margin-top: -8px; }
.km-hero-dawn .km-hero-shloka { color: #ffcf7d; text-shadow: 0 0 26px rgba(255, 153, 51, 0.55); animation: km-fade-up 1s ease-out 0.5s both; }
.km-hero-dawn .km-hero-shloka-tr { color: #d9a86a; animation: km-fade-up 1s ease-out 0.7s both; }
.km-hero-dawn h1 { animation: km-fade-up 1s ease-out 0.9s both; }
.km-hero-dawn .km-hero-sub { color: #f3d9ac; animation: km-fade-up 1s ease-out 1.15s both; }
.km-hero-dawn .km-hero-ctas { animation: km-fade-up 1s ease-out 1.35s both; }
.km-hero-dawn .km-cta-ghost { border-color: var(--km-gold-light); color: var(--km-gold-light) !important; background: rgba(46, 21, 3, 0.35); }
.km-hero-dawn .km-cta-ghost:hover { background: rgba(46, 21, 3, 0.6); }
@keyframes km-fade-up {
	from { opacity: 0; transform: translateY(22px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* golden shimmer sweeping across the title */
.km-shimmer {
	background: linear-gradient(100deg, #f3d9ac 0%, #ffd98f 28%, #fff7e0 42%, #ffcf7d 55%, #f3d9ac 100%);
	background-size: 220% auto;
	-webkit-background-clip: text; background-clip: text;
	color: transparent; -webkit-text-fill-color: transparent;
	text-shadow: none;
	animation: km-fade-up 1s ease-out 0.9s both, km-shine 5.5s linear 2s infinite;
}
@keyframes km-shine {
	0%   { background-position: 120% center; }
	55%  { background-position: -80% center; }
	100% { background-position: -80% center; }
}

/* stillness for those who ask for it */
@media (prefers-reduced-motion: reduce) {
	.km-scene-svg, .km-rays-a, .km-rays-b, .km-halo, .km-aura, .km-thirdeye, .km-ripple,
	.km-om-rise, .km-star, .km-ember, .km-hero-dawn .km-hero-shloka, .km-hero-dawn .km-hero-shloka-tr,
	.km-hero-dawn h1, .km-hero-dawn .km-hero-sub, .km-hero-dawn .km-hero-ctas, .km-shimmer,
	.km-hero-mandala { animation: none !important; }
	.km-om-rise { opacity: 0.8; }
	.km-ripple { opacity: 0; }
	.km-ember { opacity: 0; }
	.km-shimmer { color: #ffd98f; -webkit-text-fill-color: #ffd98f; }
}
