/* tpl/vastu-0a9f8589.css — page CSS shared by 1 page(s) of this template.
   Auto-extracted from inline <style> by scripts/refactor_css.py.
   Loaded after components.css; per-page :root{} stays inline. */

body { background: var(--color-base-bg) }
.v3-nav{position:sticky;top:0;z-index:var(--z-header);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:color-mix(in srgb,var(--color-base-bg) 80%,transparent)}
.v3-nav__inner{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:var(--space-5);height:72px}
.v3-logo{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-body);font-weight:700;font-size:19px;letter-spacing:-0.02em}
.v3-logo svg{width:24px;height:24px}
.v3-pillnav{display:flex;gap:2px;justify-self:center;background:var(--color-base-surface);border:1px solid var(--color-base-border);padding:4px;border-radius:var(--radius-full)}
.v3-pillnav > a{padding:8px 16px;border-radius:var(--radius-full);font-size:13px;font-weight:500;color:var(--color-text-secondary);transition:background var(--dur-fast),color var(--dur-fast)}
.v3-pillnav > a:hover{color:var(--color-text-primary);background:var(--color-base-bg)}
.v3-pillnav > a[aria-current]{background:var(--section-accent);color:#fff}
@media(max-width:1024px){.v3-pillnav{display:none}}
.v3-pill{display:inline-flex;align-items:center;gap:8px;height:42px;padding:0 18px;border-radius:var(--radius-full);font-size:13px;font-weight:600;transition:transform var(--dur-fast),filter var(--dur-fast)}
.v3-pill:active{transform:scale(0.97)}
.v3-pill--solid{background:var(--section-accent);color:#fff}
.v3-pill--solid:hover{filter:brightness(0.94)}
.v3-pill--ghost{background:transparent;border:1px solid var(--color-base-border-strong);color:var(--color-text-primary)}
.v3-nav__cta{display:flex;gap:var(--space-2)}
.section-topbar{height:3px;background:var(--section-accent);width:100%}
.section-hero{padding:var(--space-9) 0 var(--space-7)}
.section-hero__badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:var(--radius-full);background:color-mix(in srgb,var(--section-accent) 10%,var(--color-base-surface));border:1px solid color-mix(in srgb,var(--section-accent) 25%,transparent);font-size:12px;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:var(--section-accent);margin-bottom:var(--space-5)}
.section-hero__mark{width:72px;height:72px;margin-bottom:var(--space-5);color:var(--section-accent)}
.section-hero__title{font-family:var(--font-display);font-weight:500;font-size:clamp(52px,9vw,108px);line-height:0.92;letter-spacing:-0.025em}
.section-hero__sub{margin-top:var(--space-4);font-size:19px;color:var(--color-text-secondary);max-width:560px;line-height:1.6}
.sec-label{font-family:var(--font-body);font-weight:700;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--section-accent);margin-bottom:var(--space-3)}
.sec-title{font-family:var(--font-display);font-weight:500;font-size:clamp(32px,5vw,48px);letter-spacing:-0.02em;margin-bottom:var(--space-2)}
.sec-sub{font-size:16px;color:var(--color-text-secondary);max-width:540px;line-height:1.6;margin-bottom:var(--space-5)}
.compass-wrap{position:relative;width:360px;height:360px;margin:var(--space-6) auto}
@media(max-width:480px){.compass-wrap{width:280px;height:280px}}
.compass-ring{position:absolute;inset:0;border-radius:50%;border:1px solid color-mix(in srgb,var(--section-accent) 20%,transparent)}
.compass-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:72px;height:72px;border-radius:50%;background:color-mix(in srgb,var(--section-accent) 10%,var(--color-base-surface));border:1px solid color-mix(in srgb,var(--section-accent) 30%,transparent);display:grid;place-items:center;font-family:var(--font-display);font-size:11px;font-weight:600;color:var(--section-accent);text-align:center;line-height:1.2}
.compass-dir{position:absolute;display:flex;flex-direction:column;align-items:center;text-decoration:none;gap:3px;transition:transform var(--dur-fast)}
.compass-dir:hover{transform:scale(1.08)}
.compass-dir__label{font-family:var(--font-body);font-weight:700;font-size:11px;letter-spacing:0.06em;text-transform:uppercase;color:var(--section-accent)}
.compass-dir__god{font-size:11px;color:var(--color-text-secondary)}
.dir-n  {top:2%;left:50%;transform:translateX(-50%)}
.dir-ne {top:10%;right:10%}
.dir-e  {top:50%;right:2%;transform:translateY(-50%)}
.dir-se {bottom:10%;right:10%}
.dir-s  {bottom:2%;left:50%;transform:translateX(-50%)}
.dir-sw {bottom:10%;left:10%}
.dir-w  {top:50%;left:2%;transform:translateY(-50%)}
.dir-nw {top:10%;left:10%}
.dir-n:hover,.dir-ne:hover,.dir-e:hover,.dir-se:hover,.dir-s:hover,.dir-sw:hover,.dir-w:hover,.dir-nw:hover{transform:scale(1.08)}
.dir-n:hover{transform:translateX(-50%) scale(1.08)}
.dir-e:hover{transform:translateY(-50%) scale(1.08)}
.dir-s:hover{transform:translateX(-50%) scale(1.08)}
.dir-w:hover{transform:translateY(-50%) scale(1.08)}
.topic-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-4);margin:var(--space-5) 0}
.topic-card{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4) var(--space-5);border-radius:22px;background:var(--color-base-surface);border:1px solid var(--color-base-border);text-decoration:none;transition:border-color var(--dur-fast),transform var(--dur-fast)}
.topic-card:hover{border-color:var(--section-accent);transform:translateY(-2px)}
.topic-card__icon{font-size:22px}
.topic-card__name{font-family:var(--font-display);font-weight:500;font-size:20px;color:var(--color-text-primary)}
.topic-card__desc{font-size:13px;color:var(--color-text-secondary);line-height:1.55}
.topic-card__tag{display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:var(--radius-full);background:color-mix(in srgb,var(--section-accent) 8%,var(--color-base-bg));color:var(--section-accent);margin-top:4px}
.element-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-3);margin:var(--space-5) 0}
@media(max-width:600px){.element-strip{grid-template-columns:repeat(3,1fr)}}
.element-card{padding:var(--space-4);border-radius:20px;background:var(--color-base-surface);border:1px solid var(--color-base-border);text-decoration:none;text-align:center;transition:border-color var(--dur-fast)}
.element-card:hover{border-color:var(--section-accent)}
.element-card__icon{--c:var(--section-accent);width:54px;height:54px;border-radius:15px;display:grid;place-items:center;margin:0 auto var(--space-3);font-size:26px;line-height:1;color:#fff;background:radial-gradient(125% 120% at 30% 20%,rgba(255,255,255,0.55),rgba(255,255,255,0) 46%),linear-gradient(158deg,color-mix(in srgb,var(--c) 72%,#fff),var(--c) 52%,color-mix(in srgb,var(--c) 68%,#000) 100%);box-shadow:0 1px 1px rgba(255,255,255,0.6) inset,0 -8px 13px color-mix(in srgb,var(--c) 50%,#000 8%) inset,0 8px 17px color-mix(in srgb,var(--c) 30%,transparent);text-shadow:0 1px 2px color-mix(in srgb,var(--c) 60%,#000 30%)}
.element-card__name{font-family:var(--font-display);font-weight:500;font-size:17px;color:var(--color-text-primary)}
.element-card__sanskrit{font-size:11px;color:var(--color-text-secondary)}
.concept-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-4);margin:var(--space-5) 0}
.concept-tile{padding:var(--space-5) var(--space-6);border-radius:24px;background:var(--color-base-surface);border:1px solid var(--color-base-border)}
.concept-tile__icon{font-size:24px;margin-bottom:var(--space-3)}
.concept-tile__title{font-family:var(--font-display);font-weight:500;font-size:22px;margin-bottom:var(--space-2)}
.concept-tile__body{font-size:14px;line-height:1.65;color:var(--color-text-secondary)}
.related-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-4);margin:var(--space-5) 0}
.related-card{padding:var(--space-4) var(--space-5);border-radius:20px;background:var(--color-base-surface);border:1px solid var(--color-base-border);text-decoration:none;transition:border-color var(--dur-fast)}
.related-card:hover{border-color:var(--section-accent)}
.related-card__label{font-size:11px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--color-text-tertiary);margin-bottom:var(--space-2)}
.related-card__title{font-family:var(--font-display);font-weight:500;font-size:20px;color:var(--color-text-primary)}
.related-card__desc{font-size:13px;color:var(--color-text-secondary);margin-top:var(--space-1)}
.site-footer{padding:var(--space-8) 0 var(--space-7);border-top:1px solid var(--color-base-border);margin-top:var(--space-9)}
.footer-inner{display:grid;grid-template-columns:1fr auto;gap:var(--space-6);align-items:start}
@media(max-width:600px){.footer-inner{grid-template-columns:1fr}}
.footer-brand{font-family:var(--font-body);font-weight:700;font-size:16px;letter-spacing:-0.02em;margin-bottom:var(--space-2)}
.footer-tagline{font-size:13px;color:var(--color-text-secondary)}
.footer-links{display:flex;flex-wrap:wrap;gap:var(--space-4)}
.footer-links a{font-size:13px;color:var(--color-text-secondary)}
.footer-links a:hover{color:var(--color-text-primary)}
.footer-copy{margin-top:var(--space-6);font-size:12px;color:var(--color-text-tertiary)}
