:root{
  --bg:#F8F3E8;
  --bg2:#FCFAF4;
  --panel:#FFFFFF;
  --panel2:#FFFEFB;
  --text:#0B1630;
  --muted:#24324D;
  --muted2:#54637C;
  --line:rgba(15,23,42,.10);
  --line2:rgba(15,23,42,.06);
  --teal:#0B8C8A;
  --indigo:#1B2A6B;
  --gold:#C9A45B;
  --saffron:#D9A441;
  --good:#059669;
  --warn:#D97706;
  --bad:#DC2626;
  --shadow: 0 20px 52px rgba(11,22,48,.12);
  --shadow2: 0 12px 34px rgba(11,22,48,.10);
  --radius:18px;
  --radius2:14px;
  --max:1160px;
  --sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Noto Sans", "Apple Color Emoji","Segoe UI Emoji";
  --serif: ui-serif, "Iowan Old Style", "Palatino Linotype", Palatino, Garamond, Georgia, serif;
}

*{box-sizing:border-box}
html{color-scheme:light}
body{
  margin:0;
  font-family:var(--sans);
  background:
    radial-gradient(900px 520px at 8% 0%, rgba(27,42,107,.12), transparent 55%),
    radial-gradient(780px 460px at 92% 8%, rgba(201,164,91,.10), transparent 56%),
    radial-gradient(720px 500px at 70% 100%, rgba(11,140,138,.08), transparent 55%),
    linear-gradient(180deg, var(--bg), var(--bg2) 65%);
  color:var(--text);
  line-height:1.55;
}

a{color:inherit; text-decoration:none}
a:hover{opacity:.92}

.skip{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip:focus{left:16px;top:16px;width:auto;height:auto;z-index:1000;background:#000;color:#fff;padding:10px 12px;border-radius:10px}

.wrap{max-width:var(--max); margin:0 auto; padding:0 18px}

.topbar{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(10px);
  background: rgba(252,250,244,.82);
  border-bottom:1px solid var(--line);
}
.topbarInner{display:flex; align-items:center; justify-content:space-between; gap:14px; padding:14px 0}
.brand{display:flex; align-items:center; gap:10px; min-width:200px}
.logo{
  width:36px;height:36px;border-radius:12px;
  background: linear-gradient(135deg, rgba(201,164,91,.22), rgba(27,42,107,.14));
  border:1px solid var(--line2);
  box-shadow: 0 10px 24px rgba(15,23,42,.10);
  display:grid; place-items:center;
}
.logo img{width:20px;height:20px; object-fit:contain}
.brandName{display:flex;flex-direction:column;line-height:1.1}
.brandName strong{font-size:14px;letter-spacing:.2px}
.brandName span{font-size:12px;color:var(--muted2)}

.navToggle{
  display:none;
  border:1px solid var(--line);
  background: rgba(255,255,255,.75);
  color:var(--text);
  padding:10px 12px;
  border-radius: 14px;
  font-size:13px;
}
.nav{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.nav a, .nav summary{
  font-size:13px;
  color:var(--muted);
  padding:8px 10px;
  border-radius:12px;
  border:1px solid transparent;
}
.nav a[aria-current="page"]{color:var(--text); border-color:rgba(201,164,91,.42); background:rgba(201,164,91,.08)}
.nav a:hover, .nav summary:hover{background:rgba(15,23,42,.03); border-color:var(--line2); color:var(--text)}

.mega{position:relative}
.mega summary{list-style:none; cursor:pointer}
.mega summary::-webkit-details-marker{display:none}
.mega[open] summary{color:var(--text); border-color:var(--line); background:rgba(27,42,107,.06)}
.megaPanel{
  position:absolute;
  right:0;
  top:44px;
  width:min(920px, calc(100vw - 36px));
  background: rgba(255,255,255,.98);
  border:1px solid var(--line);
  border-radius: 16px;
  box-shadow: var(--shadow);
  padding:14px;
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:12px;
}
.megaPanel[aria-label="Room-wise Vastu"]{
  width:min(180px, calc(100vw - 36px));
  grid-template-columns: 1fr;
  padding:10px;
  gap:8px;
  max-height:min(70vh, 560px);
  overflow:auto;
}
.megaPanel[aria-label="Room-wise Vastu"] .megaCol{padding:8px}
.megaPanel[aria-label="Room-wise Vastu"] .megaCol a{padding:6px 8px; line-height:1.25}
.megaPanel[aria-label="Room-wise Vastu"] .megaCol small{margin-top:4px}
.megaCol{
  border:1px solid var(--line2);
  background: linear-gradient(180deg, rgba(15,23,42,.015), transparent);
  border-radius: 14px;
  padding:10px;
}
.megaCol b{display:block; font-size:12px; letter-spacing:.2px; margin-bottom:6px}
.megaCol a{display:block; padding:7px 8px; border-radius: 12px}
.megaCol a:hover{background:rgba(15,23,42,.04)}
.megaCol small{display:block; color:var(--muted2); font-size:12px; margin-top:6px}

.hero{padding:28px 0 14px}
.heroGrid{display:grid; grid-template-columns: 1.3fr .7fr; gap:18px; align-items:stretch}
.hero .card{
  position:relative;
  overflow:hidden;
}
.hero .card::after{
  content:"";
  position:absolute;
  right:-160px;
  top:-170px;
  width:560px;
  height:560px;
  background-image: url("assets/theme/mandala-watermark.svg");
  background-size: contain;
  background-repeat:no-repeat;
  opacity:.32;
  pointer-events:none;
}

.card{
  background: linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.80));
  border:1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.cardInner{padding:18px}

.kicker{
  display:inline-flex; gap:8px; align-items:center;
  font-size:12px; color:var(--muted);
  border:1px solid var(--line);
  background: rgba(255,255,255,.75);
  padding:7px 10px; border-radius:999px;
}
.kicker i{width:8px;height:8px;border-radius:50%; background:var(--gold); box-shadow:0 0 0 3px rgba(201,164,91,.14)}

h1{margin:10px 0 8px; font-size:36px; letter-spacing:-.7px; line-height:1.12; font-family:var(--serif)}
.sectionHead h2{font-family:var(--serif)}
.lede{margin:0; color:var(--muted); font-size:15px; max-width:62ch}
.heroActions{display:flex; gap:10px; flex-wrap:wrap; margin-top:14px}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:10px 12px; border-radius:14px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.85);
  color:var(--text); font-size:13px;
}
.btn.primary{
  background: linear-gradient(135deg, rgba(201,164,91,.18), rgba(27,42,107,.12));
  border-color: rgba(201,164,91,.38);
}
.btn:hover{transform: translateY(-1px)}
.btn:active{transform: translateY(0)}

.heroAside{
  position:relative;
  overflow:hidden;
}
.heroAside .cardInner{padding:16px}
.metricGrid{display:grid; grid-template-columns: 1fr 1fr; gap:10px}
.metric{
  border:1px solid var(--line);
  background: rgba(247,250,255,.95);
  border-radius: 14px;
  padding:12px;
}
.metric b{display:block; font-size:14px}
.metric span{display:block; font-size:12px; color:var(--muted2); margin-top:3px}

.section{padding:14px 0}
.sectionHead{display:flex; align-items:flex-end; justify-content:space-between; gap:12px; margin:4px 0 12px}
.sectionHead h2{margin:0; font-size:18px; letter-spacing:-.2px}
.sectionHead p{margin:0; color:var(--muted2); font-size:13px}

.grid3{display:grid; grid-template-columns: repeat(3, 1fr); gap:12px}
.grid2{display:grid; grid-template-columns: repeat(2, 1fr); gap:12px}
.grid5{display:grid; grid-template-columns: repeat(5, 1fr); gap:12px}

/* Home: Popular guides should be a single row on desktop */
.popularGrid{grid-template-columns: repeat(4, minmax(0, 1fr))}
.popularGrid .tileArt{height:128px; padding:0}
.popularGrid .tileArt img{object-fit:cover; opacity:1}

.tile{
  border:1px solid var(--line);
  background: rgba(255,255,255,.92);
  border-radius: var(--radius2);
  overflow:hidden;
  box-shadow: var(--shadow2);
}
.tile .pad{padding:14px}
.tile h3{margin:0 0 6px; font-size:14px}
.tile p{margin:0; color:var(--muted2); font-size:13px}
.tile .meta{margin-top:10px; display:flex; gap:8px; flex-wrap:wrap}
.tag{
  font-size:12px; color:var(--muted);
  padding:5px 8px; border-radius:999px;
  border:1px solid var(--line2);
  background: rgba(15,23,42,.02);
}
.tileArt{
  height:90px;
  background:
    radial-gradient(240px 120px at 28% 25%, rgba(201,164,91,.18), transparent 60%),
    radial-gradient(200px 120px at 78% 60%, rgba(27,42,107,.12), transparent 60%),
    radial-gradient(180px 110px at 55% 85%, rgba(11,140,138,.08), transparent 55%),
    rgba(247,250,255,.95);
  border-bottom:1px solid var(--line2);
  display:flex;
  align-items:center;
  justify-content:center;
  padding:10px;
}
.tileArt img{width:100%;height:100%;object-fit:contain;opacity:.95}

/* Home: make tile images wide (no blank space) */
.home .tileArt{height:128px; padding:0}
.home .tileArt img{object-fit:cover; opacity:1}

/* Home Vastu page: make grid images wide (no blank space) */
.homeVastu .tileArt{height:128px; padding:0}
.homeVastu .tileArt img{object-fit:cover; opacity:1}

.contentShell{display:grid; grid-template-columns: 1fr 340px; gap:14px; align-items:start}
.crumbs{font-size:12px;color:var(--muted2); margin:14px 0 10px}
.crumbs a{color:var(--muted)}
.crumbs span{opacity:.6}

.article{padding:0}
.article .cardInner{padding:18px}
.article h1{font-size:28px}
.article h2{margin-top:20px; font-size:18px}
.article h3{margin-top:16px; font-size:15px}
.article p{color:var(--muted); margin:10px 0}
.article ul{color:var(--muted); padding-left:18px}
.article li{margin:7px 0}
.callout{
  border:1px solid rgba(201,164,91,.32);
  background: rgba(201,164,91,.06);
  padding:12px 12px;
  border-radius: 14px;
  margin:12px 0;
}
.callout b{display:block; font-size:13px}
.callout span{display:block; font-size:12px; color:var(--muted); margin-top:3px}

.imgRow{display:grid; grid-template-columns: repeat(3, 1fr); gap:10px; margin:12px 0}
.imgBox{
  border:1px solid var(--line);
  background: rgba(255,255,255,.92);
  border-radius: 14px;
  overflow:hidden;
  min-height:120px;
}
.imgBox img{
  width:100%;
  height:220px;
  object-fit:contain;
  display:block;
  padding:10px;
  background:
    radial-gradient(220px 120px at 20% 20%, rgba(201,164,91,.10), transparent 62%),
    radial-gradient(220px 120px at 85% 75%, rgba(27,42,107,.08), transparent 64%),
    rgba(247,250,255,.95);
}
.imgBox figcaption{padding:10px 10px; font-size:12px; color:var(--muted2); border-top:1px solid var(--line2)}

/* Bigger diagrams for the Model Layouts page */
.imgBox.modelPlan img{height:360px}
@media (max-width: 860px){
  .imgBox.modelPlan img{height:300px}
}

.aside .cardInner{padding:14px}
.aside h3{margin:0 0 8px; font-size:14px}
.aside p{margin:0 0 10px; color:var(--muted2); font-size:13px}
.aside .miniList{display:grid; gap:8px}
.miniLink{
  display:flex; justify-content:space-between; align-items:center; gap:10px;
  padding:10px 10px;
  border-radius: 14px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.85);
  color:var(--text);
  font-size:13px;
}
.miniLink small{color:var(--muted2); font-size:12px}
.miniLink:hover{background:rgba(15,23,42,.02)}

.toc{
  position:sticky; top:84px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.88);
  border-radius: 16px;
  padding:12px;
}
.toc b{display:block; font-size:13px; margin-bottom:8px}
.toc a{display:block; padding:7px 8px; border-radius:12px; font-size:13px; color:var(--muted)}
.toc a:hover{background:rgba(15,23,42,.03); color:var(--text)}

.faq{margin-top:14px}
.faqItem{
  border:1px solid var(--line);
  background: rgba(255,255,255,.85);
  border-radius: 14px;
  padding:12px;
}
.faqQ{
  all:unset;
  cursor:pointer;
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  width:100%;
  font-size:13px;
}
.faqA{display:none; color:var(--muted); font-size:13px; margin-top:10px}
.faqItem[data-open="true"] .faqA{display:block}
.chev{width:18px;height:18px; opacity:.8}

.footer{margin-top:20px; padding:18px 0 28px; border-top:1px solid var(--line); color:var(--muted2); font-size:12px}
.footerGrid{display:grid; grid-template-columns: 1fr 1fr; gap:12px; align-items:start}
.footer a{color:var(--muted)}
.fine{margin-top:10px; opacity:.9}

.search{
  display:flex; align-items:center; gap:10px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.85);
  border-radius: 14px;
  padding:10px 12px;
}
.search input{
  width:100%;
  background:transparent;
  border:0;
  color:var(--text);
  outline:none;
  font-size:13px;
}
.search svg{opacity:.75}
.searchWrap{position:relative}
.searchResults{
  position:absolute;
  left:0;
  right:0;
  top:calc(100% + 8px);
  background: rgba(255,255,255,.98);
  border:1px solid var(--line);
  border-radius: 14px;
  box-shadow: var(--shadow);
  padding:8px;
  display:grid;
  gap:6px;
  max-height:280px;
  overflow:auto;
  z-index: 40;
}
.searchResult{
  display:flex;
  gap:10px;
  align-items:flex-start;
  justify-content:space-between;
  padding:8px 10px;
  border-radius: 12px;
  border:1px solid transparent;
  color: var(--text);
}
.searchResult.searchEmpty{
  cursor:default;
  justify-content:flex-start;
  color: var(--muted);
}
.searchResult:hover{background:rgba(15,23,42,.03); border-color:var(--line2)}
.searchResult.searchEmpty:hover{background:transparent; border-color:transparent}
.searchResult small{color:var(--muted2); font-size:12px; margin-left:12px; white-space:nowrap}

.roomCarousel{position:relative}
.roomCarouselViewport{
  overflow:hidden;
  border:1px solid var(--line2);
  background: rgba(255,255,255,.72);
  border-radius: 18px;
  padding:10px;
}
.roomCarouselTrack{
  display:flex;
  gap:10px;
  width:max-content;
  will-change: transform;
  animation: roomMarquee 75s linear infinite;
}
.roomCarouselViewport:hover .roomCarouselTrack{animation-play-state: paused}
.roomCarouselCard{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 12px;
  border-radius: 14px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.90);
  color: var(--text);
  font-size:13px;
  white-space:nowrap;
}
.roomCarouselCard:hover{background:rgba(15,23,42,.03)}
@keyframes roomMarquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
@media (prefers-reduced-motion: reduce){
  .roomCarouselTrack{animation:none}
}

.badge{
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.85);
  font-size:12px;
  color:var(--muted);
}

.srOnly{position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0}

@media (max-width: 980px){
  .heroGrid{grid-template-columns: 1fr}
  .contentShell{grid-template-columns: 1fr}
  .toc{position:relative; top:auto}
  .megaPanel{position:relative; top:auto; right:auto; width:auto; grid-template-columns: 1fr 1fr}
  .megaPanel[aria-label="Room-wise Vastu"]{
    width:auto;
    grid-template-columns: 1fr;
    max-height: min(70vh, 520px);
  }
  .megaPanel[aria-label="Room-wise Vastu"] .megaCol a{
    font-size:13px;
    padding:6px 8px;
  }
  .popularGrid{grid-template-columns: repeat(2, minmax(0, 1fr))}
}

@media (max-width: 860px){
  h1{font-size:30px}
  .grid3{grid-template-columns: 1fr}
  .grid2{grid-template-columns: 1fr}
  .grid5{grid-template-columns: 1fr}
  .imgRow{grid-template-columns: 1fr}
  .imgBox img{height:240px}
  .footerGrid{grid-template-columns: 1fr}
  .navToggle{display:inline-flex}
  .nav{
    display:none;
    width:100%;
    justify-content:flex-start;
    padding:10px 0 2px;
  }
  .topbarInner{flex-wrap:wrap}
  body[data-nav-open="true"] .nav{display:flex}
}
